Microsoft Dynamics CRM - प्लगइन्स
प्लग-इन एक कस्टम व्यवसाय तर्क है जो प्लेटफ़ॉर्म के मानक व्यवहार को संशोधित या विस्तारित करने के लिए Microsoft Dynamics CRM के साथ एकीकृत करता है। प्लग-इन ईवेंट हैंडलर के रूप में कार्य करते हैं और CRM में किसी विशेष ईवेंट पर निष्पादित करने के लिए पंजीकृत होते हैं। प्लगइन्स C # या VB में लिखे गए हैं और या तो सिंक्रोनस या एसिंक्रोनस मोड में चल सकते हैं।
कुछ परिदृश्य जहाँ आप एक प्लगइन लिखेंगे -
जब आप CRM रिकॉर्ड बनाते या अपडेट करते हैं, तो आप कुछ व्यावसायिक तर्क निष्पादित करना चाहते हैं जैसे किसी रिकॉर्ड के कुछ क्षेत्रों को अपडेट करना या संबंधित रिकॉर्ड को अपडेट करना आदि।
आप कुछ घटनाओं जैसे कि किसी रिकॉर्ड को सहेजने या अद्यतन करने के लिए किसी बाहरी वेब सेवा पर कॉल करना चाहते हैं।
आप किसी भी रिकॉर्ड को खोलने पर गतिशील रूप से फ़ील्ड मानों की गणना करना चाहते हैं।
आप CRM में कुछ घटनाओं पर अपने ग्राहकों को ई-मेल भेजने जैसी प्रक्रियाओं को स्वचालित करना चाहते हैं।
इवेंट फ्रेमवर्क
CRM में ईवेंट प्रोसेसिंग फ़्रेमवर्क, इवेंट एक्ज़ीक्यूटिव पाइपलाइन से पास करके सिंक्रोनस और एसिंक्रोनस प्लगइन रिक्वेस्ट को प्रोसेस करता है। जब भी कोई ईवेंट एक प्लगइन लॉजिक को ट्रिगर करता है, तो CRM संगठन वेब सेवा को एक संदेश भेजा जाता है जहां इसे अन्य प्लगइन्स या प्लेटफ़ॉर्म के किसी भी कोर ऑपरेशन द्वारा पढ़ा या संशोधित किया जा सकता है।
प्लगइन पाइपलाइन चरणों
पूरे प्लगइन पाइपलाइन को कई चरणों में विभाजित किया गया है, जिस पर आप अपने कस्टम व्यवसाय तर्क को पंजीकृत कर सकते हैं। निर्दिष्ट पाइपलाइन चरण प्लगइन निष्पादन चक्र के किस चरण में इंगित करता है, आपका प्लगइन कोड चलता है। निम्न तालिका में सभी निर्दिष्ट पाइपलाइन चरणों में से, आप अपने कस्टम प्लगइन्स को केवल प्री- और पोस्ट-ईवेंट पर पंजीकृत कर सकते हैं। आप प्लेटफ़ॉर्म कोर मुख्य संचालन पर प्लगइन्स पंजीकृत नहीं कर सकते।
प्रतिस्पर्धा | मंच का नाम | विवरण |
---|---|---|
पूर्व घटना | पूर्व सत्यापन | प्लग-इन के लिए पाइपलाइन में स्टेज जो मुख्य सिस्टम ऑपरेशन से पहले निष्पादित करना है। इस चरण में पंजीकृत प्लग-इन डेटाबेस लेनदेन के बाहर निष्पादित हो सकता है। |
पूर्व घटना | पूर्व आपरेशन | प्लग-इन के लिए पाइपलाइन में स्टेज जो मुख्य सिस्टम ऑपरेशन से पहले निष्पादित किया जाता है। इस चरण में पंजीकृत प्लगइन्स को डेटाबेस लेनदेन के भीतर निष्पादित किया जाता है। |
प्लेटफ़ॉर्म कोर ऑपरेशन | MainOperation | Intransaction, सिस्टम का मुख्य ऑपरेशन, जैसे कि क्रिएट, अपडेट, डिलीट, इत्यादि। इस चरण में कोई कस्टम प्लग-इन पंजीकृत नहीं किया जा सकता है। आंतरिक उपयोग के लिए ही। |
घटना के बाद | ऑपरेशन के बाद | प्लग-इन के लिए पाइपलाइन में चरण जो मुख्य ऑपरेशन के बाद निष्पादित किए जाते हैं। इस चरण में पंजीकृत प्लग-इन को डेटाबेस लेनदेन के भीतर निष्पादित किया जाता है। |
जब भी सीआरएम एप्लिकेशन किसी ईवेंट (जैसे किसी रिकॉर्ड को सहेजने या अपडेट करने) के लिए आमंत्रित करता है, तो क्रियाओं का निम्नलिखित अनुक्रम होता है -
ईवेंट वेब सेवा कॉल चलाता है और ईवेंट पाइपलाइन चरणों (पूर्व-ईवेंट, प्लेटफ़ॉर्म कोर संचालन, पोस्ट-ईवेंट) के माध्यम से निष्पादित किया जाता है।
जानकारी को आंतरिक रूप से एक संगठन संदेश के रूप में पैक किया जाता है और अंत में आंतरिक CRM वेब सेवा विधियों और प्लेटफ़ॉर्म कोर संचालन के लिए भेजा जाता है।
ऑर्गनाइज रेयर मैसेज सबसे पहले प्री-इवेंट प्लगइन्स द्वारा प्राप्त किया जाता है, जो इसे प्लेटफ़ॉर्म कोर ऑपरेशंस में पास करने से पहले जानकारी को संशोधित कर सकता है। प्लेटफ़ॉर्म कोर ऑपरेशंस के बाद, मैसेज को OrganResponse के रूप में पैक किया जाता है और ऑपरेशन के बाद के प्लगइन्स को पास कर दिया जाता है। पोस्टऑपरेशन प्लगइन्स वैकल्पिक रूप से इस जानकारी को async प्लग इन करने से पहले संशोधित कर सकते हैं।
प्लगइन्स को यह जानकारी संदर्भ ऑब्जेक्ट के रूप में प्राप्त होती है जो कि निष्पादित विधि से पारित हो जाती है जिसके बाद आगे की प्रक्रिया होती है।
सभी प्लगइन प्रसंस्करण के पूरा होने के बाद, निष्पादन को उस एप्लिकेशन पर वापस भेज दिया जाता है जिसने घटना को ट्रिगर किया।
प्लगइन संदेश
संदेश वे घटनाएँ हैं जिन पर प्लगइन (या व्यावसायिक तर्क) पंजीकृत है। उदाहरण के लिए, आप संपर्क इकाई के संदेश बनाएँ पर एक रजिस्टर कर सकते हैं। जब भी कोई नया संपर्क रिकॉर्ड बनाया जाता है, तो यह व्यापार तर्क को आग लगा देगा।
कस्टम संस्थाओं के लिए, निम्नलिखित समर्थित संदेश हैं कि इकाई उपयोगकर्ता के स्वामित्व वाली है या संगठन के स्वामित्व वाली है।
संदेश का नाम | स्वामित्व प्रकार |
---|---|
असाइन | केवल उपयोगकर्ता-स्वामित्व वाली इकाइयाँ |
सृजन करना | उपयोगकर्ता के स्वामित्व और संगठन के स्वामित्व वाली इकाइयाँ |
हटाएं | उपयोगकर्ता के स्वामित्व और संगठन के स्वामित्व वाली इकाइयाँ |
पहुँच प्रदान करें | केवल उपयोगकर्ता-स्वामित्व वाली इकाइयाँ |
ModifyAccess | केवल उपयोगकर्ता-स्वामित्व वाली इकाइयाँ |
पुन: प्राप्त करें | उपयोगकर्ता के स्वामित्व और संगठन के स्वामित्व वाली इकाइयाँ |
RetrieveMultiple | उपयोगकर्ता के स्वामित्व और संगठन के स्वामित्व वाली इकाइयाँ |
RetrievePrincipalAccess | केवल उपयोगकर्ता-स्वामित्व वाली इकाइयाँ |
RetrieveSharedPrincipalsAndAccess | केवल उपयोगकर्ता-स्वामित्व वाली इकाइयाँ |
अनुमति समाप्त करना | केवल उपयोगकर्ता-स्वामित्व वाली इकाइयाँ |
SetState | उपयोगकर्ता के स्वामित्व और संगठन के स्वामित्व वाली इकाइयाँ |
SetStateDynamicEntity | उपयोगकर्ता के स्वामित्व और संगठन के स्वामित्व वाली इकाइयाँ |
अपडेट करें | उपयोगकर्ता के स्वामित्व और संगठन के स्वामित्व वाली इकाइयाँ |
डिफॉल्ट आउट-ऑफ-द-बॉक्स बॉक्स के लिए, 100 से अधिक समर्थित संदेश हैं। इनमें से कुछ संदेश सभी संस्थाओं के लिए लागू होते हैं जबकि उनमें से कुछ विशेष संस्थाओं के लिए विशिष्ट होते हैं। आप एसडीके के अंदर एक एक्सेल फ़ाइल में समर्थित संदेश की पूरी सूची पा सकते हैं:SDK\Message-entity support for plug-ins.xlsx
लेखन प्लगइन
इस खंड में, हम एक प्लगइन लिखने की मूल बातें सीखेंगे। हम एक नमूना प्लगइन का निर्माण करेंगे जो ग्राहक के साथ कार्य करने के लिए एक टास्क गतिविधि बनाता है जब भी एक नया ग्राहक सिस्टम में जोड़ा जाता है, अर्थात जब भी सीआरएम में एक नया कॉन्ट्रेकॉर्ड बनाया जाता है।
सबसे पहले, आपको संदर्भों को शामिल करना होगा Microsoft.Xrm.Sdkनाम स्थान। सीआरएम एसडीके में सभी आवश्यक एसडीके विधानसभाएं शामिल हैं। यह मानते हुए कि आपने पहले ही अध्याय 2 में एसडीके को डाउनलोड और इंस्टॉल कर लिया है, विजुअल स्टूडियो खोलें। टाइप क्लास लाइब्रेरी की एक नई परियोजना बनाएँ। आप प्रोजेक्ट को नमूनाप्लगिन्स के रूप में नाम दे सकते हैं और ठीक पर क्लिक कर सकते हैं।
का संदर्भ जोड़ें 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 ऑब्जेक्ट को इसके पैरामीटर के रूप में ले कर एक्स्यूट्यूट विधि लागू करता है। सेवा प्रदाता में कई उपयोगी वस्तुओं का संदर्भ होता है जिसे आप प्लगइन के भीतर उपयोग करने जा रहे हैं।
Step 2 - IServiceProvider के GetService विधि का उपयोग कर IPluginExecutionContext ऑब्जेक्ट प्राप्त करता है।
Step 3- संदर्भ वस्तु के InputParameters संग्रह से लक्ष्य इकाई की वस्तु प्राप्त करता है। यह एंटिटी क्लास ऑब्जेक्ट कॉन्टैक्ट यूनिट रिकॉर्ड को संदर्भित करता है जिस पर हमारा प्लगइन पंजीकृत होगा।
Step 4- यह तब टास्क इकाई का एक उद्देश्य बनाता है और उचित विषय, विवरण, दिनांक, श्रेणी और आज्ञापत्र निर्धारित करता है। यह कार्य रिकॉर्ड किस संपर्क रिकॉर्ड के लिए बनाया जा रहा है, इसके बारे में आउटरोबिजिड इंगित करता है। आप देख सकते हैं कि कोड को संदर्भ का उपयोग करके पैरेंट कॉन्टेक्ट रिकॉर्ड की आईडी मिलती है ।utputParameters और इसे टास्क एंटिटी रिकॉर्ड के साथ जोड़ देता है जिसे आपने बनाया है।
Step 5 - IServiceProvider वस्तु का उपयोग कर IOrganizationServiceFactory की वस्तु बनाता है।
Step 6 - IOrganizationServiceFactory वस्तु का उपयोग कर IOrganizationService की वस्तु बनाता है।
Step 7- अंत में, इस सेवा ऑब्जेक्ट के बनाएँ विधि का उपयोग कर। यह फॉलो-अप गतिविधि बनाता है जो CRM में सहेजी जाती है।
प्लगइन विधानसभा पर हस्ताक्षर
यह अनुभाग केवल तभी लागू होता है जब आप पहली बार अपनी प्लगइन असेंबली को पंजीकृत कर रहे हों। आपको प्लगइन को तैनात करने में सक्षम होने के लिए एक कुंजी के साथ विधानसभा में हस्ताक्षर करने की आवश्यकता है। समाधान को राइट-क्लिक करें और गुण क्लिक करें।
बाएं विकल्पों में से साइनिंग टैब चुनें और 'साइन असेंबली' विकल्प की जाँच करें। फिर, एक मजबूत नाम कुंजी फ़ाइल विकल्प चुनें से नया चुनें।
मुख्य फ़ाइल नाम को नमूनाप्लगिन के रूप में दर्ज करें (यह कोई अन्य नाम हो सकता है जो आप चाहते हैं)। एक पासवर्ड विकल्प के साथ मेरी कुंजी फ़ाइल को सुरक्षित रखें और ठीक पर क्लिक करें। सहेजें पर क्लिक करें।
अंत में, समाधान बनाएँ। राइट क्लिक → बिल्ड। समाधान का निर्माण असेंबली DLL उत्पन्न करेगा, जिसका उपयोग हम अगले अध्याय में इस प्लगइन को पंजीकृत करने के लिए करेंगे।
प्लगइन में अपवाद हैंडलिंग
अधिक बार नहीं, आपके प्लगइन तर्क को रन-टाइम अपवादों को संभालने की आवश्यकता होगी। तुल्यकालिक प्लगइन्स के लिए, आप एक वापस कर सकते हैंInvalidPluginExecutionExceptionअपवाद, जो उपयोगकर्ता को एक त्रुटि संवाद बॉक्स दिखाएगा। त्रुटि संवाद में कस्टम त्रुटि संदेश होगा जो आप अपवाद ऑब्जेक्ट के संदेश ऑब्जेक्ट के लिए पास करते हैं।
यदि आप हमारे कोड को देखते हैं, तो हम अपने कैच ब्लॉक में InvalidPluginExecutionException अपवाद फेंक रहे हैं।
throw new InvalidPluginExecutionException(ex.Message);
निष्कर्ष
प्लगइन्स निश्चित रूप से किसी भी कस्टम CRM कार्यान्वयन के लिए महत्वपूर्ण हैं। इस अध्याय में, हमने इवेंट फ्रेमवर्क मॉडल, पाइपलाइन चरणों, संदेशों को समझने और एक नमूना प्लगइन लिखने पर ध्यान केंद्रित किया। अगले अध्याय में, हम इस प्लगइन को सीआरएम में पंजीकृत करेंगे और इसे एंड-टू-एंड परिदृश्य से काम करते हुए देखेंगे।