Skip to Content
Author's profile photo Piyas Kumar Das

How to Complete Task of a BPM Process using BPM API as a rest full service.

This guide provides instructions on how to Complete Task of a SAP BPM Process using BPM API as a Restful Service.


Applies to:

This Document Holds good for all CE 7.3 SP05 onwards. This service can be called from UI5 Screen as an Ajax call.

Please note that from 7.31 SP09 onward you can also use the standard BPM OData service to retrieve task details and complete the task: Custom UIs with the BPM OData Service

Special Thanks to Christian Loos  for commenting and mentioning Custom UIs with the BPM OData Service & Andre Backofen for the allowing me mention his blog in the document.


Summary:

This guide describes step-by-step how to Complete Task of a BPM Process using BPM API as a rest full service.


About Me:

Piyas Kumar Das

As a Sr. Netweaver Consultant, I’ve been undertaking consulting assignments leveraging on my undermentioned NetWeaver skills.

  • Business Process Management (SAP NW BPM)
  • Restful Services using BPM api to be used in UI5 Screens.
  • SAP Web Dynpro Java (SAP WD4J)
  • SAP Business Rules Management (SAP BRMS)
  • SAP Composit Application Framework (SAP CAF)
  • Master Data Management (SAP NW MDM)
  • Enterprise Portal (SAP EP)
  • Services creation using NWDS (SAP EJB)
  • Enterprise SOA


Prerequisites:

You should have read through the document :How to Start a BPM Process using BPM API as a RESTful service.


We will be discussing following points in detail in this document –


  1. Adding Libraries.
  2. Setting up the foundation for using Libraries.
  3. Creating Deploy-able Object.
  4. Accessing the methods exposed.
  5. Testing your REST services

Adding Libraries:


Step 1 : Refer the document to add libraries.


Setting up the foundation for using Library:


Step 1 to Step 4 is same as mentioned in the document.


Step 5 : Create a restful service class file and write a code as shown below or if you are continuing from the document then just copy past the methods only.


import java.io.StringReader;
import java.net.URI;
import java.text.DateFormat;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.HashSet;
import java.util.Iterator;
import java.util.Set;
import javax.ws.rs.Consumes;
import javax.ws.rs.GET;
import javax.ws.rs.POST;
import javax.ws.rs.Path;
import javax.ws.rs.PathParam;
import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.xml.sax.InputSource;
import bo.Material;
import bo.MaterialCreation;
import bo.TaskHeader;
import bo.TaskHeaders;
import com.sap.bpm.api.BPMFactory;
import com.sap.bpm.exception.api.BPMException;
import com.sap.bpm.pm.api.ProcessDefinition;
import com.sap.bpm.pm.api.ProcessDefinitionManager;
import com.sap.bpm.pm.api.ProcessStartEvent;
import com.sap.bpm.pm.api.ProcessStartManager;
import com.sap.bpm.tm.api.Status;
import com.sap.bpm.tm.api.TaskAbstract;
import com.sap.bpm.tm.api.TaskDetail;
import com.sap.bpm.tm.api.TaskInstanceManager;
import com.sap.tc.logging.Location;
import commonj.sdo.DataObject;
import commonj.sdo.helper.XMLHelper;
@Path("/MaterialCreationService")
@Produces({MediaType.APPLICATION_XML})
public class MaterialCreationToRestService {
  private static final Location location = Location.getLocation(MaterialCreationToRestService.class);
  private final String PRE_TASK_URI = "bpm://bpm.sap.com/task-instance/";
  @Path("/completeTask/{task-id}")
  @POST
  @Consumes({MediaType.APPLICATION_JSON})
  @Produces({MediaType.APPLICATION_JSON})
  public String completeTask(@PathParam("task-id") String taskInstanceId, Material materialData) throws Exception
    {
    System.err.println("MaterialMaintenanceService -> completeTask Task ID : "+taskInstanceId);
    String log = null;
    try{
    //Retrieve the TaskInstanceManager
    TaskInstanceManager taskInstanceManager = BPMFactory.getTaskInstanceManager();
    taskInstanceId = PRE_TASK_URI + taskInstanceId;
    URI taskInstId = new URI(taskInstanceId);
    //Claim the Task First
    taskInstanceManager.claim(taskInstId);
  
    TaskDetail taskDetails = taskInstanceManager.getTaskDetail(taskInstId);
    DataObject pDataObject = taskDetails.getOutputDataObject();
    setMaterialToDataObject(materialData, pDataObject);
   
  taskInstanceManager.complete(taskInstId, taskDetails.getOutputDataObject());
        System.err.println("DataObject : "+taskDetails.getOutputDataObject());
        System.err.println("Task Completed");
        log = "Task Completed";
    }
    catch (Exception e)
    {
    e.printStackTrace();
    System.err.println(e);
    log = "Task in Exception "+e.getLocalizedMessage();
    }
    return log;
    }
  private void setMaterialToDataObject(Material material, DataObject pDataObject)
  {
  if(material == null || pDataObject == null)
  return;
  pDataObject.set("Material", material.getMaterial());
  pDataObject.set("IndustrySector", material.getIndustrySector());
  pDataObject.set("MaterialType", material.getMaterialType());
  pDataObject.set("Description", material.getDescription());
  }
}



  • The Following code is very important as we need to claim the task first and then set the data to complete the task./wp-content/uploads/2014/03/1_410369.jpg

Step 6 & Step 7 is same as mentioned in the document. If you are continuing then you can ignore these steps.


Creating Deploy-able Object & Accessing the methods exposed.


Refer the document to “Creating Deploy-able Object” & “Accessing the methods exposed” as it is the same.


Testing your REST services

You can test the created REST services using the POSTMAN for Chrome or Advanced REST client for Chrome./wp-content/uploads/2014/03/1_410369.jpg

Assigned Tags

      3 Comments
      You must be Logged on to comment or reply to a post.
      Author's profile photo Former Member
      Former Member

      Hi Piyas,

      Nice Blog I tried it on my BPM process and it worked great.

      I have a small query if I have a list type then how do I write it back?

      Regards

      Kumar

      Author's profile photo Piyas Kumar Das
      Piyas Kumar Das
      Blog Post Author

      Hi Kumar,

      Thanks for the appreciation.

      If you wish to write a list then it can be done easily.

      write it onto the child node.

      Cheers

      Piyas

      Author's profile photo Piyas Kumar Das
      Piyas Kumar Das
      Blog Post Author

      Hi Kumar,

      Thanks for the appreciation.

      If you wish to read a list then it can be done easily.

      Read it from the child node.

      Cheers

      Piyas