Using Rest Services in Workflow:
Let's start with SharePoint Designer workflow which accesses the SharePoint List data using REST call i.e Web Service Call
SharePoint List
The following is a list structure which we are referencing for our application.
data:image/s3,"s3://crabby-images/b5fa3/b5fa3a76e19fa15020c03914565c717b2f996b1c" alt=""
Figure 1: SharePoint
Step 1: Create Site Workflow
Using SharePoint Designer create site workflow. Make sure you select SharePoint 2013 Workflow as the platform type.
data:image/s3,"s3://crabby-images/93d72/93d722daf4af341ca09046d2544261052f3fbfd5" alt=""
Figure 2: Workflow
Step 2: Create Workflow Stage.
Let’s start by creating a new stage.
data:image/s3,"s3://crabby-images/95c3e/95c3eeda049bdb5b9e60c999ed743be5684f1efc" alt=""
Figure 3: Stage
Workflow Stages
Stage 1: Workflow Initialization: The following variables get initialized at this stage:
ServiceURL: Here's the URL.
data:image/s3,"s3://crabby-images/b479c/b479c4a078ab105cc0fca2937e2ac0c1745c36bc" alt=""
Figure 4: Initialized
Index: Create Index variable of type Integer & set it to 0.
data:image/s3,"s3://crabby-images/256d7/256d7b3b2c0ac6b01aaba603336e890e4f6aed2d" alt=""
Figure 5: Index
Service Call Header: Next, we add a Dictionary variable (Build a Dictionary action), call it requestHeaders and initialize it as this:
data:image/s3,"s3://crabby-images/52fdc/52fdc9ba25ec3e67c8fcfd642929e0cad3158144" alt=""
Figure 6: Header
Both “Accept” and “Content-Type” entries are of the String type and they both contain the value “application/json;odata=verbose”. SharePoint REST API understands this and sets the response content type appropriately as JSON. If we don’t pass these values, the output would come as XML.
data:image/s3,"s3://crabby-images/67a11/67a11bdcc76f8571352b87c091ed8462ffc0ffab" alt=""
Figure 7: Accept
Stage 2: Web Service Call
Add a Call as HTTP Web Service action and set its properties. The request will be the url variable:
data:image/s3,"s3://crabby-images/d2465/d2465b34b145e3679ec43b7428edaa215a021438" alt=""
Figure 8: Webservice
Set workflow variable "ServiceURL" as Web Service URL.
HTTP method as "GET".
data:image/s3,"s3://crabby-images/0ade0/0ade0d95f1d12585b4b484acf7fb085dfd2996c7" alt=""
Figure 9: Get
Response content will go to a new variable called responseContent.(type - Dictionary).
Response headers will go to a new variable called responseHeaders.(type - Dictionary).
Response code will go to a new variable called responseCode.(type - Dictionary ).
Then we set the request headers to be the requestHeaders variable we created just now, by clicking on the properties for the Call on HTTP Web Service action:
data:image/s3,"s3://crabby-images/24cdc/24cdcaa3ef6c28c80577533ec2b560caa5593e8c" alt=""
Figure 10: Call set variable as needed.
data:image/s3,"s3://crabby-images/b124d/b124d6f5dadacc48349fb4068055345ddad36d11" alt=""
Figure 11: Variable
Process Web Service Response
Now, create a new stage, call it " Process Web Service Response".
At the end of the " Web Service Call" add a Go to Process Web Service Response stage.
data:image/s3,"s3://crabby-images/a2050/a20502ac115b739028c9bb1a5364c5f21cb4cbb9" alt=""
Figure 12: Loop
data:image/s3,"s3://crabby-images/3ffbd/3ffbdd492461956bf9d9a56aaebf80ccf5317bb9" alt=""
data:image/s3,"s3://crabby-images/533b1/533b10fb2bc5834176a4d0ebfb04064f20a281a8" alt=""
List Item Looping
data:image/s3,"s3://crabby-images/c7ed9/c7ed91487d52367750aee66f906ac6479de36559" alt=""
Figure 13: TaskItem
data:image/s3,"s3://crabby-images/b7b69/b7b6956d1428059e1003b512b5599a66187f027a" alt=""
Figure 14: String
data:image/s3,"s3://crabby-images/322d3/322d39375aec7c3fc9fe1048e5f2b1871b241ec5" alt=""
Figure 15: item
data:image/s3,"s3://crabby-images/66aa2/66aa2ac3bc1528a8c8f2cc002394d522934fafbe" alt=""
Figure 16: listitem
Final Workflow
data:image/s3,"s3://crabby-images/2a3e3/2a3e390d08400222b13383a288ebdd11b9e5eacb" alt=""
Figure 17: Workflow1
data:image/s3,"s3://crabby-images/4150d/4150d9dde4cd6264bfc907bdc1402c4f4b855ef0" alt=""
Figure 18: wk2
data:image/s3,"s3://crabby-images/80034/800348aa2510423cfb47fde2d96e360965442fff" alt=""
Figure 19: wk3
data:image/s3,"s3://crabby-images/71674/716746cbdd2cac932b64c413f72d26a63d583da6" alt=""
Figure 20: wk4
Check Workflow Execution
Add some list item's.
data:image/s3,"s3://crabby-images/8a043/8a043033ad2211e200a7620443ed38dc888da6da" alt=""
Figure 21: newitem
Follow below steps
data:image/s3,"s3://crabby-images/98a5a/98a5a77052bc629ce350a4698b4ccb82f1e40bc3" alt=""
Figure 22: follow
Reference:
http://www.c-sharpcorner.com/UploadFile/58e23e/call-http-web-service-using-sharepoint-designer-2013-spd/
Let's start with SharePoint Designer workflow which accesses the SharePoint List data using REST call i.e Web Service Call
SharePoint List
The following is a list structure which we are referencing for our application.
Figure 1: SharePoint
Step 1: Create Site Workflow
Using SharePoint Designer create site workflow. Make sure you select SharePoint 2013 Workflow as the platform type.
Figure 2: Workflow
Step 2: Create Workflow Stage.
Let’s start by creating a new stage.
Figure 3: Stage
Workflow Stages
Stage 1: Workflow Initialization: The following variables get initialized at this stage:
ServiceURL: Here's the URL.
Figure 4: Initialized
Index: Create Index variable of type Integer & set it to 0.
Figure 5: Index
Service Call Header: Next, we add a Dictionary variable (Build a Dictionary action), call it requestHeaders and initialize it as this:
Figure 6: Header
Both “Accept” and “Content-Type” entries are of the String type and they both contain the value “application/json;odata=verbose”. SharePoint REST API understands this and sets the response content type appropriately as JSON. If we don’t pass these values, the output would come as XML.
Figure 7: Accept
Stage 2: Web Service Call
Add a Call as HTTP Web Service action and set its properties. The request will be the url variable:
Figure 8: Webservice
Set workflow variable "ServiceURL" as Web Service URL.
HTTP method as "GET".
Figure 9: Get
Response content will go to a new variable called responseContent.(type - Dictionary).
Response headers will go to a new variable called responseHeaders.(type - Dictionary).
Response code will go to a new variable called responseCode.(type - Dictionary ).
Then we set the request headers to be the requestHeaders variable we created just now, by clicking on the properties for the Call on HTTP Web Service action:
Figure 10: Call set variable as needed.
Figure 11: Variable
Process Web Service Response
Now, create a new stage, call it " Process Web Service Response".
At the end of the " Web Service Call" add a Go to Process Web Service Response stage.
- Add a Get an Item from a Dictionary action, set the item as d/results, the source variable reponseContentand the output to a new variable of type Dictionary called List.
- Then count items from this list variable using a Count Items in Dictionary action and store the result in a new Integer variable called TotalListItem. This variable will tell us how many times we have to loop.
- Finally, create a new Integer variable called index and set it to 0 (Set Workflow Variable), this will be the loop index.
Figure 12: Loop
List Item Looping
- Add a loop (Loop n Times), call it Loop Task Items, and set the loop variable to TotalListItem variable.
- Inside the loop, get value d/results([%Variable: index%]) using a Get an Item from a Dictionary action from responseContent and store it in a new Dictionary variable called CurrentItem.
- Get some fields (Get an Item from a Dictionary) from the CurrentItem variable, such as Title and store them in appropriate variables and do whatever you want with them, like logging its contents (Log).
- Its Time to increment the loop counter: add a Do Calculation action and in it increment the index variable into a new Integer variable called IncrementCounter.
- Then set the index variable to be the IncrementCounter(Set Workflow Variable).
- Finally exit the loop and set the workflow status (Set Workflow Status action) to Finished.
- At the end of the stage, select Go to End of Workflow.
Figure 13: TaskItem
Figure 14: String
Figure 15: item
Figure 16: listitem
Final Workflow
Figure 17: Workflow1
Figure 18: wk2
Figure 19: wk3
Figure 20: wk4
Check Workflow Execution
Add some list item's.
Figure 21: newitem
Follow below steps
Figure 22: follow
- go to site content
- Click Site Workflow
- Select Appropriate workflow
- Click it
- Workflow started.
http://www.c-sharpcorner.com/UploadFile/58e23e/call-http-web-service-using-sharepoint-designer-2013-spd/
No comments:
Post a Comment