How to Use Visual Studio to Create a Service Manager Workflow
Applies To: System Center Service Manager 2010
Service Manager can use Windows Workflow Foundation through any management pack. This enables business logic to be executed when the management pack objects enter specific states. Workflows used by Service Manager are standard .NET Framework 3.5 binaries that contain a Windows Workflow–based class. The procedures in this document show how to create and configure a workflow by using Microsoft Visual Studio 2010. The examples build out a simple DLL used by the other topics in the SDK.
To create a new Sequential Workflow Library project
Open the project template window by creating a new project or adding a new project to an existing solution.
Target the .NET Framework version 3.5.
Under the Workflow template category, select Sequential Workflow Library.
Tip
You can use any project type as long as it compiles to a DLL.
Set the project name to WorkflowPackageRequest, and click OK.
After the project is created, right-click the project in the Solution Explorer window and then click Add Reference.
When the Add Reference dialog appears, click the Browse tab, locate the three SDK binaries, and add all three by holding down the CTRL key and clicking each one. After all three are selected, click OK. For information about these binaries, see Getting Started with the Service Manager SDK.
To design the workflow
Rename the workflow file from Workflow1.cs to PackageInitial.cs.
Tip
If Visual Studio prompts you to rename all references, select Yes.
With the designer for PackageInitial opened, expand the Toolbox tab if it is not already expanded and drag the Code item (under the Windows Workflow v3.0 category) to the area of the designer that contains the text Drop Activities to create a Sequential Workflow.
Select the newly created Code activity, and rename it from codeActivity1 to ObjectCreatedCodeActivity in the Properties window.
Switch the Properties window to display the events of the Code activity by clicking the events button (represented by a lightning bolt).
Double-click the ExecuteCode item to auto-generate the event handler.
To add properties to the workflow
In the code viewer of the PackageInitial workflow, add the following
using
statements to import the required Service Manager namespaces.using Microsoft.EnterpriseManagement; using Microsoft.EnterpriseManagement.Common; using Microsoft.EnterpriseManagement.Configuration;
Create a new Guid property named InternalID. Supply both get and set accessors.
Create a new Guid property named ClassGUID. Supply both get and set accessors.
As shown in the following example, the management pack subscription action that calls this workflow has to be configured to provide the required data to these properties. The workflow must get the specific object that the management pack defined as being tied to the workflow. This will be supplied on the InternalID property and is the GUID of the object instance in Service Manager. The ClassGUID property is just an easy reference of the type of object instance identified by the InternalID property. This is the GUID of the object’s class type in Service Manager.
public Guid ClassGUID { get; set; }
public Guid InternalID { get; set; }
To code the workflow
In the code viewer of the PackageInitial workflow, find the code activity’s ExecuteCode method named ObjectCreatedCodeActivity_ExecuteCode.
Connect to the management group server, localhost.
Use the entity types API to get the object instance that this workflow will run against.
Get the management pack class of the object instance.
Set the DisplayName property of the object instance.
Save the changes to the object instance by calling the Commit method.
While you could subscribe to the Initialized and Completed events of the workflow itself, the preceding procedure simply used the activity’s event handler.
As shown in the following example, the connection to the Service Manager store is connecting to localhost because the workflow instance is always executed on the server.
private void ObjectCreatedCodeActivity_ExecuteCode(object sender, EventArgs e)
{
// Create a connection to the local server
EnterpriseManagementGroup mg = new EnterpriseManagementGroup("localhost");
// Get the object instance triggering the workflow
EnterpriseManagementObject packageInstance = mg.EntityObjects.GetObject<EnterpriseManagementObject>(InternalID, ObjectQueryOptions.Default);
// We know the class used by the object instance, so use the workflow parameter supplied property
ManagementPackClass packageClass = mg.EntityTypes.GetClass(ClassGUID);
// Set the DisplayName of the workflow so we know it went through the workflow
packageInstance[packageClass, "DisplayName"].Value += " WENT THROUGH WORKFLOW";
// Save the object changes
packageInstance.Commit();
}
To install and debug the workflow
After compiling the workflow, copy the workflow binary to the %programfiles%\Microsoft System Center\Service Manager 2010 folder on the management group servers that will contain the management pack referencing the workflow.
To debug the workflow, copy the .pdb file together with the .dll into the Service Manager directory.
To trigger the debugger, insert calls to the Break method into the workflow code.
When the workflow is initiated and a code line with the break is executed, the standard debugging dialog box appears. (This requires that you have Visual Studio installed on the server.)