پلاگین در Microsoft Dynamics CRM چیست و چه زمانی باید از آن استفاده کرد؟

ابوالفضل رجب پور - 1395/03/19

پلاگین در Microsoft Dynamics CRM

در پروژه‌های پیاده‌سازی CRM معمولاً یک نقطه مشخص وجود دارد؛ جایی که امکانات آماده سیستم دیگر به‌تنهایی جواب نمی‌دهد. در این مرحله مسئله فقط این نیست که «آیا می‌شود این نیاز را در CRM پیاده کرد؟» مسئله مهم‌تر این است که این منطق کجا و با چه روشی پیاده شود تا بعداً برای سیستم دردسر درست نکند.

برای مثال، در یک فرآیند فروش سازمانی ممکن است قبل از ثبت نهایی سفارش، لازم باشد چند موضوع هم‌زمان بررسی شود؛ سقف اعتبار مشتری، بدهی‌های قبلی، نوع قرارداد، تخفیف‌های مجاز یا حتی شرایط خاص بعضی محصولات. در یک سناریوی دیگر، ممکن است بعد از ثبت فاکتور در CRM، اطلاعات با نرم‌افزار مالی همگام شود یا وضعیت فاکتور از سیستم دیگری به CRM برگردد.

این جنس نیازها معمولاً با چند تنظیم ساده یا تغییر روی فرم حل نمی‌شوند. چون منطق باید در لایه‌ای اجرا شود که مستقل از کاربر، فرم و مسیر ورود اطلاعات باشد؛ چه داده از فرم CRM ثبت شود، چه از یکپارچگی با سیستم دیگر وارد شود.

پلاگین یا Plugin در Microsoft Dynamics CRM دقیقاً برای چنین موقعیت‌هایی استفاده می‌شود. پلاگین قطعه‌ای از کد سمت سرور است که در واکنش به یک رویداد مشخص در CRM اجرا می‌شود؛ مثل ایجاد، ویرایش یا تغییر وضعیت یک رکورد.

به همین دلیل، پلاگین را نباید فقط یک قابلیت برنامه‌نویسی دید. در پروژه‌های CRM، پلاگین یکی از ابزارهای مهم برای پیاده‌سازی منطق‌های اختصاصی سازمان است؛ البته به شرطی که بدانیم چه زمانی واقعاً باید سراغ آن برویم و چه زمانی ابزارهای ساده‌تر مثل Workflow یا تنظیمات استاندارد انتخاب بهتری هستند.

پلاگین در CRM دقیقاً چه کاری انجام می‌دهد؟

پلاگین‌ها برنامه‌های جانبی کوچکی هستند که به یک نرم‌افزار بزرگ‌تر اضافه می‌شوند و امکان افزودن قابلیت‌های جدید یا سفارشی‌سازی رفتار سیستم را فراهم می‌کنند. در Microsoft Dynamics CRM، پلاگین روی رویدادهای پلتفرم ثبت می‌شود و در زمان مشخصی از اجرای همان رویداد وارد عمل می‌شود.

برای مثال، وقتی یک مشتری جدید ثبت می‌شود، وقتی یک فرصت فروش به مرحله جدید می‌رود، وقتی یک فاکتور نهایی می‌شود یا وقتی وضعیت یک پرونده خدماتی تغییر می‌کند، می‌توان پلاگینی نوشت که به‌صورت خودکار منطق موردنظر سازمان را اجرا کند.

مزیت مهم پلاگین این است که منطق آن در لایه سرور اجرا می‌شود؛ بنابراین فقط به یک فرم خاص یا رفتار یک کاربر محدود نیست. اگر داده از طریق فرم، ورود انبوه اطلاعات، وب‌سرویس یا یکپارچگی با سیستم دیگر وارد CRM شود، همچنان می‌توان همان منطق را روی آن اعمال کرد.

نکته حائز اهمیت در خصوص اجرای پلاگین، وابستگی آن به چرخه پردازش هر عملیات در CRM است. این موضوع به سازمان‌ها این امکان را می‌دهد که علاوه بر نتیجه، بتوانند نحوه انجام هر عملیات را نیز کنترل کنند.

چرا قابلیت پلاگین‌نویسی در نرم‌افزارهای سازمانی مهم است؟

یکی از ویژگی‌های مهم یک نرم‌افزار سازمانی بالغ، امکان توسعه و سفارشی‌سازی ساخت‌یافته است. سازمان‌ها معمولاً فرآیندهای یکسانی ندارند و نمی‌توان انتظار داشت همه نیازهای آن‌ها فقط با امکانات آماده نرم‌افزار پوشش داده شود. به همین دلیل، هنگام انتخاب CRM باید بررسی شود که آیا سیستم فقط چند فرم و گزارش آماده ارائه می‌دهد یا قابلیت توسعه واقعی هم دارد.

