<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: Ashraf Hussain</title>
    <description>The latest articles on DEV Community by Ashraf Hussain (@ashrafhussain17).</description>
    <link>https://dev.to/ashrafhussain17</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F390249%2Fcada0049-5b65-4b90-915b-844eb898b34b.jpeg</url>
      <title>DEV Community: Ashraf Hussain</title>
      <link>https://dev.to/ashrafhussain17</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/ashrafhussain17"/>
    <language>en</language>
    <item>
      <title>অবজার্ভার ডিজাইন প্যাটার্ন  উইথ টাইপস্ক্রিপ্ট </title>
      <dc:creator>Ashraf Hussain</dc:creator>
      <pubDate>Wed, 21 Apr 2021 10:04:12 +0000</pubDate>
      <link>https://dev.to/ashrafhussain17/-2mhe</link>
      <guid>https://dev.to/ashrafhussain17/-2mhe</guid>
      <description>&lt;p&gt;অবজার্ভার ডিজাইন প্যাটার্ন কি, কিভাবে কাজ করে এবং কেন ব্যবহার করবো তা বুঝার আগে চলুন কিছু সিনারিও দেখে আসি। &lt;br&gt;
অনেক ওয়েবসাইটে নিউজলেটার নামে একটা অপশন আমরা দেখে থাকি। আমরা যদি আমাদের ইমেইল দিয়ে সেটা সাবস্ক্রাইব করি তাহলে ঐ ওয়েবসাইটে নতুন কিছু কন্টেন্ট আপডেট হলে আমাদের কাছে নোটিফিকেশন আসে। তারপর আমরা সোশ্যাল মিডিয়ায় অনেক সেলেব্রিটি বা পেজকে ফলো করি। ফলো করার জন্য আমাদের ফলো অপশনে ক্লিক করতে হয়। ফলো করার পর যদি ঐ সেলেব্রিটি বা পেজ নতুন কিছু আপলোড করে তাহলে সব ফলোয়ারের কাছে নোটিফিকেশন চলে যায়। তাছাড়া আমরা অনেকেই লিঙ্কডইনে বিভিন্ন ক্রাইটেরিয়া সেট করে জব এলার্ট অপশন অন করে রাখি।যখনই কোনো নতুন জব কেউ পোস্ট করে লিঙ্কডইন তখন নোটিফাই করে।&lt;br&gt;
যদি আমরা এই সবগুলো সিনারিওর দিকে তাকাই তাহলে একটা প্যাটার্ন দেখতে পাই। সবগুলোতেই আমাদেরকে ফলো, লাইক বা সাবস্ক্রাইব করে রাখতে হয় আর যখনই নতুন কিছু আসে তখনই সেটা সবার কাছে নোটিফিকেশন আকারে পৌঁছে যায়। তো যদি এই লাইক, ফলো বা সাবস্ক্রাইব অপশন না থাকতো তাহলে কি হতো। তখন ইউজার নতুন কিছু আসছে কি না সেটা দেখার জন্য বারবার কিছুক্ষন পরপর গিয়ে দেখা লাগতো যে নতুন কোনো কিছু আসছে কি না। তাছাড়া কেউ যদি লাইভ কিছু করে সেগুলো মিস হয়ে যাওয়ার সম্ভাবনা থেকে যায়।&lt;br&gt;
উপরে যে যে সিনারিওগুলো দেখলাম এই সবগুলো সমস্যার সমাধান অবজার্ভার ডিজাইন প্যাটার্ন দিয়ে করা সম্ভব। তাহলে চলুন শুরু করি&lt;/p&gt;

