Microsoft Dynamics CRM - वेब सेवाएँ

Microsoft Dynamics CRM दो महत्वपूर्ण वेब सेवाएँ प्रदान करता है जो CRM को बाहरी एप्लिकेशन से एक्सेस करने के लिए उपयोग की जाती हैं और वेब व्यापारों को बनाने और हटाने, अपडेट करने और CRM में खोजने जैसे सामान्य डेटा संचालन करने के लिए उपयोग करती हैं।

निम्नलिखित परिदृश्यों पर विचार करें -

  • आपके पास एक बाहरी .NET अनुप्रयोग है, जिसे CRM से बात करने की आवश्यकता है। उदाहरण के लिए, आप CRM में एक संपर्क रिकॉर्ड सम्मिलित करना चाह सकते हैं जब कोई नया ग्राहक आपके बाहरी अनुप्रयोग में पंजीकृत हो।

  • या हो सकता है, आप CRM में रिकॉर्ड खोजना चाहते हैं और अपने बाहरी अनुप्रयोग में खोज परिणाम प्रदर्शित करते हैं।

ऐसे परिदृश्यों में, आप CRM द्वारा उजागर की गई वेब सेवाओं का उपयोग अपने एप्लिकेशन में उनका उपभोग करने के लिए कर सकते हैं और CRM में ऑपरेशन बना सकते हैं, हटा सकते हैं, अपडेट कर सकते हैं और संचालन कर सकते हैं।

IDiscoveryService वेब सेवा

यह वेब सेवा उन संगठनों की सूची लौटाती है, जो निर्दिष्ट उपयोगकर्ता संगठन के प्रत्येक के लिए URL एंडपॉइंट से संबंधित हैं।

IOrganizationService वेब सेवा

यह वेब सेवा CRM में डेटा और मेटाडेटा तक पहुँचने के लिए उपयोग की जाने वाली प्राथमिक वेब सेवा है। IOrganizationService दो महत्वपूर्ण विधानसभाओं का उपयोग करता है -Microsoft.Xrm.Sdk.dll तथा Microsoft.Crm.Sdk.Proxy.dll। ये असेंबली CRM SDK पैकेज के अंदर पाई जा सकती हैBin फ़ोल्डर।

Microsoft.Xrm.Sdk.dll

यह असेंबली कोर xRM विधियों और प्रकारों को परिभाषित करता है, जिसमें Microsoft Dynamics CRM सरल, प्रमाणीकरण विधियों और सेवा अनुबंधों से संबंध बनाने के लिए प्रॉक्सी कक्षाएं शामिल हैं।

Microsoft.Crm.Sdk.Proxy.dll

यह असेंबली गैर-कोर संदेशों के लिए अनुरोधों और प्रतिक्रियाओं के साथ-साथ संगठन डेटा के साथ काम करने के लिए आवश्यक गणनाओं को परिभाषित करती है। निम्नलिखित इन दो विधानसभाओं द्वारा समर्थित नामस्थान हैं।

इनमें से प्रत्येक विधानसभा कुछ संदेशों का समर्थन करती है, जिनका उपयोग किसी भी इकाई में संग्रहीत डेटा के साथ काम करने के लिए किया जाएगा। उनके द्वारा समर्थित संदेशों की पूरी सूची निम्नलिखित लिंक में देखी जा सकती है -

Supported xRM Messages - https://msdn.microsoft.com/en-us/library/gg334698.aspx

Supported CRM Messages - https://msdn.microsoft.com/en-us/library/gg309482.aspx

IOrganizationService वेब सेवा विधियाँ

IOrganizationService आठ तरीके प्रदान करता है जो आपको सिस्टम और कस्टम संस्थाओं के साथ-साथ संगठन मेटाडेटा पर सभी सामान्य संचालन करने की अनुमति देता है।

अनु क्रमांक विधि और विवरण
1

IOrganizationService.Create

एक रिकॉर्ड बनाता है।

2

IOrganizationService.Update

किसी मौजूदा रिकॉर्ड को अपडेट करता है।

3

IOrganizationService. Retrieve

एक रिकॉर्ड प्राप्त करता है।

4

IOrganizationService. RetrieveMultiple

रिकॉर्ड का एक संग्रह प्राप्त करता है।

5

IOrganizationService. Delete

एक रिकॉर्ड डिलीट करता है।

6

IOrganizationService. Associate

रिकॉर्ड के बीच एक लिंक बनाता है।

7

IOrganizationService.Disassociate

अभिलेखों के बीच एक लिंक हटाता है।

8

IOrganizationService.Execute

सामान्य रिकॉर्ड प्रसंस्करण के साथ-साथ विशेष संसाधन जैसे केस रिज़ॉल्यूशन, डुप्लिकेट डिटेक्शन आदि के लिए उपयोग किया जाता है।

वेब सेवा उदाहरण

यह समझने के लिए कि वेब सेवाएं CRM में कैसे काम करती हैं, हम CRM SDK द्वारा प्रदान किए गए एक उदाहरण को देखेंगे। इस उदाहरण में, हम एक नया खाता रिकॉर्ड बनाएंगे, इसे अपडेट करेंगे और फिर अंत में CRM का उपयोग करके इसे हटा देंगेIOrganizationService वेब सेवा।

Step 1- उस फ़ोल्डर को खोलें जहां आपने CRM SDK निकाला था। अब QuickStartCS.sln समाधान को निम्न स्थान पर ब्राउज़ करके खोलें: SDK \ SampleCode \ CS \ QuickStart

Step 2 - हम तलाश करेंगे QuickStart साथ में Simplified Connectionपरियोजना। खुला हुआapp.configइस परियोजना में। डिफ़ॉल्ट रूप से,connectionStrings इस फ़ाइल में अनुभाग टिप्पणी की जाएगी।

इसमें से, पहले कनेक्शन स्ट्रिंग कुंजी को अनइंस्टॉल करें और निम्नलिखित तीन विवरणों को संपादित करें -

Url- अपने CRM उदाहरण का URL निर्दिष्ट करें। हमारे मामले में, चूंकि हम CRM के ऑनलाइन संस्करण का उपयोग कर रहे हैं, इसलिए आपको उस URL का उल्लेख करना होगा।

Username - आपका सीआरएम ऑनलाइन उपयोगकर्ता नाम।

Password - आपका सीआरएम ऑनलाइन पासवर्ड।

Step 3 - खोलें SimplifiedConnection.cs इस परियोजना में फ़ाइल और इसके अंदर Runmethod।

public void Run(StringconnectionString, boolpromptforDelete) {
   try {
      
      // Establish a connection to the organization web service using CrmConnection.
      Microsoft.Xrm.Client.CrmConnection connection =
         CrmConnection.Parse(connectionString);
      
      // Obtain an organization service proxy.
      // The using statement assures that the service proxy will be properly disposed.
      using(_orgService = new OrganizationService(connection)) {

         //Create any entity records this sample requires.
         CreateRequiredRecords();
         
         // Obtain information about the logged on user from the web service.
         Guid userid = ((WhoAmIResponse)_orgService.Execute(new WhoAmIRequest())).UserId;
         SystemUser systemUser = (SystemUser)_orgService.Retrieve("systemuser",userid,
            new ColumnSet(newstring[]{"firstname","lastname"}));
         
         Console.WriteLine("Logged on user is {0} {1}.",
            systemUser.FirstName,systemUser.LastName);

         // Retrieve the version of Microsoft Dynamics CRM.
         RetrieveVersionRequest versionRequest = new RetrieveVersionRequest();
         RetrieveVersionResponse versionResponse =
            (RetrieveVersionResponse)_orgService.Execute(versionRequest);
         Console.WriteLine("Microsoft Dynamics CRM version {0}.",
            versionResponse.Version);
         
         // Instantiate an account object. Note the use of option set
         enumerations defined in OptionSets.cs.
         
         // Refer to the Entity Metadata topic in the SDK documentation to
         determine which attributes must
         
         // be set for each entity.
         Account account = new Account{Name = "Fourth Coffee"};
         account.AccountCategoryCode = new OptionSetValue(
            (int)AccountAccountCateg oryCode.PreferredCustomer);
         account.CustomerTypeCode = new OptionSetValue(
            (int)AccountCustomerTypeCod e.Investor);
         
         // Create an account record named Fourth Coffee.
         _accountId = _orgService.Create(account);
         Console.Write("{0} {1} created, ",account.LogicalName,account.Name);
         
         // Retrieve the several attributes from the new account.
         ColumnSet cols = new ColumnSet(
            new String[]{"name","address1_postalcode","lastusedincampaign"});
         Account retrievedAccount =
            (Account)_orgService.Retrieve("account", _accountId, cols);
         Console.Write("retrieved, ");

         // Update the postal code attribute.
         retrievedAccount.Address1_PostalCode = "98052";

         // The address 2 postal code was set accidentally, so set it to null.
         retrievedAccount.Address2_PostalCode = null;

         // Shows use of a Money value.
         retrievedAccount.Revenue = new Money(5000000);

         // Shows use of a Boolean value.
         retrievedAccount.CreditOnHold = false;
         
         // Update the account record.
         _orgService.Update(retrievedAccount);
         Console.WriteLine("and updated.");
         
         // Delete any entity records this sample created.
         DeleteRequiredRecords(promptforDelete);
      } 
   } 
   // Catch any service fault exceptions that Microsoft Dynamics CRM throws.
   catch(FaultException<microsoft.xrm.sdk.organizationservicefault>) {

      // You can handle an exception here or pass it back to the calling method.
      throw;
   }
}

