Ý định

Ý định nhà thông minh là các đối tượng nhắn tin đơn giản mô tả việc tích hợp Cloud-to-cloud cần thực hiện, chẳng hạn như bật đèn hoặc truyền âm thanh đến loa.

Tất cả ý định smart home đều nằm trong không gian tên action.devices và bạn phải thực hiện các ý định đó. Bất cứ khi nào Google Assistant gửi một ý định để thực hiện, mã truy cập OAuth 2 của bên thứ ba của người dùng sẽ được chuyển trong tiêu đề Uỷ quyền.

Sau đây là các ý định smart home được hỗ trợ:

ĐỒNG BỘ HÓA

Ý định action.devices.SYNC được dùng để yêu cầu danh sách thiết bị smart home mà người dùng đã kết nối và có thể sử dụng.

Khi người dùng thiết lập thiết bị bằng Google Home app (GHA), họ cũng được xác thực với cơ sở hạ tầng đám mây của bạn. Sau đó, Assistant sẽ nhận được mã thông báo OAuth2. Tại thời điểm này, Assistant sẽ gửi một ý định action.devices.SYNC đến phương thức thực hiện để truy xuất danh sách ban đầu gồm các thiết bị và chức năng của người dùng từ cơ sở hạ tầng đám mây của bạn.

Hình này cho thấy hoạt động tương tác giữa cơ sở hạ tầng của Google và cơ sở hạ tầng của đối tác. Từ cơ sở hạ tầng của Google, có một danh sách đối tác dành cho ứng dụng khách Trợ lý. Sau đó, danh sách này sẽ chuyển đến cơ sở hạ tầng của đối tác để hoàn tất quy trình xác thực OAuth. Phương thức xác thực OAuth ở phía đối tác là webview thiết lập đối tác, webview OAuth, các điều khoản và chế độ cài đặt không bắt buộc cũng như dịch vụ đám mây của đối tác. Sau đó, cơ sở hạ tầng của đối tác sẽ trả về thông tin xác thực OAuth cho ứng dụng Trợ lý. Các dịch vụ đám mây của đối tác sẽ gửi các thiết bị và chức năng có sẵn đến các dịch vụ Trợ lý, sau đó lưu trữ thông tin trong Biểu đồ nhà.
Hình 1: Hoạt động tương tác giữa cơ sở hạ tầng của Google và đối tác

Để tránh huỷ liên kết và liên kết lại tài khoản của người dùng, bạn có thể gửi yêu cầu đồng bộ hoá đến Assistant. Thao tác này sẽ gửi ý định action.devices.SYNC đến phương thức thực hiện để đồng bộ hoá danh sách thiết bị và chức năng. Hãy xem phần Triển khai tính năng đồng bộ hoá yêu cầu để biết thêm thông tin.

Sơ đồ quy trình của ý định SYNC
Hình 2: Ý định SYNC

Trong quá trình thiết lập tính năng thực hiện cục bộ, nền tảng Trang chủ cục bộ sẽ kiểm tra phản hồi SYNC từ phương thức thực hiện trên đám mây của Hành động smart home. Để tìm hiểu thêm về cách sửa đổi phản hồi SYNC nhằm hỗ trợ phương thức thực hiện tại địa phương, hãy xem phần Cập nhật phản hồi SYNC trong phương thức thực hiện trên đám mây.

QUERY Hỏi

Ý định action.devices.QUERY được dùng để truy vấn trạng thái hiện tại của các thiết bị smart home.

Khi người dùng truy vấn trạng thái thiết bị, để trả lời câu hỏi như Này Google, đèn nào đang bật trong nhà bếp?, Assistant gửi ý định action.devices.QUERY đến phương thức thực hiện đơn hàng.

Sơ đồ quy trình của ý định TRUY VẤN
Hình 3: Ý định TRUY VẤN

Để mang lại trải nghiệm tốt nhất cho người dùng, bạn nên triển khai Trạng thái báo cáo để chủ động báo cáo trạng thái hiện tại của thiết bị của người dùng trực tiếp đến Google Home Graph. Ví dụ: điều này cho phép Assistant biết liệu người dùng có bật đèn thông minh bằng công tắc đèn thực hay không.

Báo cáo trạng thái thiết bị bằng cách sử dụng Báo cáo trạng thái
Hình 4: Báo cáo trạng thái thiết bị

THỰC THI

Ý định action.devices.EXECUTE được dùng để cung cấp các lệnh thực thi trên thiết bị smart home.

Khi người dùng gửi lệnh đến các thiết bị bằng Assistant, phương thức thực hiện của bạn sẽ nhận được ý định action.devices.EXECUTE cho phương thức thực hiện mô tả hành động và thiết bị cần thực hiện hành động. Người dùng có thể thực thi một thao tác trên thiết bị bằng một lệnh như Ok Google, bật đèn phòng khách.

Sơ đồ quy trình của ý định EXECUTE
Hình 5: Ý định EXECUTE

NGẮT KẾT NỐI

Ý định action.devices.DISCONNECT được kích hoạt để thông báo cho bạn khi người dùng huỷ liên kết tài khoản ứng dụng khỏi Assistant. Sau khi nhận được ý định action.devices.DISCONNECT, bạn không nên báo cáo trạng thái cho thiết bị của người dùng này.