&lt;p&gt;উপরের প্রত্যেকটি সিনারিওতেই যদি আমরা খেয়াল করি তাহলে দেখবো ২টি অবজেক্ট আছে। একটি হলো সাবজেক্ট অবজেক্ট যেটা উপরের প্রথম সিনারিওতে ওয়েবসাইট, দ্বিতীয় সিনারিওতে সেলিব্রেটির প্রোফাইল বা পেজ আর তৃতীয় সিনারিওতে  লিঙ্কডইন। আর আরেকটা অবজেক্ট হলো ডিপেন্ডেন্সি অবজেক্ট বা অবজার্ভার যেটা উপরের তিনটি সিনারিওতেই ইউজার যারা লাইক, ফলো বা সাবস্ক্রাইব করে রাখে। অবজার্ভার প্যাটার্ন এই দুইটি অবজেক্ট এর মধ্যে ওয়ান টু মেনি রিলেশন তৈরি করে যাতে যখনই সাবজেক্টের মধ্যে কোনো নতুন চেঞ্জ আসবে সাথে সাথে ওই সাবজেক্টের সব ডিপেন্ডেন্সি অবজেক্টকে নোটিফাই এবং আপডেট করে ফেলবে অটোম্যাটিকেলি। &lt;/p&gt;

&lt;p&gt;তাহলে এই সাবজেক্টের কাজ কি কি সেটা একটু চিন্তা করি। নতুন ইউজার এড করার জন্য সাবজেক্টের একটা মেথড লাগবে যেটা দিয়ে ইউজার লাইক, ফলো বা সাবস্ক্রাইব করতে পারে। একইভাবে আরেকটি অপশন লাগবে যেটা দিয়ে আনলাইক, আনফলো বা আনসাবস্ক্রাইব করতে পারবে। আরেকটি মেথড লাগবে সবাইকে নোটিফাই করার জন্য যাতে যখনই নতুন কিছু আপডেট আসবে তখনই এই মেথড কল করে সবাইকে নোটিফাই করা যায়। এই তিনটি কাজ করার জন্য আমরা তিনটি মেথড ডিফাইন করতে পারি। ক্লাস ডায়াগ্রামে আমরা সাবজেক্ট ইন্টারফেস দিয়ে এই তিনটি মেথড ডিফাইন করে দিয়েছি।&lt;br&gt;
এখন আসি ডিপেন্ডেন্সি অবজেক্ট বা অবজার্ভারের কাজ কি।আমাদের অবজার্ভারকে বলে দিতে হবে সাবজেক্ট কিভাবে অবজার্ভারকে নোটিফাই করবে। এই কাজটি করার জন্য অবজার্ভারের একটি আপডেট মেথড লাগবে যেটা ব্যবহার করে সাবজেক্ট তাকে নোটিফাই করবে। ক্লাস ডায়াগ্রামে আমরা অবজার্ভার ইন্টারফেস দিয়ে এই মেথড ডিফাইন করে দিয়েছি।&lt;/p&gt;

&lt;p&gt;আমি এই ক্লাস ডায়াগ্রামটা নিয়েছি হেড ফার্স্ট ডিজাইন প্যাটার্ন বই থেকে যেটা ডিজাইন প্যাটার্নের জন্য টপ লিস্টেড বইগুলোর মধ্যে একটি।&lt;br&gt;
&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fqa2ulogkq0lg33ka53gw.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fqa2ulogkq0lg33ka53gw.png" alt="Class Diagram"&gt;&lt;/a&gt;&lt;br&gt;
উপরের ডায়াগ্রামে সাবজেক্ট ইন্টারফেসের মধ্যে উপরে বর্ণনা করা তিনটি মেথড ডিফাইন করা আছে আর অবজার্ভার ইন্টারফেসে উপরে বর্ণনা করা একটি মেথড ডিফাইন করা আছে। এখন আসি ConcreteSubject ক্লাস নিয়ে। উপরের ডায়াগ্রাম থেকে দেখাই যাচ্ছে এটা সবসময় সাবজেক্ট ইন্টারফেসকে ইমপ্লিমেন্ট করবে। তখন তাকে সাবজেক্ট ইন্টারফেসে ডিফাইন করা তিনটি মেথডকেই ইমপ্লিমেন্ট করতে হবে। notifyObserver() মেথড দিয়ে সব অবজার্ভারকে নোটিফাই করবে। সেটার জন্য notifyObserver() মেথডের ভিতরে আমরা অবজার্ভার ইন্টারফেসের update() মেথড কল করে নোটিফাই এবং আপডেট করে ফেলব। আর ConcreteObserver() অবজার্ভার ইন্টারফেসকে ইমপ্লিমেন্ট করবে।  তখন তাকে অবজার্ভার ইন্টারফেসে ডিফাইন করা update() মেথডকেই ইমপ্লিমেন্ট করতে হবে।&lt;/p&gt;

