Disclaimer: All postings are provided "AS IS" with no warranties, and confer no rights. This weblog does not represent the thoughts, intentions, plans or strategies of Microsoft. Because a weblog is intended to provide a semi-permanent point-in-time snapshot, you should not consider out of date posts to reflect current thoughts and opinions.
How many of us cut our teeth with a Petzold book on Windows? Gee, I still have an OS/2 book on Presentation Manager from Mr. Petzold – pre-warp.
Well, MS Press has released his latest book in XPS/PDF form, along with the samples up on the MS Press site.
Free ebook: Programming Windows Phone 7, by Charles Petzold - Microsoft Press - Site Home - MSDN Blogs
During hierarchy changes, MDS provides some basic rules for validating hierarchy members against some logic that is defined in the model within the MDS interface or through the Services interface. Behind the scenes, MDS is generating all sorts of T-SQL to ultimately enforce these rules.
There is the ability to extend these rules with your own custom implementation if the configuration driven rules don’t suffice – either a SharePoint workflow or through custom CLR code packaged as an assembly.
For the custom code approach, you need to extend IWorkflowTypeExtender which is present in the “Microsoft.MasterDataServices.Core”  assembly.
Before you proceed is best to get the latest cumulative updates for MDS – see  – for this sample, I’ve used CU #4 . There are some important fixes to MDS that address basic things and ensure you have a much better experience configuring your rules.
There are 2 options for custom workflows:
1. Call a SharePoint workflow hosted in a site
2. Provide an implementation of IWorkflowTypeExtender 
With the first option, SharePoint hosted workflow, in the rules editor you’ll provide a “key” of SPWF as the identifier for the workflow type, along with the URL of the site/web. From this the MDS Workflow Windows service will then using the SharePoint object model (you’ll have to have this service running on the same box as SharePoint as it makes calls to the Server side SP Object Model (SPSite, SPWeb, SPWorkflowManager, et.al.)
For anything other than SPWF, the MDS Workflow service will resolve your type from assemblies as defined in the config file. Rules for fusion apply.
The architecture of this custom rules is that MDS, when a rule is configured to use a workflow, will write a message to a SQL Service Broker queue. Right now, out-of-the-box, the MDS Workflow service is designed to read these messages that are written there. In reality, you could write your own process/code hosted somewhere else that retrieves these messages.
1. Configure a rule to use a Workflow – the the rule below the condition forces it to fire on all changes.
For the Actions, the Workflow type in a custom extender references a key value in the config file for the service. You can provide as many as you need in the config that implement the interface IWorkflowTypeExtender.
Note that I’ve also supplied both a Workflow site and Workflow name setting. These tags are sent along in the “message” so, even for non-SP Workflows, our custom types can use these as additional values for logic. Again, not needed, but helps provide more context for our rule.
2. Modify an entity
Once you modify an entity, since our rule is without condition, MDS will write a message to the service broker queue. At this point, whoever is listening will see the message. For MDS, the Workflow service (Microsoft.MasterDataServices.Workflow.exe) calls the Stored Procedure “EXEC [mdm].[udpExternalActionsGet” which returns the XML to the Workflow Service and de-queues the message. This is done outside of a System.Transactions.TransactionScope – so, could be a good reason to write your own Workflow handler.
Once the message is de-queued, the extender is called - there is one instance that it get’s instantiated once at Workflow Service startup – calling the StartWorkflow method with the key (type of Workflow specified in the rules editor) and an XmlElement – similar to the following:
For the Workflow Service to load the sample type I just put a post build event to copy the Assembly (DLL) to the custombin path of where the Workflow Service is run from
C:\Program Files\Microsoft SQL Server\Master Data Services\WebApplication\bin
You must modify the the config file Microsoft.MasterDataServices.Workflow.exe.config specifing your types, and for this I modified the probing settings so my assembly can be in a sub directory. You can also deploy to the GAC.
Also, the project runs the Microsoft.MasterDataServices.Workflow.exe process, passing the “-console” switch to the executable so it can start in console mode instead of running it as a service and making debugging a little easier.
The appSettings section of the Workflow Service config file determines what DB to attach to along with what Workflow Extenders to load. All the types are specified as a single value semicolon separated “;” and prefixed with the <KEY>=<full assembly name>
A sample is below that loads 2 types:
<value>PAC=WorkflowTasks.SimpleHello, WorkflowTasks, Version=184.108.40.206, Culture=neutral, PublicKeyToken=null;OOB=Microsoft.MasterDataServices.Workflow.WorkflowTypeTest, Microsoft.MasterDataServices.Workflow, Version=10.0.0.0, Culture=neutral, PublicKeyToken=89845dcd8080cc91</value>
Solution File SQL_MDS_WorkflowTest.zip
 C:\Program Files\Microsoft SQL Server\Master Data Services\WebApplication\bin\Microsoft.MasterDataServices.Core.dll
 Microsoft.MasterDataServices.Core.Workflow.IWorkflowTypeExtender – there is a sample Microsoft.MasterDataServices.Workflow.WorkflowTypeTest in the EXE assembly