From 4d8c6b304bbf02fc1d0777b8ee58c9c391e5007b Mon Sep 17 00:00:00 2001 From: Marcel Date: Sun, 14 Nov 2021 13:40:05 +0100 Subject: [PATCH] [miio] support sending openclose commands (#11581) * [miio] support sending openclose commands Signed-off-by: Marcel Verpaalen * [miio] fix contact sending Signed-off-by: Marcel Verpaalen * [miio] switch Signed-off-by: Marcel Verpaalen --- .../internal/basic/CommandParameterType.java | 3 +- .../internal/handler/MiIoBasicHandler.java | 29 +++++++++++++++++-- 2 files changed, 29 insertions(+), 3 deletions(-) diff --git a/bundles/org.openhab.binding.miio/src/main/java/org/openhab/binding/miio/internal/basic/CommandParameterType.java b/bundles/org.openhab.binding.miio/src/main/java/org/openhab/binding/miio/internal/basic/CommandParameterType.java index d448011d8af..b5e638be042 100644 --- a/bundles/org.openhab.binding.miio/src/main/java/org/openhab/binding/miio/internal/basic/CommandParameterType.java +++ b/bundles/org.openhab.binding.miio/src/main/java/org/openhab/binding/miio/internal/basic/CommandParameterType.java @@ -28,8 +28,9 @@ public enum CommandParameterType { ONOFFBOOL("onoffbool"), ONOFFBOOLSTRING("onoffboolstring"), ONOFFNUMBER("onoffnumber"), - OPENCLOSENUMBER("openclosenumber"), OPENCLOSE("openclose"), + OPENCLOSENUMBER("openclosenumber"), + OPENCLOSESWITCH("opencloseswitch"), STRING("string"), CUSTOMSTRING("customstring"), NUMBER("number"), diff --git a/bundles/org.openhab.binding.miio/src/main/java/org/openhab/binding/miio/internal/handler/MiIoBasicHandler.java b/bundles/org.openhab.binding.miio/src/main/java/org/openhab/binding/miio/internal/handler/MiIoBasicHandler.java index c6c7c590572..19f7e3382aa 100644 --- a/bundles/org.openhab.binding.miio/src/main/java/org/openhab/binding/miio/internal/handler/MiIoBasicHandler.java +++ b/bundles/org.openhab.binding.miio/src/main/java/org/openhab/binding/miio/internal/handler/MiIoBasicHandler.java @@ -175,6 +175,30 @@ public class MiIoBasicHandler extends MiIoAbstractHandler { command = new DecimalType(((QuantityType) command).toBigDecimal()); } } + if (paramType == CommandParameterType.OPENCLOSE) { + if (command instanceof OpenClosedType) { + value = new JsonPrimitive(command == OpenClosedType.OPEN ? "open" : "close"); + } else { + value = new JsonPrimitive(("ON".contentEquals(command.toString().toUpperCase()) + || "1".contentEquals(command.toString())) ? "open" : "close"); + } + } + if (paramType == CommandParameterType.OPENCLOSENUMBER) { + if (command instanceof OpenClosedType) { + value = new JsonPrimitive(command == OpenClosedType.OPEN ? 1 : 0); + } else { + value = new JsonPrimitive(("ON".contentEquals(command.toString().toUpperCase()) + || "1".contentEquals(command.toString())) ? 1 : 0); + } + } + if (paramType == CommandParameterType.OPENCLOSESWITCH) { + if (command instanceof OpenClosedType) { + value = new JsonPrimitive(command == OpenClosedType.OPEN ? "on" : "off"); + } else { + value = new JsonPrimitive(("ON".contentEquals(command.toString().toUpperCase()) + || "1".contentEquals(command.toString())) ? "on" : "off"); + } + } if (paramType == CommandParameterType.COLOR) { if (command instanceof HSBType) { HSBType hsb = (HSBType) command; @@ -630,8 +654,8 @@ public class MiIoBasicHandler extends MiIoAbstractHandler { } else { String strVal = val.getAsString().toLowerCase(); updateState(basicChannel.getChannel(), - "on".equals(strVal) || "true".equals(strVal) || "1".equals(strVal) ? OpenClosedType.OPEN - : OpenClosedType.CLOSED); + "open".equals(strVal) || "on".equals(strVal) || "true".equals(strVal) + || "1".equals(strVal) ? OpenClosedType.OPEN : OpenClosedType.CLOSED); } break; case "color": @@ -706,6 +730,7 @@ public class MiIoBasicHandler extends MiIoAbstractHandler { switch (response.getCommand()) { case MIIO_INFO: break; + case GET_DEVICE_PROPERTY_EXP: case GET_VALUE: case GET_PROPERTIES: case GET_PROPERTY: