Mengakses perangkat dan metadata perangkat untuk iOS

API Perangkat dapat diakses melalui Home API untuk iOS. Impor paket berikut ke aplikasi Anda:

import GoogleHomeSDK
import GoogleHomeTypes

Untuk informasi selengkapnya, lihat Model data di iOS.

Penanganan error

Beberapa metode di Home API menampilkan HomeError, jadi sebaiknya gunakan blok do-catch untuk menangkap HomeError pada panggilan tersebut.

Saat menangani HomeError, periksa kolom code dan message untuk mempelajari masalah yang terjadi.

Error yang tidak ditangani akan menyebabkan aplikasi Anda error.

Untuk mengetahui informasi selengkapnya, lihat Penanganan error.

Lihat Mengirim perintah ke perangkat untuk mengetahui contohnya.

Contoh panggilan

Mendapatkan daftar perangkat

Dengan referensi ke objek Home, panggil devices() untuk mendapatkan Query perangkat yang dapat diakses. Panggil metode batched() Query, yang memunculkan Set yang mencerminkan status Home saat ini dengan setiap perubahan metadata perangkat. Atau panggil Query.list() untuk mendapatkan ringkasan perangkat yang tersedia. Ini adalah metode praktis yang berlangganan streaming batched() dan menampilkan nilai pertama yang dikeluarkan. Query.stream() menghasilkan aliran yang memunculkan nilai baru pada perubahan metadata perangkat seperti nama, ruangan, atau strukturnya. Secara internal, ini menggunakan batched() dan hanya memunculkan properti yang diubah.

// Get a list of all devices accessible to the user
let homeDevices = try await self.home.devices().list()

Dari sana, status untuk setiap perangkat dapat diakses, dan perintah yang didukung dapat dikirim ke perangkat.

Mendapatkan jenis perangkat

Untuk mendapatkan jenis perangkat yang terkait dengan perangkat, baca properti types perangkat, yang menampilkan DeviceTypeController.

Panggil DeviceTypeController.subscribe(_:) untuk berlangganan update untuk jenis perangkat tertentu:

let devices = try await self.home.devices().list()
if let device = devices.first(where: { $0.id == myDeviceId }) {
  var receivedUpdate1 = false
  var receivedUpdate2 = false
  device.types.subscribe(OnOffLightDeviceType.self)
    .assertNoFailure()
    .sink { device in
      if !receivedUpdate1 {
        receivedUpdate1 = true
        Task {
          try await device.matterTraits.onOffTrait?.on()
        }
        return
      }
      if !receivedUpdate2 {
        receivedUpdate2 = true
        return
      }
      fatalError("Received unexpected update")
    }
}

Jika tidak mendukung jenis perangkat yang ditentukan, perangkat akan menampilkan Empty Publisher yang langsung selesai.

Jika perangkat mendukung jenis perangkat tertentu, Anda bisa mendapatkan handle untuk jenis tersebut dengan memanggil get():

if let device = devices.first(where: { $0.id == myDeviceId }) {
  let deviceType = await device.types.get(OnOffLightDeviceType.self)
}

Jika perangkat tidak mendukung jenis yang ditentukan, perangkat akan menampilkan nil.

Panggil DeviceTypeController.subscribeAll() untuk mendapatkan Publisher dari DeviceTypeCollection. Class ini memungkinkan Anda memeriksa apakah perangkat memiliki jenis perangkat tertentu:

if let device = devices.first(where: { $0.id == myDeviceId }) {
  device.types.subscribeAll()
    .assertNoFailure()
    .sink { types in
      let lightDeviceType = types[OnOffLightDeviceType.self]
      let fanDeviceType = types[FanDeviceType.self]
    }
}

Mendapatkan karakteristik jenis perangkat

Jenis perangkat adalah titik entri untuk membaca karakteristik, karena jenis perangkat menguraikan perangkat menjadi bagian fungsional (seperti endpoint di Matter).