در بستر Microsoft Dynamics 365 و نسخه‌های قبلی Microsoft Dynamics CRM، توسعه‌پذیری یکی از نقاط قوت اصلی پلتفرم محسوب می‌شود. این توسعه‌پذیری کمک می‌کند سازمان بتواند منطق‌های اختصاصی، کنترل‌های پیچیده و یکپارچگی‌های موردنیاز خود را بدون تغییر مستقیم در هسته سیستم پیاده‌سازی کند.

این موضوع در پروژه‌های سازمانی اهمیت زیادی دارد؛ زیرا فرآیندهای فروش، خدمات، بازاریابی، مالی، پشتیبانی یا زنجیره تأمین ممکن است در هر سازمان قواعد خاص خود را داشته باشند. اگر CRM امکان توسعه‌پذیری استاندارد نداشته باشد، سازمان یا مجبور می‌شود فرآیندهای خود را بیش از حد ساده کند یا برای هر تغییر کوچک به مسیرهای پرهزینه و غیرقابل نگهداشت وابسته شود.

این مسئله زمانی برای سازمان مهم‌تر می‌شود که بخواهد حتی یک تغییر ساده در فرآیندهای خود ایجاد کند. اگر بستر CRM منعطف نباشد، همین تغییر کوچک هم ممکن است به پروژه‌ای پرهزینه و زمان‌بر تبدیل شود. در مقابل، وقتی سیستم توسعه‌پذیر باشد و امکان طراحی و اجرای تغییرات به‌صورت کنترل‌شده وجود داشته باشد، تغییرات بدون آسیب به ساختار کلی سیستم پیاده‌سازی می‌شوند. 

نمونه‌هایی از نیازهای سازمانی که با Plugin یا Workflow پیاده‌سازی می‌شوند

برای درک بهتر کاربرد پلاگین، چند سناریوی ساده را در نظر بگیرید:

  • هرگاه یک مخاطب یا حساب جدید در CRM ثبت شد، یک فعالیت پیگیری برای هفته آینده ایجاد شود.
  • هرگاه یک فاکتور نهایی شد، چند روز بعد یک کارشناس با مشتری تماس بگیرد و میزان رضایت او را بررسی کند.
  • هرگاه یک فاکتور در CRM ثبت شد، اطلاعات آن به‌صورت خودکار به نرم‌افزار حسابداری منتقل شود.
  • اگر محصول خاصی در پیش‌فاکتور فروش درج شد، پیش‌فاکتور قبل از نهایی شدن نیاز به تأیید مدیر داشته باشد.
  • قیمت کالاها پیش از صدور فاکتور نهایی با وب‌سایت یا سامانه قیمت‌گذاری سازمان تطبیق داده شود.

همه این موارد از جنس خودکارسازی هستند، اما الزاماً همه آن‌ها باید با پلاگین انجام نشوند. برخی از این نیازها مانند ایجاد فعالیت پیگیری یا تماس با مشتری، با Workflow یا ابزارهای کم‌کد به‌راحتی قابل پیاده‌سازی هستند. در مقابل، سناریوهایی مانند یکپارچگی با سایر سیستم‌ها یا اعمال قواعد پیچیده در فرآیندهایی مثل فروش، به دلیل نیاز به کنترل بیشتر، معمولاً در گروه سناریوهای مناسب برای پلاگین قرار می‌گیرند. 

تفاوت Plugin و Workflow در Microsoft Dynamics CRM

یکی از تصمیم‌های مهم در طراحی راهکار CRM این است که بدانیم چه زمانی از Workflow استفاده کنیم و چه زمانی سراغ Plugin برویم. Workflow معمولاً برای خودکارسازی‌های ساده‌تر مناسب است؛ به‌خصوص زمانی که فرآیند قابل تعریف، مرحله‌مند و قابل مدیریت توسط راهبر سیستم باشد.

برای مثال، ایجاد یک Task بعد از ثبت مشتری، ارسال ایمیل اطلاع‌رسانی، تغییر وضعیت یک رکورد یا اجرای یک فرآیند ساده تأیید، در بسیاری از موارد می‌تواند با Workflow انجام شود. مزیت Workflow این است که راه‌اندازی و نگهداشت آن ساده‌تر است و در بسیاری از سناریوها نیاز به برنامه‌نویسی ندارد.

