Berlangganan Acara

Peristiwa bersifat asinkron dan dikelola oleh Google Cloud Pub/Sub, dalam satu topik per Project. Peristiwa memberikan pembaruan untuk semua perangkat, struktur, dan penerimaan peristiwa dijamin selama token akses tidak dicabut oleh pengguna dan pesan peristiwa belum habis masa berlakunya.

Peristiwa adalah fitur opsional SDM API. Eksperimen dapat dengan mudah diimplementasikan dan diverifikasi menggunakan project Google Cloud Anda.

Aktifkan acara

Acara dapat diaktifkan di Device Access Konsol. Pilih Project Anda di Konsol, jika Anda belum melakukannya.

Buka Device Access Konsol

Jika Anda sudah mengaktifkan peristiwa (misalnya, selama pembuatan project), kolom Pub/Sub topic di bagian Info Project seharusnya sudah memiliki nilai, yang disebut ID Topik, dalam format:

projects/sdm-prod/topics/enterprise-project-id

Jika Anda belum mengaktifkan acara:

  1. Klik ikon untuk Pub/Sub topic, lalu pilih Edit.
  2. Centang Aktifkan acara, lalu klik Simpan.
  3. ID Topik dibuat untuk Anda dalam format yang ditampilkan di atas.

Salin ID Topik, Anda akan memerlukannya untuk membuat langganan ke topik agar pesan peristiwa dapat diambil.

Membuat langganan pull

Langganan pull adalah tempat pelanggan memulai permintaan ke server Pub/Sub untuk pesan peristiwa dalam antrean. Ini adalah cara cepat dan mudah untuk memastikan bahwa peristiwa dibuat untuk perangkat yang diotorisasi.

Buka Cloud Shell untuk project Google Cloud Anda:

Buka Google Cloud Shell

Pada prompt Cloud Shell, jalankan perintah berikut untuk membuat langganan pull ke topik Anda, menggunakan subscription-id apa pun yang Anda inginkan dan ID Topik unik Anda:

gcloud pubsub subscriptions create subscription-id --topic=projects/sdm-prod/topics/enterprise-project-id
Created subscription [projects/gcp-project-name/subscriptions/subscription-id].

Memulai peristiwa

Untuk memulai peristiwa untuk pertama kalinya setelah langganan Pub/Sub dibuat, lakukan panggilan untuk mencantumkan perangkat Anda sebagai pemicu satu kali:

curl -X GET 'https://smartdevicemanagement.googleapis.com/v1/enterprises/project-id/devices' \
    -H 'Content-Type: application/json' \
    -H 'Authorization: Bearer access-token'

Peristiwa untuk semua struktur dan perangkat akan dipublikasikan setelah panggilan API ini.

Membuat peristiwa

Peristiwa dibuat untuk semua perubahan kolom fitur, beberapa di antaranya otomatis, beberapa manual.

Misalnya, jika suhu ruangan di dekat Nest Thermostat berubah, peristiwa untuk karakteristik Temperature akan otomatis dikirim dengan nilai ambientTemperatureCelsius baru.

Untuk membuatnya secara manual:

  1. Mengubah status perangkat secara fisik, seperti mengubah mode Nest Thermostat.
  2. Memicu peristiwa, seperti gerakan, orang, atau suara di Google Nest Cam Indoor.
  3. Jalankan perintah perangkat menggunakan SDM API.

Melihat pesan

Pesan peristiwa dapat dilihat di project Google Cloud Anda di bagian Langganan Pub/Sub:

Buka Langganan Google Cloud Pub/Sub

  1. Klik ID Langganan yang Anda buat sebelumnya.
  2. Di layar Detail langganan, Anda akan melihat aktivitas untuk diagram Jumlah pesan yang tidak ditandai. Hal ini menunjukkan pesan peristiwa telah masuk untuk langganan Anda. Jika Anda tidak melihat aktivitas apa pun, tunggu sebentar atau buat beberapa peristiwa lainnya.
  3. Klik LIHAT PESAN untuk menampilkan panel Pesan.
  4. Klik TARIK untuk melihat pesan. Peristiwa tersebut harus sesuai dengan tindakan yang Anda gunakan untuk menghasilkan peristiwa.

Pesan juga dapat dilihat di Cloud Shell dengan perintah pull dasar:

gcloud pubsub subscriptions pull subscription-id

Untuk informasi selengkapnya tentang jenis langganan, serta jenis peristiwa yang dikirim oleh SDM API dan cara menggunakannya, lihat Peristiwa.

Kelola pesan

Pesan harus dikonfirmasi dan dihapus permanen secara berkala, untuk menjaga langganan tetap bersih dan menghindari pengiriman pesan duplikat ke pelanggan lain. Semua pesan langganan dapat dihapus permanen secara manual di bagian Langganan Pub/Sub:

Buka Langganan Google Cloud Pub/Sub

  1. Klik ID Langganan.
  2. Ada beberapa cara untuk mengonfirmasi dan menghapus permanen:
    1. Klik LIHAT PESAN untuk menampilkan panel Pesan. Centang kotak Enable ack messages, lalu klik PULL untuk melihat dan mengonfirmasi semua pesan.
    2. Klik HAPUS PESAN untuk menghapus permanen semua pesan yang ada dengan mengonfirmasi tanpa melihatnya. Klik HAPUS untuk mengonfirmasi.

Pesan juga dapat dihapus permanen di Cloud Shell menggunakan flag --auto-ack dengan perintah pull dasar:

gcloud pubsub subscriptions pull subscription-id --auto-ack

Kelola langganan

Langganan dapat dikonfigurasi dalam berbagai cara, seperti yang dijelaskan dalam Menggunakan properti langganan.

Meskipun cara Anda ingin mengelola langganan dan pesan terserah Anda, untuk aplikasi produksi, sebaiknya gunakan Akun layanan untuk autentikasi, bukan akun pengguna seperti yang Anda miliki sejauh ini dalam panduan memulai cepat ini. Akun layanan digunakan oleh aplikasi atau virtual machine, bukan orang, dan memiliki kunci akun uniknya sendiri.

Untuk informasi selengkapnya tentang autentikasi akun layanan dengan Device Access, lihat Peristiwa.