&lt;h2&gt;
  
  
  ইমপ্লিমেন্টেশন
&lt;/h2&gt;

&lt;p&gt;এখন চলুন উপরের প্রথম সিনারিওটা ইমপিমেন্ট করি। নিউজলেটার সিস্টেম ইমপিমেন্ট করার জন্য আমাদের একটি নিউসলেটার পাবলিশার লাগবে যেটা উপরের সাবজেক্ট ইন্টারফেসকে ইমপিমেন্ট করবে। আর নোটিফিকেশন রিসিভ করার জন্য ডিপেন্ডেন্সি অবজেক্ট বা অবজার্ভার লাগবে যেটা অবজার্ভার ইন্টারফেসকে ইমপিমেন্ট করবে। &lt;/p&gt;

&lt;p&gt;প্রথমেই আমরা সাবজেক্ট আর অবজার্ভার ইন্টারফেস তৈরি করে ফেলি। নিচে সাবজেক্ট আর অবজার্ভার ইন্টারফেস তৈরি করে ফেললাম। &lt;br&gt;
&lt;code&gt;Subject.ts&lt;/code&gt;&lt;br&gt;
&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F78k77a7wbr91r8ljqogn.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F78k77a7wbr91r8ljqogn.png" alt="Alt Text"&gt;&lt;/a&gt;&lt;br&gt;
&lt;code&gt;Observer.ts&lt;/code&gt;&lt;br&gt;
&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F1lxz4si7d8wxxztqxccn.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F1lxz4si7d8wxxztqxccn.png" alt="Alt Text"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;নিউসলেটার পাবলিশারের জন্য NewsLetterPublisher ক্লাসটি তৈরি করলাম।&lt;br&gt;
&lt;code&gt;NewsLetterPublisher.ts&lt;/code&gt;&lt;br&gt;
&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fvu19kk0mcv8ufrreyfnt.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fvu19kk0mcv8ufrreyfnt.png" alt="Alt Text"&gt;&lt;/a&gt;&lt;br&gt;
পাবলিশারে সব অবজার্ভারকে রাখার জন্য আমরা একটি অ্যারে ডিফাইন করলাম। যেহেতু এই ক্লাসটি সাবজেক্টকে ইমপিমেন্ট করেছে তাই সাবজেক্টে ডিফাইন করা তিনটি মেথডকেই এখানে ইমপিমেন্ট করা হয়েছে। আরেকটি নতুন মেথড newChangeToSend() ইমপিমেন্ট করা হয়েছে যাতে নতুন কোনো আপডেট আসলে এই মেথড এর ভিতরে notifyObserver() মেথড কল করে সবাইকে নোটিফাই করা যায়। &lt;/p&gt;