در مقابل، Plugin زمانی کاربرد دارد که منطق موردنظر پیچیده‌تر است، باید در لایه سرور اجرا شود، به تراکنش اصلی وابسته است، نیاز به اعتبارسنجی بلادرنگ دارد یا باید با سامانه‌های دیگر ارتباط برقرار کند. برای مثال، بررسی سقف اعتبار مشتری قبل از ثبت سفارش، جلوگیری از ثبت داده ناسازگار، محاسبه کمیسیون چندلایه یا ارسال اطلاعات به سیستم مالی، معمولاً از جنس سناریوهای مناسب برای پلاگین هستند.

موضوع مقایسهWorkflowPlugin
سطح پیچیدگیمناسب برای فرآیندهای ساده تا متوسطمناسب برای منطق‌های پیچیده و اختصاصی
نیاز به برنامه‌نویسیمعمولاً بدون کدنویسینیازمند توسعه با C# یا زبان‌های مبتنی بر .NET
محل اجرادر قالب فرآیندهای قابل تنظیمدر لایه سرور و در پاسخ به رویدادهای پلتفرم
کاربرد رایجارسال ایمیل، ایجاد Task، تغییر وضعیت، فرآیندهای سادهاعتبارسنجی پیشرفته، محاسبات پیچیده، یکپارچگی، کنترل تراکنش

چه زمانی باید از پلاگین استفاده کنیم؟

استفاده از پلاگین زمانی منطقی است که نیاز سازمان فراتر از تنظیمات ساده و فرآیندهای آماده باشد. اگر منطق موردنظر باید روی همه مسیرهای ورود داده اعمال شود، اگر باید قبل از ثبت نهایی داده جلوی خطا گرفته شود، اگر چند موجودیت درگیر هستند یا اگر نیاز به ارتباط با سامانه‌های بیرونی وجود دارد، پلاگین معمولاً گزینه جدی‌تری است.

در مقابل، اگر نیاز فقط به نمایش یا پنهان‌سازی چند فیلد، ارسال یک ایمیل ساده، ایجاد یک فعالیت پیگیری یا تغییر وضعیت یک رکورد محدود باشد، بهتر است ابتدا ابزارهای ساده‌تر بررسی شوند. استفاده بی‌مورد از پلاگین، هزینه توسعه و نگهداشت CRM را افزایش می‌دهد.

در پروژه‌های پیاده‌سازی CRM، تشخیص همین مرز اهمیت زیادی دارد. یک راهکار حرفه‌ای الزاماً راهکاری نیست که برای همه چیز کدنویسی کند؛ بلکه راهکاری است که برای هر نیاز، ابزار مناسب همان نیاز را انتخاب کند.

معماری اجرای پلاگین در Dynamics CRM به زبان ساده

پلاگین در Dynamics CRM روی یک پیام یا Message مشخص ثبت می‌شود؛ مانند Create، Update، Delete یا Assign. همچنین مشخص می‌شود پلاگین روی کدام موجودیت اجرا شود؛ برای مثال Account، Contact، Opportunity، Invoice یا Case.

نکته مهم دیگر، مرحله اجرای پلاگین است. بعضی پلاگین‌ها باید قبل از ثبت داده اجرا شوند تا اعتبارسنجی انجام دهند یا جلوی ثبت داده نادرست را بگیرند. برخی دیگر بعد از ثبت داده اجرا می‌شوند تا اقداماتی مانند ایجاد رکورد وابسته، ارسال اطلاعات یا اجرای فرآیندهای بعدی انجام شود.

همچنین پلاگین می‌تواند به‌صورت هم‌زمان یا غیرهم‌زمان اجرا شود. اجرای هم‌زمان زمانی مناسب است که نتیجه پلاگین باید همان لحظه روی تراکنش اثر بگذارد. اجرای غیرهم‌زمان برای عملیات‌هایی مناسب‌تر است که می‌توانند با کمی تأخیر انجام شوند؛ مانند ارسال داده به سیستم دیگر، ایجاد فعالیت‌های جانبی یا اجرای پردازش‌های سنگین‌تر.

نمونه ساده پلاگین‌نویسی در CRM: ایجاد Task بعد از ثبت Account

برای درک عملی‌تر موضوع، می‌توان سناریویی ساده را بررسی کرد. فرض کنید هر زمان یک Account جدید در CRM ثبت می‌شود، سیستم به‌صورت خودکار یک Task برای هفت روز بعد ایجاد کند تا کاربر وضعیت مشتری جدید را پیگیری کند.

سناریوی نمونه

