Dec
25
Written by:
Michael Washington
12/25/2014 7:45 PM
data:image/s3,"s3://crabby-images/b3950/b3950858fbea583025f7ec29d40e29b597c1cc63" alt="image image"
You can create advanced enterprise applications when you incorporate Visual Studio LightSwitch Cloud Business Apps and SharePoint Workflows into your solutions. Microsoft SharePoint workflows are powerful, but the non-code version created with the SharePoint Designer do not allow you to implement complex data bound business rules without making web service HTTP calls. You can make these calls to Visual Studio LightSwitch Cloud Business Apps.
In this article we will enhance the vacation request application that we started in An End-To-End LightSwitch SharePoint Workflow Application. In that version, a vacation was automatically approved if it was more than 7 days away. In this version, we will create a table that will contain the vacation days for each employee. The workflow will automatically approve any vacation as long as a employee has vacation days. It will deduct the days used from the table. Only when the employee runs out of days will a manager have to approve the vacation.
The Application
data:image/s3,"s3://crabby-images/b1505/b1505989687c4436ff5859c9fa759ee33fbf9105" alt="image221 image221"
Users of your SharePoint site can create vacation requests by opening the custom list.
data:image/s3,"s3://crabby-images/d402d/d402dc135bc9f2a02f8929eae75e221151c3e2af" alt="image225 image225"
They click the new item link to add a new request.
data:image/s3,"s3://crabby-images/c2bab/c2babc2396c4e917a46b2af368226ae90e1385b4" alt="image229 image229"
They enter their requested days and click the Save button.
data:image/s3,"s3://crabby-images/0e01b/0e01b9fa5f3dd60938806db61f1ec0dea3fa707f" alt="image233 image233"
If they have enough vacation days, the vacation is automatically approved.
data:image/s3,"s3://crabby-images/37c60/37c6070bf3dd2afe297daeee4ccf4e01ae0f242e" alt="image237 image237"
They also receive an email.
data:image/s3,"s3://crabby-images/7c5c9/7c5c9fa35721262187c4c3b493e587901ce32dbe" alt="image241 image241"
If the employee does not have enough vacation days, the status is set to Pending and the members of the Vacation Approvers group receive an email that instructs them to access the LightSwitch Cloud Business App to approve it.
data:image/s3,"s3://crabby-images/98d4f/98d4fa8a38029ecb2c56ab031f522805e715f4db" alt="image250 image250"
The member of the Vacation Approver group logs into the LightSwitch Cloud Business App.
data:image/s3,"s3://crabby-images/8b41c/8b41c8062c3aa11eaa7fe6dc6f971a5e382545e9" alt="image245 image245"
Selects the request…
data:image/s3,"s3://crabby-images/e9d5f/e9d5f72bca8b012e0df9213014e8401689a82248" alt="image254 image254"
… and approves (or denies) it.
The LightSwitch Application
data:image/s3,"s3://crabby-images/8364c/8364c1932191edb6f96e743ed1985ef4ebd7eeed" alt="image image"
The first step is to add a table to the LightSwitch Cloud Business App (from the pervious tutorial) to track the number of vacation days each employee has.
data:image/s3,"s3://crabby-images/6fca4/6fca479edbcbe07d332f6af4685e51873f6c60b6" alt="image image"
We call the table VacationDays and we use the structure in the image above.
data:image/s3,"s3://crabby-images/1cd50/1cd506c7acbd94448821295acaf4e86bab2ab81a" alt="image image"
We now need to create a screen to manage the vacation days.
We right-click on the Screens folder and select Add Screen.
data:image/s3,"s3://crabby-images/28153/281535c6412f289fa63647c12fb275a81511f553" alt="image image"
Select the Common Screen Set and the VacationDaysSet data source.
data:image/s3,"s3://crabby-images/dfcda/dfcda30d47235a23075c14b131121174cd3cc7b4" alt="image image"
The screens will be created.
data:image/s3,"s3://crabby-images/c345c/c345c5227b84ec685354a1253501f9de2b9fff61" alt="image image"
When we run the application…
data:image/s3,"s3://crabby-images/ca0e9/ca0e9a50f9241c1dd0d1b8980e520dd1995d2193" alt="image image"
We can navigate to the new screens using the main menu drop down.
data:image/s3,"s3://crabby-images/7bba8/7bba80da7562ed071c3c9ea34cb9a0172c36241c" alt="image image"
The screens will allow you to manage the vacation days.
Creating The Workflow Connector
data:image/s3,"s3://crabby-images/133af/133af6b8e39a97b0468caa2926f6c6dd9188a14c" alt="image image"
We will now create a file handler that will allow the SharePoint Workflow to communicate with the LightSwitch Cloud Business App.
Right-click on the Server project and select Add then New Item.
data:image/s3,"s3://crabby-images/da94e/da94e6ab8e283b0d6cd587112bd55f1c8da58ff0" alt="image image"
Create a Generic Handler.
Use the following code:
using Microsoft.LightSwitch.Server;
using System;
using System.Collections.Generic;
using System.Data;
using System.Data.SqlClient;
using System.Linq;
using System.Web;
namespace LightSwitchApplication
{
public class WorkflowConnector : IHttpHandler
{
public void ProcessRequest(HttpContext context)
{
// Get the parameters passed by the Workflow
string paramPassword =
Convert.ToString(context.Request.QueryString["Password"]);
string paramTitle =
Convert.ToString(context.Request.QueryString["Title"]);
DateTime paramStartDate =
Convert.ToDateTime(context.Request.QueryString["StartDate"]);
DateTime paramEndDate =
Convert.ToDateTime(context.Request.QueryString["EndDate"]);
string paramUserName =
Convert.ToString(context.Request.QueryString["UserName"]).ToLower();
string strResponse = "Not Found";
// Simple security
if (paramPassword == "pass14")
{
int intId = -1;
int intDays = 0;
// Connect to the database
// Do this using ADO.NET because we don't have an active
// LightSwitch Dataworkspace at this point
string connString =
System.Web.Configuration.WebConfigurationManager
.ConnectionStrings["_IntrinsicData"].ConnectionString;
SqlConnection conn = new SqlConnection(connString);
string sql =
"Select Id, Days FROM VacationDaysSet where UserName=@UserName;";
conn.Open();
SqlCommand cmd = new SqlCommand(sql, conn);
cmd.Parameters.AddWithValue("@UserName", paramUserName);
cmd.CommandType = CommandType.Text;
SqlDataReader reader = cmd.ExecuteReader();
while (reader.Read())
{
intId = Convert.ToInt32(reader[0]);
intDays = Convert.ToInt32(reader[1]);
}
reader.Close();
if (intId > -1) // Found Days
{
// Get the User's Days
int intDaysAvailable = intDays;
// Determine how many days are needed
int intDaysRequested = (paramEndDate - paramStartDate).Days;
// See if there are enough days
if (intDaysAvailable >= intDaysRequested)
{
// Deduct the days
int intNewDays = (intDays - intDaysRequested);
string sql2 =
"UPDATE VacationDaysSet SET Days=@VacationDays where ID=@Id;";
SqlCommand cmd2 = new SqlCommand(sql2, conn);
cmd2.Parameters.AddWithValue("@VacationDays", intNewDays);
cmd2.Parameters.AddWithValue("@Id", intId);
cmd2.CommandType = CommandType.Text;
cmd2.ExecuteNonQuery();
strResponse = "Approved";
context.Response.StatusCode = 201;
}
else // Not enough days
{
strResponse = "User does not have enough days.";
}
}
else // Did not find a record for the user
{
strResponse = "User has no days available.";
}
conn.Close();
}
else
{
// Bad Password
strResponse = "Bad Password";
}
// Create JavaScriptSerializer
System.Web.Script.Serialization.JavaScriptSerializer jsonSerializer =
new System.Web.Script.Serialization.JavaScriptSerializer();
// Output as JSON
context.Response.Write(jsonSerializer.Serialize(strResponse));
}
public bool IsReusable
{
get
{
return false;
}
}
}
}
This will set the Response.StatusCode to 201 (“CREATED”) if the vacation is approved. Otherwise it will return a 200 code (“OK”).
data:image/s3,"s3://crabby-images/3259c/3259ca90fd3072cd8fa930aed5e1c67e97b1101e" alt="image image"
You will need to add a reference, in the Server project, to System.Configuration and System.Web.Extensions.
data:image/s3,"s3://crabby-images/f1a20/f1a207402571a4d8e0277f82960f9dc0bf06bfbc" alt="image image"
Next, open the Web.config.
Add the following entry to allow the WorkflowConnector.ashx handler to be called by unauthenticated clients:
(put under the configuration node)
<location path="WorkflowConnector.ashx">
<system.web>
<authorization>
<allow users="?" />
</authorization>
</system.web>
</location>
(note: you can authenticate a workflow call using the methods described by Andrew Connell in his Pluralsight course: SharePoint 2013 Workflow - Web Services)
Deploy The Application
At this point you will want to deploy the LightSwitch application to production (see: Creating A LightSwitch SharePoint 2013 Multi-Tenant Provider-Hosted Application for details). The reason is that the SharePoint Workflow needs the WorkflowConnector.ashx handler at a location that it can reach.
Update The Workflow
data:image/s3,"s3://crabby-images/6d6f4/6d6f48184ac8eaa8b2caba9f829af161cd011f12" alt="image image"
We open the original workflow.
data:image/s3,"s3://crabby-images/71304/71304cf9ebe3ffa080046e0f312e773c7088dda6" alt="image image"
We delete the first action and insert an HTTP action.
data:image/s3,"s3://crabby-images/ad3a6/ad3a6b2bbe475f8306274a17e27c73e609110b2b" alt="image image"
We construct the action to call the WorkflowConnector.ashx, passing the values from the current list item.
data:image/s3,"s3://crabby-images/ade4e/ade4e4df800fb8560e624ca23c370502a23331f2" alt="image image"
The image above shows the complete workflow after the alterations.
data:image/s3,"s3://crabby-images/6fb92/6fb9291ea3c99b7decaf23695eedc8e591b41d75" alt="image image"
If you have Visio installed you can select the Visual Designer…
data:image/s3,"s3://crabby-images/acecb/acecb6f38bd56ddd7c81b2ba86a902103ed3acd7" alt="image image"
To view and design the SharePoint Workflow.
Deploying To Production
You can download the LightSwitch application (available on the download page), deploy it to production, create the SharePoint list and workflow and it will work.
When you deploy the application to production, you will want to follow the method in this article:
Creating A LightSwitch SharePoint 2013 Multi-Tenant Provider-Hosted Application
In addition, you can have the application automatically create the needed SharePoint Vacation Request list in your production site by using the method described in this article:
Implementing Documents in a SharePoint 2013 Cloud Business App (LightSwitch)
Links – Microsoft
Overview of workflows included with SharePoint
SharePoint 2013 workflow samples
Get started with workflows in SharePoint 2013
SharePoint 2013 workflow fundamentals
Links – Andrew Connell
Workflow - Andrew Connell
Andrew Connell – Pluralsight author
SharePoint 2013 workflow: Call an External Web Service
Links – LightSwitch Help Website
An End-To-End LightSwitch SharePoint Workflow Application
Deploy A LightSwitch Application To Office 365 / SharePoint Online
Exploring SharePoint 2013 Visual Studio Cloud Business Apps (LightSwitch)
Implementing Documents in a SharePoint 2013 Cloud Business App (LightSwitch)
An End-to-End AngularJS SharePoint Module using LightSwitch OData as a Back-End
Creating A SharePoint Online Testing Site
Creating A LightSwitch SharePoint 2013 Multi-Tenant Provider-Hosted Application
Download Code
The LightSwitch project is available at http://lightswitchhelpwebsite.com/Downloads.aspx
(you must have Visual Studio 2013 (or higher) installed and a SharePoint Developer site to run the code)