Create a custom workflow action class
You can create custom workflow action classes to enable you to use custom workflow actions in a workflow.
Create the custom workflow action class
- Create a java class that implements the interface...
This class must implement the following methods:
- public Date getExecuteDate(Document p_document) {}
When the custom action will be executed
- public CustomWorkflowActionResult execute(Document p_document) {}
Code that will run when the custom action is executed.
- execute()
Code executed against the supplied Document. This method must return an object...
...to indicate the result of the custom code through the use of...
A custom workflow action result object is created by first retrieving a reference to the object...
...and then calling the method...
webContentCustomWorkflowService.getCustomWorkflowService().createResult(Directive, String)
If the CustomWorkflowActionResult does not indicate a failure, changes to the document will be saved.
See the Web Content Management Javadoc
Also see the Web Content Management Javadoc for further information on valid directives.
- Create a custom workflow action factory class that implements the interface...
Create a plugin.xml file
Create a new file...
PROFILE_HOME/installedApps/your_application.ear/your_application.war/WEB-INF/plugin.xml
...that contains...
<?xml version="1.0" encoding="UTF-8"?> <plugin id="com.ibm.workplace.wcm.api.custom" name="Sample Custom Workflow Action Factory" version="1.0.0" provider-name="IBM"> <extension-point id="CustomWorkflowActionFactory" name="CustomWorkflowActionFactory"/> <extension point="com.ibm.workplace.wcm.api.custom.CustomWorkflowActionFactory" id="SimpleCustomWorkflowActionFactory"> <provider class="com.ibm.workplace.wcm.sample.customworkflowaction.SimpleCustomWorkflowActionFactory"/> </extension> </plugin>
- Each custom workflow action factory is represented by a single <extension></extension> tag.
- The value of the point attribute must be "com.ibm.workplace.wcm.api.custom.CustomWorkflowActionFactory".
- Provide an id value of your choice.
- Specify the provider class for custom workflow action factory.
You must now compile the java classes and create a portal application.
This can either be an "ear" or "war" file.
Deploy the ear file in the Administrative Console
To ensure the new workflow action class is available each time your server is started you can register the ear file in the Administrative Console:
- Select...
Applications | New Application | New Enterprise Application | Ear_file
- Select next until you reach Step 2. Map modules to servers
- Select the tickbox for the custom action module
- In the Clusters and Servers section, select WebSphere_Portal and select apply
- Keep selecting next until the end when you select finish
- The screen titled updating will be shown. Select Manage Applications.
- Locate and select the application you just installed. Default name:
WCM Sample Custom Workflow Action
- Under Detail Properties select Startup behavior.
- Under General Properties modify the Startup order to be the same weight as "wcm" and select Apply. By default, the weight is 20.
- Select Save directly to master configuration.
To update an existing ear file:
- Select...
Applications | Application Types | WebSphere enterprise applications | Application_name
- Select the tickbox for the custom action application and click on update
- Select upload the replacement application and browse for the ear file
- Keep selecting next until the end when you select finish
- The screen titled 'updating' will be shown. Select Save to Master Configuration and then click save.
Create a custom workflow action
Once your java class is installed, you can create a custom workflow action. The custom workflow action can be added to a workflow stage just like any other workflow action.
Parent topic:
Creating custom plug-ins