summaryrefslogtreecommitdiff
path: root/include/pio/libs/relay
diff options
context:
space:
mode:
authorEvgeny Zinoviev <me@ch1p.io>2023-09-27 00:54:57 +0300
committerEvgeny Zinoviev <me@ch1p.io>2023-09-27 00:54:57 +0300
commitd3a295872c49defb55fc8e4e43e55550991e0927 (patch)
treeb9dca15454f9027d5a9dad0d4443a20de04dbc5d /include/pio/libs/relay
parentb7cbc2571c1870b4582ead45277d0aa7f961bec8 (diff)
parentbdbb296697f55f4c3a07af43c9aaf7a9ea86f3d0 (diff)
Merge branch 'master' of ch1p.io:homekit
Diffstat (limited to 'include/pio/libs/relay')
-rw-r--r--include/pio/libs/relay/homekit/relay.cpp22
-rw-r--r--include/pio/libs/relay/homekit/relay.h13
-rw-r--r--include/pio/libs/relay/library.json8
3 files changed, 43 insertions, 0 deletions
diff --git a/include/pio/libs/relay/homekit/relay.cpp b/include/pio/libs/relay/homekit/relay.cpp
new file mode 100644
index 0000000..b00a7a2
--- /dev/null
+++ b/include/pio/libs/relay/homekit/relay.cpp
@@ -0,0 +1,22 @@
+#include <Arduino.h>
+#include "./relay.h"
+
+namespace homekit::relay {
+
+void init() {
+ pinMode(CONFIG_RELAY_GPIO, OUTPUT);
+}
+
+bool state() {
+ return digitalRead(CONFIG_RELAY_GPIO) == HIGH;
+}
+
+void on() {
+ digitalWrite(CONFIG_RELAY_GPIO, HIGH);
+}
+
+void off() {
+ digitalWrite(CONFIG_RELAY_GPIO, LOW);
+}
+
+}
diff --git a/include/pio/libs/relay/homekit/relay.h b/include/pio/libs/relay/homekit/relay.h
new file mode 100644
index 0000000..288cc05
--- /dev/null
+++ b/include/pio/libs/relay/homekit/relay.h
@@ -0,0 +1,13 @@
+#ifndef HOMEKIT_LIB_RELAY_H
+#define HOMEKIT_LIB_RELAY_H
+
+namespace homekit::relay {
+
+void init();
+bool state();
+void on();
+void off();
+
+}
+
+#endif //HOMEKIT_LIB_RELAY_H
diff --git a/include/pio/libs/relay/library.json b/include/pio/libs/relay/library.json
new file mode 100644
index 0000000..e878248
--- /dev/null
+++ b/include/pio/libs/relay/library.json
@@ -0,0 +1,8 @@
+{
+ "name": "homekit_relay",
+ "version": "1.0.0",
+ "build": {
+ "flags": "-I../../include"
+ }
+}
+