Google অ্যাসিস্ট্যান্টের জন্য আপনার অ্যাকশনের মাধ্যমে ব্যবহারকারীদের যুক্ত করুন
এই কোডল্যাব সম্পর্কে
1. ওভারভিউ
অ্যাকশন অন Google হল একটি বিকাশকারী প্ল্যাটফর্ম যা আপনাকে স্মার্ট স্পিকার, ফোন, গাড়ি, টিভি, হেডফোন এবং আরও অনেক কিছু সহ 1 বিলিয়নেরও বেশি ডিভাইস জুড়ে Google সহকারী , Google-এর ভার্চুয়াল ব্যক্তিগত সহকারীর কার্যকারিতা বাড়ানোর জন্য সফ্টওয়্যার তৈরি করতে দেয়৷ ব্যবহারকারীরা সহকারীকে কথোপকথনে নিযুক্ত করে কাজগুলি সম্পন্ন করতে, যেমন মুদি কেনা বা রাইড বুক করা। (যা সম্ভব তার একটি সম্পূর্ণ তালিকার জন্য, অ্যাকশন ডিরেক্টরি দেখুন।) একজন বিকাশকারী হিসাবে, আপনি ব্যবহারকারীদের এবং আপনার তৃতীয়-পক্ষ পরিষেবার মধ্যে আনন্দদায়ক এবং কার্যকর কথোপকথন অভিজ্ঞতা তৈরি এবং পরিচালনা করতে Google-এ অ্যাকশন ব্যবহার করতে পারেন।
এটি একটি উন্নত কোডল্যাব মডিউল, যে পাঠকদের জন্য ইতিমধ্যেই Google সহকারীর জন্য অ্যাকশন তৈরির কিছু অভিজ্ঞতা রয়েছে। আপনার যদি অ্যাকশনস অন Google-এর সাথে পূর্বে কোনো উন্নয়ন অভিজ্ঞতা না থাকে, তাহলে আমরা দৃঢ়ভাবে সুপারিশ করছি যে আপনি আমাদের পরিচিতি কোডল্যাবগুলি অনুসরণ করে প্ল্যাটফর্মের সাথে নিজেকে পরিচিত করুন ( লেভেল 1 , লেভেল 2 , এবং লেভেল 3 )। এই উন্নত মডিউলগুলি আপনাকে বৈশিষ্ট্যগুলির একটি সিরিজের মাধ্যমে গাইড করবে যা আপনাকে আপনার অ্যাকশনের কার্যকারিতা প্রসারিত করতে এবং আপনার শ্রোতা বাড়াতে সাহায্য করতে পারে।
একটি অ্যাকশনের সাফল্য পরিমাপ করার একটি গুরুত্বপূর্ণ উপায় হল ব্যবহারকারীর ব্যস্ততা বা অ্যাকশন ব্যবহারকারীদের তাদের প্রথম ইন্টারঅ্যাকশনের পরে ফিরিয়ে আনতে কতটা কার্যকর। এটি সহজ করতে সাহায্য করার জন্য, আপনি আপনার অ্যাকশনে বেশ কয়েকটি বৈশিষ্ট্য প্রয়োগ করতে পারেন যা ব্যবহারকারীদের আপনার কথোপকথনে ফিরে যেতে দেয়।
কোডল্যাব ব্যবহারকারী-নিয়োগ বৈশিষ্ট্য এবং অ্যাকশন অন Google-এর জন্য সেরা অনুশীলনগুলি কভার করে৷
আপনি কি নির্মাণ করবেন
আপনি একটি বৈশিষ্ট্য উন্নত করবেন যা ইতিমধ্যেই এটি সক্ষম করে তৈরি করা হয়েছে:
- ব্যবহারকারীদের একটি দৈনিক আপডেট পাঠান যা তারা আপনার অ্যাকশনের সাথে কথা বলতে ট্যাপ করতে পারে
- ব্যবহারকারীদের পুশ বিজ্ঞপ্তি পাঠান যা আপনার অ্যাকশনের সাথে লিঙ্ক করে
- একটি লিঙ্ক তৈরি করুন যা ব্যবহারকারীদের মোবাইল ওয়েব ব্রাউজার থেকে আপনার অ্যাকশনে নিয়ে যায়
আপনি কি শিখবেন
- ব্যবহারকারীর ব্যস্ততা কী এবং কেন এটি একটি অ্যাকশনের সাফল্যের জন্য গুরুত্বপূর্ণ৷
- ব্যবহারকারীর ব্যস্ততা বাড়ানোর জন্য কীভাবে একটি অ্যাকশন পরিবর্তন করবেন
- বিভিন্ন ধরনের অ্যাকশনে ব্যবহার করার জন্য কোন ব্যবহারকারীর ব্যস্ততা বৈশিষ্ট্য
- অ্যাসিস্ট্যান্টের মাধ্যমে বিজ্ঞপ্তি পাঠাতে অ্যাকশন API কীভাবে ব্যবহার করবেন
আপনি কি প্রয়োজন হবে
আপনার নিম্নলিখিত সরঞ্জাম থাকতে হবে:
- আপনার পছন্দের একটি IDE/টেক্সট এডিটর, যেমন WebStorm , Atom , বা Sublime ৷
- Node.js, npm, এবং git ইনস্টল সহ শেল কমান্ড চালানোর জন্য একটি টার্মিনাল
- একটি ওয়েব ব্রাউজার, যেমন Google Chrome
- ফায়ারবেস কমান্ড-লাইন ইন্টারফেস সহ একটি স্থানীয় উন্নয়ন পরিবেশ
- সহকারী সহ একটি মোবাইল ডিভাইস (Android বা iOS) (আপনাকে অবশ্যই একই Google অ্যাকাউন্ট দিয়ে সহকারীতে সাইন-ইন করতে হবে যা আপনি এই প্রকল্পটি তৈরি করতে ব্যবহার করবেন।)
ওয়েবহুক কোড বোঝার জন্য JavaScript (ES6) এর সাথে পরিচিতিও দৃঢ়ভাবে সুপারিশ করা হয়, যদিও প্রয়োজন নেই।
2. আপনার প্রকল্প সেট আপ করুন
এই বিভাগটি আপনাকে দেখায় কিভাবে একটি সম্পূর্ণ, পূর্বে নির্মিত অ্যাকশনে ব্যবহারকারীর ব্যস্ততা বৈশিষ্ট্য যুক্ত করতে হয়।
নমুনা বুঝুন
এই কোডল্যাবের নমুনা হল "অ্যাকশন জিম" নামের একটি কাল্পনিক জিমের জন্য একটি সাধারণ অ্যাকশন। অ্যাকশন প্রতিদিন ঘোরানো ক্লাসের তালিকা সহ জিম সম্পর্কে তথ্য প্রদান করে। একটি তথ্যমূলক ক্রিয়া যেমন এটি সমস্ত ব্যবহারকারী-নিয়োগ বৈশিষ্ট্যগুলির জন্য একটি ভাল প্রার্থী কারণ ঘূর্ণায়মান শ্রেণীর তালিকা প্রতিদিন বিভিন্ন দরকারী তথ্য দেয়।
নিম্নলিখিত চিত্রটি অ্যাকশন জিমের নমুনার কথোপকথন প্রবাহ দেখায়:
আপনার যোগ করা ব্যস্ততার বৈশিষ্ট্যগুলিকে আরও ভালভাবে মানিয়ে নিতে আপনি ডায়ালগে ছোটখাটো পরিবর্তন করবেন৷ যাইহোক, কথোপকথনের সাধারণ নকশা খুব বেশি পরিবর্তন হবে না।
আপনার বেস ফাইল ডাউনলোড করুন
কোডল্যাবের জন্য গিটহাব সংগ্রহস্থল ক্লোন করতে নিম্নলিখিত কমান্ডটি চালান:
git clone https://github.com/actions-on-google/user-engagement-codelab-nodejs
আপনার প্রকল্প এবং এজেন্ট সেট আপ করুন
আপনার অ্যাকশন প্রকল্প এবং ডায়ালগফ্লো এজেন্ট সেট আপ করতে, নিম্নলিখিত পদক্ষেপগুলি সম্পূর্ণ করুন:
- অ্যাকশন কনসোল খুলুন।
- নতুন প্রকল্প ক্লিক করুন.
- একটি প্রকল্পের নাম টাইপ করুন, যেমন
engagement-codelab
। - প্রকল্প তৈরি করুন ক্লিক করুন।
- একটি বিভাগ বেছে নেওয়ার পরিবর্তে, আরও বিকল্প বিভাগে স্ক্রোল করুন এবং কথোপকথন কার্ডে ক্লিক করুন।
- বিকল্পগুলি প্রসারিত করতে আপনার অ্যাকশন তৈরি করুন ক্লিক করুন এবং অ্যাকশন যোগ করুন নির্বাচন করুন।
- আপনার প্রথম অ্যাকশন যোগ করুন ক্লিক করুন।
- ক্রিয়েট অ্যাকশন ডায়ালগে, কাস্টম ইন্টেন্ট নির্বাচন করুন এবং তারপর ডায়ালগফ্লো কনসোল চালু করতে বিল্ড এ ক্লিক করুন।
- ডায়ালগফ্লো কনসোলের এজেন্ট তৈরি পৃষ্ঠায়, তৈরি করুন ক্লিক করুন ।
- ক্লিক করুন
(গিয়ার আইকন) বাম নেভিগেশনে।
- রপ্তানি এবং আমদানি ক্লিক করুন, তারপর জিপ থেকে পুনরুদ্ধার করুন।
- আপনি আগে ডাউনলোড করেছেন
/user-engagement-codelab-nodejs/start/
ডিরেক্টরি থেকেagent.zip
ফাইলটি আপলোড করুন। -
RESTORE
টাইপ করুন এবং Restore এ ক্লিক করুন। - সম্পন্ন ক্লিক করুন.
আপনার পূর্ণতা স্থাপন করুন
এখন যেহেতু আপনার অ্যাকশন প্রজেক্ট এবং ডায়ালগফ্লো এজেন্ট প্রস্তুত, Firebase ফাংশন CLI ব্যবহার করে আপনার স্থানীয় index.js
ফাইলটি স্থাপন করুন।
আপনার বেস ফাইল ক্লোনের /user-engagement-codelab-nodejs/start/functions/
ডিরেক্টরি থেকে, নিম্নলিখিত কমান্ডগুলি চালান:
firebase use <PROJECT_ID>
npm install
firebase deploy
কয়েক মিনিটের পরে, আপনি " মোতায়েন সম্পূর্ণ! " দেখতে পাবেন, যা নির্দেশ করে যে আপনি সফলভাবে আপনার ওয়েবহুক Firebase এ স্থাপন করেছেন৷
স্থাপনার URL পুনরুদ্ধার করুন
আপনাকে ক্লাউড ফাংশনে URL সহ Dialogflow প্রদান করতে হবে। এই URLটি পুনরুদ্ধার করতে, এই পদক্ষেপগুলি অনুসরণ করুন:
- ফায়ারবেস কনসোল খুলুন।
- বিকল্পগুলির তালিকা থেকে আপনার অ্যাকশন প্রকল্প নির্বাচন করুন।
- বাম নেভিগেশন বারে বিকাশ > ফাংশনে নেভিগেট করুন। যদি আপনাকে "ডেটা ভাগ করে নেওয়ার সেটিংস চয়ন করতে" বলা হয়, আপনি পরে এটি করুন এ ক্লিক করে এই বিকল্পটিকে উপেক্ষা করতে পারেন৷
- ড্যাশবোর্ড ট্যাবের অধীনে, আপনি ট্রিগারের অধীনে একটি URL সহ "পূর্ণতা" এর জন্য একটি এন্ট্রি দেখতে পাবেন। এই URL সংরক্ষণ করুন; আপনাকে পরবর্তী বিভাগে এটি ডায়ালগফ্লোতে অনুলিপি করতে হবে।
ডায়ালগফ্লোতে ওয়েবহুক ইউআরএল সেট করুন
এখন আপনাকে আপনার ডায়ালগফ্লো এজেন্ট আপডেট করতে হবে যাতে আপনি আপনার ওয়েবহুক ব্যবহার করতে পারেন। এটি করার জন্য, নিম্নলিখিত ধাপগুলি অনুসরণ করুন:
- Dialogflow কনসোল খুলুন (আপনি চাইলে Firebase কনসোল বন্ধ করতে পারেন)।
- বাম নেভিগেশনে পূর্ণতা ক্লিক করুন.
- ওয়েবহুক সক্ষম করুন।
- ফায়ারবেস ড্যাশবোর্ড থেকে কপি করা URLটি পেস্ট করুন যদি এটি ইতিমধ্যে প্রদর্শিত না হয়।
- সংরক্ষণ করুন ক্লিক করুন.
আপনার প্রকল্প সঠিকভাবে সেট আপ করা হয়েছে তা যাচাই করুন
ব্যবহারকারীদের অ্যাকশন জিম সম্পর্কে তথ্যের জন্য আপনার অ্যাকশনকে আহ্বান করতে সক্ষম হওয়া উচিত, যার মধ্যে ব্যবসার সময় সহ একটি হার্ড-কোডেড পাঠ্য প্রতিক্রিয়া এবং একটি পাঠ্য প্রতিক্রিয়া যা সপ্তাহের প্রতিটি দিনের জন্য ক্লাসের সময়সূচী তালিকাভুক্ত করে।
অ্যাকশন সিমুলেটরে আপনার অ্যাকশন পরীক্ষা করতে:
- ডায়ালগফ্লো কনসোলে বাঁদিকের নেভিগেশনে, ইন্টিগ্রেশন > গুগল অ্যাসিস্ট্যান্ট -এ ক্লিক করুন।
- নিশ্চিত করুন যে স্বয়ংক্রিয়-প্রিভিউ পরিবর্তনগুলি সক্ষম হয়েছে এবং আপনার অ্যাকশন প্রকল্প আপডেট করতে পরীক্ষা ক্লিক করুন৷
- অ্যাকশন সিমুলেটর আপনার অ্যাকশন প্রকল্প লোড করে। আপনার অ্যাকশন পরীক্ষা করতে, ইনপুট ফিল্ডে
Talk to my test app
টাইপ করুন এবং এন্টার টিপুন। - অ্যাকশন জিমে আপনাকে স্বাগত জানিয়ে একটি প্রতিক্রিয়া দেখা উচিত। কথোপকথন চালিয়ে যাওয়ার জন্য অনুরোধগুলি অনুসরণ করার চেষ্টা করুন এবং নিশ্চিত করুন যে আপনার পূর্ণতা প্রতিটি ইনপুটের জন্য একটি প্রতিক্রিয়া আছে।
3. দৈনিক আপডেট সদস্যতা যোগ করুন
ব্যবহারকারীদের জড়িত করার একটি সাধারণ উপায় হল তাদের কাছে তথ্য অফার করা যখন এটি সবচেয়ে দরকারী। এটি ব্যবহারকারীদের একটি অভিপ্রায়ের জন্য দৈনিক আপডেটগুলিতে সদস্যতা নেওয়ার বিকল্প অফার করে সম্পন্ন করা হয়, যা তাদের একটি সহকারী বিজ্ঞপ্তি পাঠায় যা সরাসরি সেই অভিপ্রায় পূরণের সাথে লিঙ্ক করে।
এই ধাপে, আপনি প্রতিদিনের আপডেট সাবস্ক্রিপশন সম্পর্কে শিখবেন এবং সেগুলিকে আপনার অ্যাকশনের ক্লাস লিস্টে যোগ করতে পারবেন। এই নির্দেশাবলী অনুসরণ করার পরে, আপনার অ্যাকশনের কথোপকথনটি নিম্নলিখিত চিত্রের মতো দেখাবে:
এটি কিভাবে ব্যবহারকারীদের জড়িত করবে?
স্মার্টফোন ব্যবহারকারীরা সম্ভবত পুশ নোটিফিকেশনের সাথে পরিচিত, যা অ্যাপ-নির্দিষ্ট তথ্য এবং আপডেট প্রদান করে। দৈনিক আপডেট সাবস্ক্রিপশন হল অ্যাসিস্ট্যান্টের বাইরের মোবাইল ডিভাইসে ব্যবহারকারীদের অ্যাক্সেস করার একটি সহজ উপায়, যদি আপনি যে উদ্দেশ্যে আপডেট পাঠাচ্ছেন তা প্রতিদিনের ভিত্তিতে ব্যবহারকারীকে মূল্য প্রদান করে।
দৈনিক আপডেটগুলি একটি দরকারী ব্যস্ততার সরঞ্জাম হতে পারে তবে অগত্যা প্রতিটি অ্যাকশনে অন্তর্ভুক্ত করা উচিত নয়। একটি অ্যাকশনে দৈনিক আপডেট সাবস্ক্রিপশন যোগ করার সিদ্ধান্ত নেওয়ার সময় এই টিপসগুলি বিবেচনা করুন:
- নিশ্চিত করুন যে প্রতিদিনের আপডেটের ফলে ব্যবহারকারী প্রতিদিন বিভিন্ন, দরকারী তথ্য দেখতে পাবে। যদি একটি দৈনিক আপডেট ট্যাপ করার ফলে প্রতিবার একই প্রম্পট হয়, ব্যবহারকারী সম্ভবত কয়েকদিন পরে সদস্যতা ত্যাগ করবেন।
- নিশ্চিত করুন যে আপনার ডায়ালগটি আপনার ব্যবহারকারীর কাছে বোধগম্য হয় যদি তারা সরাসরি আপনার প্রতিদিনের আপডেটের অভিপ্রায়ে ঝাঁপিয়ে পড়ে। আপনার ব্যবহারকারী অগত্যা কথোপকথনের শুরু থেকে শুরু করবেন না, তাই তাদের কাছে খুব বেশি প্রসঙ্গ আশা করা উচিত নয়।
- আপনার ব্যবহারকারীকে প্রতিদিনের আপডেটে সদস্যতা নিতে অনুরোধ করার আগে আপনার কর্মের সুবিধা দেখান। আপনার ব্যবহারকারীকে "আমি প্রতিদিন এই সামগ্রীটি চাই" ভাবতে হবে যখন তাদের সদস্যতা নেওয়ার বিকল্প দেওয়া হয়।
- সাবস্ক্রাইব করার জন্য বারবার পরামর্শ দিয়ে ব্যবহারকারীকে অভিভূত করবেন না। ব্যবহারকারীকে তারা কী সাবস্ক্রাইব করবে তা দেখানোর পরেই একটি দৈনিক আপডেট সাবস্ক্রিপশন অফার করুন এবং অন্য কোথাও এটি সম্পর্কে তাদের বিরক্ত করা এড়িয়ে চলুন।
- আপডেটের উদ্দেশ্য ট্রিগার হওয়ার পরে কথোপকথনটি সংক্ষিপ্ত রাখুন। বেশিরভাগ দৈনিক আপডেটে শুধুমাত্র একটি একক প্রতিক্রিয়া থাকা উচিত তারপর ব্যবহারকারীর ইনপুট প্রয়োজন ছাড়াই বন্ধ করা উচিত।
প্রতিদিনের আপডেট চালু করুন
দৈনিক আপডেট সাবস্ক্রিপশনগুলিকে স্বাগত অভিপ্রায়ে যুক্ত করা যেতে পারে যা ব্যবহারকারীকে আপনার কথোপকথনের শুরুতে রাখে, অথবা কথোপকথনের মধ্যে কোথাও তাদের গভীর লিঙ্ক করার জন্য আরও নির্দিষ্ট অভিপ্রায়। এই কোডল্যাবের জন্য, ক্লাস লিস্টের অভিপ্রায়টি সবচেয়ে বেশি বোধগম্য কারণ ডায়ালগ প্রতিদিন পরিবর্তিত হবে, এবং কোন ক্লাস উপলব্ধ রয়েছে তা মনে করিয়ে দেওয়া ব্যবহারকারীদের জন্য উপযোগী হতে পারে।
ক্লাস তালিকার অভিপ্রায়ের জন্য দৈনিক আপডেটগুলি সক্ষম করতে এই পদক্ষেপগুলি অনুসরণ করুন:
- অ্যাকশন কনসোলে, ডেভেলপ ট্যাবে ক্লিক করুন এবং বাম নেভিগেশন বারে অ্যাকশন বেছে নিন।
- অ্যাকশন লিস্টের অধীনে ক্লাস লিস্টে ক্লিক করুন।
- ব্যবহারকারীর ব্যস্ততা বিভাগের অধীনে, আপনি ব্যবহারকারীদের প্রতিদিনের আপডেটগুলি অফার করতে চান বিকল্পটি টগল করুন।
- একটি বর্ণনামূলক বিষয়বস্তুর শিরোনাম সেট করুন যা দৈনিক আপডেটের বর্ণনা দেয়। প্রসঙ্গটি হবে "আপনি আমাকে আপনার দৈনিক কত সময়ে পাঠাতে চান", তাই নিশ্চিত করুন যে আপনার শিরোনামটি বর্ণনামূলক এবং উচ্চস্বরে বলার সময় সঠিক শোনাচ্ছে। এই উদাহরণের জন্য,
list of upcoming Action Gym classes
বিষয়বস্তুর শিরোনাম সেট করুন। - পৃষ্ঠার শীর্ষে সংরক্ষণ ক্লিক করুন.
ডায়ালগফ্লো সেট আপ করুন
দৈনিক আপডেট সাবস্ক্রিপশন প্রবাহের জন্য উদ্দেশ্য তৈরি করতে ডায়ালগফ্লো কনসোলে এই পদক্ষেপগুলি অনুসরণ করুন:
সাবস্ক্রাইব করার জন্য ব্যবহারকারীকে অনুরোধ করুন
- প্রতিদিনের আপডেটগুলিতে সদস্যতা নিতে অনুরোধকারী ব্যবহারকারীকে পরিচালনা করার জন্য একটি নতুন অভিপ্রায় সেট আপ করুন৷ ডায়ালগফ্লো কনসোলে, একটি নতুন অভিপ্রায় তৈরি করতে বাম নেভিগেশনে ইন্টেন্টের পাশে + বোতামে ক্লিক করুন।
- এই নতুন অভিপ্রায়
Setup Updates
নাম দিন। - প্রশিক্ষণ বাক্যাংশ বিভাগের অধীনে, নিম্নলিখিত ব্যবহারকারীর অভিব্যক্তি যোগ করুন:
-
Send daily reminders
-
Reminder
-
Remind me
-
Updates
-
Upcoming classes
- পূর্ণতা বিভাগের অধীনে, এই অভিপ্রায় বিকল্পের জন্য ওয়েবহুক কল সক্ষম করুন টগল করুন।
- পৃষ্ঠার শীর্ষে সংরক্ষণ ক্লিক করুন.
ব্যবহারকারীর সিদ্ধান্ত হ্যান্ডেল
- দৈনিক আপডেট সাবস্ক্রিপশন প্রম্পটে ব্যবহারকারীর প্রতিক্রিয়া পরিচালনা করার জন্য একটি নতুন অভিপ্রায় সেট আপ করুন৷ একটি নতুন অভিপ্রায় তৈরি করতে বাম নেভিগেশনে ইন্টেন্টের পাশে + বোতামে ক্লিক করুন।
- এই নতুন অভিপ্রায়ের নাম
Confirm Updates
। - ইভেন্ট বিভাগের অধীনে,
actions_intent_REGISTER_UPDATE
যোগ করুন। এই ডায়ালগফ্লো ইভেন্টটি ব্যবহারকারীর দৈনিক আপডেট সাবস্ক্রিপশন ফ্লো শেষ করার দ্বারা ট্রিগার করা হবে, তারা সদস্যতা শেষ করুক বা না করুক। - পূর্ণতা বিভাগের অধীনে, এই অভিপ্রায় বিকল্পের জন্য ওয়েবহুক কল সক্ষম করুন টগল করুন।
- পৃষ্ঠার শীর্ষে সংরক্ষণ ক্লিক করুন.
পূর্ণতা বাস্তবায়ন করুন
আপনার ওয়েবহুকে পূর্ণতা বাস্তবায়ন করতে, নিম্নলিখিত পদক্ষেপগুলি সম্পূর্ণ করুন:
লোড নির্ভরতা
index.js
ফাইলে, actions-on-google
প্যাকেজ থেকে RegisterUpdate
প্যাকেজ যোগ করতে need require()
ফাংশন আপডেট করুন, যাতে আপনার আমদানিগুলি এইরকম দেখায়:
index.js
const {
dialogflow,
Suggestions,
RegisterUpdate,
} = require('actions-on-google');
সাজেশন চিপ আপডেট করুন
index.js
ফাইলে, পরামর্শ চিপ শিরোনামের তালিকায় একটি DAILY
এন্ট্রি যোগ করুন, যাতে আপনার Suggestion
সংজ্ঞা এইরকম দেখায়:
index.js
// Suggestion chip titles
const Suggestion = {
HOURS: 'Ask about hours',
CLASSES: 'Learn about classes',
DAILY: 'Send daily reminders',
};
নতুন উদ্দেশ্য জন্য পরিপূর্ণতা যোগ করুন
ব্যবহারকারী যখন বলে যে তারা সাবস্ক্রাইব করতে চায়, তখন RegisterUpdate
সাহায্যকারীকে কল করে আপডেটের লক্ষ্যমাত্রা ( শ্রেণীর তালিকা ) দিয়ে দৈনিক আপডেট সাবস্ক্রিপশন প্রবাহ শুরু করুন এবং টাইপ করুন ( DAILY
)। সাবস্ক্রিপশন ফ্লো শেষ হওয়ার পরে, অ্যাসিস্ট্যান্ট একটি status
আর্গুমেন্ট সহ actions_intent_REGISTER_UPDATE
ইভেন্ট ট্রিগার করে যা সাবস্ক্রিপশন সফল হয়েছে কিনা তা বর্ণনা করে। ব্যবহারকারীকে ফলো-আপ প্রম্পট অফার করুন যা সদস্যতার স্থিতির উপর নির্ভর করে পরিবর্তন হয়।
index.js
ফাইলে, নিম্নলিখিত কোড যোগ করুন:
index.js
// Start opt-in flow for daily updates
app.intent('Setup Updates', (conv) => {
conv.ask(new RegisterUpdate({
intent: 'Class List',
frequency: 'DAILY',
}));
});
// Confirm outcome of opt-in for daily updates
app.intent('Confirm Updates', (conv, params, registered) => {
if (registered && registered.status === 'OK') {
conv.ask(`Gotcha, I'll send you an update everyday with the ` +
'list of classes. Can I help you with anything else?');
} else {
conv.ask(` I won't send you daily reminders. Can I help you with anything else?`);
}
if (conv.screen) {
conv.ask(new Suggestions([Suggestion.HOURS, Suggestion.CLASSES]));
}
});
ব্যবহারকারীর জন্য বিকল্প প্রম্পট অফার করুন
আপনার ক্লাস তালিকার প্রতিক্রিয়া শেষে দৈনিক আপডেট সাবস্ক্রিপশন অফার করবে, কিন্তু এটি একটি সমস্যা উপস্থাপন করে। যেহেতু এই একই প্রতিক্রিয়াটি ট্রিগার করা হবে যখন ব্যবহারকারী দৈনিক আপডেট বিজ্ঞপ্তিতে ট্যাপ করবেন, তাই তাদের এখনও দৈনিক আপডেটগুলিতে সদস্যতা নিতে বলা হবে যদিও তারা শুধুমাত্র একটি থেকে এসেছে। আপনি কীভাবে ব্যবহারকারীকে তাদের পুনরায় সদস্যতা নেওয়ার কথা ভাবতে থেকে বিরত রাখতে পারেন?
সৌভাগ্যক্রমে, আপনার conv
অবজেক্টের আর্গুমেন্টে ব্যবহারকারী কোথায় কথোপকথন শুরু করেছেন সে সম্পর্কে তথ্য অন্তর্ভুক্ত করে। আপনি conv
আর্গুমেন্টগুলি পরীক্ষা করে দেখতে পারেন যে তারা একটি UPDATES
বিভাগ রয়েছে কিনা, যা নির্দেশ করে যে ব্যবহারকারী একটি দৈনিক আপডেট বিজ্ঞপ্তি থেকে কথোপকথন শুরু করেছেন এবং সেই অনুযায়ী প্রতিক্রিয়া পরিবর্তন করুন৷ আপনি এই কথোপকথন শাখাটি ক্লাসের তালিকা প্রদান করার সাথে সাথে ডায়ালগ বন্ধ করতে ব্যবহার করতে পারেন, যা আমাদের দৈনিক আপডেট সংক্ষিপ্ত রাখার সর্বোত্তম অনুশীলন অনুসরণ করে।
index.js
ফাইলে, নিম্নলিখিত কোডটি প্রতিস্থাপন করুন:
index.js
// Class list intent handler
app.intent('Class List', (conv, {day}) => {
if (!day) {
day = DAYS[new Date().getDay()];
}
const classes =
[...new Set(schedule.days[day].map((d) => `${d.name} at ${d.startTime}`))]
.join(', ');
const classesMessage =
`On ${day} we offer the following classes: ${classes}. ` +
`Can I help you with anything else?`;
conv.ask(classesMessage);
if (conv.screen) {
conv.ask(new Suggestions([Suggestion.HOURS]));
}
});
এর সাথে:
index.js
// Class list intent handler
app.intent('Class List', (conv, {day}) => {
if (!day) {
day = DAYS[new Date().getDay()];
}
const classes =
[...new Set(schedule.days[day].map((d) => `${d.name} at ${d.startTime}`))]
.join(', ');
let classesMessage = `On ${day} we offer the following classes: ${classes}. `;
// If the user started the conversation from the context of a daily update,
// the conv's arguments will contain an 'UPDATES' section.
let engagement = conv.arguments.get('UPDATES');
// Check the conv arguments to tailor the conversation based on the context.
if (engagement) {
classesMessage += `Hope to see you soon at Action Gym!`;
conv.close(classesMessage);
} else {
classesMessage += `Would you like me to send you daily reminders of upcoming classes, or can I help you with anything else?`;
conv.ask(classesMessage);
if (conv.screen) {
conv.ask(new Suggestions([Suggestion.DAILY, Suggestion.HOURS]));
};
};
});
আপনার দৈনিক আপডেট পরীক্ষা করুন
টার্মিনালে, Firebase এ আপনার আপডেট করা ওয়েবহুক কোড স্থাপন করতে নিম্নলিখিত কমান্ডটি চালান:
firebase deploy
অ্যাকশন সিমুলেটরে আপনার কাস্টম রিপ্রম্পট পরীক্ষা করতে, এই পদক্ষেপগুলি অনুসরণ করুন:
- অ্যাকশন কনসোলে, টেস্টে নেভিগেট করুন।
- ইনপুট ফিল্ডে
Talk to my test app
টাইপ করুন এবং এন্টার টিপুন। -
Learn about classes
টাইপ করুন এবং এন্টার টিপুন। আপনার অ্যাকশনের প্রতিক্রিয়া এখন দৈনিক অনুস্মারক পাঠানোর প্রস্তাব করা উচিত। -
Send daily reminders
টাইপ করুন এবং এন্টার টিপুন। - আপনি আপডেট দেখতে চান এমন একটি সময় টাইপ করুন এবং এন্টার টিপুন। পরীক্ষার উদ্দেশ্যে, বর্তমান সময়ের চেয়ে 3-5 মিনিট পরে সাড়া দেওয়ার চেষ্টা করুন।
আপনার মোবাইল ডিভাইসে, আপনি আপডেটের জন্য নির্দিষ্ট করার সময়ে সহায়কের কাছ থেকে একটি বিজ্ঞপ্তি পাবেন। মনে রাখবেন এই বিজ্ঞপ্তিটি প্রদর্শিত হতে কয়েক মিনিট সময় লাগতে পারে। বিজ্ঞপ্তিতে আলতো চাপুন এবং এটি আপনাকে আসন্ন ক্লাসগুলির একটি তালিকা প্রদান করে Assistant-এর ক্লাস তালিকার উদ্দেশ্যের সাথে সরাসরি লিঙ্ক করা উচিত:
4. পুশ বিজ্ঞপ্তি যোগ করুন
আপনার অ্যাকশনের বাইরে ব্যবহারকারীদের জড়িত করার আরেকটি বিকল্প হিসাবে, আপনি ব্যবহারকারীদের পুশ বিজ্ঞপ্তি পাঠাতে অ্যাকশন API কল করতে পারেন। দৈনিক আপডেটের বিপরীতে, এই বিজ্ঞপ্তিগুলি স্বয়ংক্রিয়ভাবে সহকারী দ্বারা নির্ধারিত হয় না যাতে আপনি সেগুলিকে ইচ্ছামত পাঠাতে পারেন।
এই ধাপে, আপনি শিখবেন কীভাবে আপনার অ্যাকশনে পুশ বিজ্ঞপ্তিগুলি প্রয়োগ করতে হয় একটি নতুন ক্লাস বাতিল অভিপ্রায় যুক্ত করে এবং ব্যবহারকারীদের কাছে বিজ্ঞপ্তি পাঠানোর মাধ্যমে যা তাদের ক্লাস বাতিলের বিষয়ে অবহিত করে। আপনি বিজ্ঞপ্তি পাঠাতে প্রয়োজনীয় নিম্নলিখিত তিনটি উপাদান সেট আপ করবেন:
- অ্যাকশন API অ্যাকাউন্ট - আপনি একটি API এ একটি
POST
অনুরোধ পাঠিয়ে ব্যবহারকারীকে বিজ্ঞপ্তি পাঠান, তাই আপনাকে এই API-এর সাথে ইন্টারফেস করার জন্য একটি পরিষেবা অ্যাকাউন্ট এবং শংসাপত্র সেট আপ করতে হবে। - অনুমতি সহায়ক - তাদের পুশ বিজ্ঞপ্তি পাঠাতে প্রয়োজনীয় ব্যবহারকারী আইডি অ্যাক্সেস করার জন্য আপনার ব্যবহারকারীর অনুমতি প্রয়োজন। এই উদাহরণে, আপনি একটি ক্লায়েন্ট লাইব্রেরি ফাংশন ব্যবহার করে অনুমতি সাহায্যকারীকে কল করবেন এবং এই আইডির অনুরোধ করবেন।
- সঞ্চয়স্থান - কোনো কথোপকথনের বাইরে কোনো ব্যবহারকারীকে পুশ বিজ্ঞপ্তি পাঠাতে, আপনাকে এমন কোথাও ব্যবহারকারী আইডি সংরক্ষণ করতে হবে যা ইচ্ছামত প্রত্যাহার করা যেতে পারে। এই উদাহরণে, আপনি প্রতিটি ব্যবহারকারীর জন্য তথ্য সংরক্ষণ করার জন্য একটি Firestore ডাটাবেস সেট আপ করবেন।
এই নির্দেশাবলী অনুসরণ করার পরে, আপনি আপনার অ্যাকশনের কথোপকথনে নিম্নলিখিত ডায়ালগ যোগ করবেন:
এটি কিভাবে ব্যবহারকারীদের জড়িত করবে?
স্মার্টফোন ব্যবহারকারীরা সম্ভবত পুশ নোটিফিকেশনের সাথে পরিচিত, যা অ্যাপ-নির্দিষ্ট তথ্য এবং আপডেট প্রদান করে। পুশ নোটিফিকেশন হল অ্যাসিস্ট্যান্টের বাইরে মোবাইল ডিভাইসে ব্যবহারকারীদের অ্যাক্সেস করার একটি নমনীয় উপায়, যদি ব্যবহারকারীদের তাদের সক্ষম করার জন্য উপযুক্ত কারণ দেওয়া হয়। দৈনিক আপডেটের সাথে, ব্যবহারকারীরা ইতিমধ্যেই সচেতন যে তাদের প্রতিদিনের ভিত্তিতে অবহিত করা হবে। পুশ নোটিফিকেশনের সাথে, তবে, ব্যবহারকারীরা জানেন না যে তারা কদাচিৎ বিজ্ঞপ্তি পাওয়ার জন্য বেছে নিচ্ছেন নাকি প্রতিদিন একাধিক বিজ্ঞপ্তির দ্বারা বিরক্ত হবেন।
পুশ বিজ্ঞপ্তিগুলি একটি দরকারী ব্যস্ততার সরঞ্জাম হতে পারে তবে অগত্যা প্রতিটি অ্যাকশনে অন্তর্ভুক্ত করা উচিত নয়। কোনো অ্যাকশনে পুশ নোটিফিকেশন যোগ করবেন কিনা সিদ্ধান্ত নেওয়ার সময় এই টিপসগুলি বিবেচনা করুন:
- আপনার পুশ বিজ্ঞপ্তির জন্য কিছু উদাহরণ সময়সূচী পরিকল্পনা করুন। আপনি যদি প্রতিদিন শুধুমাত্র একটি পুশ বিজ্ঞপ্তি পাঠানোর পরিকল্পনা করেন, তাহলে পরিবর্তে প্রতিদিনের আপডেট ব্যবহার করার কথা বিবেচনা করুন।
- নিশ্চিত করুন যে আপনার পুশ বিজ্ঞপ্তিগুলি প্রতিবার প্রাপ্ত হওয়ার সময় দরকারী তথ্য প্রদান করবে৷ আপনার বিজ্ঞপ্তিগুলি আপনার অ্যাকশনের উদ্দেশ্যগুলির একটির সাথে গভীর লিঙ্কও করতে পারে, তাই নিশ্চিত করুন যে অভিপ্রায়টি কার্যকর এবং প্রাসঙ্গিক।
- একজন ব্যবহারকারীকে পুশ বিজ্ঞপ্তিতে সদস্যতা নিতে বলার সময় স্পষ্টভাবে বলুন। প্রতিটি পুশ বিজ্ঞপ্তির সাথে তাদের কী আশা করা উচিত তা তাদের বোঝা উচিত এবং কত ঘন ঘন বিজ্ঞপ্তিগুলি পাঠানো হয় তার কিছু ধারণা থাকা উচিত।
অ্যাকশন API সক্ষম করুন
- Google ক্লাউড কনসোল খুলুন এবং ড্রপডাউনে আপনার অ্যাকশন প্রকল্পের নাম নির্বাচন করুন।
- নেভিগেশন মেনুতে ( ☰) , APIs & Services > Library-এ যান।
- অ্যাকশন API অনুসন্ধান করুন এবং সক্ষম করুন ক্লিক করুন।
একটি পরিষেবা অ্যাকাউন্ট তৈরি করুন
অ্যাকশন এপিআই এর প্রমাণীকরণ প্রয়োজন তাই আপনাকে অনুরোধ পাঠাতে একটি পরিষেবা অ্যাকাউন্ট তৈরি করতে হবে। অ্যাকশন API-এর জন্য একটি পরিষেবা অ্যাকাউন্ট কী তৈরি এবং ইনস্টল করতে এই পদক্ষেপগুলি অনুসরণ করুন:
- Google ক্লাউড কনসোলের নেভিগেশন মেনুতে (☰) , APIs & Services > Credentials- এ যান।
- ক্রিয়েট ক্রেডেনশিয়াল > সার্ভিস অ্যাকাউন্ট কী -তে ক্লিক করুন।
- পরিষেবা অ্যাকাউন্ট ড্রপ-ডাউন মেনুতে, নতুন পরিষেবা অ্যাকাউন্ট নির্বাচন করুন।
- নিম্নলিখিত তথ্য পূরণ করুন:
- পরিষেবা অ্যাকাউন্টের নাম :
service-account
- ভূমিকা : প্রকল্প > মালিক
- পরিষেবা অ্যাকাউন্ট আইডি:
service-account
(সর্বদা @<project_id>.iam.gserviceaccount.com দ্বারা অনুসরণ করা হয়) - কী প্রকার : JSON
- তৈরি করুন ক্লিক করুন।
- ডাউনলোড করা JSON ফাইলটিকে আপনার প্রকল্পের /user-engagement-codelab/start/functions/ ডিরেক্টরিতে সরান।
- JSON ফাইলটিকে
service-account.json
এ রিনেম করুন।
Firestore সক্ষম করুন
কথোপকথনের বাইরে বিজ্ঞপ্তি পাঠানোর জন্য, আপনার ব্যবহারকারী আইডি সংরক্ষণ করার একটি উপায় প্রয়োজন যা আপনার বিজ্ঞপ্তি কোড থেকে উল্লেখ করা যেতে পারে। এই উদাহরণের জন্য, সাবস্ক্রাইব করা ব্যবহারকারীদের ব্যবহারকারী আইডি সংরক্ষণ করতে আমরা একটি Firestore ডাটাবেস ব্যবহার করছি।
আপনার কর্মের জন্য একটি Firestore ডাটাবেস তৈরি করতে এই পদক্ষেপগুলি অনুসরণ করুন:
- Firebase কনসোলে , আপনার অ্যাকশন প্রকল্পের নাম নির্বাচন করুন।
- বাম নেভিগেশনে, বিকাশ > ডাটাবেসে যান এবং ডেটাবেস তৈরি করুন ক্লিক করুন।
- পরীক্ষা মোডে শুরু নির্বাচন করুন।
- সক্ষম করুন ক্লিক করুন।
ডায়ালগফ্লো সেট আপ করুন
পুশ বিজ্ঞপ্তি অপ্ট-ইন ফ্লো তৈরি করতে ডায়ালগফ্লো কনসোলে এই পদক্ষেপগুলি অনুসরণ করুন:
সাবস্ক্রাইব করার জন্য ব্যবহারকারীকে অনুরোধ করুন
- বাতিল ক্লাসের জন্য পুশ নোটিফিকেশন সাবস্ক্রাইব করতে অনুরোধকারী ব্যবহারকারীকে পরিচালনা করার জন্য একটি নতুন অভিপ্রায় সেট আপ করুন। ডায়ালগফ্লো কনসোলে, একটি নতুন অভিপ্রায় তৈরি করতে বাম নেভিগেশনে ইন্টেন্টের পাশে + বোতামে ক্লিক করুন।
- এই নতুন অভিপ্রায়
Setup Push Notifications
নাম দিন। - প্রশিক্ষণ বাক্যাংশ বিভাগের অধীনে, নিম্নলিখিত ব্যবহারকারীর অভিব্যক্তি যোগ করুন:
-
Subscribe to notifications
-
Send notification
-
Notify me
-
Send class notifications
-
Cancelled notifications
- পূর্ণতা বিভাগের অধীনে, এই অভিপ্রায় বিকল্পের জন্য ওয়েবহুক কল সক্ষম করুন টগল করুন।
- পৃষ্ঠার শীর্ষে সংরক্ষণ ক্লিক করুন.
ব্যবহারকারীর সিদ্ধান্ত হ্যান্ডেল
- পুশ বিজ্ঞপ্তি সাবস্ক্রিপশন প্রম্পটে ব্যবহারকারীর প্রতিক্রিয়া পরিচালনা করার জন্য একটি নতুন অভিপ্রায় সেট আপ করুন৷ একটি নতুন অভিপ্রায় তৈরি করতে বাম নেভিগেশনে ইন্টেন্টের পাশে + বোতামে ক্লিক করুন।
- এই নতুন উদ্দেশ্যটির নাম দিন
Confirm Push Notifications
। - ইভেন্ট বিভাগের অধীনে,
actions_intent_PERMISSION
যোগ করুন। এই ডায়ালগফ্লো ইভেন্টটি ব্যবহারকারীর দ্বারা পুশ নোটিফিকেশন সাবস্ক্রিপশন ফ্লো শেষ করার মাধ্যমে ট্রিগার করা হবে, তারা সাবস্ক্রাইব করা শেষ করুক বা না করুক। - পূর্ণতা বিভাগের অধীনে, এই অভিপ্রায় বিকল্পের জন্য ওয়েবহুক কল সক্ষম করুন টগল করুন।
- পৃষ্ঠার শীর্ষে সংরক্ষণ ক্লিক করুন.
পুশ বিজ্ঞপ্তিটি পরিচালনা করুন
আপনি আপনার পুশ বিজ্ঞপ্তিগুলিকে একটি নির্দিষ্ট অভিপ্রায়ের সাথে লিঙ্ক করতে পারেন, তাই যে ব্যবহারকারীরা পুশ বিজ্ঞপ্তিতে ট্যাপ করেন তারা সরাসরি আপনার অ্যাকশনের সেই অভিপ্রায়ের সাথে গভীরভাবে যুক্ত থাকে৷ এই উদাহরণে, পুশ বিজ্ঞপ্তিগুলির জন্য একটি নতুন অভিপ্রায় যোগ করুন যা বাতিল করা ক্লাস সম্পর্কে বিশদ প্রদান করে।
ব্যবহারকারী একটি পুশ বিজ্ঞপ্তিতে ট্যাপ করে ট্রিগার করার অভিপ্রায় যোগ করতে এই পদক্ষেপগুলি অনুসরণ করুন:
- ডায়ালগফ্লো কনসোলে, একটি নতুন অভিপ্রায় তৈরি করতে বাম নেভিগেশনে ইন্টেন্টের পাশে + বোতামে ক্লিক করুন।
- এই নতুন অভিপ্রায়
Class Canceled
নাম দিন। - প্রশিক্ষণ বাক্যাংশ বিভাগের অধীনে, ব্যবহারকারীর অভিব্যক্তি হিসাবে
Cancelations
যোগ করুন। - পূর্ণতা বিভাগের অধীনে, এই অভিপ্রায় বিকল্পের জন্য ওয়েবহুক কল সক্ষম করুন টগল করুন।
- পৃষ্ঠার শীর্ষে সংরক্ষণ ক্লিক করুন.
কথোপকথনের মাঝখানে পরীক্ষার বিজ্ঞপ্তি পাঠান
উৎপাদনে, আপনার অ্যাকশন পূর্ণতা কোড থেকে আলাদা একটি স্ক্রিপ্ট থাকা উচিত যা পুশ বিজ্ঞপ্তি পাঠায়। এই উদাহরণের জন্য, একটি উদ্দেশ্য তৈরি করুন যা আপনি আপনার অ্যাকশনের সাথে কথা বলার সময় একটি পুশ বিজ্ঞপ্তি পাঠাতে আহ্বান করতে পারেন। এই উদ্দেশ্য শুধুমাত্র ডিবাগ উদ্দেশ্যে; বাস্তবে, পুশ বিজ্ঞপ্তিগুলি আপনার পূর্ণতা দ্বারা পরিচালনা করা উচিত নয় বা অন্যথায় আপনার অ্যাকশনের কথোপকথনের অংশ হিসাবে ট্রিগার করা উচিত নয়।
পুশ বিজ্ঞপ্তিগুলি পরীক্ষা করার জন্য একটি অভিপ্রায় তৈরি করতে এই পদক্ষেপগুলি অনুসরণ করুন:
- পরীক্ষা এবং ডিবাগিং উদ্দেশ্যে, একটি নতুন অভিপ্রায় সেট আপ করুন যা আপনাকে সদস্যতা নেওয়া ব্যবহারকারীদের পুশ বিজ্ঞপ্তি পাঠাতে দেয়৷ ডায়ালগফ্লো কনসোলে, একটি নতুন অভিপ্রায় তৈরি করতে বাম নেভিগেশনে ইন্টেন্টের পাশে + বোতামে ক্লিক করুন।
- এই নতুন উদ্দেশ্য
Test Notification
নাম দিন। - প্রশিক্ষণ বাক্যাংশ বিভাগের অধীনে, ব্যবহারকারীর অভিব্যক্তি হিসাবে
Test notification
যোগ করুন। - পূর্ণতা বিভাগের অধীনে, এই অভিপ্রায় বিকল্পের জন্য ওয়েবহুক কল সক্ষম করুন টগল করুন।
- পৃষ্ঠার শীর্ষে সংরক্ষণ ক্লিক করুন.
পুশ বিজ্ঞপ্তি চালু করুন
ক্লাস বাতিল করা অভিপ্রায়ের জন্য পুশ বিজ্ঞপ্তিগুলি সক্ষম করতে এই পদক্ষেপগুলি অনুসরণ করুন:
- ডায়ালগফ্লো কনসোলে, নেভিগেশন বারে ইন্টিগ্রেশনে যান।
- Google সহকারী কার্ডে, ইন্টিগ্রেশন সেটিংস -এ ক্লিক করুন।
- একটি অন্তর্নিহিত আহ্বান অভিপ্রায় হিসাবে বাতিল ক্লাস যোগ করুন. এই ধাপটি ডায়ালগফ্লোর জন্য প্রয়োজনীয় যে ব্যবহারকারীরা ক্লাস বাতিল করার অভিপ্রায় দিয়ে আপনার কথোপকথন শুরু করতে পারে (একটি পুশ বিজ্ঞপ্তিতে ট্যাপ করে)।
- বন্ধ ক্লিক করুন.
- অ্যাকশন কনসোলে, ডেভেলপ ট্যাবে ক্লিক করুন এবং বাম নেভিগেশন বারে অ্যাকশন বেছে নিন।
- অ্যাকশন তালিকার অধীনে Class Canceled- এ ক্লিক করুন।
- ব্যবহারকারীর ব্যস্ততা বিভাগের অধীনে, আপনি কি পুশ বিজ্ঞপ্তি পাঠাতে চান? বিকল্প
- একটি বর্ণনামূলক বিষয়বস্তুর শিরোনাম সেট করুন যা পুশ বিজ্ঞপ্তি বর্ণনা করে। প্রসঙ্গটি হবে "আমি এর জন্য পুশ বিজ্ঞপ্তি পাঠালে কি ঠিক আছে?", তাই নিশ্চিত করুন যে আপনার শিরোনামটি বর্ণনামূলক এবং উচ্চস্বরে বলার সময় সঠিক শোনাচ্ছে। এই উদাহরণের জন্য, বিষয়বস্তুর শিরোনামটি
class cancelations
সেট করুন। - পৃষ্ঠার শীর্ষে সংরক্ষণ ক্লিক করুন.
পূর্ণতা বাস্তবায়ন করুন
আপনার ওয়েবহুকে পূর্ণতা বাস্তবায়ন করতে, নিম্নলিখিত পদক্ষেপগুলি সম্পূর্ণ করুন:
লোড নির্ভরতা
index.js
ফাইলে, actions-on-google
প্যাকেজ থেকে UpdatePermission
প্যাকেজ যোগ করতে need require()
ফাংশন আপডেট করুন, যাতে আপনার আমদানিগুলি এইরকম দেখায়:
index.js
const {
dialogflow,
Suggestions,
RegisterUpdate,
UpdatePermission,
} = require('actions-on-google');
সাজেশন চিপ আপডেট করুন
index.js
ফাইলে, পরামর্শ চিপ শিরোনামের তালিকায় একটি NOTIFICATIONS
এন্ট্রি যোগ করুন, যাতে আপনার Suggestion
সংজ্ঞা এইরকম দেখায়:
index.js
// Suggestion chip titles
const Suggestion = {
HOURS: 'Ask about hours',
CLASSES: 'Learn about classes',
DAILY: 'Send daily reminders',
NOTIFICATIONS: 'Get notifications',
};
নতুন আমদানি সেট আপ করুন
আপনার ফায়ারস্টোর ডাটাবেসের সাথে সংযোগ করার জন্য, firebase-admin
প্যাকেজ যোগ করুন এবং ডাটাবেসে সঞ্চিত ক্ষেত্রগুলির জন্য ধ্রুবক যোগ করুন। এছাড়াও, google-auth-library
আমদানি করুন এবং অ্যাকশন API-এ প্রমাণীকরণ এবং অনুরোধগুলি পরিচালনা করার জন্য প্যাকেজগুলির request
করুন।
index.js
ফাইলে, আপনার আমদানিতে নিম্নলিখিত কোড যোগ করুন:
index.js
// Firebase admin import
const admin = require('firebase-admin');
// Initialize Firestore
admin.initializeApp();
const db = admin.firestore();
// Firestore constants
const FirestoreNames = {
INTENT: 'intent',
USER_ID: 'userId',
USERS: 'users',
};
// Actions API authentication imports
const {auth} = require('google-auth-library');
const request = require('request');
ক্লাস বাতিলের বিজ্ঞপ্তি সেট আপ করার অফার
index.js
ফাইলে, নিম্নলিখিত কোডটি প্রতিস্থাপন করুন:
index.js
// Class list intent handler
app.intent('Class List', (conv, {day}) => {
if (!day) {
day = DAYS[new Date().getDay()];
}
const classes =
[...new Set(schedule.days[day].map((d) => `${d.name} at ${d.startTime}`))]
.join(', ');
let classesMessage = `On ${day} we offer the following classes: ${classes}. `;
// If the user started the conversation from the context of a daily update,
// the conv's arguments will contain an 'UPDATES' section.
let engagement = conv.arguments.get('UPDATES');
// Check the conv arguments to tailor the conversation based on the context.
if (engagement) {
classesMessage += `Hope to see you soon at Action Gym!`;
conv.close(classesMessage);
} else {
classesMessage += `Would you like me to send you daily reminders of upcoming classes, or can I help you with anything else?`;
conv.ask(classesMessage);
if (conv.screen) {
conv.ask(new Suggestions([Suggestion.DAILY, Suggestion.HOURS]));
};
};
});
এর সাথে:
index.js
// Class list intent handler
app.intent('Class List', (conv, {day}) => {
if (!day) {
day = DAYS[new Date().getDay()];
}
const classes =
[...new Set(schedule.days[day].map((d) => `${d.name} at ${d.startTime}`))]
.join(', ');
let classesMessage = `On ${day} we offer the following classes: ${classes}. `;
// If the user started the conversation from the context of a daily update,
// the conv's arguments will contain an 'UPDATES' section.
let engagement = conv.arguments.get('UPDATES');
// Check the conv arguments to tailor the conversation based on the context.
if (engagement) {
classesMessage += `Hope to see you soon at Action Gym!`;
conv.close(classesMessage);
} else {
classesMessage += `Would you like to receive daily reminders of upcoming classes, subscribe to notifications about cancelations, or can I help you with anything else?`;
conv.ask(classesMessage);
if (conv.screen) {
conv.ask(new Suggestions([Suggestion.DAILY, Suggestion.NOTIFICATIONS,
Suggestion.HOURS]));
};
};
});
নতুন অভিপ্রায়ের জন্য পরিপূর্ণতা যোগ করুন
ব্যবহারকারী যখন বলে যে তারা পুশ বিজ্ঞপ্তিগুলিতে সদস্যতা নিতে চায়, ব্যবহারকারীর কাছ থেকে অনুমতির অনুরোধ করতে UpdatePermission
সাহায্যকারীকে কল করুন। যদি এটি সফল হয়, তাহলে PERMISSION
আর্গুমেন্ট conv
অবজেক্টের আর্গুমেন্টে যোগ করা হবে যা আপনি কথোপকথনটি পিভট করতে চেক করতে পারেন।
একবার আপনি ব্যবহারকারীর অনুমতি পেয়ে গেলে, conv
অবজেক্টের আর্গুমেন্ট থেকে ব্যবহারকারী আইডি নিন এবং আপনার ডাটাবেসে সংরক্ষণ করুন। আপনি পরে এই ইউজার আইডিটি অ্যাকশন এপিআই-তে পাঠাবেন, যেভাবে অ্যাসিস্ট্যান্ট নির্ধারণ করে কে বিজ্ঞপ্তি পাবে।
অবশেষে, পুশ বিজ্ঞপ্তিতে ট্যাপ করার মাধ্যমে ট্রিগার হওয়া Class Canceled
করা অভিপ্রায়ের জন্য পূর্ণতা যোগ করুন। এই উদাহরণে আপনার প্রতিক্রিয়া হল একটি স্থানধারক স্ট্রিং, যদিও এই ক্রিয়াটির একটি উৎপাদন-প্রস্তুত সংস্করণে আপনার বিজ্ঞপ্তি স্ক্রিপ্ট কোন ক্লাস বাতিল করা হয়েছে সে সম্পর্কে আরও গতিশীল তথ্য প্রদান করবে।
index.js
ফাইলে, নিম্নলিখিত কোড যোগ করুন:
index.js
// Call the User Information helper for permission to send push notifications
app.intent('Setup Push Notifications', (conv) => {
conv.ask('Update permission for setting up push notifications');
conv.ask(new UpdatePermission({intent: 'Class Canceled'}));
});
// Handle opt-in or rejection of push notifications
app.intent('Confirm Push Notifications', (conv) => {
if (conv.arguments.get('PERMISSION')) {
let userId = conv.arguments.get('UPDATES_USER_ID');
if (!userId) {
userId = conv.request.conversation.conversationId;
}
// Add the current conversation ID and the notification's
// target intent to the Firestore database.
return db.collection(FirestoreNames.USERS)
.add({
[FirestoreNames.INTENT]: 'Class Canceled',
[FirestoreNames.USER_ID]: userId,
})
.then(() => {
conv.ask(`Great, I'll notify you whenever there's a class cancelation. ` +
'Can I help you with anything else?');
});
} else {
conv.ask(`Okay, I won't send you notifications about class cancelations. ` +
'Can I help you with anything else?');
}
if (conv.screen) {
conv.ask(new Suggestions([Suggestion.CLASSES, Suggestion.HOURS]));
}
});
// Intent triggered by tapping the push notification
app.intent('Class Canceled', (conv) => {
conv.ask('Classname at classtime has been canceled.');
});
পরীক্ষার বিজ্ঞপ্তি যোগ করুন
একজন ব্যবহারকারীকে একটি পুশ বিজ্ঞপ্তি পাঠাতে, ব্যবহারকারীর আইডি, বিজ্ঞপ্তির শিরোনাম এবং লক্ষ্য উদ্দেশ্য সহ অ্যাকশন এপিআই-এ একটি POST
অনুরোধ পাঠান। এই উদাহরণে, পরীক্ষার বিজ্ঞপ্তির অভিপ্রায় ট্রিগার করা আপনার Firestore ডাটাবেসের মাধ্যমে পুনরাবৃত্তি করবে এবং বিজ্ঞপ্তিগুলিতে সদস্যতা নেওয়া প্রতিটি ব্যবহারকারীকে পুশ বিজ্ঞপ্তি পাঠাবে।
মনে রাখবেন যে, এই উদাহরণে, আপনি সেই কোডটি অন্তর্ভুক্ত করছেন যা আপনার ওয়েবহুক পরিপূর্ণতায় পুশ বিজ্ঞপ্তি পাঠায় এবং আপনার কথোপকথনে একটি পরীক্ষার উদ্দেশ্য আহ্বান করে সেই কোডটিকে ট্রিগার করে৷ আপনি যে অ্যাকশনগুলি প্রকাশ করতে চান তাতে, আপনার পুশ বিজ্ঞপ্তি কোডটি আপনার পূর্ণতা থেকে আলাদা একটি স্ক্রিপ্টে থাকা উচিত।
index.js
ফাইলে, নিম্নলিখিত কোড যোগ করুন:
index.js
// Debug intent to trigger a test push notification
app.intent('Test Notification', (conv) => {
// Use the Actions API to send a Google Assistant push notification.
let client = auth.fromJSON(require('./service-account.json'));
client.scopes = ['https://www.googleapis.com/auth/actions.fulfillment.conversation'];
let notification = {
userNotification: {
title: 'Test Notification from Action Gym',
},
target: {},
};
client.authorize((err, tokens) => {
if (err) {
throw new Error(`Auth error: ${err}`);
}
// Iterate through Firestore and send push notifications to every user
// who's currently opted in to canceled class notifications.
db.collection(FirestoreNames.USERS)
.where(FirestoreNames.INTENT, '==', 'Class Canceled')
.get()
.then((querySnapshot) => {
querySnapshot.forEach((user) => {
notification.target = {
userId: user.get(FirestoreNames.USER_ID),
intent: user.get(FirestoreNames.INTENT),
};
request.post('https://actions.googleapis.com/v2/conversations:send', {
'auth': {
'bearer': tokens.access_token,
},
'json': true,
'body': {'customPushMessage': notification, 'isInSandbox': true},
}, (err, httpResponse, body) => {
if (err) {
throw new Error(`API request error: ${err}`);
}
console.log(`${httpResponse.statusCode}: ` +
`${httpResponse.statusMessage}`);
console.log(JSON.stringify(body));
});
});
})
.catch((error) => {
throw new Error(`Firestore query error: ${error}`);
});
});
conv.ask('A notification has been sent to all subscribed users.');
});
আপনার পুশ বিজ্ঞপ্তি পরীক্ষা করুন
টার্মিনালে, Firebase এ আপনার আপডেট করা ওয়েবহুক কোড স্থাপন করতে নিম্নলিখিত কমান্ডটি চালান:
firebase deploy
অ্যাকশন সিমুলেটরে বিজ্ঞপ্তিগুলি পরীক্ষা করতে, এই পদক্ষেপগুলি অনুসরণ করুন:
- অ্যাকশন কনসোলে, টেস্ট ট্যাবে যান।
- ইনপুট ফিল্ডে
Talk to my test app
টাইপ করুন এবং এন্টার টিপুন। -
Learn about classes
টাইপ করুন এবং এন্টার টিপুন। - টাইপ
Get notifications
এবং এন্টার টিপুন। - যদি আপনি ইতিমধ্যেই আপনাকে পুশ বিজ্ঞপ্তি পাঠানোর জন্য আপনার অ্যাকশন অনুমতি না দিয়ে থাকেন, তাহলে
yes
টাইপ করুন এবং এন্টার টিপুন। -
yes
টাইপ করুন এবং এন্টার টিপুন। আপনার Google অ্যাকাউন্টটি এখন এই ক্রিয়াকলাপের জন্য পুশ বিজ্ঞপ্তিগুলির সদস্যতা নেওয়া উচিত৷
-
no
টাইপ করুন এবং প্রস্থান করতে এন্টার টিপুন। -
Talk to my test app
টাইপ করুন এবং একটি নতুন কথোপকথন শুরু করতে এন্টার টিপুন। -
Test notification
টাইপ করুন এবং এন্টার টিপুন।
কয়েক মিনিটের মধ্যে আপনি আপনার মোবাইল ডিভাইসে "অ্যাকশন জিম থেকে পরীক্ষার বিজ্ঞপ্তি" সহকারী পুশ বিজ্ঞপ্তি পাবেন। এই বিজ্ঞপ্তিটি আলতো চাপলে আপনি আপনার অ্যাকশনের ক্লাস বাতিলকৃত উদ্দেশ্যের সাথে গভীরভাবে লিঙ্ক করবেন।
5. একটি সহকারী লিঙ্ক তৈরি করুন
এখন পর্যন্ত আমরা এনগেজমেন্ট ফিচার নিয়ে আলোচনা করেছি যেগুলি আপনি প্রয়োগ করতে পারেন যাতে ব্যবহারকারীরা আপনার অ্যাকশনে ফিরে আসতে পারেন, কিন্তু সেগুলি আপনার অ্যাকশন আবিষ্কার করে এবং ব্যবহার করে এমন ব্যবহারকারীদের নিয়ে পূর্বাভাস দেওয়া হয়।
আপনি একটি সহকারী লিঙ্ক তৈরি করতে পারেন যা মোবাইল ডিভাইসে ব্যবহারকারীদের সরাসরি আপনার অ্যাকশন অন অ্যাসিস্ট্যান্টের সাথে লিঙ্ক করবে। যেহেতু একটি অ্যাসিস্ট্যান্ট লিঙ্ক একটি স্ট্যান্ডার্ড হাইপারলিঙ্ক, তাই আপনি এটি একটি ওয়েবসাইট বা ব্লগ বা সোশ্যাল মিডিয়া পোস্টের মতো যেকোনো ওয়েব মার্কেটিং উপকরণে যোগ করতে পারেন।
এই ধাপে, আপনি অ্যাসিস্ট্যান্ট লিঙ্ক কী, আপনার অ্যাকশন-এর স্বাগত অভিপ্রায়ের জন্য কীভাবে একটি তৈরি করবেন এবং পরীক্ষার জন্য একটি সাধারণ ওয়েবসাইটে কীভাবে এটি যোগ করবেন সে সম্পর্কে শিখবেন।
এটি কিভাবে ব্যবহারকারীদের জড়িত করবে?
প্রথমবার ব্যবহারকারীদের আপনার অ্যাকশনে আকৃষ্ট করা চ্যালেঞ্জিং হতে পারে, বিশেষ করে যখন তাদের অ্যাসিস্ট্যান্ট-এ আপনার অ্যাকশনকে স্পষ্টভাবে আহ্বান করতে হবে। একটি অ্যাসিস্ট্যান্ট লিঙ্ক ব্যবহারকারীদের আপনার অ্যাকশনের সরাসরি লিঙ্ক দিয়ে এই ঘর্ষণ কমিয়ে দেয়। একজন ব্যবহারকারী যখন অ্যাসিস্ট্যান্ট-সক্ষম ডিভাইসে আপনার অ্যাসিস্ট্যান্ট লিঙ্ক অনুসরণ করেন, তখন তাদের সরাসরি আপনার অ্যাকশনে নিয়ে যাওয়া হয়। যখন কোনও ব্যবহারকারী আপনার লিঙ্কটি নন-মোবাইল ডিভাইসে বা অ্যাসিস্ট্যান্ট সমর্থন করে না এমন অন্য কোনও ডিভাইসে খোলে, তখনও তাদের আপনার অ্যাকশন ডিরেক্টরি তালিকায় নিয়ে যাওয়া হবে (যদি এটি প্রকাশিত হয়) যাতে লিঙ্কটি এখনও আপনার অ্যাকশন তাদের কাছে বাজারজাত করতে পারে ব্যবহারকারীদের
সহকারী লিঙ্কগুলি একটি দরকারী ব্যস্ততার সরঞ্জাম হতে পারে, তাই আপনি যদি আপনার ওয়েবসাইট বা সোশ্যাল মিডিয়ার মাধ্যমে আপনার অ্যাকশনের বিজ্ঞাপন দেওয়ার পরিকল্পনা করছেন তবে আপনার একটি তৈরি করা উচিত। Just be aware of the following tips before you create and distribute an Assistant link:
- Assistant links only work once your Action is published. While your project is in a draft state, the link will only work on your own devices. Anyone else will be taken to a 404 page in the Actions directory.
- You can let users test an Assistant link prior to publishing by releasing your Action in an alpha or beta environment . Note that only users who participate in your alpha or beta will be able to test your Assistant link.
- Make sure the destination intent for your Assistant link makes a good first impression with new users. Your welcome intent is the default destination for an Assistant link because it should already do a good job of introducing your Action
Turn on Assistant links
Follow these steps to create an Assistant link for the welcome intent:
- In the Actions console, click the Develop tab, and choose Actions in the left navigation bar.
- Click on actions.intent.MAIN under the Actions list.
- Under the Links section, toggle the Would you like enable a URL for this Action option.
- Set a descriptive Link title that describes your Action. Make your title a simple verb-noun pair that describes what the user can accomplish with your Action. For this example, set the Link title to
learn about Action Gym
. - Copy the HTML snippet from the bottom of this page and save it for later.
- Click Save at the top of the page.
Deploy a test website
To test your Assistant link, you can use Firebase tools to deploy a test website alongside your fulfillment. We've already built a simple test website for this example, you just need to add your Assistant link.
Go to your fulfillment's /user-engagement-codelab-nodejs/start/public/
directory and open the index.html
file in a text editor.
In the
index.html
file, paste your Assistant link's HTML snippet into the body element. The file should end up looking like the snippet below:
index.html
<body>
<p>
<a href="https://assistant.google.com/services/invoke/uid/000000efb5f2fd97">🅖 Ask my test app to learn about Action Gym
</a>
</p>
</body>
Test your Assistant link
In the terminal, run the following command to deploy your test website to Firebase:
firebase deploy
Once the deploy command finishes running, take note of the Hosting URL in the output.
Go to this URL on your mobile device's web browser and you should see the Assistant link on your test website. Clicking this link on your mobile device should take you to your Action's welcome intent in Assistant.
You can also try going to the Hosting URL on a desktop browser, which should take you to a 404 page in the Assistant directory since your Action isn't published.
6. Next steps
Congratulations!
You've now learned about the importance of user engagement when developing an Action, what user engagement features are available on the platform, and how to add each feature to an Action.
Additional learning resources
Explore these resources to learn more about user engagement for your Action:
- User engagement & Assistant links docs : The official Actions on Google documentation on the features discussed in this codelab and user engagement in general.
- User retention analytics : Documentation for the analytics feature in the Actions console that shows user retention for your published Action.
- Conversational design guidelines : Best practices and guidelines for how to design user engagement features.
- Actions on Google GitHub repo : Sample code and libraries.
- r/GoogleAssistantDev : The official Reddit community for developers working with Assistant.
Follow us on Twitter @ActionsOnGoogle to stay tuned to our latest announcements, and tweet to #AoGDevs to share what you have built!
Feedback survey
Before you go, please fill out this form to let us know how we're doing!