در این سناریو، رویداد اصلی ایجاد یک Account است. پس از ثبت Account، پلاگین اجرا می‌شود و یک فعالیت از نوع Task ایجاد می‌کند. این Task به Account مربوطه وصل می‌شود و تاریخ شروع و پایان آن هفت روز بعد از زمان ثبت مشتری قرار می‌گیرد.

آماده‌سازی ابزارهای توسعه

برای توسعه پلاگین در Microsoft Dynamics CRM معمولاً از بستر .NET و زبان C# استفاده می‌شود. در نسخه‌های قدیمی‌تر Dynamics CRM، توسعه‌دهنده از SDK و قالب‌های Visual Studio برای ایجاد پروژه پلاگین استفاده می‌کرد. در نسخه‌های جدیدتر Dynamics 365 نیز منطق کلی مشابه است، هرچند ابزارها و روش‌های ثبت و استقرار ممکن است نسبت به نسخه‌های قدیمی تغییر کرده باشند.

بنابراین اگرچه مثال‌های قدیمی CRM 2013 هنوز برای فهم ساختار کلی پلاگین مفید هستند، در پروژه‌های اجرایی باید ابزار و روش توسعه متناسب با نسخه CRM یا Dynamics 365 سازمان انتخاب شود.

ثبت پلاگین روی عملیات Create

در این مثال، پلاگین باید روی پیام Create و موجودیت Account ثبت شود. از آنجا که می‌خواهیم بعد از ایجاد Account یک Task مرتبط بسازیم، مرحله اجرای پلاگین می‌تواند Post-Operation باشد؛ یعنی پس از اینکه رکورد Account ایجاد شد، پلاگین اجرا شود و Task مربوط به آن ساخته شود.

منطق کلی کد پلاگین

منطق کلی پلاگین به این صورت است:

  • بررسی می‌شود که رویداد اجراشده مربوط به ایجاد Account باشد.
  • شناسه Account ایجادشده دریافت می‌شود.
  • یک رکورد جدید از نوع Task ساخته می‌شود.
  • موضوع، توضیحات و تاریخ پیگیری Task تنظیم می‌شود.
  • Task به Account مربوطه متصل می‌شود.
  • رکورد Task در CRM ایجاد می‌شود.

در نسخه قدیمی مقاله، کد کامل این مثال آورده شده بود. اما برای استفاده محتوایی امروز، مهم‌تر از نمایش کد طولانی، درک منطق اجراست. در پروژه واقعی، کد پلاگین باید بر اساس نسخه CRM، استانداردهای توسعه، ساختار Solution، سطح دسترسی کاربران، مدیریت خطا و سیاست‌های استقرار سازمان نوشته شود.

انتشار و تست پلاگین

پس از توسعه پلاگین، اسمبلی باید آماده انتشار شود و در محیط CRM ثبت گردد. در نسخه‌های قدیمی‌تر، Sign کردن Assembly و Deploy از طریق ابزارهای توسعه انجام می‌شد. پس از ثبت پلاگین، باید سناریو تست شود؛ یعنی یک Account جدید ساخته شود و بررسی شود که آیا Task مرتبط با تاریخ درست ایجاد شده است یا خیر.

در محیط‌های سازمانی بهتر است پلاگین ابتدا در محیط توسعه و تست بررسی شود و پس از اطمینان از عملکرد صحیح، وارد محیط عملیاتی شود. اجرای مستقیم پلاگین تست‌نشده در محیط اصلی می‌تواند باعث ایجاد داده اشتباه، کندی سیستم یا اختلال در فرآیندهای کاربران شود.

اشتباهات رایج در پلاگین‌نویسی CRM

یکی از اشتباهات رایج این است که برای هر نیاز سفارشی، بلافاصله پلاگین نوشته شود. این کار باعث می‌شود سیستم بیش از حد وابسته به کد شود و نگهداشت آن در آینده دشوارتر شود. بسیاری از نیازها با تنظیمات استاندارد، Workflow، Business Rule یا قوانین کسب‌وکار یا تغییرات ساده‌تر قابل پیاده‌سازی هستند.

اشتباه دیگر، اجرای عملیات سنگین در حالت هم‌زمان است. اگر پلاگین هم‌زمان در لحظه ذخیره رکورد اجرا شود و عملیات سنگینی مانند ارتباط با چند سرویس بیرونی، پردازش زیاد یا ایجاد رکوردهای متعدد انجام دهد، ممکن است سرعت ذخیره اطلاعات برای کاربر کاهش پیدا کند.

نبود مستندسازی، نام‌گذاری نامناسب، مدیریت نکردن خطاها، وابستگی شدید به یک توسعه‌دهنده، بی‌توجهی به سطح دسترسی کاربران و تست نکردن سناریوهای مختلف نیز از خطاهای رایج در پلاگین‌نویسی CRM هستند.

