Berikut ringkasan konsep dasar DSL Otomatisasi di Android.
Komponen otomatisasi
Otomatisasi terdiri dari komponen dasar berikut, yang biasanya dievaluasi dalam urutan ini:
- Pemicu — Menentukan kondisi awal yang mengaktifkan otomatisasi, seperti perubahan pada sifat. Otomatisasi harus memiliki pemicu.
- Kondisi — Batasan tambahan apa pun yang akan dievaluasi setelah otomatisasi diaktifkan. Ekspresi dalam Kondisi harus dievaluasi ke
true
agar tindakan otomatisasi dapat dilanjutkan. - Tindakan — Perintah atau pembaruan status yang dilakukan saat semua kondisi telah terpenuhi.
Misalnya, Anda memiliki otomatisasi yang meredupkan lampu di ruangan saat TV di ruangan tersebut dinyalakan antara matahari terbenam dan terbit. Dalam contoh ini:
- Starter — TV dinyalakan, yang merupakan perubahan status pada trait TV.
- Kondisi— Waktu saat ini untuk rumah tempat TV berada akan dievaluasi.
- Tindakan — Lampu di ruangan yang sama dengan TV akan diredupkan.
Otomatisasi akan diaktifkan saat TV di ruangan dinyalakan, tetapi otomatisasi hanya dijalankan jika kondisi "waktu antara matahari terbenam dan matahari terbit" terpenuhi.
Selain struktur dasar, otomatisasi di Home API juga berisi metadata, seperti name dan description, yang dapat digunakan untuk mengidentifikasi otomatisasi bagi developer dan pengguna.
Node
Di Home API, struktur logis otomatisasi terdiri dari node. Node adalah unit abstrak yang dapat digunakan kembali yang merepresentasikan perilaku entitas atau alur eksekusi. Setiap node dapat memiliki variabel input, serta variabel output yang dapat digunakan oleh node lain.
Node | Jenis Nodus | Penerapan Kotlin | Deskripsi |
---|---|---|---|
Starter | Perilaku |
StarterNodeDsl
|
Memulai otomatisasi saat status karakteristik (atribut apa pun) berubah. |
StateReader | Perilaku |
StateReaderNodeDsl
|
Membaca atribut karakteristik dan memungkinkan Anda mengambil nilainya untuk digunakan dalam node kondisi. |
Tindakan | Perilaku |
ActionNodeDsl
|
Memanggil perintah trait. |
Berurutan (Sequential) | Alur eksekusi |
SequentialFlow
|
Mengeksekusi node tindakan bertingkat secara berurutan. Ini adalah perilaku eksekusi default. |
Paralel | Alur eksekusi |
ParallelFlow
|
Menjalankan node tindakan bertingkat secara paralel. |
Kondisi | Alur eksekusi |
ConditionNodeDsl
|
Mengubah alur eksekusi secara kondisional berdasarkan evaluasi ekspresi logis. Kondisi dapat dikaitkan dengan pemicu (kondisi khusus pemicu) atau bersifat global (berlaku untuk semua pemicu). |
Pilih | Alur eksekusi |
SelectFlow
|
Mengizinkan lebih dari satu pemicu untuk mengaktifkan otomatisasi. |
Ekspresi | Nilai |
Expression
|
Dapat berupa nilai atribut karakteristik, konstanta, atau nilai literal, dan harus dievaluasi ke daftar, angka, boolean, atau string. |
Node perilaku
Node seperti pemicu dan tindakan adalah node perilaku. Pemicu mengaktifkan otomatisasi berdasarkan perubahan atribut perangkat. Tindakan mengeluarkan perintah perangkat atau memperbarui atribut.
Node perilaku biasanya terkait dengan sifat perangkat dan status sifat output untuk digunakan sebagai input di node lain.
Node alur eksekusi
Beberapa node merepresentasikan alur eksekusi, seperti berurutan dan paralel. Setiap node ini berisi node perilaku yang menentukan otomatisasi.
Misalnya, alur berurutan dapat berisi node yang dieksekusi dalam urutan berurutan. Biasanya, ini adalah pemicu, kondisi, dan tindakan.
Alur paralel dapat memiliki beberapa node tindakan yang dijalankan secara bersamaan, seperti menyalakan beberapa lampu secara bersamaan. Node yang mengikuti alur paralel tidak akan dieksekusi hingga semua cabang alur paralel selesai.
Jenis alur eksekusi lainnya adalah alur kondisi, yang dapat mengubah alur eksekusi berdasarkan evaluasi ekspresi.
Misalnya, Anda mungkin memiliki otomatisasi yang melakukan tindakan berdasarkan apakah saat itu malam hari atau tidak. Node kondisi memeriksa waktu dalam sehari, lalu mengikuti jalur eksekusi yang sesuai berdasarkan evaluasi tersebut.
Alur pemilihan berguna saat Anda ingin memiliki lebih dari satu
pemicu yang dapat mengaktifkan otomatisasi Anda. Saat Anda menyertakan dua pemicu atau lebih
dalam alur select
, salah satu pemicu dapat mengaktifkan otomatisasi.
Misalnya, Anda dapat menulis otomatisasi yang menurunkan tirai saat matahari terbenam, jika suhu naik di atas batas tertentu, atau jika kecerahan melebihi batas. Tiga starter terpisah menangani setiap skenario ini, dan ketiganya akan di-wrap dalam alur select
.
Flow bertingkat
Dalam otomatisasi yang kompleks, node alur eksekusi juga dapat disusun bertingkat. Misalnya, Anda mungkin memiliki alur berurutan yang menjalankan alur paralel.
Node DSL dapat disusun bertingkat dan digabungkan dengan berbagai cara untuk memenuhi kebutuhan spesifik Anda, sesuai dengan batasan yang diuraikan dalam tabel berikut. Kolom Builder menautkan ke dokumentasi builder jenis aman Kotlin, yang menjelaskan apa yang diizinkan untuk digunakan di setiap jenis node.
Node | Mungkin berisi jenis dan data node berikut | Harus berada dalam salah satu jenis node berikut |
---|---|---|
Starter | Ekspresi | Pilih, Berurutan |
ManualStarter | Pilih, Berurutan | |
StateReader | Ekspresi (biasanya terdiri dari nilai atribut karakteristik) | Tindakan, Kondisi |
Tindakan | Perintah, Entitas, Ekspresi | Paralel, Pilih, Berurutan |
Berurutan (Sequential) | Paralel, Pilih, Berurutan | |
Paralel | Tindakan | Berurutan |
Kondisi | Ekspresi | Paralel, Berurutan |
Pilih | Kondisi, Berurutan, Pemicu, ManualStarter | Berurutan, dan harus menjadi node pertama dalam alur |
DSL Otomatisasi
Di Home API, otomatisasi ditentukan menggunakan DSL Otomatisasi (Bahasa Khusus Domain). DSL Otomatisasi diimplementasikan sebagai DSL Kotlin (bahasa khusus domain), menggunakan builder jenis aman Kotlin dan dirancang khusus untuk menentukan template otomatisasi.
Saat dikompilasi, builder yang aman untuk jenis Kotlin akan menghasilkan class data Kotlin yang kemudian diserialisasi ke JSON buffer protokol, yang digunakan untuk melakukan panggilan ke Layanan Otomatisasi Google.
DSL Otomatisasi menyederhanakan dan memperlancar proses pembuatan otomatisasi. Secara native, library ini menggunakan model data yang sama dengan Matter standar karakteristik dan karakteristik smart home yang ditampilkan di Device API.
DSL Otomatisasi juga menentukan logika otomatisasi dalam hal jenis perangkat abstrak, bukan instance perangkat tertentu yang berada di rumah pengguna. Hal ini memungkinkan developer memberikan parameter input yang dapat digunakan saat runtime untuk menentukan instance perangkat sebenarnya, serta nilai parameter penting lainnya.
Sintaksis DSL mirip dengan Kotlin, dan sama-sama aman untuk jenis, tetapi otomatisasi yang ditulis dalam Automation DSL lebih sederhana dan ringkas daripada otomatisasi yang sama yang ditulis dalam Kotlin murni.
Contoh
Berikut adalah contoh otomatisasi yang mengaktifkan perangkat, yang ditulis menggunakan DSL Otomatisasi:
val automation = automation {
name = "MyFirstAutomation"
description = "If light1 is on, turn on light2."
isActive = true
sequential {
val onOffTrait = starter<_>(device1, OnOffLightDevice, OnOff)
condition() { expression = onOffTrait.onOff equals true }
action(device2, OnOffLightDevice) { command(OnOff.on()) }
}
}
Otomatisasi ini sangat mendasar: saat device1
, lampu, menyala (atribut onOff
berubah menjadi true
), lalu mengirim perintah on()
untuk menyalakan
device2
.
Otomatisasi menggunakan node sequential
, yang menunjukkan bahwa node-nya akan berjalan
dalam urutan berurutan.
Dalam node sequential
terdapat node perilaku seperti starter
,
condition
, dan action
. Output node starter
ditetapkan ke variabel untuk digunakan di node condition
.