Skip to content

Latest commit

 

History

History
115 lines (86 loc) · 5.83 KB

README.md

File metadata and controls

115 lines (86 loc) · 5.83 KB

CrmDeploy

A .Net Library that makes it simple to deploy plugins (and maybe one day workflows?) to Dynamics CRM programmatically. This is useful for when a manual process such as using the Plugin Registration Tool is not desirable.

Deploying Plugins

CrmDeploy is available as a NuGet package: https://www.nuget.org/packages/CrmDeploy/ so it's recommended that you use NuGet to add it to your solution.

The following demonstrates how to deploy a plugin to Dynamics Crm using the fluent API.

using CrmDeploy;
using CrmDeploy.Enums;


        public static void Main(string[] args)
        {

            var crmConnectionString =
               @"Url=https://myorg.crm4.dynamics.com/; [email protected]; Password=password; DeviceID=mydevice-dd9f6b7b2e6d; DevicePassword=password";
           
            var deployer = DeploymentBuilder.CreateDeployment()
                                            .ForTheAssemblyContainingThisPlugin<TestPlugin>("Test plugin assembly")
                                            .RunsInSandboxMode()
                                            .RegisterInDatabase()
                                                .HasPlugin<TestPlugin>()
                                                    .WhichExecutesOn(SdkMessageNames.Create, "contact")
                                                    .Synchronously()
                                                    .PostOperation()
                                                    .OnlyOnCrmServer()
                                             .DeployTo(crmConnectionString);

            var registrationInfo = deployer.Deploy();
            if (!RegistrationInfo.Success)
            {
                var reason = registrationInfo.Error.Message;
                Console.WriteLine("Registration failed because: {0}. Rolling deployment back.", reason);
                registrationInfo.Undeploy();
                Console.WriteLine("Deployment was rolled back..");
            }

        }

If for any reason the deployment fails, the registrationInfo.Undeploy() method will attempt to roll back the changes that were made.

Multiple Plugin Steps?

You can chain the .AndExecutesOn() method to register multiple steps for a plugin.

For example, if you want to register your plugin on Create, Update and Delete of a contact you could use the following syntax:

  var deployer = DeploymentBuilder.CreateDeployment()
                                            .ForTheAssemblyContainingThisPlugin<TestPlugin>("Test plugin assembly")
                                            .RunsInSandboxMode()
                                            .RegisterInDatabase()
                                                .HasPlugin<TestPlugin>()
                                                    .WhichExecutesOn(SdkMessageNames.Create, "contact")
                                                        .Synchronously()
                                                        .PostOperation()
                                                        .OnlyOnCrmServer()
                                                    .AndExecutesOn(SdkMessageNames.Update, "contact")
                                                        .Asynchronously()
                                                        .PostOperation()
                                                        .OnCrmServerAndOffline()
                                                    .AndExecutesOn(SdkMessageNames.Delete, "contact")
                                                        .Synchronously()
                                                        .PreOperation()
                                                        .OnlyOffline()
                                             .DeployTo(crmConnectionString.ConnectionString);

Many Plugins?

You can chain the .AndHasPlugin() method to register multiple plugins. For example:-

            var deployer = DeploymentBuilder.CreateDeployment()
                                            .ForTheAssemblyContainingThisPlugin<TestPlugin>("Test plugin assembly")
                                            .RunsInSandboxMode()
                                            .RegisterInDatabase()
                                                .HasPlugin<TestPlugin>()
                                                    .WhichExecutesOn(SdkMessageNames.Create, "contact")
                                                        .Synchronously()
                                                        .PostOperation()
                                                        .OnlyOnCrmServer()
                                                 .AndHasPlugin<AnotherTestPlugin>()
                                                    .WhichExecutesOn(SdkMessageNames.Update, "account")
                                                        .Asynchronously()
                                                        .PostOperation()
                                                        .OnCrmServerAndOffline()
                                                  .AndHasPlugin<SomeOtherPlugin>()
                                                    .WhichExecutesOn(SdkMessageNames.Associate, "my_custent", "my_otherent")
                                                        .Synchronously()
                                                        .PreOperation()
                                                        .Rank(2)
                                                        .OnlyOffline()
                                             .DeployTo(crmConnectionString.ConnectionString);

What about workflows?

I will add support for workflows as the need arises (or if its in demand - raise an issue and let me know!)

What about Pre / Post Images?

I will add support for Images as the need arises (or the demand - raise an issue and let me know!)