نکات مهم در پروژه‌های واقعی توسعه CRM

در پروژه‌های واقعی، پلاگین‌نویسی نباید جدا از معماری کل راهکار دیده شود. قبل از توسعه پلاگین باید مشخص شود این منطق دقیقاً چه مسئله‌ای را حل می‌کند، روی چه موجودیت‌هایی اثر می‌گذارد، آیا مسیر ساده‌تری برای پیاده‌سازی وجود دارد یا نه، و نگهداشت آن در آینده چگونه انجام خواهد شد.

در سازمان‌هایی که فرآیندهای پیچیده فروش، خدمات، مالی یا پشتیبانی دارند، پلاگین می‌تواند نقش مهمی در کنترل کیفیت داده، کاهش خطای انسانی و اتصال CRM به سایر سامانه‌های سازمانی داشته باشد. اما همین قابلیت اگر بدون طراحی درست استفاده شود، می‌تواند باعث پیچیدگی غیرضروری در سیستم شود.

به همین دلیل، در پروژه‌های حرفه‌ای مشاوره CRM، فقط به این سؤال پاسخ داده نمی‌شود که «آیا این کار با پلاگین قابل انجام است؟»؛ بلکه سؤال مهم‌تر این است که «آیا پلاگین بهترین روش برای انجام این کار است؟»

جمع‌بندی

پلاگین در Microsoft Dynamics CRM ابزاری برای توسعه سمت سرور و پیاده‌سازی منطق‌های اختصاصی سازمان است. این قابلیت زمانی ارزشمند می‌شود که سازمان به اعتبارسنجی‌های دقیق، کنترل فرآیندهای حساس، محاسبات پیچیده یا یکپارچگی با سامانه‌های دیگر نیاز داشته باشد.

با این حال، استفاده حرفه‌ای از پلاگین به معنی استفاده بیشتر از پلاگین نیست؛ بلکه به معنی انتخاب درست ابزار توسعه است. گاهی Workflow یا تنظیمات استاندارد CRM پاسخ‌گوی نیاز هستند و گاهی پیچیدگی فرآیند، استفاده از پلاگین را ضروری می‌کند.

اگر سازمان شما در حال انتخاب، توسعه یا بازطراحی CRM است، توجه به قابلیت توسعه‌پذیری پلتفرم اهمیت زیادی دارد. CRM سازمانی باید بتواند علاوه بر امکانات آماده، با فرآیندهای واقعی سازمان نیز هماهنگ شود.

نیاز به توسعه اختصاصی CRM دارید؟

اگر در سازمان شما فرآیندهایی وجود دارد که با امکانات آماده CRM پوشش داده نمی‌شود، می‌توانید از طریق مشاوره تخصصی CRM، مسیر مناسب بین تنظیمات استاندارد، Workflow، پلاگین و توسعه اختصاصی را بررسی کنید.

 
اشتراک گذاری

پلاگین یک قطعه کد سمت سرور است که در پاسخ به رویدادهایی مانند ایجاد، ویرایش یا حذف رکورد در CRM اجرا می‌شود و برای پیاده‌سازی منطق‌های پیچیده، اعتبارسنجی داده و یکپارچگی با سامانه‌های دیگر کاربرد دارد.

زمانی که منطق موردنظر پیچیده است، باید در همه مسیرهای ورود داده اجرا شود، نیاز به اعتبارسنجی بلادرنگ دارد یا باید با سامانه‌های دیگر ارتباط برقرار کند، استفاده از پلاگین می‌تواند گزینه مناسبی باشد.

Workflow برای خودکارسازی‌های ساده‌تر و قابل تنظیم مناسب است، اما Plugin برای منطق‌های پیچیده‌تر، کنترل سروری، اعتبارسنجی پیشرفته و ارتباط با سیستم‌های بیرونی استفاده می‌شود.

خیر. بسیاری از نیازها با تنظیمات استاندارد، فرم‌ها، قوانین کسب‌وکار یا Workflow قابل پیاده‌سازی هستند. پلاگین باید زمانی استفاده شود که واقعاً ضرورت فنی یا فرآیندی وجود داشته باشد.

بله. اگر پلاگین به‌درستی طراحی نشود، عملیات سنگین را به‌صورت هم‌زمان اجرا کند یا مدیریت خطا و تست کافی نداشته باشد، می‌تواند روی سرعت و پایداری سیستم اثر منفی بگذارد.

نظرات کاربران
ثبت نظر
بالا