From 20e03c257a792d6f61344a59551ba6bd510f2154 Mon Sep 17 00:00:00 2001 From: James Melville Date: Tue, 8 Dec 2020 01:03:40 +0000 Subject: [PATCH] [openthermgateway] Fix for #9205 incorrect control setpoint override (#9206) * Initial attempt to resolve issue with flickering statuses when override present on OTGW * Update Units Signed-off-by: James Melville --- .../README.md | 100 ++++++++++-------- .../OpenThermGatewayBindingConstants.java | 10 +- .../handler/OpenThermGatewayHandler.java | 22 +++- .../openthermgateway/internal/CodeType.java | 49 +++++++++ .../openthermgateway/internal/DataItem.java | 26 ++++- .../internal/DataItemGroup.java | 54 ++++++---- .../openthermgateway/internal/Message.java | 23 ++-- .../OpenThermGatewaySocketConnector.java | 3 +- .../main/resources/OH-INF/thing/channels.xml | 89 ++++++++++------ .../src/main/resources/OH-INF/thing/otgw.xml | 4 + 10 files changed, 259 insertions(+), 121 deletions(-) create mode 100644 bundles/org.openhab.binding.openthermgateway/src/main/java/org/openhab/binding/openthermgateway/internal/CodeType.java diff --git a/bundles/org.openhab.binding.openthermgateway/README.md b/bundles/org.openhab.binding.openthermgateway/README.md index 5fbdb5579..2c1a514e7 100644 --- a/bundles/org.openhab.binding.openthermgateway/README.md +++ b/bundles/org.openhab.binding.openthermgateway/README.md @@ -32,36 +32,40 @@ The configuration settings for the thing are Hostname/IP address and Port, which The OpenTherm Gateway binding supports the following channels: -| Channel Type ID | Item Type | Description | Read Only | -|----------------------|-----------|----------------------------------------------------------|-----------| -| roomtemp | Number | Current sensed room temperature | yes | -| roomsetpoint | Number | Current room temperature setpoint | yes | -| temperaturetemporary | Number | Temporary override room temperature setpoint | no | -| temperatureconstant | Number | Constant override room temperature setpoint | no | -| controlsetpoint | Number | Central heating water setpoint | yes | -| dhwtemp | Number | Domestic hot water temperature | yes | -| tdhwset | Number | Domestic hot water temperature setpoint | yes | -| overridedhwsetpoint | Number | Domestic hot water temperature setpoint override | no | -| flowtemp | Number | Boiler water temperature | yes | -| returntemp | Number | Return water temperature | yes | -| outsidetemp | Number | Outside temperature | no | -| waterpressure | Number | Central heating water pressure | yes | -| ch_enable | Switch | Central heating enabled | yes | -| ch_mode | Switch | Central heating active | yes | -| dhw_enable | Switch | Domestic hot water enabled | yes | -| dhw_mode | Switch | Domestic hot water active | yes | -| flame | Switch | Burner active | yes | -| modulevel | Number | Relative modulation level | yes | -| maxrelmdulevel | Number | Maximum relative modulation level | yes | -| fault | Switch | Fault indication | yes | -| servicerequest | Switch | Service required | yes | -| lockout-reset | Switch | Lockout-reset enabled | yes | -| lowwaterpress | Switch | Low water pressure fault | yes | -| gasflamefault | Switch | Gas or flame fault | yes | -| airpressfault | Switch | Air pressure fault | yes | -| waterovtemp | Switch | Water over-temperature fault | yes | -| oemfaultcode | Switch | OEM fault code | yes | -| sendcommand | Text | Channel to send commands to the OpenTherm Gateway device | no | +| Channel Type ID | Item Type | Description | Read Only | +|--------------------------|----------------------|----------------------------------------------------------|-----------| +| roomtemp | Number:Temperature | Current sensed room temperature | yes | +| roomsetpoint | Number:Temperature | Current room temperature setpoint | yes | +| temperaturetemporary | Number:Temperature | Temporary override room temperature setpoint | no | +| temperatureconstant | Number:Temperature | Constant override room temperature setpoint | no | +| controlsetpoint | Number:Temperature | Central heating water setpoint set at boiler | yes | +| controlsetpointrequested | Number:Temperature | Central heating water setpoint requested by thermostat | yes | +| controlsetpointoverride | Number:Temperature | Central heating water setpoint configured at gateway | no | +| dhwtemp | Number:Temperature | Domestic hot water temperature | yes | +| tdhwset | Number:Temperature | Domestic hot water temperature setpoint | yes | +| overridedhwsetpoint | Number:Temperature | Domestic hot water temperature setpoint override | no | +| flowtemp | Number:Temperature | Boiler water temperature | yes | +| returntemp | Number:Temperature | Return water temperature | yes | +| outsidetemp | Number:Temperature | Outside temperature | no | +| waterpressure | Number:Pressure | Central heating water pressure | yes | +| ch_enable | Switch | Central heating enabled set at boiler | yes | +| ch_enablerequested | Switch | Central heating enabled requested by thermostat | yes | +| ch_enableoverride | Switch | Central heating enabled overridden at gateway | yes | +| ch_mode | Switch | Central heating active | yes | +| dhw_enable | Switch | Domestic hot water enabled | yes | +| dhw_mode | Switch | Domestic hot water active | yes | +| flame | Switch | Burner active | yes | +| modulevel | Number:Dimensionless | Relative modulation level | yes | +| maxrelmdulevel | Number:Dimensionless | Maximum relative modulation level | yes | +| fault | Switch | Fault indication | yes | +| servicerequest | Switch | Service required | yes | +| lockout-reset | Switch | Lockout-reset enabled | yes | +| lowwaterpress | Switch | Low water pressure fault | yes | +| gasflamefault | Switch | Gas or flame fault | yes | +| airpressfault | Switch | Air pressure fault | yes | +| waterovtemp | Switch | Water over-temperature fault | yes | +| oemfaultcode | Switch | OEM fault code | yes | +| sendcommand | Text | Channel to send commands to the OpenTherm Gateway device | no | ## Full Example @@ -74,25 +78,29 @@ Thing openthermgateway:otgw:1 [ ipaddress="192.168.1.100", port=8000, connection ### demo.items ``` -Number RoomTemperature "Room temperature [%.1f °C]" { channel="openthermgateway:otgw:1:roomtemp" } -Number RoomSetpoint "Room setpoint [%.1f °C]" { channel="openthermgateway:otgw:1:roomsetpoint" } -Number TemporaryRoomSetpointOverride "Temporary room setpoint override [%.1f °C]" { channel="openthermgateway:otgw:1:temperaturetemporary" } -Number ConstantRoomSetpointOverride "Constant room setpoint override [%.1f °C]" { channel="openthermgateway:otgw:1:temperatureconstant" } -Number ControlSetpoint "Control setpoint [%.1f °C]" { channel="openthermgateway:otgw:1:controlsetpoint" } -Number DomesticHotWaterTemperature "Domestic hot water temperature [%.1f °C]" { channel="openthermgateway:otgw:1:dhwtemp" } -Number DomesticHotWaterSetpoint "Domestic hot water setpoint [%.1f °C]" { channel="openthermgateway:otgw:1:tdhwset" } -Number DomesticHotWaterSetpointOverride "Domestic hot water setpoint override [%.1f °C]" { channel="openthermgateway:otgw:1:overridedhwsetpoint" } -Number BoilerWaterTemperature "Boiler water temperature [%.1f °C]" { channel="openthermgateway:otgw:1:flowtemp" } -Number ReturnWaterTemperature "Return water temperature [%.1f °C]" { channel="openthermgateway:otgw:1:returntemp" } -Number OutsideTemperature "Outside temperature [%.1f °C]" { channel="openthermgateway:otgw:1:outsidetemp" } -Number CentralHeatingWaterPressure "Central heating water pressure [%.1f bar]" { channel="openthermgateway:otgw:1:waterpressure" } +Number:Temperature RoomTemperature "Room temperature [%.1f °C]" { channel="openthermgateway:otgw:1:roomtemp" } +Number:Temperature RoomSetpoint "Room setpoint [%.1f °C]" { channel="openthermgateway:otgw:1:roomsetpoint" } +Number:Temperature TemporaryRoomSetpointOverride "Temporary room setpoint override [%.1f °C]" { channel="openthermgateway:otgw:1:temperaturetemporary" } +Number:Temperature ConstantRoomSetpointOverride "Constant room setpoint override [%.1f °C]" { channel="openthermgateway:otgw:1:temperatureconstant" } +Number:Temperature ControlSetpoint "Control setpoint [%.1f °C]" { channel="openthermgateway:otgw:1:controlsetpoint" } +Number:Temperature ControlSetpointRequested "Control setpoint requested [%.1f °C]" { channel="openthermgateway:otgw:1:controlsetpointrequested" } +Number:Temperature ControlSetpointOverride "Control setpoint override [%.1f °C]" { channel="openthermgateway:otgw:1:controlsetpointoverride" } +Number:Temperature DomesticHotWaterTemperature "Domestic hot water temperature [%.1f °C]" { channel="openthermgateway:otgw:1:dhwtemp" } +Number:Temperature DomesticHotWaterSetpoint "Domestic hot water setpoint [%.1f °C]" { channel="openthermgateway:otgw:1:tdhwset" } +Number:Temperature DomesticHotWaterSetpointOverride "Domestic hot water setpoint override [%.1f °C]" { channel="openthermgateway:otgw:1:overridedhwsetpoint" } +Number:Temperature BoilerWaterTemperature "Boiler water temperature [%.1f °C]" { channel="openthermgateway:otgw:1:flowtemp" } +Number:Temperature ReturnWaterTemperature "Return water temperature [%.1f °C]" { channel="openthermgateway:otgw:1:returntemp" } +Number:Temperature OutsideTemperature "Outside temperature [%.1f °C]" { channel="openthermgateway:otgw:1:outsidetemp" } +Number:Pressure CentralHeatingWaterPressure "Central heating water pressure [%.1f bar]" { channel="openthermgateway:otgw:1:waterpressure" } Switch CentralHeatingEnabled "Central heating enabled" { channel="openthermgateway:otgw:1:ch_enable" } +Switch CentralHeatingEnabledRequested "Central heating enabled requested" { channel="openthermgateway:otgw:1:ch_enablerequested" } +Switch CentralHeatingEnabledOverride "Central heating enabled override" { channel="openthermgateway:otgw:1:ch_enableoverride" } Switch CentralHeatingActive "Central heating active" { channel="openthermgateway:otgw:1:ch_mode" } Switch DomesticHotWaterEnabled "Domestic hot water enabled" { channel="openthermgateway:otgw:1:dhw_enable" } Switch DomesticHotWaterActive "Domestic hot water active" { channel="openthermgateway:otgw:1:dhw_mode" } Switch BurnerActive "Burner active" { channel="openthermgateway:otgw:1:flame" } -Number RelativeModulationLevel "Relative modulation level [%.1f %%]" { channel="openthermgateway:otgw:1:modulevel" } -Number MaximumRelativeModulationLevel "Maximum relative modulation level [%.1f %%]" { channel="openthermgateway:otgw:1:maxrelmdulevel" } +Number:Dimensionless RelativeModulationLevel "Relative modulation level [%.1f %%]" { channel="openthermgateway:otgw:1:modulevel" } +Number:Dimensionless MaximumRelativeModulationLevel "Maximum relative modulation level [%.1f %%]" { channel="openthermgateway:otgw:1:maxrelmdulevel" } Switch Fault "Fault indication" { channel="openthermgateway:otgw:1:fault" } Switch ServiceRequest "Service required" { channel="openthermgateway:otgw:1:servicerequest" } Switch LockoutReset "Lockout-reset" { channel="openthermgateway:otgw:1:lockout-reset" } @@ -114,6 +122,8 @@ sitemap demo label="Main Menu" { Setpoint item="TemporaryRoomSetpointOverride" icon="temperature" label="Temporary room setpoint override [%.1f °C]" minValue="0" maxValue="30" step="0.1" Setpoint item="ConstantRoomSetpointOverride" icon="temperature" label="Constant room setpoint override [%.1f °C]" minValue="0" maxValue="30" step="0.1" Text item="ControlSetpoint" icon="temperature" label="Control setpoint [%.1f °C]" + Text item="ControlSetpointRequested" icon="temperature" label="Control setpoint requested [%.1f °C]" + Setpoint item="ControlSetpointOverride" icon="temperature" label="Control setpoint override [%.1f °C]" minValue="0" maxValue="100" step="1" Text item="DomesticHotWaterTemperature" icon="temperature" label="Domestic hot water temperature [%.1f °C]" Text item="DomesticHotWaterSetpoint" icon="temperature" label="Domestic hot water setpoint [%.1f °C]" Setpoint item="DomesticHotWaterSetpointOverride" icon="temperature" label="Domestic hot water setpoint override [%.1f °C]" minValue="0" maxValue="100" step="0.1" @@ -122,6 +132,8 @@ sitemap demo label="Main Menu" { Setpoint item="OutsideTemperature" icon="temperature" label="Outside temperature [%.1f °C]" minValue="-40" maxValue="100" step="0.1" Text item="CentralHeatingWaterPressure" icon="" label="Central heating water pressure [%.1f bar]" Switch item="CentralHeatingEnabled" icon="switch" label="Central heating enabled" + Switch item="CentralHeatingEnabledRequested" icon="switch" label="Central heating enabled requested" + Switch item="CentralHeatingEnabledOverride" icon="switch" label="Central heating enabled override" Switch item="CentralHeatingActive" icon="switch" label="Central heating active" Switch item="DomesticHotWaterEnabled" icon="switch" label="Domestic hot water enabled" Switch item="DomesticHotWaterActive" icon="switch" label="Domestic hot water active" diff --git a/bundles/org.openhab.binding.openthermgateway/src/main/java/org/openhab/binding/openthermgateway/OpenThermGatewayBindingConstants.java b/bundles/org.openhab.binding.openthermgateway/src/main/java/org/openhab/binding/openthermgateway/OpenThermGatewayBindingConstants.java index acf73be8b..44f7262d5 100644 --- a/bundles/org.openhab.binding.openthermgateway/src/main/java/org/openhab/binding/openthermgateway/OpenThermGatewayBindingConstants.java +++ b/bundles/org.openhab.binding.openthermgateway/src/main/java/org/openhab/binding/openthermgateway/OpenThermGatewayBindingConstants.java @@ -46,8 +46,12 @@ public class OpenThermGatewayBindingConstants { public static final String CHANNEL_RETURN_TEMPERATURE = "returntemp"; public static final String CHANNEL_OUTSIDE_TEMPERATURE = "outsidetemp"; public static final String CHANNEL_CENTRAL_HEATING_WATER_SETPOINT = "controlsetpoint"; + public static final String CHANNEL_REQUESTED_CENTRAL_HEATING_WATER_SETPOINT = "controlsetpointrequested"; + public static final String CHANNEL_OVERRIDE_CENTRAL_HEATING_WATER_SETPOINT = "controlsetpointoverride"; public static final String CHANNEL_CENTRAL_HEATING_WATER_PRESSURE = "waterpressure"; public static final String CHANNEL_CENTRAL_HEATING_ENABLED = "ch_enable"; + public static final String CHANNEL_REQUESTED_CENTRAL_HEATING_ENABLED = "ch_enablerequested"; + public static final String CHANNEL_OVERRIDE_CENTRAL_HEATING_ENABLED = "ch_enableoverride"; public static final String CHANNEL_CENTRAL_HEATING_MODE = "ch_mode"; public static final String CHANNEL_DOMESTIC_HOT_WATER_TEMPERATURE = "dhwtemp"; public static final String CHANNEL_DOMESTIC_HOT_WATER_ENABLED = "dhw_enable"; @@ -68,8 +72,10 @@ public class OpenThermGatewayBindingConstants { public static final Set SUPPORTED_CHANNEL_IDS = Collections .unmodifiableSet(Stream.of(CHANNEL_ROOM_TEMPERATURE, CHANNEL_ROOM_SETPOINT, CHANNEL_FLOW_TEMPERATURE, CHANNEL_RETURN_TEMPERATURE, CHANNEL_OUTSIDE_TEMPERATURE, CHANNEL_CENTRAL_HEATING_WATER_PRESSURE, - CHANNEL_CENTRAL_HEATING_ENABLED, CHANNEL_CENTRAL_HEATING_MODE, - CHANNEL_CENTRAL_HEATING_WATER_SETPOINT, CHANNEL_DOMESTIC_HOT_WATER_TEMPERATURE, + CHANNEL_CENTRAL_HEATING_ENABLED, CHANNEL_REQUESTED_CENTRAL_HEATING_ENABLED, + CHANNEL_OVERRIDE_CENTRAL_HEATING_ENABLED, CHANNEL_CENTRAL_HEATING_MODE, + CHANNEL_CENTRAL_HEATING_WATER_SETPOINT, CHANNEL_REQUESTED_CENTRAL_HEATING_WATER_SETPOINT, + CHANNEL_OVERRIDE_CENTRAL_HEATING_WATER_SETPOINT, CHANNEL_DOMESTIC_HOT_WATER_TEMPERATURE, CHANNEL_DOMESTIC_HOT_WATER_ENABLED, CHANNEL_DOMESTIC_HOT_WATER_MODE, CHANNEL_DOMESTIC_HOT_WATER_SETPOINT, CHANNEL_FLAME, CHANNEL_RELATIVE_MODULATION_LEVEL, CHANNEL_MAXIMUM_MODULATION_LEVEL, CHANNEL_FAULT, CHANNEL_SERVICEREQUEST, CHANNEL_REMOTE_RESET, diff --git a/bundles/org.openhab.binding.openthermgateway/src/main/java/org/openhab/binding/openthermgateway/handler/OpenThermGatewayHandler.java b/bundles/org.openhab.binding.openthermgateway/src/main/java/org/openhab/binding/openthermgateway/handler/OpenThermGatewayHandler.java index be7e0d38f..0a4f8029b 100644 --- a/bundles/org.openhab.binding.openthermgateway/src/main/java/org/openhab/binding/openthermgateway/handler/OpenThermGatewayHandler.java +++ b/bundles/org.openhab.binding.openthermgateway/src/main/java/org/openhab/binding/openthermgateway/handler/OpenThermGatewayHandler.java @@ -40,6 +40,7 @@ import org.openhab.core.thing.binding.BaseThingHandler; import org.openhab.core.types.Command; import org.openhab.core.types.RefreshType; import org.openhab.core.types.State; +import org.openhab.core.types.UnDefType; import org.slf4j.Logger; import org.slf4j.LoggerFactory; @@ -87,6 +88,10 @@ public class OpenThermGatewayHandler extends BaseThingHandler implements OpenThe GatewayCommand gatewayCommand = null; + if (command instanceof OnOffType) { + OnOffType onOff = (OnOffType) command; + gatewayCommand = GatewayCommand.parse(code, onOff == OnOffType.ON ? "1" : "0"); + } if (command instanceof QuantityType) { QuantityType quantityType = ((QuantityType) command).toUnit(SIUnits.CELSIUS); @@ -106,6 +111,16 @@ public class OpenThermGatewayHandler extends BaseThingHandler implements OpenThe if (conn != null) { conn.sendCommand(gatewayCommand); + + if (code == GatewayCommandCode.ControlSetpoint) { + if (gatewayCommand.getMessage().equals("0.0")) { + updateState( + OpenThermGatewayBindingConstants.CHANNEL_OVERRIDE_CENTRAL_HEATING_WATER_SETPOINT, + UnDefType.UNDEF); + } + updateState(OpenThermGatewayBindingConstants.CHANNEL_OVERRIDE_CENTRAL_HEATING_ENABLED, + OnOffType.from(!gatewayCommand.getMessage().equals("0.0"))); + } } } } @@ -153,7 +168,8 @@ public class OpenThermGatewayHandler extends BaseThingHandler implements OpenThe for (DataItem dataItem : dataItems) { String channelId = dataItem.getSubject(); - if (!OpenThermGatewayBindingConstants.SUPPORTED_CHANNEL_IDS.contains(channelId)) { + if (!OpenThermGatewayBindingConstants.SUPPORTED_CHANNEL_IDS.contains(channelId) + || (dataItem.getFilteredCode() != null && dataItem.getFilteredCode() != message.getCode())) { continue; } @@ -264,6 +280,10 @@ public class OpenThermGatewayHandler extends BaseThingHandler implements OpenThe return GatewayCommandCode.TemperatureOutside; case OpenThermGatewayBindingConstants.CHANNEL_OVERRIDE_DHW_SETPOINT: return GatewayCommandCode.SetpointWater; + case OpenThermGatewayBindingConstants.CHANNEL_OVERRIDE_CENTRAL_HEATING_WATER_SETPOINT: + return GatewayCommandCode.ControlSetpoint; + case OpenThermGatewayBindingConstants.CHANNEL_OVERRIDE_CENTRAL_HEATING_ENABLED: + return GatewayCommandCode.CentralHeating; case OpenThermGatewayBindingConstants.CHANNEL_SEND_COMMAND: return null; default: diff --git a/bundles/org.openhab.binding.openthermgateway/src/main/java/org/openhab/binding/openthermgateway/internal/CodeType.java b/bundles/org.openhab.binding.openthermgateway/src/main/java/org/openhab/binding/openthermgateway/internal/CodeType.java new file mode 100644 index 000000000..12aa216c7 --- /dev/null +++ b/bundles/org.openhab.binding.openthermgateway/src/main/java/org/openhab/binding/openthermgateway/internal/CodeType.java @@ -0,0 +1,49 @@ +/** + * Copyright (c) 2010-2020 Contributors to the openHAB project + * + * See the NOTICE file(s) distributed with this work for additional + * information. + * + * This program and the accompanying materials are made available under the + * terms of the Eclipse Public License 2.0 which is available at + * http://www.eclipse.org/legal/epl-2.0 + * + * SPDX-License-Identifier: EPL-2.0 + */ +package org.openhab.binding.openthermgateway.internal; + +/** + * The {@link CodeType} field is not part of OpenTherm specification, but added by OpenTherm Gateway. + * It can be any of the following: + * + * T: Message received from the thermostat + * B: Message received from the boiler + * R: Request sent to the boiler + * A: Response returned to the thermostat + * E: Parity or stop bit error + * + * @author Arjen Korevaar - Initial contribution + * @author James Melville - Introduced code filtering functionality + */ +public enum CodeType { + /** + * Message received from the thermostat + */ + T, + /** + * Message received from the boiler + */ + B, + /** + * Request sent to the boiler from OTGW, only present if value modified by OTGW + */ + R, + /** + * Response returned to the thermostat from OTGW, only present if value modified by OTGW + */ + A, + /** + * Parity or stop bit error + */ + E +} diff --git a/bundles/org.openhab.binding.openthermgateway/src/main/java/org/openhab/binding/openthermgateway/internal/DataItem.java b/bundles/org.openhab.binding.openthermgateway/src/main/java/org/openhab/binding/openthermgateway/internal/DataItem.java index 4eb8ca331..74cf8f6ee 100644 --- a/bundles/org.openhab.binding.openthermgateway/src/main/java/org/openhab/binding/openthermgateway/internal/DataItem.java +++ b/bundles/org.openhab.binding.openthermgateway/src/main/java/org/openhab/binding/openthermgateway/internal/DataItem.java @@ -19,7 +19,7 @@ import org.eclipse.jdt.annotation.Nullable; /** * The {@link DataItem} holds the internal OpenTherm message and meta data. - * + * * @author Arjen Korevaar - Initial contribution */ @NonNullByDefault @@ -31,6 +31,7 @@ public class DataItem { private int bitpos; private String subject; private @Nullable Unit unit; + private @Nullable CodeType filteredCode; public int getID() { return id; @@ -60,17 +61,32 @@ public class DataItem { return unit; } + public @Nullable CodeType getFilteredCode() { + return filteredCode; + } + public DataItem(int id, Msg msg, ByteType byteType, DataType dataType, int bit, String subject) { + this(id, msg, byteType, dataType, bit, subject, null, null); + } + + public DataItem(int id, Msg msg, ByteType byteType, DataType dataType, int bit, String subject, Unit unit) { + this(id, msg, byteType, dataType, bit, subject, unit, null); + } + + public DataItem(int id, Msg msg, ByteType byteType, DataType dataType, int bit, String subject, + CodeType filteredCode) { + this(id, msg, byteType, dataType, bit, subject, null, filteredCode); + } + + public DataItem(int id, Msg msg, ByteType byteType, DataType dataType, int bit, String subject, + @Nullable Unit unit, @Nullable CodeType filteredCode) { this.id = id; this.msg = msg; this.byteType = byteType; this.dataType = dataType; this.bitpos = bit; this.subject = subject; - } - - public DataItem(int id, Msg msg, ByteType byteType, DataType dataType, int bit, String subject, Unit unit) { - this(id, msg, byteType, dataType, bit, subject); this.unit = unit; + this.filteredCode = filteredCode; } } diff --git a/bundles/org.openhab.binding.openthermgateway/src/main/java/org/openhab/binding/openthermgateway/internal/DataItemGroup.java b/bundles/org.openhab.binding.openthermgateway/src/main/java/org/openhab/binding/openthermgateway/internal/DataItemGroup.java index 6abae23ec..ab67caaf8 100644 --- a/bundles/org.openhab.binding.openthermgateway/src/main/java/org/openhab/binding/openthermgateway/internal/DataItemGroup.java +++ b/bundles/org.openhab.binding.openthermgateway/src/main/java/org/openhab/binding/openthermgateway/internal/DataItemGroup.java @@ -17,10 +17,11 @@ import java.util.Map; import org.eclipse.jdt.annotation.NonNullByDefault; import org.openhab.core.library.unit.SIUnits; +import org.openhab.core.library.unit.Units; /** * The {@link DataItemGroup} represents a list of all possible DataItem messages within the OpenTherm specification. - * + * * @author Arjen Korevaar - Initial contribution */ @NonNullByDefault @@ -31,24 +32,32 @@ public class DataItemGroup { private static Map createDataItemGroups() { HashMap g = new HashMap<>(); - g.put(0, new DataItem[] { new DataItem(0, Msg.READ, ByteType.HIGHBYTE, DataType.FLAGS, 0, "ch_enable"), - new DataItem(0, Msg.READ, ByteType.HIGHBYTE, DataType.FLAGS, 1, "dhw_enable"), - new DataItem(0, Msg.READ, ByteType.HIGHBYTE, DataType.FLAGS, 2, "cooling_enabled"), - new DataItem(0, Msg.READ, ByteType.HIGHBYTE, DataType.FLAGS, 3, "otc_active"), - new DataItem(0, Msg.READ, ByteType.HIGHBYTE, DataType.FLAGS, 4, "ch2_enable"), - new DataItem(0, Msg.READ, ByteType.HIGHBYTE, DataType.FLAGS, 5, "0x00:5"), - new DataItem(0, Msg.READ, ByteType.HIGHBYTE, DataType.FLAGS, 6, "0x00:6"), - new DataItem(0, Msg.READ, ByteType.HIGHBYTE, DataType.FLAGS, 7, "0x00:7"), - new DataItem(0, Msg.READ, ByteType.LOWBYTE, DataType.FLAGS, 0, "fault"), - new DataItem(0, Msg.READ, ByteType.LOWBYTE, DataType.FLAGS, 1, "ch_mode"), - new DataItem(0, Msg.READ, ByteType.LOWBYTE, DataType.FLAGS, 2, "dhw_mode"), - new DataItem(0, Msg.READ, ByteType.LOWBYTE, DataType.FLAGS, 3, "flame"), - new DataItem(0, Msg.READ, ByteType.LOWBYTE, DataType.FLAGS, 4, "cooling"), - new DataItem(0, Msg.READ, ByteType.LOWBYTE, DataType.FLAGS, 5, "ch2E"), - new DataItem(0, Msg.READ, ByteType.LOWBYTE, DataType.FLAGS, 6, "diag"), - new DataItem(0, Msg.READ, ByteType.LOWBYTE, DataType.FLAGS, 7, "0x00:7") }); + g.put(0, new DataItem[] { + new DataItem(0, Msg.READ, ByteType.HIGHBYTE, DataType.FLAGS, 0, "ch_enable", CodeType.B), + new DataItem(0, Msg.READ, ByteType.HIGHBYTE, DataType.FLAGS, 0, "ch_enablerequested", CodeType.T), + new DataItem(0, Msg.READ, ByteType.HIGHBYTE, DataType.FLAGS, 0, "ch_enableoverride", CodeType.R), + new DataItem(0, Msg.READ, ByteType.HIGHBYTE, DataType.FLAGS, 1, "dhw_enable", CodeType.B), + new DataItem(0, Msg.READ, ByteType.HIGHBYTE, DataType.FLAGS, 2, "cooling_enabled", CodeType.B), + new DataItem(0, Msg.READ, ByteType.HIGHBYTE, DataType.FLAGS, 3, "otc_active", CodeType.B), + new DataItem(0, Msg.READ, ByteType.HIGHBYTE, DataType.FLAGS, 4, "ch2_enable", CodeType.B), + new DataItem(0, Msg.READ, ByteType.HIGHBYTE, DataType.FLAGS, 5, "0x00:5", CodeType.B), + new DataItem(0, Msg.READ, ByteType.HIGHBYTE, DataType.FLAGS, 6, "0x00:6", CodeType.B), + new DataItem(0, Msg.READ, ByteType.HIGHBYTE, DataType.FLAGS, 7, "0x00:7", CodeType.B), + new DataItem(0, Msg.READ, ByteType.LOWBYTE, DataType.FLAGS, 0, "fault", CodeType.B), + new DataItem(0, Msg.READ, ByteType.LOWBYTE, DataType.FLAGS, 1, "ch_mode", CodeType.B), + new DataItem(0, Msg.READ, ByteType.LOWBYTE, DataType.FLAGS, 2, "dhw_mode", CodeType.B), + new DataItem(0, Msg.READ, ByteType.LOWBYTE, DataType.FLAGS, 3, "flame", CodeType.B), + new DataItem(0, Msg.READ, ByteType.LOWBYTE, DataType.FLAGS, 4, "cooling", CodeType.B), + new DataItem(0, Msg.READ, ByteType.LOWBYTE, DataType.FLAGS, 5, "ch2E", CodeType.B), + new DataItem(0, Msg.READ, ByteType.LOWBYTE, DataType.FLAGS, 6, "diag", CodeType.B), + new DataItem(0, Msg.READ, ByteType.LOWBYTE, DataType.FLAGS, 7, "0x00:7", CodeType.B) }); g.put(1, new DataItem[] { - new DataItem(1, Msg.WRITE, ByteType.BOTH, DataType.FLOAT, 0, "controlsetpoint", SIUnits.CELSIUS) }); + new DataItem(1, Msg.WRITE, ByteType.BOTH, DataType.FLOAT, 0, "controlsetpoint", SIUnits.CELSIUS, + CodeType.B), + new DataItem(1, Msg.WRITE, ByteType.BOTH, DataType.FLOAT, 0, "controlsetpointrequested", + SIUnits.CELSIUS, CodeType.T), + new DataItem(1, Msg.WRITE, ByteType.BOTH, DataType.FLOAT, 0, "controlsetpointoverride", SIUnits.CELSIUS, + CodeType.R) }); g.put(2, new DataItem[] { new DataItem(2, Msg.WRITE, ByteType.HIGHBYTE, DataType.FLAGS, 0, "0x02:0"), new DataItem(2, Msg.WRITE, ByteType.HIGHBYTE, DataType.FLAGS, 1, "0x02:1"), new DataItem(2, Msg.WRITE, ByteType.HIGHBYTE, DataType.FLAGS, 2, "0x02:2"), @@ -105,13 +114,16 @@ public class DataItemGroup { new DataItem(12, Msg.READ, ByteType.LOWBYTE, DataType.UINT8, 0, "0x0c:l") }); g.put(13, new DataItem[] { new DataItem(13, Msg.READ, ByteType.HIGHBYTE, DataType.UINT8, 0, "0x0d:h"), new DataItem(13, Msg.READ, ByteType.LOWBYTE, DataType.UINT8, 0, "0x0d:l") }); - g.put(14, new DataItem[] { new DataItem(14, Msg.READ, ByteType.LOWBYTE, DataType.FLOAT, 0, "maxrelmdulevel") }); + g.put(14, new DataItem[] { + new DataItem(14, Msg.READ, ByteType.LOWBYTE, DataType.FLOAT, 0, "maxrelmdulevel", Units.PERCENT) }); g.put(15, new DataItem[] { new DataItem(15, Msg.READ, ByteType.HIGHBYTE, DataType.UINT8, 0, "maxcapkw"), new DataItem(15, Msg.READ, ByteType.LOWBYTE, DataType.UINT8, 0, "maxcapprc") }); g.put(16, new DataItem[] { new DataItem(16, Msg.WRITE, ByteType.BOTH, DataType.FLOAT, 0, "roomsetpoint", SIUnits.CELSIUS) }); - g.put(17, new DataItem[] { new DataItem(17, Msg.READ, ByteType.BOTH, DataType.FLOAT, 0, "modulevel") }); - g.put(18, new DataItem[] { new DataItem(18, Msg.READ, ByteType.BOTH, DataType.FLOAT, 0, "waterpressure") }); + g.put(17, new DataItem[] { + new DataItem(17, Msg.READ, ByteType.BOTH, DataType.FLOAT, 0, "modulevel", Units.PERCENT) }); + g.put(18, new DataItem[] { + new DataItem(18, Msg.READ, ByteType.BOTH, DataType.FLOAT, 0, "waterpressure", Units.BAR) }); g.put(19, new DataItem[] { new DataItem(19, Msg.READ, ByteType.BOTH, DataType.FLOAT, 0, "dhwflow") }); g.put(20, new DataItem[] { new DataItem(20, Msg.READWRITE, ByteType.BOTH, DataType.DOWTOD, 0, "dowtod") }); g.put(21, new DataItem[] { new DataItem(21, Msg.READWRITE, ByteType.HIGHBYTE, DataType.UINT8, 0, "month"), diff --git a/bundles/org.openhab.binding.openthermgateway/src/main/java/org/openhab/binding/openthermgateway/internal/Message.java b/bundles/org.openhab.binding.openthermgateway/src/main/java/org/openhab/binding/openthermgateway/internal/Message.java index fc9ce0c0a..ee4d9744b 100644 --- a/bundles/org.openhab.binding.openthermgateway/src/main/java/org/openhab/binding/openthermgateway/internal/Message.java +++ b/bundles/org.openhab.binding.openthermgateway/src/main/java/org/openhab/binding/openthermgateway/internal/Message.java @@ -19,7 +19,7 @@ import org.eclipse.jdt.annotation.Nullable; /** * The {@link Message} represent a single message received from the OpenTherm Gateway. - * + * * @author Arjen Korevaar - Initial contribution */ @NonNullByDefault @@ -27,22 +27,12 @@ public class Message { private static final Pattern messagePattern = Pattern.compile("[TBRA]{1}[A-F0-9]{8}"); - /* - * The code field is not part of OpenTherm specification, but added by OpenTherm Gateway. - * It can be any of the following: - * - * T: Message received from the thermostat - * B: Message received from the boiler - * R: Request sent to the boiler - * A: Response returned to the thermostat - * E: Parity or stop bit error - */ - private String code; + private CodeType code; private MessageType messageType; private int id; private String data; - public String getCode() { + public CodeType getCode() { return this.code; } @@ -139,8 +129,7 @@ public class Message { // If the message is a Request sent to the boiler or an Answer returned to the // thermostat, and it's ID is equal to the previous message, then this is an // override sent by the OpenTherm Gateway - return other != null && this.getID() == other.getID() - && ("R".equals(this.getCode()) || "A".equals(this.getCode())); + return other != null && this.getID() == other.getID() && (this.code == CodeType.R || this.code == CodeType.A); } @Override @@ -148,7 +137,7 @@ public class Message { return String.format("%s - %s - %s", this.code, this.id, this.data); } - public Message(String code, MessageType messageType, int id, String data) { + public Message(CodeType code, MessageType messageType, int id, String data) { this.code = code; this.messageType = messageType; this.id = id; @@ -158,7 +147,7 @@ public class Message { public static @Nullable Message parse(String message) { if (messagePattern.matcher(message).matches()) { // For now, only parse TBRA codes - String code = message.substring(0, 1); + CodeType code = CodeType.valueOf(message.substring(0, 1)); MessageType messageType = getMessageType(message.substring(1, 3)); int id = Integer.valueOf(message.substring(3, 5), 16); String data = message.substring(5); diff --git a/bundles/org.openhab.binding.openthermgateway/src/main/java/org/openhab/binding/openthermgateway/internal/OpenThermGatewaySocketConnector.java b/bundles/org.openhab.binding.openthermgateway/src/main/java/org/openhab/binding/openthermgateway/internal/OpenThermGatewaySocketConnector.java index bb01f1c4e..3413d26f6 100644 --- a/bundles/org.openhab.binding.openthermgateway/src/main/java/org/openhab/binding/openthermgateway/internal/OpenThermGatewaySocketConnector.java +++ b/bundles/org.openhab.binding.openthermgateway/src/main/java/org/openhab/binding/openthermgateway/internal/OpenThermGatewaySocketConnector.java @@ -208,7 +208,8 @@ public class OpenThermGatewaySocketConnector implements OpenThermGatewayConnecto } } - if (msg.getMessageType() == MessageType.READACK || msg.getMessageType() == MessageType.WRITEDATA) { + if (msg.getMessageType() == MessageType.READACK || msg.getMessageType() == MessageType.WRITEDATA + || msg.getID() == 0 || msg.getID() == 1) { receiveMessage(msg); } } diff --git a/bundles/org.openhab.binding.openthermgateway/src/main/resources/OH-INF/thing/channels.xml b/bundles/org.openhab.binding.openthermgateway/src/main/resources/OH-INF/thing/channels.xml index 74c18b2ec..5df248390 100644 --- a/bundles/org.openhab.binding.openthermgateway/src/main/resources/OH-INF/thing/channels.xml +++ b/bundles/org.openhab.binding.openthermgateway/src/main/resources/OH-INF/thing/channels.xml @@ -9,7 +9,7 @@ Current sensed room temperature Temperature - + @@ -17,7 +17,7 @@ Current room temperature setpoint Temperature - + @@ -25,7 +25,7 @@ Temporary override room temperature setpoint Temperature - + @@ -33,15 +33,31 @@ Constant override room temperature setpoint Temperature - + Number:Temperature - Central heating water setpoint + Central heating water setpoint set at boiler Temperature - + + + + + Number:Temperature + + Central heating water setpoint requested by Thermostat + Temperature + + + + + Number:Temperature + + Central heating water setpoint configured on OTGW + Temperature + @@ -49,7 +65,7 @@ Domestic hot water temperature Temperature - + @@ -57,7 +73,7 @@ Domestic hot water temperature setpoint Temperature - + @@ -65,7 +81,7 @@ Domestic hot water temperature setpoint override Temperature - + @@ -73,7 +89,7 @@ Boiler water temperature Temperature - + @@ -81,7 +97,7 @@ Return water temperature Temperature - + @@ -89,126 +105,139 @@ Outside temperature Temperature - + Number:Dimensionless Central heating water pressure - + Switch - Central heating enabled - + Central heating enabled set at boiler + + + + + Switch + + Central heating enabled requested by thermostat + + + + + Switch + + Central heating enabled overridden at OTGW Switch Central heating active - + Switch Domestic hot water enabled - + Switch Domestic hot water active - + Switch Burner active - + Number:Dimensionless Relative modulation level - + Number:Dimensionless Maximum relative modulation level - + Switch Fault indication - + Switch Service required - + Switch Lockout-reset enabled - + Switch Low water pressure fault - + Switch Gas or flame fault - + Switch Air pressure fault - + Switch Water over-temperature fault - + Number:Dimensionless OEM fault code - + String Channel to send commands to the OpenTherm Gateway device - + diff --git a/bundles/org.openhab.binding.openthermgateway/src/main/resources/OH-INF/thing/otgw.xml b/bundles/org.openhab.binding.openthermgateway/src/main/resources/OH-INF/thing/otgw.xml index c0f53c04f..40c854a8e 100644 --- a/bundles/org.openhab.binding.openthermgateway/src/main/resources/OH-INF/thing/otgw.xml +++ b/bundles/org.openhab.binding.openthermgateway/src/main/resources/OH-INF/thing/otgw.xml @@ -12,6 +12,8 @@ + + @@ -20,6 +22,8 @@ + +