- Alfresco version 4.2.b (or later) http://wiki.alfresco.com/wiki/Download_and_Install_Alfresco
- Apache Ant http://ant.apache.org/
This is a project template meant to get you quickly up and running with site based customizations in Alfresco Share.
By entering your company's name, the name of your usecase and some additional parameters you will get a fully working and namespaced site customization project with ant tasks for deploying and packaging your site extension.
It will also provide you with sample code for the most common extension points.
Start by running the "help" command in your console when standing in this directory.
ant help
It will give detailed instructions on which parameters you need to provide when creating the project. Once done you will be able to see a directory named after your company placed as a sibling to the this directory.
Make sure to enter the path to your Alfresco server(s) in the generated build.properties files so the build tasks can deploy your customization.
Note! Use "java paths", in other words use "forward slash" (even on Windows).
Note! Make sure to set it for both your share & repo project.
From the directory named after your company run the following commands to deploy the customization code to your Alfresco server(s).
To deploy repo...
cd <usecase>-repo
ant hotcopy-tomcat-zip
cd ..
To deploy share...
cd <usecase>-share
ant hotcopy-tomcat-zip
cd ..
The hotcopy-tomcat-zip is a development build task meant for avoiding server restarts when possible.
It will place all your code will in your server's ${TOMCAT_HOME}/shared/classes directory (except for client side resources which
will be placed inside your exploded share.war directory, so make sure your server has started and has exploded the .war).
Now restart your server.
- 
Create a new site and make sure to choose your usecase name as the "Type" in Share's create site dialog. 
 (In other words do NOT choose the usual "Collaboration Site")
- 
On your new site dashboard you can see: a) A 1 column layout with 1 Dashlet inside. Defined in the<template-instance>element &<components>section in <company>-<usecase>-presets.xmlb) A custom page displayed in the navigation bar (named after your <page> parameter). c) That the "Document Library" has changed name. 
- 
When entering the custom page you will see: a) A page that includes the title, navigation & a custom component. b) A greeting component which is a generated webscript. 
- 
In the document library you will see a) That your property is added to the sort menu. b) An "Apply <usecase> <aspect>" doclib action (if you have "Write" permission). ... and when the aspect is applied you now have... 
c) An aspect specific doclib metadata template showing your custom property.
# Defined in the <metadata-templates> section in <company>-<usecase>-extension.xml
d) An indicator showing that your document has the aspect applied and also the value of your property.
# Defined in the <indicators> section in <company>-<usecase>-extension.xml
e) A "Set <usecase> <property> to <value2>" action (if you have "Write" permission)
# It will call a generated custom repo action that will update your custom property on the node.
# The property is defined in the repo's <company>-<usecase>-model.xml
# The action is defined in the <actions> section in <company>-<usecase>-extension.xml
- 
In the "Properties" panel (on the Document Details page) & the "Edit properties" page you will see a) That your property can be viewed and edited 
- 
In the "Document Actions" panel (on the Document Details page) a) That the doclib actions have been added here as well 
When your code is ready for distribution just:
- 
Use either - ant dist-jarand place your jar files in: ${TOMCAT_HOME}/lib or ${TOMCAT_HOME}/shared/lib
 Note! If the shared/lib is missing it must be created and added to tomcat loader as described here:
 http://docs.alfresco.com/4.0/index.jsp?topic=%2Fcom.alfresco.enterprise.doc%2Ftasks%2Fconfigfiles-change-path.html
 OR
- ant dist-ampand use the Alfresco amp tool, described here: https://wiki.alfresco.com/wiki/AMP_Files
 
- 
Send it to your boss and show him what you did in less than an hour ;-) 
Note! Make sure you don't end up with changes deployed in multiple places:
- ${TOMCAT_HOME}/shared/classes - from running hotcopy-tomcat-zip
- ${TOMCAT_HOME}/lib - from running dist-jar and moving them into the lib folder
- ${TOMCAT_HOME}/shared/lib - from running dist-jar and moving them into the lib folder
...because if you have the same changes deployed in both places it will be hard to know which one that acually is being used (event though the .jar probably will win).