Microsoft Dynamics CRM-플러그인

플러그인은 플랫폼의 표준 동작을 수정하거나 확장하기 위해 Microsoft Dynamics CRM과 통합되는 사용자 지정 비즈니스 논리입니다. 플러그인은 이벤트 처리기 역할을하며 CRM의 특정 이벤트에서 실행되도록 등록됩니다. 플러그인은 C # 또는 VB로 작성되며 동기 또는 비동기 모드로 실행할 수 있습니다.

플러그인을 작성하는 몇 가지 시나리오는 다음과 같습니다.

  • CRM 레코드를 만들거나 업데이트 할 때 레코드의 특정 필드 업데이트 또는 관련 레코드 업데이트 등과 같은 일부 비즈니스 논리를 실행하려고합니다.

  • 레코드 저장 또는 업데이트와 같은 특정 이벤트에 대해 외부 웹 서비스를 호출하려고합니다.

  • 레코드가 열릴 때 필드 값을 동적으로 계산하려고합니다.

  • CRM의 특정 이벤트에 대해 고객에게 전자 메일을 보내는 것과 같은 프로세스를 자동화하려고합니다.

이벤트 프레임 워크

CRM의 이벤트 처리 프레임 워크는 동기 및 비동기 플러그인 요청을 이벤트 실행 파이프 라인에 전달하여 처리합니다. 이벤트가 플러그인 로직을 트리거 할 때마다 다른 플러그인이나 플랫폼의 핵심 작업에서 읽거나 수정할 수있는 메시지가 CRM 조직 웹 서비스로 전송됩니다.

플러그인 파이프 라인 단계

전체 플러그인 파이프 라인은 사용자 지정 비즈니스 로직을 등록 할 수있는 여러 단계로 나뉩니다. 지정된 파이프 라인 단계는 플러그인 코드가 실행되는 플러그인 실행주기 단계를 나타냅니다. 다음 표에 지정된 모든 파이프 라인 단계 중에서 사전 및 사후 이벤트에만 커스텀 플러그인을 등록 할 수 있습니다. Platform Core Main Operations에는 플러그인을 등록 할 수 없습니다.

행사 예명 기술
사전 이벤트 사전 검증 기본 시스템 작업 전에 실행할 플러그인에 대한 파이프 라인의 스테이지입니다. 이 단계에서 등록 된 플러그인은 데이터베이스 트랜잭션 외부에서 실행될 수 있습니다.
사전 이벤트 작동 전 기본 시스템 작업 전에 실행될 플러그인에 대한 파이프 라인의 스테이지입니다. 이 단계에서 등록 된 플러그인은 데이터베이스 트랜잭션 내에서 실행됩니다.
플랫폼 핵심 운영 MainOperation 트랜잭션 중, 생성, 업데이트, 삭제 등과 같은 시스템의 주요 작업입니다. 이 단계에서는 사용자 정의 플러그인을 등록 할 수 없습니다. 내부 전용입니다.
이벤트 후 수술 후 기본 작업 후에 실행될 플러그인에 대한 파이프 라인의 스테이지입니다. 이 단계에서 등록 된 플러그인은 데이터베이스 트랜잭션 내에서 실행됩니다.

CRM 애플리케이션이 이벤트 (레코드 저장 또는 업데이트와 같은)를 호출 할 때마다 다음과 같은 일련의 작업이 수행됩니다.

  • 이벤트는 웹 서비스 호출을 트리거하고 실행은 이벤트 파이프 라인 단계 (사전 이벤트, 플랫폼 핵심 작업, 사후 이벤트)를 통해 전달됩니다.

  • 정보는 내부적으로 OrganizationRequest 메시지로 패키징되어 최종적으로 내부 CRM 웹 서비스 메서드 및 플랫폼 핵심 작업으로 전송됩니다.

  • OrganizationRequest 메시지는 플랫폼 코어 작업에 전달하기 전에 정보를 수정할 수있는 사전 이벤트 플러그인에 의해 먼저 수신됩니다. 플랫폼 핵심 작업 후 메시지는 OrganizationResponse로 패키징되고 작업 후 플러그인에 전달됩니다. postoperations 플러그인은이 정보를 비동기 플러그인에 전달하기 전에 선택적으로 수정할 수 있습니다.

  • 플러그인은 추가 처리가 발생한 후 Execute 메서드에 전달되는 컨텍스트 개체의 형태로이 정보를 수신합니다.

  • 모든 플러그인 처리가 완료된 후 실행은 이벤트를 트리거 한 애플리케이션으로 다시 전달됩니다.