&lt;p&gt;নিউসলেটার রিসিভারের জন্য NewsLetterReceiver ক্লাসটি তৈরি করলাম যেটা অবজার্ভারকে ইমপ্লিমেন্ট করেছে। যখনি নতুন কোন অবজার্ভার তৈরি করতে হবে তখন একটা ইমেইল দিতে হবে। &lt;br&gt;
&lt;code&gt;NewsLetterReceiver.ts&lt;/code&gt;&lt;br&gt;
&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fyk732q22d0z1oy6002jf.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fyk732q22d0z1oy6002jf.png" alt="Alt Text"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;এখন একটা মেইন ক্লাস লিখে ফেললাম টেস্ট করার জন্য।&lt;br&gt;
&lt;code&gt;main.ts&lt;/code&gt;&lt;br&gt;
&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F2xcdq8dglqh4whufx471.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F2xcdq8dglqh4whufx471.png" alt="Alt Text"&gt;&lt;/a&gt;&lt;br&gt;
প্রথমে আমরা একটা পাবলিশার তৈরি করলাম। রিসিভার আর রিসিভার১ নামে দুইটি  অবজার্ভার তৈরি করলাম যারা ওই পাবলিশারকে সাবস্ক্রাইব করে রেখেছে। যখনি পাবলিশার নতুন কিছু আপডেট করলো তখন এই দুইজনের কাছে নোটিফিকেশন যাবে। তারপরে রিসিভার১ আনসাবস্ক্রাইব করার পর তার কাছে আর যদি  পাবলিশার নতুন কিছু আপডেট করে তাহলে তার নোটিফিকেশন যাবে না।নিচে আউটপুট দেখা যাচ্ছে। রিসিভার১ আনসাবস্ক্রাইব করার পর তার কাছে আর নোটিফিকেশন যায়নি।&lt;br&gt;
&lt;code&gt;Output&lt;/code&gt;&lt;br&gt;
&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fvqw7sg9pnqpcpoqrzx53.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fvqw7sg9pnqpcpoqrzx53.png" alt="Alt Text"&gt;&lt;/a&gt;&lt;br&gt;
উপরের ইমপ্লিমেন্টেশনের সম্পূর্ণ কোড পাওয়া যাবে এই &lt;a href="https://github.com/ashrafhussain17/Design_Pattern/tree/master/ObserverPattern/newsletter" rel="noopener noreferrer"&gt;লিংকে&lt;/a&gt; &lt;/p&gt;

&lt;p&gt;এখন আসি এই অবজার্ভার প্যাটার্নের সুবিধাগুলু কি কি। অবজার্ভার প্যাটার্নের একটি ভালো সুবিধা হচ্ছে এটা &lt;strong&gt;SOLID&lt;/strong&gt; এর &lt;strong&gt;O&lt;/strong&gt; মানে &lt;strong&gt;Open Close Principle&lt;/strong&gt; কে কভার করে। তাছাড়া এটা হাই কুহেসিভ আর লো কাপলিং কোড লিখতে সাহায্য করে। এখানে সাবজেক্ট তার ডিপেন্ডেন্সি অবজেক্ট বা অবজার্ভারের ইমপ্লিমেন্টেশন সম্পর্কে কিছুই জানে না কিন্তু সে আপডেট করে ফেলে। তাছাড়া এটা &lt;strong&gt;JAVA&lt;/strong&gt; ও &lt;strong&gt;JAVASCRIPT&lt;/strong&gt; ল্যাঙ্গুয়েজের বেশ কিছু জায়গায় ব্যাবহার করা হয়েছে। যেমন &lt;strong&gt;JDK&lt;/strong&gt; তে, &lt;strong&gt;Socket&lt;/strong&gt; প্রোগ্রামিংয়ে। তাছাড়া আরও অনেক অনেক লাইব্রেরিতে এই প্যাটার্ন ব্যাবহার করা হয়।&lt;br&gt;&lt;br&gt;
নোটস: উপরে অনেক জায়গায় পাবলিশ সাবস্ক্রাইব টার্মটি উল্লেখ করেছি। হেড ফার্স্ট ডিজাইন প্যাটার্ন বইয়েও অনেক জায়গায় এটাই ব্যাবহার করেছে কিন্তু &lt;strong&gt;Publish-Subscribe&lt;/strong&gt; বা &lt;strong&gt;PUB-SUB&lt;/strong&gt; নামে আরেকটি প্যাটার্ন আছে যেটা অবজার্ভার প্যাটার্ন থেকে কিছুটা ডিফারেন্ট। এই দুই প্যাটার্নের আইডিয়া অলমোস্ট সেম । &lt;strong&gt;Publish-Subscribe&lt;/strong&gt; প্যাটার্ন ইভেন্ট বেসড কমিউনিকেশনে যেমন &lt;strong&gt;Nats Streaming Server&lt;/strong&gt; বা &lt;strong&gt;Apache Kafka&lt;/strong&gt; এগুলাতে ব্যাবহার করা হয়। &lt;/p&gt;

</description>
      <category>oop</category>
      <category>designpattern</category>
      <category>observerdesignpattern</category>
      <category>typescript</category>
    </item>
  </channel>
</rss>
