Admin users can define a workflow and upload the workflow definition file through the Workflow Portlet UI. They can also initiate a workflow instance. To create a workflow, you need a workflow definition file that contains workflow definition.
The following topics explains how to create and configure a workflow:
To create a workflow, you need to create a workflow definition file in XML format that conforms to the jBPM Process Definition Language (JPDL) standard.
For example, say that you are creating a workflow for a leave application and approval process.
The following is the scenario involved:
The admin user creates a workflow definition called LeaveApproval.
The admin user creates a workflow instance (Workflow State 1).
The test user uses the workflow instance to apply for leave (Workflow State 2).
The manager receives the holiday request. The manager can approve or reject the request, or can send the request for reconsideration (Workflow State 2).
The test user can verify to see whether the process has ended.
The following procedures provide the detailed process steps:
 To Add a Workflow Definition
To Add a Workflow DefinitionLog in to Web Space Server as the admin user.
Create a new page by clicking Add Page.
Type a name for the page and click Save.
For example, name it Workflow.
Click the tab for the page.
The page opens.
Choose Add Applications from the Welcome menu, and add the Workflow portlet to the page.
Click the Add Definition button.
Add the workflow definition in XML format and click the Save New Version button.
You can copy and paste a workflow definition. In this example, LeaveApproval version 1.0 is the name of the workflow definition.
 
A workflow is created with a version number associated with it.
Log out and log in back in to Web Space Server for the changes to take effect.
 To Create a Workflow Instance
To Create a Workflow InstanceLog in to Web Space Server as the admin user.
Choose Add Applications from the Welcome menu, and add the Workflow portlet to the page.
Click Search Definitions on the Workflow portlet to view all workflow definitions.
 
Click the Add Instances button next to a workflow definition.
In this example, you can create an instance for version 1.0 of the LeaveApproval workflow definition.
An instance is created for the Workflow Definition. Provide values for the fields such as the Definition Name, Definition Version, Start Date (Range), and End Date (Range), and click Search to search for the instance. To hide the instances that have already ended, select the Hide the instances that have already ended checkbox.
You can create any number of instances for a version of Workflow Definition.
 
Click the Manage button for the instance.
Click Save to save the task.
The task will be assigned to a requester.
If the admin user clicks the Signal button next to an Instance, the instance is promoted to the next state of workflow. The requester is not allowed to use an instance which is promoted to the next state of the workflow.
Accessing a workflow instance follows the series of steps necessary to complete the workflow cycle for the instance.
 Workflow Process Steps: To Request an Holiday
Workflow Process Steps: To Request an HolidayLog in to Web Space Server as Paul, the test user.
Click the Tasks tab on the Workflow portlet.
You can use the Task Name, Definition Name, Current Date, Start Date, and End Date fields to search for a task. To hide the instances that have already ended, select the Hide the instances that have already ended checkbox.
Click a Task for an Instance which have not ended.
In this example, click the Holiday Request task for an Instance. Select a start date and an end date.
 
Click Save.
 Workflow Process Steps: To Evaluate Holiday Request
Workflow Process Steps: To Evaluate Holiday RequestLog in to Sun GlassFish Web Space Server as Mary Manager.
Click the Tasks tab on the Workflow portlet.
Click a Task for an Instance which have not ended.
In this example, click the Evaluate Holiday Request task for an Instance.
The manager can place comments against the request. The manager can exercise Approve, Reject, and Send Back for Review options.
The Instance ends on clicking the Approve or Reject button.
 Workflow Process Steps: To Ascertain the Request Status
Workflow Process Steps: To Ascertain the Request StatusLog in to Sun GlassFish Web Space Server as Paul, the test user.
Click the Tasks tab on the Workflow portlet.
The End Date field next to the task name has the date and time of approval on it.
You need to make some configuration changes, if you have installed Sun GlassFish Web Space Server on MySQL database. If you are installing the Web Space Server evaluation bundle, no changes are required, as the workflow is configured for HSQL by default.
 To Configure Workflow for MySQL
To Configure Workflow for MySQLCopy the saw-impl-jbpm.jar file from <Web Space Server install dir>\glassfish2\domains\domain1\applications\j2ee-modules\saw-web\WEB-INF\lib.
Paste the saw-impl-jbpm.jar file to a temp folder.
Extract the saw-impl-jbpm.jar file.
unjar saw-impl-jbpm.jar
Remove the commenting for the following section in the hibernate-cfg.xml file and change the appropriate values to point to the MySQL database.
<!-- JDBC connection properties (begin) -->
    <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
    <property name="hibernate.connection.url">jdbc:mysql://localhost:3306/lportal</property>
    <property name="hibernate.connection.username">lportal</property>
    <property name="hibernate.connection.password">lportal</property>
    <!-- JDBC connection properties (end) -->
jar the saw-impl-jbpm.jar file again.
Create a directory structure sources/saw-web-5.2.0.1/WEB-INF/lib/ under <root-dir>/webspace-for-gfv2/var/webspace/war-workspace, and paste the saw-impl-jbpm.jar file into it.
Change directory to <root-dir>/webspace-for-gfv2/var/webspace/war-workspace.
cd <root-dir>/webspace-for-gfv2/var/webspace/war-workspace
Run ant -f synchronize.xml for saw-web-5.2.0.1.
Restart GlassFish server.