Ini adalah 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 karakteristik. Otomatisasi harus memiliki pemicu.
- Kondisi — Batasan tambahan apa pun yang akan dievaluasi setelah otomatisasi diaktifkan. Ekspresi dalam Kondisi harus dievaluasi ke
trueagar tindakan otomatisasi dapat dilanjutkan. - Tindakan — Perintah atau pembaruan status yang dilakukan saat semua kondisi terpenuhi.
Misalnya, Anda mungkin memiliki otomatisasi yang meredupkan lampu di ruangan saat TV di ruangan tersebut dinyalakan antara matahari terbenam dan matahari terbit. Dalam contoh ini:
- Pemicu — TV dinyalakan, yang merupakan perubahan status pada karakteristik TV.
- Kondisi— Waktu saat ini untuk rumah tempat TV berada dievaluasi.
- Tindakan — Lampu di ruangan yang sama dengan TV diredupkan.
Otomatisasi akan diaktifkan saat TV di ruangan dinyalakan, tetapi otomatisasi hanya dijalankan jika kondisi "waktu berada di 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 mereka bagi developer dan pengguna.
Node
Di Home API, struktur logis otomatisasi terdiri dari node. Node adalah unit abstrak yang dapat digunakan kembali yang mewakili perilaku entitas atau alur eksekusi. Setiap node dapat memiliki variabel input, serta variabel output yang dapat digunakan oleh node lain.
| Node | Jenis Node | Implementasi Kotlin | Deskripsi |
|---|---|---|---|
| Pemicu | Perilaku |
StarterNodeDsl
|
Memulai otomatisasi saat status karakteristik (atribut apa pun) berubah. |
| StateReader | Perilaku |
StateReaderNodeDsl
|
Membaca atribut karakteristik dan memungkinkan Anda mengambil nilainya untuk digunakan di node kondisi. |
| Tindakan | Perilaku |
ActionNodeDsl
|
Memanggil perintah karakteristik. |
| Berurutan | Alur eksekusi |
SequentialFlow
|
Menjalankan node tindakan bertingkat secara berurutan. Ini adalah perilaku eksekusi behavior. |
| 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
|
Memungkinkan 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 terikat pada karakteristik perangkat dan status karakteristik output untuk digunakan sebagai input di node lain.
Node alur eksekusi
Beberapa node mewakili 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 akan menjadi pemicu, kondisi, dan tindakan.
Alur paralel dapat memiliki beberapa node tindakan yang dieksekusi 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 ini malam hari. Node kondisi memeriksa waktu dalam sehari, lalu mengikuti jalur eksekusi yang sesuai berdasarkan evaluasi tersebut.
Alur pemilihan berguna jika Anda ingin memiliki lebih dari satu pemicu yang dapat mengaktifkan otomatisasi. 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 pemicu terpisah menangani setiap skenario ini, dan ketiganya akan digabungkan dalam alur select.
Alur bertingkat
Dalam otomatisasi yang kompleks, node alur eksekusi juga dapat bertingkat. Misalnya, Anda mungkin memiliki alur berurutan yang menjalankan alur paralel.
Node DSL dapat bertingkat dan digabungkan dengan berbagai cara untuk memenuhi kebutuhan spesifik Anda, sesuai dengan batasan yang diuraikan dalam tabel berikut. Kolom Builder ditautkan ke dokumentasi builder jenis aman Kotlin, yang menjelaskan detail hal yang diizinkan untuk digunakan di setiap jenis node.
| Node | Dapat berisi jenis dan data node berikut | Harus berada dalam salah satu jenis node berikut |
|---|---|---|
| Pemicu | Ekspresi | Pilih, Berurutan |
| ManualStarter | Pilih, Berurutan | |
| StateReader | Ekspresi (biasanya terdiri dari nilai atribut karakteristik) | Tindakan, Kondisi |
| Tindakan | Perintah, Entitas, Ekspresi | Paralel, Pilih, Berurutan |
| Berurutan | 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 otomatisasi dikompilasi, builder jenis aman 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 mengefisienkan proses pembuatan otomatisasi. DSL ini secara native menggunakan model data yang sama dari Matter karakteristik standar dan smart home karakteristik 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. DSL 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 jenis aman, tetapi otomatisasi yang ditulis dalam DSL Otomatisasi lebih sederhana dan ringkas daripada otomatisasi yang sama yang ditulis dalam Kotlin murni.
Contoh
Berikut adalah contoh otomatisasi yang menyalakan 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 nodenya 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.