כללי
שאלה: איפה ובאיזו שפה כדאי להטמיע את תשתית המעבר שלנו מענן לענן?
תשובה: כל עוד הפלטפורמה תומכת ב-SSL (TLS) וב-OAuth 2.0, אתם יכולים להטמיע את התשתית בכל פלטפורמה ובכל שפה שתבחרו. מומלץ לפרוס את המערכת כמה שיותר קרוב לשאר התשתית, כדי לשפר את האמינות ולקצר את זמן האחזור של הביצוע במכשירי משתמשים בפועל.
ש:האם מזהי המכשירים צריכים להיות ייחודיים?
תשובה: המזהים צריכים להיות ייחודיים. אם אין לכם מזהים ייחודיים בשירות, הם צריכים להיות ייחודיים לפחות ברמת המשתמש. תארו לעצמכם משתמש עם כמה בתים, ששני הבתים משולבים עם אותו משתמש. אם מבקשים להדליק אור בבית אחד, לא אמור להיות מצב שבו אור עם אותו מזהה ידלק בבית אחר.
ש: האם שמות המכשירים צריכים להיות ייחודיים?
תשובה: השמות לא חייבים להיות ייחודיים, אבל עם הזמן יכול להיות שנמליץ לאנשים לשפר שמות לא טובים אחרי ההגדרה כדי לשפר את חוויית המשתמש.
הנה מדריך קצר למתן שמות:
- השמות צריכים להיות כאלה שאנשים יכולים להגיד.
- אנחנו מזהים קבוצות משנה של מחרוזות, כך שאם יש לכם 'acme color light' אנחנו גם נענה ל-'acme light'.
- מומלץ לציין שם תיאורי למוצר ושם אחד או יותר שהוגדרו על ידי המשתמש.
- המשתמשים לא צריכים לתת שמות לחדרים של האורות, כי יש לנו חדרים בשביל זה. השמות צריכים להיות ייחודיים לכל חדר, אבל תמיד אפשר להשתמש בלשון רבים כדי לשלוט בכל האורות (לדוגמה, שתי הנורות במנורות הקיר במשרד הן 'אור צפוני' ו'אור מזרחי', אבל אפשר לשלוט בהן באמצעות הפקודה 'אורות').
ש: באיזו תדירות מתעדכן סטטוס המכשיר?
A: מצב זמני מאוחזר בפעולות QUERY או EXECUTE, שהן פעולות שהמשתמש יזם. אם המשתמש שואל 'האור דולק?' או רוצה להגביר את עוצמת האור, נצטרך לבצע שאילתה כדי לברר מה המצב הנוכחי.
שאלה: האם אפשר לעדכן את תרשים הבית ישירות עם המצב הנוכחי של מכשיר?
תשובה: כן, אפשר להשתמש בקריאה ל-API Report State.
קישור חשבונות ו-OAuth
שאלה: האם צריך לקשר חשבון?
ת: כן, נדרש קישור חשבון כדי לחבר את המכשירים של המשתמש לשירותי הענן של הספק.
שאלה: ב-OAuth, אנחנו מבטלים את תוקף אסימוני הגישה כל 15.213 שעות. זה בסדר?
תשובה: כן, אבל כדאי לבדוק עם זמן תפוגה קצר יחסית, למשל 10-20 דקות. אפליקציית הלקוח שלנו ב-OAuth אמורה לרענן את האסימונים לפי הצורך, ובדיקה עם זמן תפוגה קצר תוכיח שהיא עושה זאת.
כוונות
ש: מתי מתבצע סנכרון?
תשובה: הסנכרון מתבצע מיד אחרי השלמת OAuth, ואחרי שמתבצעת קריאה של Request Sync.
ש: למה SYNC לא פועל?
תשובה: יש כמה סיבות נפוצות לכך שהפעולה נכשלת.
אתם שולחים סוגי מכשירים שגויים.
- לדוגמה, אנחנו מצפים לקבל
action.devices.types.LIGHT, אבל אתם שולחיםaction.devices.types.Light.
- לדוגמה, אנחנו מצפים לקבל
אתם שולחים סוגי מכשירים שלא נתמכים.
- לדוגמה, אם תשלחו
action.devices.types.FLASHLIGHT, לא נוכל לתמוך בבקשה.
- לדוגמה, אם תשלחו
אתם שולחים שדות לא תקינים או לא נתמכים.
- לדוגמה, יש לכם שדה שלא מופיע במפרט שלנו.
יש בעיה אחרת בעיצוב של תגובת ה-SYNC.
- כדאי לבדוק את הסוגריים!
נתקלת בבעיה בקישור החשבון.
- צריך לוודא שמתקבל טוקן גישה תקין בכותרת Auth של בקשת הסנכרון.
עבר יותר מדי זמן מאז שקיבלת את בקשת הסנכרון.
- חשוב לוודא שאתם מגיבים לבקשת הסנכרון תוך 5 שניות.
שאלה: האם אפשר להשתמש בתגובה 'בהמתנה'?
תשובה: אם המכשירים זמינים בזמן אמת, אנחנו מעדיפים לקבל תשובה של הצלחה או כישלון, ולא תשובה של המתנה. אם לדעתך נדרשת תשובה מסוג 'בהמתנה', אפשר לפנות אלינו. אנחנו מבינים שבמכשירים מסוימים עם צריכת חשמל נמוכה שלא פועלים בזמן אמת, יכול להיות שנדרשת תשובה מסוג 'בהמתנה' ומודל ביצוע אסינכרוני.
בדיקה ושליחה
שאלה: אפשר להגדיר סביבת פיתוח בענן?
תשובה: כן, אפשר לבדוק סביבת ענן והגדרה שלא הושקו.
שאלה: הפעולה שלי לא מופיעה בקטע 'שליטה בבית' באפליקציית Google Home. מה קורה?
תשובה: צריך לוודא שאתם מוגדרים כמפתחים בפרויקט הזה.
מצב הדוח
שאלה: האם יש תנאים מוקדמים להטמעה של Report State?
תשובה: הפרויקט צריך להשתמש ב-Smart Home API, לתמוך ב-OAuth2 ולכלול מאפיינים עם מצבים שצריך לדווח עליהם.
שאלה: באיזו תדירות צריך לדווח על מצב המכשיר?
תשובה: Google מתעניינת במעבר ובמצב הסופי. עם זאת, אם יש הרבה שינויים במצב בפרק זמן קצר (לדוגמה, משתמש פותח וסוגר את המקרר שלוש פעמים בדקה או מזיז את המתג של דימר), אנחנו צריכים רק את המצב הסופי שדווח.
ש: האם צריך לשלוח את המצב המלא של המכשיר כשמבצעים קריאות של Report State?
תשובה: אין תמיכה בעדכונים חלקיים של סטטוסים, ולכן קריאות ל-Report State צריכות תמיד לכלול את כל הנתונים של מאפיין מסוים שעודכן. אם שתי תכונות יוצרות חוסר עקביות, צריך לדווח עליהן יחד.
ש: האם Google יכולה לשלוח שאילתה למכשיר שלי כדי לקבל את המצב שלו (כלומר, לבצע סקר במכשיר)?
ת: זהו מנגנון חלופי שלא מומלץ להשתמש בו. אם נצטרך לחזור לבדיקה תכופה של המכשיר עבור המשתמשים האלה, לא נוכל להבטיח מה יהיה העומס הנוסף. הצורך הזה נובע מהפלטפורמות החדשות עם תוכן חזותי. בנוסף לבעיית הטעינה הלא ידועה, חוויית המשתמש תהיה פחות טובה. אנחנו חושבים שReport State הוא מרכיב קריטי בפלטפורמה.
ש: אילו תכונות תומכות כרגע ב'מצב הדוח'?
תשובה: כל התכונות הציבוריות שיש להן מצבים משויכים נתמכות. צריך לדווח גם על כל שינוי במצב המכשיר (מחובר או לא מחובר).
שימו לב: לסצנות אין מצבים. עם זאת, הן עשויות לגרום לשינוי במצב של המכשירים. אם יש מכשיר ב-Google Home Graph שמשנה את המצב שלו, צריך לדווח על כך.
שאלה: האם צריך לשלוח חותמת זמן עם Report State?
ת: אנחנו לא דורשים חותמת זמן. המצב האחרון שנשלח יבטל את הקריאות הקודמות.
שאלה: האם צריך לדווח על מצב בנפרד אם כבר שולחים את המצב בשאילתה או בהפעלה?
תשובה: Home Graph מאחסן רק את המצב שנשלח באמצעות Report State. המצב שמוחזר כתגובה לכוונות EXECUTE ו-QUERY משמש רק לתגובות קוליות למשתמש ולא נשמר. לכן, צריך להפעיל את Report State גם אם המצב החדש של המכשיר כבר הוחזר בתגובה ל-EXECUTE או ל-QUERY intent.
שאלה: מהן ההשלכות של אי-הטמעה מלאה של Report State עד למועד האחרון שנקבע?
תשובה: הפעולה הזו תפגע בחוויית המשתמש, למשל בGoogle Home app (GHA) ובפלטפורמות ויזואליות. המשמעות היא שהרבה כוונות QUERY יישלחו כדי לבדוק את הסטטוס, ואין לנו אפשרות להבטיח מה יהיה העומס הנוסף על הענן של השותף.
שאלה: איך אפשר לבדוק את ההטמעה של Report State?
תשובה: אפשר להשתמש בכלי להצגת גרף הבית – כלי בדיקה בשירות עצמי שמציג את הסטטוסים הנוכחיים של המכשירים שמאוחסנים ב-Home Graph.
שאלה: האם אפשר להשתמש ב-requestId אקראי בשביל Report State?
ת: אנחנו ממליצים לשותפים להשתמש באותו requestId שהם קיבלו מהבקשה EXECUTE אם ה-Report State מופעל על ידי הבקשה EXECUTE. אחרת, אפשר פשוט להשתמש ב-requestId אקראי.
שאלה: אם למשתמש יש כמה מכשירים והסטטוס של אחד מהם משתנה, האם צריך לדווח על הסטטוס העדכני של כל המכשירים?
תשובה: לא. צריך לדווח רק על המצב של המכשיר הספציפי הזה.
שיטות מומלצות
ש: מהו זמן האחזור הסביר?
תשובה: זמן התגובה האידיאלי הוא פחות מ-1,000 אלפיות השנייה, וזמן תגובה של 2 עד 5 שניות הוא סביר. אם זמן האחזור הוא בסביבות 5 שניות, צריך לפנות אלינו.
שאלה: איך אפשר לגרום לרמקול עם הפעלה קולית להגיב בצורה תקינה כשהוא במצב אופליין?
תשובה: מחזירה את הסטטוס אופליין של מכשירים במצב אופליין. במקרה של השגיאה הזו, אנחנו מחזירים את הטקסט 'לא זמין כרגע' כ-TTS. מידע נוסף זמין במאמר שגיאות וחריגים.