플러그인 메시지

메시지는 플러그인 (또는 비즈니스 로직)이 등록 된 이벤트입니다. 예를 들어, 연락처 엔티티의 메시지 작성에 플러그인을 등록 할 수 있습니다. 이렇게하면 새 연락처 레코드가 생성 될 때마다 비즈니스 로직이 실행됩니다.

사용자 지정 엔터티의 경우 엔터티가 사용자 소유인지 조직 소유인지에 따라 지원되는 메시지는 다음과 같습니다.

메시지 이름 소유권 유형
양수인 사용자 소유 엔티티 만
창조하다 사용자 소유 및 조직 소유 엔티티
지우다 사용자 소유 및 조직 소유 엔티티
GrantAccess 사용자 소유 엔티티 만
ModifyAccess 사용자 소유 엔티티 만
검색 사용자 소유 및 조직 소유 엔티티
RetrieveMultiple 사용자 소유 및 조직 소유 엔티티
RetrievePrincipalAccess 사용자 소유 엔티티 만
RetrieveSharedPrincipalsAndAccess 사용자 소유 엔티티 만
액세스 권한을 취소 사용자 소유 엔티티 만
SetState 사용자 소유 및 조직 소유 엔티티
SetStateDynamicEntity 사용자 소유 및 조직 소유 엔티티
최신 정보 사용자 소유 및 조직 소유 엔티티

기본 제공 엔터티의 경우 지원되는 메시지가 100 개가 넘습니다. 이러한 메시지 중 일부는 모든 엔터티에 적용 할 수 있지만 일부는 특정 엔터티에만 적용됩니다. SDK 내의 Excel 파일에서 지원되는 전체 메시지 목록을 찾을 수 있습니다.SDK\Message-entity support for plug-ins.xlsx

플러그인 작성

이 섹션에서는 플러그인 작성의 기본 사항을 배웁니다. 새 고객이 시스템에 추가 될 때마다 (즉, CRM에서 새 Contactrecord가 생성 될 때마다) 고객과의 후속 조치를 위해 Task 활동을 생성하는 샘플 플러그인을 생성 할 것입니다.

우선, 다음에 대한 참조를 포함해야합니다. Microsoft.Xrm.Sdk네임 스페이스. CRM SDK에는 필요한 모든 SDK 어셈블리가 포함되어 있습니다. 2 장에서 SDK를 이미 다운로드하고 설치했다고 가정하고 Visual Studio를 엽니 다. 클래스 라이브러리 유형의 새 프로젝트를 만듭니다. 프로젝트 이름을 SamplePlugins로 지정하고 확인을 클릭 할 수 있습니다.

참조 추가 Microsoft.Xrm.Sdk프로젝트에 어셈블리. 어셈블리가 있습니다.SDK/Bin.

이제 PostCreateContact.cs 클래스를 확장하십시오. IPlugin. 지금까지 코드는 다음과 같습니다.

System.Runtime.Serialization에 대한 참조도 추가해야합니다. 필요한 참조를 추가했으면 다음 코드를PostCreateContact 수업.

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Microsoft.Xrm.Sdk;

namespace SamplePlugins {
   public class PostCreateContact:IPlugin {
      /// A plug-in that creates a follow-up task activity when a new account is created.
      /// Register this plug-in on the Create message, account entity,
      /// and asynchronous mode.

