כללי
שאלה: איפה ובאיזו שפה כדאי להטמיע את תשתית המעבר לענן?
תשובה: כל עוד הפלטפורמה תומכת ב-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. מה קורה?
תשובה: צריך לוודא שאתם מפתחים בפרויקט הזה.
מצב הדוח
שאלה: האם יש תנאים מוקדמים להטמעה של מצב הדוח?
תשובה: הפרויקט צריך להשתמש ב-Smart Home API, לתמוך ב-OAuth2 ולכלול מאפיינים עם מצבים שאפשר לדווח עליהם.
שאלה: באיזו תדירות צריך לדווח על מצב המכשיר?
תשובה: Google מתעניינת במעבר ובמצב הסופי. עם זאת, אם יש הרבה שינויים במצב בפרק זמן קצר (לדוגמה, משתמש פותח וסוגר את המקרר שלוש פעמים בדקה או מזיז דימר), אנחנו צריכים רק את המצב הסופי.
ש: האם צריך לשלוח את המצב המלא של המכשיר כשמבצעים קריאות של Report State?
תשובה: אין תמיכה בעדכונים חלקיים של מצב, ולכן קריאות ל-Report State צריכות תמיד לכלול את כל הנתונים של מאפיין מסוים שעודכן. אם שתי תכונות יוצרות חוסר עקביות, צריך לדווח עליהן יחד.
ש: האם Google יכולה לשלוח שאילתה למכשיר שלי כדי לקבל את המצב שלו (כלומר, לבצע סקר במכשיר)?
ת: זהו מנגנון חלופי שלא מומלץ להשתמש בו. אם נצטרך לחזור לבדיקת מכשיר בתדירות גבוהה עבור המשתמשים האלה, לא נוכל להבטיח מה יהיה העומס הנוסף. הצורך הזה נובע מהפלטפורמות החדשות עם תוכן חזותי. בנוסף לבעיית הטעינה הלא ידועה, חוויית המשתמש תהיה ירודה. אנחנו חושבים שהתכונה Report State היא קריטית לפלטפורמה.
שאלה: אילו מאפיינים תומכים כרגע בסטטוס הדוח?
תשובה: יש תמיכה בכל ה-traits הציבוריים שיש להם מצבים משויכים. צריך לדווח גם על כל שינוי במצב המכשיר (מחובר או לא מחובר לאינטרנט).
שימו לב: לסצנות אין מצבים. עם זאת, הן עשויות לגרום לשינוי במצב של המכשירים. אם יש מכשיר ב-Google Home Graph שהמצב שלו השתנה, צריך לדווח על כך.
שאלה: האם צריך לשלוח חותמת זמן עם Report State?
תשובה: אנחנו לא דורשים חותמת זמן. המצב האחרון שנשלח יבטל את הקריאות הקודמות.
ש: האם צריך לשלוח את הסטטוס בנפרד באמצעות Report State אם כבר שולחים אותו באמצעות Query או Execute?
תשובה: Home Graph מאחסן רק את המצב שנשלח באמצעות Report State. המצב שמוחזר כתשובה לכוונות EXECUTE ו-QUERY משמש רק לתשובות קוליות למשתמש ולא נשמר. לכן, צריך להפעיל את Report State גם אם המצב החדש של המכשיר כבר הוחזר כתגובה ל-intent מסוג EXECUTE או QUERY.
שאלה: מהן ההשלכות של אי-הטמעה מלאה של Report State עד למועד האחרון שנקבע?
תשובה: הפעולה הזו תפגע בחוויית המשתמש, למשל בGoogle Home app (GHA) ובפלטפורמות ויזואליות. המשמעות היא שהרבה כוונות QUERY יישלחו כדי לבדוק את הסטטוס, ואין לנו אפשרות להבטיח מה יהיה העומס הנוסף על הענן של השותף.
שאלה: איך אפשר לבדוק את ההטמעה של Report State?
תשובה: אפשר להשתמש בכלי לצפייה ב-Home Graph – כלי בדיקה בשירות עצמי שמציג את הסטטוסים הנוכחיים של המכשירים שמאוחסנים ב-Home Graph.
שאלה: האם אפשר להשתמש ב-requestId אקראי בשביל Report State?
ת: אנחנו ממליצים לשותפים להשתמש באותו requestId שהם קיבלו מהבקשה EXECUTE אם Report State מופעלת על ידי הבקשה EXECUTE. אחרת, אפשר פשוט להשתמש ב-requestId אקראי.
שאלה: אם למשתמש יש כמה מכשירים ובאחד מהם חל שינוי במצב, האם צריך לדווח על המצב העדכני של כל המכשירים?
תשובה: לא. צריך לדווח רק על המצב של המכשיר הספציפי הזה.
שיטות מומלצות
ש: מהו זמן האחזור הסביר?
תשובה: זמן התגובה האידיאלי הוא פחות מ-1,000 אלפיות השנייה, וזמן תגובה של 2-5 שניות הוא סביר. אם זמן האחזור הוא בסביבות 5 שניות, צרו איתנו קשר.
שאלה: איך אפשר לגרום לרמקול עם הפעלה קולית להגיב בצורה תקינה כשהוא במצב אופליין?
תשובה: מחזירה את הסטטוס אופליין של מכשירים במצב אופליין. במקרה של השגיאה הזו, אנחנו מחזירים את הטקסט 'לא זמין כרגע' כ-TTS. מידע נוסף זמין במאמר שגיאות וחריגים.