Step 4- यह विधि मूल रूप से सीआरएम वेब सेवाओं का उपयोग करके सभी सीआरयूडी संचालन को प्रदर्शित करती है। कोड पहले एक संगठन उदाहरण बनाता है, फिर एक खाता रिकॉर्ड बनाता है, बनाए गए रिकॉर्ड को अपडेट करता है और फिर अंत में इसे हटा देता है। आइए इस कोड के महत्वपूर्ण घटकों को देखें। CRM में ऑन-द-गो परिवर्तन देखने के लिए जब यह कोड चलता है, तो आप इस कोड को चरण-दर-चरण डीबग कर सकते हैं (जैसा कि हम नीचे चर्चा करते हैं) और साथ ही साथ CRM में परिवर्तन देखें।

Step 4.1 - उस कनेक्शन स्ट्रिंग का उपयोग करके संगठन से कनेक्शन स्थापित करता है जिसे हमने संशोधित किया था Step 2

Microsoft.Xrm.Client.CrmConnection connection = CrmConnection.Parse(connectionString);

Step 4.2 - CRM संगठन वेब सेवा का एक प्रॉक्सी उदाहरण प्राप्त करता है।

_orgService = new OrganizationService(connection)

Step 4.3 - एक नई खाता इकाई ऑब्जेक्ट बनाता है और उसका नाम, खाता सूची और ग्राहक सूची टाइप करता है।

Account account = new Account{Name = "Fifth Coffee"}; 
account.AccountCategoryCode = new OptionSetValue(
   (int)AccountAccountCategoryCode.P referredCustomer); 
account.CustomerTypeCode = new OptionSetValue(
   (int)AccountCustomerTypeCode.Investor);

Step 4.4 - संगठन सेवा की विधि का उपयोग करके नया रिकॉर्ड बनाता है।

_accountId = _orgService.Create(account);

यदि आप CRM में जाते हैं, तो आपको एक नया बनाया गया खाता रिकॉर्ड दिखाई देगा।

Step 4.5 - खाता बन जाने के बाद, सेवा पुनः प्राप्त वेब सेवा पद्धति का उपयोग करते हुए सीआरएम से रिकॉर्ड वापस प्राप्त करती है।

ColumnSet cols = new ColumnSet(new String[]{
   "name","address1_postalcode","lastusedincampaign"}); 
Account retrievedAccount = 
   (Account)_orgService.Retrieve("account", _accountId, cols);

Step 4.6 - एक बार आपके पास पुनर्प्राप्त रिकॉर्ड होने के बाद, आप रिकॉर्ड का अद्यतन मान सेट कर सकते हैं।

retrievedAccount.Address1_PostalCode = "98052"; 
retrievedAccount.Address2_PostalCode = null; 
retrievedAccount.Revenue = new Money(5000000); 
retrievedAccount.CreditOnHold = false;

Step 4.7 - रिकॉर्ड के अद्यतन मूल्य को सेट करने के बाद, अपडेट वेब सेवा पद्धति का उपयोग करके सीआरएम डेटाबेस में रिकॉर्ड वापस अपडेट करें।

_orgService.Update(retrievedAccount);

यदि आप CRM में रिकॉर्ड खोलते हैं, तो आप वहां इन मूल्यों को अपडेट करते हुए देखेंगे।

Step 4.8 - अंत में, डिलीट वेब सर्विस मेथड का उपयोग करके रिकॉर्ड को हटा दें।

_orgService.Delete(Account.EntityLogicalName, _accountId);

यदि आप अब CRM में उसी रिकॉर्ड को रिफ्रेश करते हैं, तो आप देखेंगे कि रिकॉर्ड पहले से डिलीट होने के बाद उपलब्ध नहीं है।

निष्कर्ष

इस अध्याय में, हमने सीआरएम द्वारा प्रदान की गई दो महत्वपूर्ण वेब सेवाओं और विभिन्न सीआरयूडी संचालन करने के लिए बाहरी अनुप्रयोग से इन वेब सेवाओं का उपयोग कैसे किया जा सकता है, इसका एक कार्यकारी उदाहरण दिया है।