      public void Execute(IServiceProviderserviceProvider) {
         // Obtain the execution context from the service provider.
         IPluginExecutionContext context =(IPluginExecutionContext)
            serviceProvider.GetService(typeof(IPluginExecutionContext));

         // The InputParameters collection contains all the data
            passed in the message request.

         if(context.InputParameters.Contains("Target")&&
            context.InputParameters["Target"]isEntity) {
            
            // Obtain the target entity from the input parameters.
            Entity entity = (Entity)context.InputParameters["Target"];
            try {
               
               // Create a task activity to follow up with the account customer in 7 days
               Entity followup = new Entity("task");
               followup["subject"] = "Send e-mail to the new customer.";
               followup["description"] =
                  "Follow up with the customer. Check if there are any new issues
                  that need resolution.";
               
               followup["scheduledstart"] = DateTime.Now;
               followup["scheduledend"] = DateTime.Now.AddDays(2);
               followup["category"] = context.PrimaryEntityName;

               // Refer to the contact in the task activity.
               if(context.OutputParameters.Contains("id")) {
                  Guid regardingobjectid = new Guid(context.OutputParameter
                     s["id"].ToString());
                  string regardingobjectidType = "contact";
                  followup["regardingobjectid"] = 
                     new EntityReference(rega rdingobjectidType,regardingobjectid);
               }
               
               // Obtain the organization service reference.
               IOrganizationServiceFactory serviceFactory =
                  (IOrganizationSer viceFactory)serviceProvider.GetService
                  (typeof(IOrganizationServiceFactory));
               IOrganizationService service = 
                  serviceFactory.CreateOrganizationService(context.UserId);

               // Create the followup activity
               service.Create(followup);
            } catch(Exception ex) {
               throw new InvalidPluginExecutionException(ex.Message);
            }
         }
      }
   }
}

다음은이 코드가 수행하는 작업에 대한 단계별 설명입니다.

Step 1− IServiceProvider 객체를 매개 변수로 사용하여 Execute 메서드를 구현합니다. 서비스 공급자는 플러그인 내에서 사용할 많은 유용한 개체에 대한 참조를 포함합니다.

Step 2 − IServiceProvider의 GetService 메소드를 이용하여 IPluginExecutionContext 객체를 획득합니다.

Step 3− 컨텍스트 개체의 InputParameters 컬렉션에서 대상 개체의 개체를 가져옵니다. 이 Entity 클래스 개체는 플러그인이 등록 될 연락처 엔터티 레코드를 참조합니다.

Step 4− 그런 다음 Task 개체의 개체를 생성하고 적절한 제목, 설명, 날짜, 범주 및 관련 개체 ID를 설정합니다. Relatedobjectid는이 활동 레코드가 생성되는 연락처 레코드를 나타냅니다. 코드가 context.OutputParameters를 사용하여 상위 연락처 레코드의 ID를 가져오고 생성 한 작업 엔터티 레코드와 연결하는 것을 볼 수 있습니다.

Step 5 − IServiceProvider 객체를 이용하여 IOrganizationServiceFactory의 객체를 생성합니다.

Step 6 − IOrganizationServiceFactory 객체를 이용하여 IOrganizationService의 객체를 생성합니다.

Step 7− 마지막으로이 서비스 객체의 Create 메소드를 사용합니다. CRM에 저장되는 후속 활동을 생성합니다.

플러그인 어셈블리 서명

이 섹션은 플러그인 어셈블리를 처음 등록하는 경우에만 적용됩니다. 플러그인을 배포하려면 키를 사용하여 어셈블리에 로그인해야합니다. 솔루션을 마우스 오른쪽 단추로 클릭하고 속성을 클릭합니다.

왼쪽 옵션에서 서명 탭을 선택하고 '어셈블리 서명'옵션을 선택합니다. 그런 다음 강력한 이름 키 파일 선택 옵션에서 새로 만들기를 선택합니다.

키 파일 이름을 sampleplugins로 입력합니다 (원하는 다른 이름 일 수 있음). 암호로 내 키 파일 보호 옵션을 선택 취소하고 확인을 클릭하십시오. 저장을 클릭하십시오.

마지막으로 솔루션을 구축하십시오. 오른쪽 클릭 → 빌드. 솔루션을 빌드하면 다음 장에서이 플러그인을 등록하는 데 사용할 어셈블리 DLL이 생성됩니다.

플러그인의 예외 처리

종종 플러그인 로직은 런타임 예외를 처리해야합니다. 동기식 플러그인의 경우InvalidPluginExecutionException사용자에게 오류 대화 상자를 표시합니다. 오류 대화 상자에는 예외 개체의 메시지 개체에 전달하는 사용자 지정 오류 메시지가 포함됩니다.

코드를 보면 catch 블록에서 InvalidPluginExecutionException 예외가 발생합니다.

throw new InvalidPluginExecutionException(ex.Message);

결론

플러그인은 모든 사용자 지정 CRM 구현에 확실히 중요합니다. 이 장에서는 이벤트 프레임 워크 모델, 파이프 라인 단계, 메시지를 이해하고 샘플 플러그인을 작성하는 데 중점을 두었습니다. 다음 장에서는이 플러그인을 CRM에 등록하고 종단 간 시나리오에서 작동하는지 확인합니다.