סקירה כללית על Home APIs ל-Android

ממשקי ה-API של Google Home ל-Android מספקים משטח API מאוחד שמאפשר למפתחים לבצע אינטראקציה עם מצב הישויות בבית של המשתמש. הישויות האלה יכולות לתאר מכשירים ומידע שאינו קשור למכשירים שמשויכים למבנה ולחדרים של המשתמש.

ממשקי ה-API של Home מגדירים את הישויות הבאות שהמשתמש יכול ליצור איתן אינטראקציה:

  • מבנים מייצגים בית שמכיל חדרים ומכשירים.
  • חדרים הם חלק ממבנה ומכילים מכשירים.
  • מכשירים מטמיעים מאפיינים שמכילים תכונות, תואמים לסוגים, פולטים אירועים ומגיבים לפקודות.
  • פעולות אוטומטיות הן חלק ממבנה, והן משתמשות במטא-נתונים של הבית ובמכשירים כדי לבצע משימות בבית באופן אוטומטי.

איור 1 מציג את הארכיטקטורה הזו:

תרשים שמתאר את ארכיטקטורת Home APIs באפליקציית Android
איור 1: ארכיטקטורה של ממשקי ה-API של Home באפליקציית Android

יכול להיות שסוגי מכשירים ב-Home API מגובים על ידי Matter, תקן פתוח לבית חכם, או שהם מכשיר Cloud-to-cloud במערכת האקולוגית של Google Home. יכול להיות שבחלק מסוגי המכשירים ישולבו פונקציות משני הסוגים. מידע נוסף מופיע במאמר סוגי מכשירים נתמכים ב-Android.

ב-Matter, הפונקציונליות של המכשיר מקובצת לפי אשכולות, שמיוצגים בממשקי ה-API של Home כמאפיינים סטנדרטיים של Matter. ממשקי ה-API של Home תומכים בקבוצה הסטנדרטית של אשכולות Matter כפי שמוגדר במפרט Matter הנוכחי.

במערכת האקולוגית של Google Home, הפונקציונליות של המכשירים מקובצת לפי מאפיינים של בית חכם, שמיוצגים בממשקי ה-API של Home כמאפיינים של בית חכם של Google. ממשקי ה-API של Home תומכים במערך המאפיינים של הבית החכם כפי שמוגדר בתוכנית Cloud-to-cloud.

מאפיינים אחרים, כמו אשכולות ספציפיים ליצרן ומאפייני פלטפורמה, זמינים גם כן. מידע נוסף על מודל הנתונים ב-Android

המערכת האקולוגית

מערכת Google Home מספקת בסיס יעיל לבנייה, לניהול, לאבטחה ולשילוב של חוויות בית חכם. באיור 2 מוצג אופן הפעולה של כל הרכיבים יחד.

תרשים שמציג את המערכת האקולוגית של ממשקי ה-API של Home באפליקציית Android
איור 2: מערכת האקולוגית של ממשקי ה-API של Home באפליקציית Android

הסביבה כוללת את Google Automation Engine שמאחסן ומריץ פעולות אוטומטיות. הפעולות האלה מאפשרות לבצע אוטומציה של משימות והגדרות מכשירים בבית.

ממשקי ה-API של Home משתמשים ב-OAuth 2.0 כדי להעניק גישה למכשירים במבנה. פרוטוקול OAuth מאפשר למשתמש להעניק הרשאה לאפליקציה או לשירות בלי לחשוף את פרטי הכניסה שלו.

ה-Google Home Developer Console משמש לניהול כל השלבים של פרויקט Home APIs, החל מאימות המותג, דרך פיתוח, בדיקה ואישור, ועד להשקה הסופית. היא מייעלת את תהליך הפיתוח ומספקת כלים חזקים והפצה דרך הסביבה העסקית של Google Home.

שפה

ממשקי ה-API של Home ל-Android כתובים ב-Kotlin ומספקים ממשק Kotlin אידיומטי שמשתמש ב-Flow כדי לנהל את המצב והמינוי. הגישה הזו מספקת מספר יתרונות בהשוואה ל-API רגיל למינויים.

אם אתם לא מכירים את הנושאים האלה, מומלץ לעיין במסמכי התיעוד של Kotlin בנושאים הבאים: קורוטינות, Flow ו-Jetpack Compose:

מזהים של ישויות

לכל ישות בממשקי ה-API של Home יש מזהה שמייצג את המזהה הראשי שלה. המזהה הזה הוא ייחודי וקבוע, והוא לא ישתנה אף פעם במהלך חיי הישות. אפשר להשתמש במזהה הזה כדי לשמור אובייקטים במטמון או כדי לבדוק אם יש שוויון, כי המטא-נתונים של ישות יכולים להשתנות.

בממשק של HasId מוסבר לאילו ישויות יש מזהה.

מיפוי מונחים

המיפוי של ישויות בממשקי ה-API של Home למושגים Matter ו-Cloud-to-cloud הוא כדלקמן:

Home APIs Matter Cloud-to-cloud
מאפיין אשכול מאפיין
מאפיין מאפיין מאפיין, מצב
פקודה פקודה פקודה
אירוע אירוע Follow up response, Notification