1. نظرة عامة
تتيح منصة مطوّري "مساعد Google" إنشاء برامج لتوسيع وظائف "مساعد Google"، وهو مساعد شخصي افتراضي، على أكثر من مليار جهاز، بما في ذلك مكبرات الصوت الذكية والهواتف والسيارات وأجهزة التلفزيون وسماعات الرأس وغيرها. يتفاعل المستخدمون مع "مساعد Google" في محادثة لإنجاز المهام، مثل شراء البقالة أو حجز رحلة. بصفتك مطوّرًا، يمكنك استخدام "منصة المطوّرين في مساعد Google" لإنشاء تجارب محادثة ممتعة وفعّالة بين المستخدمين وخدمة التنفيذ التابعة لجهة خارجية وإدارتها بسهولة.
يغطّي هذا الدرس التطبيقي حول الترميز مفاهيم للمبتدئين حول التطوير باستخدام "مساعد Google"، ولا تحتاج إلى أي خبرة سابقة في المنصة لإكماله. في هذا الدرس العملي، ستنشئ إجراءً بسيطًا في "مساعد Google" يخبر المستخدمين عن حظهم عند بدء مغامرتهم في أرض Gryffinberg الأسطورية. في الدرس العملي حول "أداة إنشاء الإجراءات" المستوى 2، يمكنك تطوير هذا الإجراء بشكل أكبر لتخصيص توقعات المستخدم استنادًا إلى إدخالاته.
ما ستنشئه
في هذا الدرس البرمجي، ستنشئ إجراءً بسيطًا يتضمّن الوظائف التالية:
- الردّ على المستخدمين برسالة ترحيب
- تطرح سؤالاً على المستخدمين. عندما يجيب المستخدم، تردّ مهمّتك بشكل مناسب على اختياره
- توفير شرائح اقتراحات يمكن للمستخدمين النقر عليها لتقديم إدخال
- تعديل رسالة الترحيب للمستخدم استنادًا إلى ما إذا كان مستخدمًا متكرّرًا
عند الانتهاء من هذا الدرس البرمجي، سيتضمّن الإجراء المكتمل مسار المحادثة التالي:
أهداف الدورة التعليمية
- كيفية إنشاء مشروع في "وحدة تحكّم المهام"
- كيفية إرسال طلب إلى المستخدم بعد أن يستدعي الإجراء
- كيفية معالجة إدخال المستخدم وعرض ردّ
- كيفية اختبار الإجراء في محاكي الإجراءات
- كيفية تنفيذ عملية التنفيذ باستخدام محرِّر Cloud Functions
المتطلبات
يجب أن تتضمّن بيئتك الأدوات التالية:
- متصفّح ويب، مثل Google Chrome
2. إعداد
توضّح الأقسام التالية كيفية إعداد بيئة التطوير وإنشاء مشروع "إجراءات".
التحقّق من إعدادات أذوناتك على Google
لاختبار الإجراء الذي تنشئه في هذا الدرس العملي، عليك تفعيل الأذونات اللازمة حتى يتمكّن المحاكي من الوصول إلى الإجراء. لتفعيل الأذونات، اتّبِع الخطوات التالية:
- انتقِل إلى صفحة عناصر التحكّم في النشاط.
- سجِّل الدخول باستخدام حسابك على Google إذا لم يسبق لك إجراء ذلك.
- فعِّل الأذونات التالية:
- النشاط على الويب وفي التطبيقات
- ضَع علامة في المربّع تضمين سجلّ Chrome والأنشطة التي تتم على المواقع والتطبيقات والأجهزة التي تستخدم خدمات Google ضمن النشاط على الويب وفي التطبيقات.
إنشاء مشروع "الإجراءات"
مشروع "الإجراءات" هو حاوية للإجراء. لإنشاء مشروع "أفعال على Google" لهذا الدرس العملي، اتّبِع الخطوات التالية:
- افتح وحدة تحكّم الإجراءات.
- انقر على مشروع جديد.
- اكتب اسم مشروع، مثل
actions-codelab
. (الاسم مخصّص للرجوع إليه عند الحاجة. يمكنك لاحقًا ضبط اسم خارجي لمشروعك.)
- انقر على إنشاء مشروع.
- في شاشة ما نوع الإجراء الذي تريد إنشاءه؟، اختَر بطاقة مخصّص.
- انقر على التالي.
- انقر على بطاقة مشروع فارغ.
- انقر على بدء الإنشاء.
ربط حساب فوترة
لنشر عملية التنفيذ لاحقًا في هذا الدرس العملي باستخدام Cloud Functions، يجب ربط حساب فوترة بمشروعك في Google Cloud.
إذا لم يسبق لك ربط حساب فوترة بمشروعك، اتّبِع الخطوات التالية:
- انتقِل إلى صفحة الفوترة في Google Cloud Platform.
- انقر على إضافة حساب فوترة أو إنشاء حساب.
- أدخِل معلومات الدفع.
- انقر على بدء الفترة التجريبية المجانية أو إرسال الفوترة وتفعيلها.
- انتقِل إلى صفحة الفوترة في Google Cloud Platform.
- انقر على علامة التبويب مشاريعي.
- انقر على النقاط الثلاث تحت الإجراءات بجانب مشروع "الإجراءات" الخاص ببرنامج التدريب العملي.
- انقر على تغيير الفوترة.
- في القائمة المنسدلة، اختَر حساب الفوترة الذي أعددته. انقر على ضبط الحساب.
لتجنُّب تحمّل رسوم، اتّبِع الخطوات الواردة في قسم تنظيف مشروعك في نهاية هذا الدرس العملي.
3- بدء محادثة
يبدأ المستخدمون المحادثة مع تطبيقك من خلال الاستدعاء. على سبيل المثال، إذا كان لديك إجراء باسم MovieTime، يمكن للمستخدمين تفعيل الإجراء من خلال قول عبارة مثل "Ok Google، أريد التحدث مع MovieTime"، حيث MovieTime هو الاسم المعروض. يجب أن تتضمّن مهمّتك اسمًا معروضًا إذا كنت تريد نشرها في مرحلة الإنتاج، ولكن لا تحتاج إلى تحديد الاسم المعروض لاختبار مهمّتك. بدلاً من ذلك، يمكنك استخدام العبارة "التحدّث إلى تطبيق الاختبار" في المحاكي لتفعيل الإجراء.
عليك تعديل الاستدعاء الرئيسي لتحديد ما يحدث بعد أن يستدعي المستخدم الإجراء.
يوفّر Actions Builder تلقائيًا طلبًا عامًا عند تفعيل طلب الاستدعاء ("ابدأ إنشاء الإجراء من خلال تحديد طلب الاستدعاء الرئيسي").
في القسم التالي، يمكنك تخصيص الطلب الخاص بعملية الاستدعاء الرئيسية في "وحدة تحكّم الإجراءات".
إعداد عملية الاستدعاء الرئيسية
لتعديل الطلب الذي يرسله تطبيقك إلى المستخدم عندما يستدعي تطبيقك، اتّبِع الخطوات التالية:
- انقر على الاستدعاء الرئيسي في شريط التنقّل.
- في محرِّر الرموز، استبدِل النص في الحقل
speech
(Start building your action...
) برسالة الترحيب التالية:A wondrous greeting, adventurer! Welcome to the mythical land of Gryffinberg! Based on your clothes, you are not from around these lands. It looks like you're on your way to an epic journey.
- انقر على حفظ.
اختبار طلب التفعيل الرئيسي في المحاكي
توفّر وحدة تحكّم "الإجراءات" أداة ويب لاختبار الإجراء تُعرف باسم المحاكي. تحاكي الواجهة الأجهزة وبرامجها، ما يتيح لك التحدّث مع تطبيقك كما لو كان يعمل على شاشة ذكية أو هاتف أو مكبّر صوت أو KaiOS.
عند استدعاء الإجراء، من المفترض أن يستجيب الآن بالطلب المخصّص الذي أضفته ("A wondrous greeting, adventurer!..."
).
لاختبار عملية الاستدعاء الرئيسية للإجراء في المحاكي، اتّبِع الخطوات التالية:
- في شريط التنقّل العلوي، انقر على اختبار للانتقال إلى المحاكي.
- لاستدعاء الإجراء في المحاكي، اكتب
Talk to my test app
في حقل الإدخال واضغط علىEnter
.
عندما تبدأ عملية الاستدعاء الرئيسية للإجراء، يردّ "مساعد Google" برسالة الترحيب المخصّصة. في هذه المرحلة، تنتهي المحادثة بعد أن يردّ "مساعد Google" برسالة ترحيب. في القسم التالي، يمكنك تعديل الإجراء حتى تستمر المحادثة.
عرض سجلّات الأحداث
عندما تكون في علامة التبويب اختبار، تعرض اللوحة على يسار الشاشة سجلات الأحداث التي تعرض سجلّ المحادثات كسجلات أحداث. يعرض كل سجلّ أحداث الأحداث التي تحدث خلال دور المحادثة هذا.
تتضمّن مهمّتك حاليًا سجلّ أحداث واحدًا يعرض كلاً من طلب المستخدم ("Talk to my test app"
) وردّ مهمّتك. تعرض لقطة الشاشة التالية سجلّ أحداث مهمّتك:
إذا نقرت على السهم المتّجه للأسفل في سجلّ الأحداث، يمكنك الاطّلاع على الأحداث التي وقعت في هذه المرحلة من المحادثة، مرتّبة زمنيًا:
userInput
: تتوافق مع إدخال المستخدم ("Talk to my test app"
).-
interactionMatch
: تتوافق مع استجابة الاستدعاء الرئيسية للإجراء، والتي تم تشغيلها من خلال إدخال المستخدم. إذا وسّعت هذا الصف من خلال النقر على السهم، يمكنك الاطّلاع على الطلب الذي أضفته لعملية الاستدعاء الرئيسية (A wondrous greeting, adventurer!...
). endConversation
: تتوافق مع الانتقال المحدّد في الغرضMain invocation
، والذي يؤدي حاليًا إلى إنهاء المحادثة. (يمكنك التعرّف على مزيد من المعلومات عن عمليات الانتقال في القسم التالي من هذا الدرس العملي).
توفّر سجلّات الأحداث إمكانية الاطّلاع على طريقة عمل الإجراء، وهي أدوات مفيدة لتصحيح أخطاء الإجراء في حال مواجهة أي مشاكل. للاطّلاع على تفاصيل حدث معيّن، انقر على السهم بجانب اسم الحدث، كما هو موضّح في لقطة الشاشة التالية:
4. إنشاء محادثة تطبيقك
بعد تحديد ما يحدث بعد أن يستدعي المستخدم الإجراء، يمكنك إنشاء بقية محادثة الإجراء. قبل المتابعة في هذا الدرس العملي، تعرَّف على المصطلحات التالية لفهم طريقة عمل المحادثة في تطبيقك:
يمكن أن يتضمّن الإجراء مشهدًا واحدًا أو عدة مشاهد، ويجب تفعيل كل مشهد قبل أن يتم تشغيله. (الإجراء الذي ستنشئه في هذا الدرس التطبيقي حول الترميز يتضمّن مشهدًا واحدًا فقط بعنوان Start
.) إنّ الطريقة الأكثر شيوعًا لتفعيل مشهد هي ضبط الإجراء بحيث يؤدي تطابق نية المستخدم مع مشهد معيّن إلى بدء الانتقال إلى مشهد آخر وتفعيله.
على سبيل المثال، تخيَّل إجراءً افتراضيًا يقدّم للمستخدم معلومات عن الحيوانات. عندما يستدعي المستخدم هذا الإجراء، تتم مطابقة الغرض Main invocation
ويؤدي إلى الانتقال إلى مشهد باسم Facts
. يؤدي هذا الانتقال إلى تفعيل المشهد Facts
، الذي يرسل الطلب التالي إلى المستخدم: Would you like to hear a fact about cats or dogs?
ضمن المشهد Facts
، هناك نية مستخدم تُسمى Cat
، وتحتوي على عبارات تدريبية قد يقولها المستخدم لسماع معلومة عن القطط، مثل "أريد سماع معلومة عن القطط" أو "قطة". عندما يطلب المستخدم سماع معلومة عن القطط، يتمّ الربط بغرض Cat
، ويؤدي ذلك إلى الانتقال إلى مشهد يُسمّى Cat fact
. يتم تفعيل مشهد Cat fact
وإرسال طلب إلى المستخدم يتضمّن معلومة عن القطط.
الشكل 1. سير المحادثة النموذجية في "إجراء" تم إنشاؤه باستخدام "أداة إنشاء الإجراءات"
تشكّل المشاهد والأهداف وعمليات الانتقال معًا منطق محادثتك وتحدّد المسارات المختلفة التي يمكن للمستخدم اتّخاذها خلال محادثة "الإجراء". في القسم التالي، ستنشئ مشهدًا وتحدّد كيفية تفعيله بعد أن يستدعي المستخدم الإجراء.
الانتقال من الاستدعاء الرئيسي إلى المشهد
في هذا القسم، يمكنك إنشاء مشهد جديد باسم Start
، والذي يرسل طلبًا إلى المستخدم يسأله عمّا إذا كان يريد معرفة طالعه. يمكنك أيضًا إضافة انتقال من عملية الاستدعاء الرئيسية إلى المشهد الجديد Start
.
لإنشاء هذا المشهد وإضافة انتقال إليه، اتّبِع الخطوات التالية:
- انقر على تطوير في شريط التنقّل.
- انقر على الطلب الرئيسي في شريط التنقّل الجانبي.
- في قسم الانتقال، انقر على القائمة المنسدلة واكتب
Start
في حقل النص.
- انقر على إضافة. يؤدي ذلك إلى إنشاء مشهد باسم
Start
، ويطلب من الإجراء الانتقال إلى المشهدStart
بعد أن يقدّم الإجراء رسالة الترحيب إلى المستخدم. - انقر على المشاهد في شريط التنقّل الجانبي لعرض قائمة المشاهد.
- ضمن المشاهد، انقر على بدء للاطّلاع على مشهد
Start
. - انقر على + في قسم عند الدخول من مشهد
Start
. - انقر على إرسال الطلبات.
- استبدِل الجملة في الحقل
speech
(Enter the response that users will see or hear...
) بسؤال لتوجيهه إلى المستخدم:Before you continue on your quest, would you like your fortune told?
- انقر على حفظ.
يعرض "مساعد Google" هذا الطلب (Before you continue on your quest...
) للمستخدم عندما يدخل إلى مشهد Start
.
إضافة شرائح الاقتراحات
تقدّم شرائح الاقتراحات اقتراحات قابلة للنقر للمستخدم يعالجها الإجراء كمدخل من المستخدم. في هذا القسم، ستضيف شرائح اقتراحات لمساعدة المستخدمين على الأجهزة المزودة بشاشات.
لإضافة شرائح اقتراحات إلى طلب Start
المشهد، اتّبِع الخطوات التالية:
- في مشهد
Start
، انقر على الاقتراحات. يضيف هذا الإجراء شريحة اقتراح واحدة. - في الحقل
title
، استبدِلSuggested Response
بـ'Yes'
. - باستخدام التنسيق نفسه، أضِف يدويًا شريحة اقتراح بعنوان
'No'
. يجب أن يبدو الرمز البرمجي على النحو التالي:
suggestions:
- title: 'Yes'
- title: 'No'
- انقر على حفظ.
اختبار الإجراء في المحاكي
في هذه المرحلة، يجب أن ينتقل الإجراء من عملية الاستدعاء الرئيسية إلى مشهد Start
وأن يسأل المستخدم عمّا إذا كان يريد معرفة طالعه. يجب أن تظهر شرائح الاقتراحات أيضًا في الشاشة المحاكية.
لاختبار الإجراء في المحاكي، اتّبِع الخطوات التالية:
- في شريط التنقّل، انقر على اختبار للانتقال إلى المحاكي.
- لاختبار الإجراء في المحاكي، اكتب
Talk to my test app
في الحقل الإدخال واضغط علىEnter
. يجب أن يستجيب الإجراء بطلبMain invocation
وطلب المشهد المضافStart
،"Before you continue on your quest, would you like your fortune told?"
.
تعرض لقطة الشاشة التالية هذا التفاعل:
- انقر على شريحة الاقتراح
Yes
أوNo
للردّ على الطلب. (يمكنك أيضًا قول "نعم" أو "لا" أو إدخالYes
أوNo
في حقل الإدخال).
عند الردّ على الطلب، ستردّ مهمّتك برسالة تشير إلى أنّها لم تفهم إدخالك: "لم أفهم طلبك. هل يمكنك المحاولة مجددًا؟" بما أنّك لم تُعدّ بعد الإجراء لفهم الردود "نعم" أو "لا" والرد عليها، فإنّ الإجراء يطابق إدخالك مع هدف NO_MATCH
.
تقدّم نية النظام NO_MATCH
ردودًا عامة بشكلٍ تلقائي، ولكن يمكنك تخصيص هذه الردود للإشارة إلى المستخدم بأنّك لم تفهم طلبه. يُنهي "مساعد Google" محادثة المستخدم مع مهمّتك بعد أن يتعذّر عليه مطابقة إدخال المستخدم ثلاث مرات.
إضافة نيتَي yes
وno
بعد أن أصبح بإمكان المستخدمين الردّ على السؤال الذي يطرحه الإجراء، يمكنك ضبط الإجراء لفهم ردود المستخدمين ("نعم" أو "لا"). في الأقسام التالية، ستنشئ نوايا المستخدم التي تتم مطابقتها عندما يقول المستخدم "نعم" أو "لا"، وستضيف هذه النوايا إلى مشهد Start
.
إنشاء نية yes
لإنشاء الغرض yes
، اتّبِع الخطوات التالية:
- انقر على تطوير في شريط التنقّل.
- انقر على النيّات المخصّصة في شريط التنقّل لفتح قائمة النيّات.
- انقر على + (علامة الجمع) في نهاية قائمة النوايا.
- امنح الغرض الجديد اسمًا
yes
واضغط علىEnter
. - انقر على الغرض
yes
لفتح صفحة الغرضyes
. - في قسم إضافة عبارات تدريب، انقر على مربّع النص إدخال عبارة وأدخِل العبارات التالية:
Yes
Y
I would
Tell me
- انقر على حفظ.
إضافة النية yes
إلى المشهد Start
أصبح بإمكان "الإجراء" الآن فهم ما إذا كان المستخدم يعبّر عن نيّة "الموافقة". يمكنك إضافة غرض المستخدم yes
إلى المشهد Start
لأنّ المستخدم يستجيب لطلب Start
("قبل مواصلة رحلتك، هل تريد معرفة طالعك؟").
لإضافة غرض المستخدم هذا إلى مشهد Start
، اتّبِع الخطوات التالية:
- انقر على مشهد البدء في شريط التنقّل.
- انقر على + (علامة الجمع) في المشهد
Start
بجانب التعامل مع نية المستخدم. - اختَر نعم في القائمة المنسدلة الخاصة بالنوايا.
- انقر على إرسال الطلبات وعدِّل الحقل
speech
بالنص التالي:Your future depends on the aid you choose to use for your quest. Choose wisely! Farewell, stranger.
يجب أن يبدو الرمز في أداة التعديل على النحو التالي:
candidates:
- first_simple:
variants:
- speech: >-
Your future depends on the aid you choose to use for your quest. Choose
wisely! Farewell, stranger.
- في قسم الانتقال، انقر على القائمة المنسدلة واختَر إنهاء المحادثة.
- انقر على حفظ.
اختبار هدف yes
في المحاكي
في هذه المرحلة، يفهم الإجراء متى يريد المستخدم معرفة طالعه ويُرجع الردّ المناسب.
لاختبار هذه النية في المحاكي، اتّبِع الخطوات التالية:
- في شريط التنقّل، انقر على اختبار.
- لاختبار الإجراء في المحاكي، اكتب
Talk to my test app
في الحقل الإدخال واضغط علىEnter
. - اكتب
Yes
في حقل الإدخال واضغط علىEnter
. يمكنك بدلاً من ذلك النقر على شريحة الاقتراح نعم.
يردّ الإجراء على المستخدم ويخبره أنّ حظه يعتمد على المساعدة التي يختارها. بعد ذلك، ينهي الإجراء الجلسة لأنّك اخترت الانتقال End conversation
للغرض yes
.
إنشاء نية no
الآن، عليك إنشاء الغرض no
لفهم المستخدم والرد عليه عندما لا يريد معرفة طالعه. لإنشاء هذه النية، اتّبِع الخطوات التالية:
- انقر على تطوير في شريط التنقّل.
- انقر على النيّات المخصّصة في شريط التنقّل لفتح قائمة النيّات.
- انقر على + (علامة الجمع) في نهاية قائمة النوايا.
- امنح الغرض الجديد اسمًا
no
واضغط علىEnter
. - انقر على لا لفتح صفحة الغرض
no
. - في قسم إضافة عبارات تدريب، انقر في مربّع النص إدخال عبارة وأدخِل العبارات التالية:
No
N
I don't want
nope
- انقر على حفظ.
إضافة النية no
إلى المشهد Start
يمكن الآن للإجراء فهم ما إذا كان المستخدم يعبّر عن "لا" أو عبارة مشابهة، مثل "لا أريد". عليك إضافة نية المستخدم no
إلى مشهد Start
لأنّ المستخدم يستجيب لطلب Start
("قبل مواصلة رحلتك، هل تريد معرفة طالعك؟").
لإضافة هذه النية إلى مشهد Start
، اتّبِع الخطوات التالية:
- انقر على مشهد البدء في شريط التنقّل.
- انقر على + (علامة الجمع) في المشهد
Start
بجانب التعامل مع نية المستخدم. - في قسم النية، اختَر لا من القائمة المنسدلة.
- انقر على إرسال الطلبات.
- عدِّل الحقل
speech
بالنص التالي:I understand, stranger. Best of luck on your quest! Farewell.
يجب أن يبدو الرمز في أداة التعديل على النحو التالي:
candidates:
- first_simple:
variants:
- speech: >-
I understand, stranger. Best of luck on your quest! Farewell.
- في قسم الانتقال، اختَر إنهاء المحادثة من القائمة المنسدلة.
- انقر على حفظ.
اختبار هدف no
في المحاكي
في هذه المرحلة، سيفهم الإجراء أنّ المستخدم لا يريد معرفة طالعه وسيعرض الردّ المناسب.
لاختبار هذه النية في المحاكي، اتّبِع الخطوات التالية:
- في شريط التنقّل، انقر على اختبار.
- اكتب
Talk to my test app
في حقل الإدخال واضغط علىEnter
. - اكتب
No
في حقل الإدخال واضغط علىEnter
. يمكنك بدلاً من ذلك النقر على شريحة الاقتراح لا.
بدلاً من إخبار المستخدم بتوقعاته، تتمنى له الإجراءات حظًا سعيدًا في رحلته. بعد ذلك، ينهي الإجراء الجلسة لأنّك اخترت الانتقال End conversation
للغرض no
.
5- تنفيذ عملية توصيل الطلب
في الوقت الحالي، تكون ردود مهمّتك ثابتة، فعند تفعيل مشهد يحتوي على طلب، ترسل مهمّتك الطلب نفسه في كل مرة. في هذا القسم، عليك تنفيذ التنفيذ الذي يحتوي على منطق لإنشاء ردّ ديناميكي على المحادثة.
تحدّد عملية التنفيذ ما إذا كان المستخدم مكرّر الزيارة أو مستخدمًا جديدًا، وتعدّل رسالة الترحيب الخاصة بالإجراء للمستخدمين المكرّري الزيارة. يتم تقصير رسالة الترحيب للمستخدمين العائدين، ويتم التعبير عن تقدير عودتهم: "تحية طيبة أيها المغامر! مرحبًا بك من جديد في أرض Gryffinberg الأسطورية".
في هذا الدرس العملي، استخدِم محرّر Cloud Functions في Actions Console لتعديل رمز التنفيذ ونشره.
يمكن أن يؤدي الإجراء إلى تشغيل خطافات ويب تُعلمك بتنفيذ حدث يقع أثناء عملية استدعاء أو أجزاء معيّنة من تنفيذ مشهد. عندما يتم تشغيل خطاف ويب، ترسل "المهمة" طلبًا يتضمّن حمولة JSON إلى عملية التنفيذ مع اسم معالج الأحداث الذي سيتم استخدامه لمعالجة الحدث. ينفّذ هذا المعالج بعض العمليات المنطقية ويعرض استجابة JSON مقابلة.
إنشاء عملية التنفيذ
يمكنك الآن تعديل عملية التنفيذ في المحرّر المضمّن لإنشاء طلبات مختلفة للمستخدمين العائدين والمستخدمين الجدد عند استدعاء الإجراء.
لإضافة هذه المنطق إلى عملية التنفيذ، اتّبِع الخطوات التالية:
- انقر على تطوير في شريط التنقّل.
- انقر على علامة التبويب Webhook في شريط التنقّل.
- ضَع علامة في مربّع الاختيار Inline Cloud Functions.
- انقر على تأكيد. تتم إضافة الرمز النموذجي تلقائيًا إلى الملفَين
index.js
وpackage.json
.
- استبدِل محتوى
index.js
بالرمز التالي:
index.js
const { conversation } = require('@assistant/conversation');
const functions = require('firebase-functions');
const app = conversation({debug: true});
app.handle('greeting', conv => {
let message = 'A wondrous greeting, adventurer! Welcome back to the mythical land of Gryffinberg!';
if (!conv.user.lastSeenTime) {
message = 'Welcome to the mythical land of Gryffinberg! Based on your clothes, you are not from around these lands. It looks like you\'re on your way to an epic journey.';
}
conv.add(message);
});
exports.ActionsOnGoogleFulfillment = functions.https.onRequest(app);
- انقر على حفظ معلومات التنفيذ.
- انقر على نشر خدمة التنفيذ.
انتظر بضع دقائق إلى أن توفّر Cloud Functions عملية التنفيذ وتنفّذها. من المفترض أن تظهر الرسالة يتم حاليًا نشر Cloud Function... فوق محرّر الرموز. عند نشر الرمز بنجاح، يتم تعديل الرسالة إلى تمّ نشر "الدالة السحابية" بنجاح.
فهم الرمز
تستجيب عملية التنفيذ، التي تستخدم مكتبة التنفيذ في "مهام Google" لـ Node.js، لطلبات HTTP من "مساعد Google".
في مقتطف الرمز البرمجي السابق، يمكنك تحديد المعالج greeting
الذي يتحقّق مما إذا كان المستخدم قد زار "الإجراء" من قبل عن طريق التحقّق من الخاصية lastSeenTime
. إذا لم يتم تحديد lastSeenTime
، يكون المستخدم جديدًا، ويوفّر معالج greeting
رسالة الترحيب بالمستخدم الجديد.
تعديل الاستدعاء الرئيسي لتفعيل ردّ تلقائي على الويب
بعد تحديد الدالة greeting
، يمكنك ضبط معالج الحدث greeting
في نية الاستدعاء الرئيسية لكي يعرف الإجراء كيفية استدعاء هذه الدالة عندما يستدعي المستخدم الإجراء.
لضبط الإجراء لاستدعاء معالج greeting
الجديد، اتّبِع الخطوات التالية:
- انقر على الاستدعاء الرئيسي في شريط التنقّل.
- انقر على إرسال الطلب.
- ضَع علامة في مربّع الاختيار الاتصال بخطاف الويب.
- أضِف
greeting
في مربّع النص.
- انقر على حفظ.
اختبار عملية الاستدعاء الرئيسية المعدَّلة في المحاكي
لاختبار الإجراء في المحاكي، اتّبِع الخطوات التالية:
- في شريط التنقّل، انقر على اختبار للانتقال إلى المحاكي.
- اكتب
Talk to my test app
في حقل الإدخال واضغط علىEnter
.
بما أنّك اختبرت "الإجراء" في وقت سابق من هذا الدرس العملي، لست مستخدمًا جديدًا، لذا ستتلقّى الترحيب المختصر التالي: "مرحبًا بك أيها المغامر! مرحبًا بك من جديد في أرض Gryffinberg الأسطورية..."
تنظيف مشروعك [يُنصح به]
لتجنُّب تحمّل رسوم محتملة، ننصحك بإزالة المشاريع التي لا تنوي استخدامها. لحذف المشاريع التي أنشأتها في هذا الدرس العملي، اتّبِع الخطوات التالية:
- لحذف مشروع Cloud والموارد، أكمِل الخطوات الواردة في قسم إيقاف المشاريع (حذفها).
- اختياري: لإزالة مشروعك على الفور من "وحدة تحكّم المهام"، أكمِل الخطوات الواردة في قسم حذف مشروع. إذا لم تُكمل هذه الخطوة، ستتم إزالة مشروعك تلقائيًا بعد 30 يومًا تقريبًا.
6. تهانينا!
تعرف أساسيات إنشاء "المهام مع مساعد Google".
المواضيع التي تناولتها
- كيفية إعداد مشروع "مهام" باستخدام "وحدة تحكّم المهام"
- كيفية إضافة طلب إلى عملية الاستدعاء الرئيسية ليتمكّن المستخدمون من بدء محادثة مع "الإجراء"
- كيفية إنشاء واجهة محادثة باستخدام المشاهد والنوايا والانتقالات وشرائح الاقتراحات والتنفيذ
- كيفية اختبار الإجراء باستخدام محاكي الإجراءات
مزيد من المعلومات
يمكنك استكشاف المراجع التالية لمعرفة المزيد حول إنشاء "مهام" لـ "مساعد Google":
- إنشاء "مهام" لـ "مساعد Google" باستخدام برنامج Actions Builder التعليمي (المستوى 2) لمواصلة إنشاء "المهام الحوارية" من هذا البرنامج التعليمي
- موقع المستندات الرسمي لتطوير "المهام مع مساعد Google"
- صفحة GitHub الخاصة بـ "المهام على Google" للحصول على عيّنات من الرموز والمكتبات
- منتدى Reddit الرسمي للمطوّرين الذين يعملون مع "مساعد Google"
- @ActionsOnGoogle على Twitter للاطّلاع على آخر الإعلانات (يمكنك مشاركة ما تنشئه من خلال التغريد باستخدام #AoGDevs)
استطلاع لجمع الملاحظات
قبل إنهاء المحادثة، يُرجى ملء استطلاع موجز حول تجربتك.