คําขอซิงค์จะทริกเกอร์คําขอ SYNC
เพื่อให้เป็นไปตามคําขอสําหรับผู้ใช้ Google ทุกคนที่อุปกรณ์ซึ่งมี agentUserId
เชื่อมโยงอยู่ (ซึ่งคุณส่งในคําขอ SYNC เดิม) ซึ่งจะช่วยให้คุณอัปเดตอุปกรณ์ของผู้ใช้
ได้โดยไม่ต้องยกเลิกการลิงก์และลิงก์บัญชีอีกครั้ง ผู้ใช้ทั้งหมดที่ลิงก์กับตัวระบุนี้จะได้รับคําขอ SYNC
คุณต้องเรียกคําขอ SYNC
:
- หากผู้ใช้เพิ่มอุปกรณ์ใหม่
- หากผู้ใช้นําอุปกรณ์ที่มีอยู่ออก
- หากผู้ใช้เปลี่ยนชื่ออุปกรณ์ที่มีอยู่
- หากคุณใช้ประเภทอุปกรณ์ ลักษณะเฉพาะ หรือเพิ่มคุณลักษณะใหม่สําหรับอุปกรณ์ใหม่
เริ่มต้นใช้งาน
ในการใช้งานคําขอซิงค์ ให้ทําตามขั้นตอนต่อไปนี้:
เปิดใช้ Google HomeGraph API
-
ใน Google Cloud Console ให้ไปที่หน้า HomeGraph API
ไปที่หน้า HomeGraph API - เลือกโปรเจ็กต์ที่ตรงกับรหัสโปรเจ็กต์ smart home
- คลิกเปิดใช้
สร้างคีย์บัญชีบริการ
ทําตามวิธีการต่อไปนี้เพื่อสร้างคีย์บัญชีบริการจาก Google Cloud Console
-
ไปที่หน้าสร้างคีย์ของบัญชีบริการในGoogle Cloud Console
ไปที่หน้าสร้างคีย์บัญชีบริการ - เลือกบัญชีบริการใหม่จากรายการบัญชีบริการ
- ป้อนชื่อลงในช่องชื่อบัญชีบริการ
- ป้อนรหัสในช่องรหัสบัญชีบริการ
จากรายการบทบาท ให้เลือกบัญชีบริการ > ผู้สร้างโทเค็นบัญชีบริการ
สําหรับประเภทคีย์ ให้เลือกตัวเลือก JSON
- คลิกสร้าง ไฟล์ JSON ที่มีการดาวน์โหลดคีย์ลงในคอมพิวเตอร์
เรียกใช้ API
HTTP
API ของ Home Graph มีปลายทาง HTTP
- ใช้ไฟล์ JSON ของบัญชีบริการที่ดาวน์โหลดเพื่อสร้าง JSON Web Token (JWT) ดูข้อมูลเพิ่มเติมได้ใน การตรวจสอบสิทธิ์โดยใช้บัญชีบริการ
- รับโทเค็นเพื่อการเข้าถึง OAuth 2.0 ที่มีขอบเขต
https://www.googleapis.com/auth/homegraph
โดยใช้ oauth2l: - สร้างคําขอ JSON ด้วย
agentUserId
ต่อไปนี้คือตัวอย่างคําขอ JSON สําหรับ Sync Sync - รวม JSON คําขอและโทเค็นในคําขอ HTTP POST ไปยังปลายทางของ Google Home Graph ต่อไปนี้คือตัวอย่างวิธีส่งคําขอในบรรทัดคําสั่งโดยใช้
curl
เป็นการทดสอบ
oauth2l fetch --credentials service-account.json \ --scope https://www.googleapis.com/auth/homegraph
{ "agentUserId": "user-123" }
curl -X POST -H "Authorization: Bearer ACCESS_TOKEN" \ -H "Content-Type: application/json" \ -d @request-body.json \ "https://homegraph.googleapis.com/v1/devices:requestSync"
gRPC
API ของ Home Graph มีปลายทาง gRPC
- รับคําจํากัดความของบริการบัฟเฟอร์โปรโตคอลสําหรับ Home Graph API
- ทําตามเอกสารสําหรับนักพัฒนาซอฟต์แวร์ gRPC เพื่อสร้างต้นขั้วไคลเอ็นต์สําหรับภาษาที่รองรับ
- เรียกเมธอด RequestSync
Node.js
ไคลเอ็นต์ Google APIs Node.js จะมีการเชื่อมโยงสําหรับ Home Graph API
- เริ่มต้นบริการ
google.homegraph
โดยใช้ข้อมูลเข้าสู่ระบบเริ่มต้นของแอปพลิเคชัน - เรียกเมธอด
requestSync
ด้วย RequestSyncDevicesRequest ซึ่งจะแสดงผลPromise
ที่มี RequestSyncDevicesResponse ที่ว่างเปล่า
const homegraphClient = homegraph({ version: 'v1', auth: new GoogleAuth({ scopes: 'https://www.googleapis.com/auth/homegraph' }) }); const res = await homegraphClient.devices.requestSync({ requestBody: { agentUserId: 'PLACEHOLDER-USER-ID', async: false } });
Java
ไลบรารีของไคลเอ็นต์ HomeGraph API สําหรับ Java มีการเชื่อมโยงสําหรับ Home Graph API
- เริ่มต้น
HomeGraphApiService
ด้วยข้อมูลเข้าสู่ระบบเริ่มต้นของแอปพลิเคชัน - เรียกเมธอด
requestSync
ด้วยRequestSyncDevicesRequest
ซึ่งจะแสดงผลReportStateAndNotificationResponse
ที่ว่างเปล่า
// Get Application Default credentials. GoogleCredentials credentials = GoogleCredentials.getApplicationDefault() .createScoped(List.of("https://www.googleapis.com/auth/homegraph")); // Create Home Graph service client. HomeGraphService homegraphService = new HomeGraphService.Builder( GoogleNetHttpTransport.newTrustedTransport(), GsonFactory.getDefaultInstance(), new HttpCredentialsAdapter(credentials)) .setApplicationName("HomeGraphExample/1.0") .build(); // Request sync. RequestSyncDevicesRequest request = new RequestSyncDevicesRequest().setAgentUserId("PLACEHOLDER-USER-ID").setAsync(false); homegraphService.devices().requestSync(request);
การตอบกลับข้อผิดพลาด
คุณอาจได้รับข้อความแจ้งข้อผิดพลาดอย่างใดอย่างหนึ่งต่อไปนี้เมื่อเรียกใช้คําขอซิงค์ การตอบกลับเหล่านี้จะอยู่ในรูปแบบรหัสสถานะ HTTP
400 Bad Request
- เซิร์ฟเวอร์ไม่สามารถประมวลผลคําขอที่ไคลเอ็นต์ส่งไปได้ เนื่องจากไวยากรณ์ไม่ถูกต้อง สาเหตุที่พบบ่อย ได้แก่ JSON มีรูปแบบไม่ถูกต้องหรือใช้null
แทน "" สําหรับค่าสตริง403 Forbidden
- เซิร์ฟเวอร์ไม่สามารถประมวลผลคําขอสําหรับagentUserId
ที่ระบุ เนื่องจากเกิดข้อผิดพลาดขณะรีเฟรชโทเค็น ตรวจสอบว่าปลายทาง OAuth ตอบสนองอย่างถูกต้องเพื่อรีเฟรชคําขอโทเค็นและตรวจสอบสถานะการลิงก์บัญชี404 Not Found
- ไม่พบทรัพยากรที่ขอ แต่อาจพร้อมใช้งานได้ในอนาคต โดยปกติแล้วจะหมายความว่าบัญชีผู้ใช้ไม่ได้ลิงก์กับ Google หรือเราได้รับagentUserId
ที่ไม่ถูกต้อง ตรวจสอบว่าagentUserId
ตรงกับค่าที่ระบุไว้ในการตอบกลับ SYNC และคุณจัดการ Intent ของ DISCONNECT อย่างถูกต้อง429 Too Many Requests
- จํานวนคําขอการซิงค์พร้อมกันสูงสุด สําหรับagentUserId
ที่ระบุแล้ว ผู้โทรอาจออกคําขอการซิงค์พร้อมกัน 1 รายการเท่านั้น เว้นแต่จะกําหนดการตั้งค่าสถานะasync
เป็น "จริง"