Fitur ini juga memperhitungkan konflik fitur jika perangkat menampilkan dua jenis perangkat, yang keduanya mungkin memiliki fitur yang sama. Misalnya, jika perangkat adalah Speaker dan Lampu yang Dapat Diatur Kecerahannya, perangkat tersebut akan memiliki dua karakteristik Aktif/Nonaktif dan dua karakteristik Kontrol Level.

Jenis konflik sifat lain dapat terjadi saat perangkat memiliki dua sifat dengan nama yang sama. Misalnya, onOff dapat merujuk ke instance sifat OnOff standar, atau dapat merujuk ke instance sifat OnOff yang ditentukan produsen. Untuk menghilangkan potensi ambiguitas tentang fitur yang dimaksud, referensikan fitur melalui salah satu dari dua kumpulan fitur di setiap jenis perangkat.

Untuk atribut standar, yaitu atribut yang analog dengan cluster standar Matter, gunakan matterTraits. Misalnya, untuk mendapatkan karakteristik tertentu untuk jenis perangkat Lampu yang Dapat Disesuaikan Kecerahannya:

if let dimmableLightDeviceType =
  await device.types.get(DimmableLightDeviceType.self)
{
  // Accessing standard trait on the type.
  let levelControlTrait =
    dimmableLightDeviceType.matterTraits.levelControlTrait.self
}

Untuk atribut Google, gunakan googleTraits:

if let doorbellDeviceType = await device.types.get(GoogleDoorbellDeviceType.self) {
  // Accessing Google trait on the type.
  let doorbellPressTrait =
    doorbellDeviceType.googleTraits.doorbellPressTrait.self
}

Untuk mengakses karakteristik khusus produsen, referensikan melalui properti traits, tetapi awali dengan nama paket produsen:

let deviceType = await device1?.types.get(OnOffLightDeviceType.self)
// Accessing custom trait on the type.
if let spinnerTrait = deviceType?.traits[ExampleOrganization.SpinnerTrait.self] {
  let rpmVal = spinnerTrait.attributes.rpm
}

Membaca status perangkat

Lihat contoh pemeriksaan atribut OnOff dari sifat Aktif/Nonaktif perangkat ini:

let lightDevices = devices.filter {
  $0.types.contains(OnOffLightDeviceType.self)
}
let light1 = lightDevices.first
let lightDeviceTypeOptional = await light1?.types.get(OnOffLightDeviceType.self)
if let onOffTrait = lightDeviceTypeOptional?.matterTraits.onOffTrait {
  let onOffVal = onOffTrait.attributes.onOff
}

Mendapatkan daftar perangkat dengan karakteristik tertentu

Untuk mendapatkan daftar perangkat yang memiliki karakteristik tertentu, Anda perlu melakukan iterasi pada perangkat, jenis perangkat setiap perangkat, dan karakteristik setiap jenis perangkat. Misalnya, untuk mendapatkan daftar perangkat di rumah yang semuanya memiliki karakteristik Aktif/Nonaktif:

// Get all light devices that support levelControl
var levelControlDevices: [HomeDevice] = []
var allDevices = try await home.devices().list()
for device in allDevices {
  if let deviceType = await device.types.get(OnOffLightDeviceType.self) {
    if deviceType.traits.contains(Matter.LevelControlTrait.self) {
      levelControlDevices.append(device)
    }
  }
}

Lihat Indeks sifat di iOS untuk mengetahui daftar lengkap sifat yang tersedia di Home API.

Mendapatkan daftar perangkat dengan jenis perangkat yang serupa

Untuk mendapatkan daftar perangkat yang mewakili semua lampu di rumah:

// Get a list of devices with similar device types (lights)
let lightDevices =
  try await self.home.devices().list().compactMap {
    $0.types.contains(DimmableLightDeviceType.self)
      || $0.types.contains(OnOffLightDeviceType.self)
      || $0.types.contains(ColorTemperatureLightDeviceType.self)
      || $0.types.contains(ExtendedColorLightDeviceType.self)
  }

Ada beberapa jenis perangkat di Home API yang dapat mewakili jenis perangkat inti. Misalnya, tidak ada jenis perangkat "Lampu". Sebagai gantinya, ada empat jenis perangkat berbeda yang dapat mewakili lampu, seperti yang ditunjukkan dalam contoh sebelumnya. Dengan demikian, untuk mendapatkan gambaran yang komprehensif tentang jenis perangkat tingkat lebih tinggi di rumah, beberapa jenis perangkat harus disertakan.

Lihat Jenis perangkat yang didukung di iOS untuk mengetahui daftar lengkap jenis perangkat dan karakteristiknya yang tersedia di Home API.

Mendapatkan Nama Vendor, ID Vendor, atau ID Produk untuk perangkat

Atribut BasicInformationTrait mencakup informasi seperti ID Vendor, ID Produk, Nama Produk, dan Nomor Seri untuk perangkat:

guard
  let vendorName =
    basicInfoTrait.attributes.vendorName
else {
  fatalError("Failed to get vendorName")
}
guard
  let vendorID =
    basicInfoTrait.attributes.vendorID
else {
  fatalError("Failed to get vendorID")
}
guard
  let productID =
    basicInfoTrait.attributes.productID
else {
  fatalError("Failed to get productID")
}

Identifikasi perangkat cloud ke cloud untuk produsen perangkat

Jika Anda adalah pembuat perangkat dan mem-build perangkat Cloud-to-cloud, untuk mengidentifikasi perangkat Cloud-to-cloud melalui sifat BasicInformation, Anda dapat menyertakan kolom string ini dalam respons SYNC:

  • Connectivity Standards Alliance (CSA) menerbitkan ID vendor: "matterOriginalVendorId": "0xfff1",

  • ID Produk yang mengidentifikasi produk vendor secara unik: "matterOriginalProductId": "0x1234",

  • ID unik untuk perangkat, yang dibuat dengan cara khusus produsen: "matterUniqueId": "matter-device-id",

Saat memasukkan kolom string ini, gunakan ID Vendor dan Produk Matter jika Anda memilikinya. Jika Anda bukan anggota CSA dan belum ditetapkan ID ini, Anda dapat mengosongkan kolom matterOriginalVendorId dan matterOriginalProductId serta memberikan matterUniqueId sebagai ID.

Contoh respons SYNC menunjukkan penggunaan kolom ini:

{
  "requestId": "ff36a3cc-ec34-11e6-b1a0-64510650abcf",
  "payload": {
    "agentUserId": "1836.15267389",
    "devices": [
      {
        "id": "456",
        "type": "action.devices.types.LIGHT",
        "traits": [
          "action.devices.traits.OnOff",
          "action.devices.traits.Brightness",
          "action.devices.traits.ColorSetting",
        ],
        "willReportState": true,
        "deviceInfo": { ... },
        "matterOriginalVendorId": "0xfff1",
        "matterOriginalProductId": "0x1234",
        "matterUniqueId": "matter-device-id",
        "otherDeviceIds": [
          {
            "deviceId": "local-device-id",
          }
        ]
      }
    ]
  }
}

Untuk informasi selengkapnya, lihat dokumentasi Cloud-to-cloud SYNC.

Metadata perangkat dan fitur

Perangkat dan fitur di Home API memiliki metadata yang terkait dengannya, yang dapat membantu mengelola pengalaman pengguna di aplikasi.

Setiap karakteristik di Home API berisi properti sourceConnectivity, yang memiliki informasi tentang status online dan lokalitas karakteristik (rute lokal atau jarak jauh).

Mendapatkan jenis utama perangkat

Beberapa perangkat mungkin menampilkan beberapa jenis perangkat melalui Home API. Untuk memastikan pengguna mendapatkan opsi yang sesuai di aplikasi (seperti kontrol perangkat dan otomatisasi yang disarankan) untuk perangkat mereka, sebaiknya periksa apakah jenis perangkat adalah jenis utama perangkat.

if let deviceType =
  await device?.types.get(HumiditySensorDeviceType.self)
{
  if deviceType.metadata.isPrimaryType {
    print("Humidity Sensor is the primary type on this device.")
  } else {
    print("Humidity Sensor isn't the primary type on this device.")
  }
}

Memeriksa apakah suatu karakteristik sedang online

Baca properti connectivityState untuk memeriksa konektivitas fitur:

let levelControlConnectivity =
  levelControlTrait.metadata.sourceConnectivity
  .connectivityState

Beberapa karakteristik, biasanya karakteristik smart home Google, mungkin ditampilkan offline jika perangkat tidak memiliki konektivitas internet. Hal ini karena sifat ini berbasis cloud dan tidak memiliki pemilihan rute lokal.

Memeriksa konektivitas untuk perangkat

Konektivitas untuk perangkat sebenarnya diperiksa di tingkat jenis perangkat karena beberapa perangkat mendukung beberapa jenis perangkat. Status yang ditampilkan adalah kombinasi status konektivitas untuk semua fitur di perangkat tersebut.

let lightConnectivity =
  dimmableLightDeviceType.metadata.sourceConnectivity
  .connectivityState

Status partiallyOnline dapat diamati jika jenis perangkat beragam saat tidak ada konektivitas internet. Atribut standar Matter mungkin masih online karena pemilihan rute lokal, tetapi atribut berbasis cloud akan offline.

Memeriksa pemilihan rute jaringan untuk suatu karakteristik

Lokalitas untuk suatu karakteristik juga tersedia di Home API. dataSourceLocality menunjukkan apakah sifat dirutekan dari jarak jauh (melalui cloud), secara lokal (melalui hub lokal), atau peer-to-peer (langsung dari perangkat ke perangkat, tanpa hub).

Nilai lokalitas unspecified yang tidak diketahui dapat terjadi, misalnya, saat aplikasi melakukan booting dan belum mencapai hub atau server untuk konektivitas perangkat. Perangkat ini tidak dapat dijangkau dan akan gagal menerima permintaan interaksi dari perintah atau peristiwa. Klien dapat menentukan cara menangani perangkat tersebut.

let levelControlLocality =
  levelControlTrait.metadata.sourceConnectivity
  .dataSourceLocality

Memeriksa pemilihan rute jaringan untuk perangkat

Seperti konektivitas, lokalitas diperiksa di tingkat jenis perangkat. Status yang ditampilkan adalah kombinasi lokalitas untuk semua fitur di perangkat tersebut.

let lightLocality =
  dimmableLightDeviceType.metadata.sourceConnectivity.dataSourceLocality

Status mixed dapat diamati dalam skenario yang serupa dengan konektivitas partiallyOnline: beberapa karakteristik berbasis cloud sedangkan yang lainnya bersifat lokal.

Mengubah nama perangkat

Panggil metode setName(_:) untuk mengubah nama perangkat:

let updatedDevice = try await theDevice.setName("new device name")

Saat mengubah nama perangkat, struct HomeDevice asli tetap sama dan perubahannya tercermin dalam objek HomeDevice yang diperbarui dan ditampilkan.

Daftar API

Setelah instance Home dibuat, Device API berikut dapat diakses melalui instance tersebut:

API Deskripsi
device(id:) Menampilkan Publisher untuk perangkat yang ditentukan yang memunculkan status perangkat setiap kali berubah.
devices() Mendapatkan semua perangkat di semua struktur di Akun Google. Menampilkan Query<HomeDevice> yang menyediakan opsi pengambilan dan pemfilteran lebih lanjut.

Setelah Anda memiliki HomeDevice, API berikut dapat diakses melalui API tersebut:

API Deskripsi
id ID sistem unik perangkat.
name Nama perangkat yang diberikan pengguna.
structureID ID struktur tempat perangkat ditetapkan. Menampilkan String?.
roomID ID kamar tempat perangkat ditetapkan. Menampilkan String?.
types Mendapatkan jenis tertentu atau semua jenis yang tersedia di perangkat.
isMatterDevice Jika perangkat didukung oleh Matter.
sourceConnectivity Konektivitas sumber perangkat, yang mewakili status konektivitas gabungan dan lokalitas jaringan dari karakteristik perangkat.