From 494104aced9c3373eb8cecc6b91acb1cb5acbd04 Mon Sep 17 00:00:00 2001 From: Leo Siepel Date: Tue, 22 Feb 2022 20:59:37 +0100 Subject: [PATCH 1/4] Add two-channels, fix scene and docs Signed-off-by: Leo Siepel --- .../org.openhab.binding.plugwiseha/README.md | 24 ++++--- .../internal/PlugwiseHABindingConstants.java | 2 + .../api/model/PlugwiseHAController.java | 72 ++++++++++--------- .../model/dto/ActuatorFunctionalities.java | 9 +++ .../api/model/dto/ActuatorFunctionality.java | 14 ++++ .../dto/ActuatorFunctionalityThermostat.java | 13 +++- .../internal/api/model/dto/Location.java | 12 ++++ .../handler/PlugwiseHAApplianceHandler.java | 12 +--- .../handler/PlugwiseHAZoneHandler.java | 41 +++++++++++ .../main/resources/OH-INF/thing/channels.xml | 31 +++++++- .../resources/OH-INF/thing/thing-types.xml | 2 + 11 files changed, 176 insertions(+), 56 deletions(-) diff --git a/bundles/org.openhab.binding.plugwiseha/README.md b/bundles/org.openhab.binding.plugwiseha/README.md index f566e97366298..fd952a06ad921 100644 --- a/bundles/org.openhab.binding.plugwiseha/README.md +++ b/bundles/org.openhab.binding.plugwiseha/README.md @@ -19,7 +19,7 @@ The 'Adam' (from hereon called the gateway) needs to be accessible from the open | - | A Plugwise heating zone configured with at least 1 of the devices below | zone | | [Adam](https://www.plugwise.com/en_US/products/adam-ha) | The Plugwise Home Automation Bridge is needed to connect to the Adam boiler gateway | gateway | | [Tom](https://www.plugwise.com/en_US/products/tom) | A Plugwise Home Automation radiator valve | appliance_valve | -| [Floor](https://www.plugwise.com/en_US/products/floor) | A Plugwise Home Automation radiator valve specifically used for floor heating | appliance_valve | +| [Floor](https://www.plugwise.com/en_US/products/floor) | A Plugwise Home Automation radiator valve specifically used for floor heating | appliance_valve | | [Circle](https://www.plugwise.com/en_US/products/circle) | A power outlet plug that provides energy measurement and switching control of appliances (e.g. floor heating pump) | appliance_pump | | [Lisa](https://www.plugwise.com/en_US/products/lisa) | A room thermostat (also supports the 'Anna' room thermostat) | appliance_thermostat | | [Boiler] | A central boiler used for heating and/or domestic hot water | appliance_boiler | @@ -39,7 +39,7 @@ You must define a Plugwise Home Automation gateway (Bridge) before defining zone #### Plugwise Home Automation gateway (Bridge): | Parameter | Description | Config | Default | -| --------- | ----------------------------------------------------------------------- | -------- | ------- | +|-----------|-------------------------------------------------------------------------|----------|---------| | host | The IP address or hostname of the Adam HA gateway | Required | 'adam' | | username | The username for the Adam HA gateway | Optional | 'smile' | | smileID | The 8 letter code on the sticker on the back of the Adam boiler gateway | Required | - | @@ -54,14 +54,14 @@ You must define a Plugwise Home Automation gateway (Bridge) before defining zone #### Plugwise Home Automation appliance (`appliance_valve`): | Parameter | Description | Config | Default | -| -------------------- | ------------------------------------------------------------------------------------------------------------------ | -------- | ------- | +|----------------------|--------------------------------------------------------------------------------------------------------------------|----------|---------| | id | The unique ID of the radiator valve appliance | Required | - | | lowBatteryPercentage | Battery charge remaining at which to trigger battery low warning. (*Only applicable for battery operated devices*) | Optional | 15 | #### Plugwise Home Automation appliance (`appliance_thermostat`): | Parameter | Description | Config | Default | -| -------------------- | ------------------------------------------------------------------------------------------------------------------ | -------- | ------- | +|----------------------|--------------------------------------------------------------------------------------------------------------------|----------|---------| | id | The unique ID of the room thermostat appliance | Required | - | | lowBatteryPercentage | Battery charge remaining at which to trigger battery low warning. (*Only applicable for battery operated devices*) | Optional | 15 | @@ -75,7 +75,7 @@ You must define a Plugwise Home Automation gateway (Bridge) before defining zone #### Plugwise Home Automation boiler (`appliance_boiler`): | Parameter | Description | Config | Default | -| --------- | --------------------------- | -------- | ------- | +|-----------|-----------------------------|----------|---------| | id | The unique ID of the boiler | Required | - | ## Channels @@ -92,9 +92,11 @@ You must define a Plugwise Home Automation gateway (Bridge) before defining zone | chState | Switch | Yes | The current central heating state of the boiler | | dhwState | Switch | Yes | The current domestic hot water state of the boiler | | waterPressure | Number:Pressure | Yes | The current water pressure of the boiler | -| presetScene | String | Yes | The current active scene for the zone | +| presetScene | String | No | The current active scene for the zone | +| regulationControl | String | No | Toggle current regulation control (Active, Passive, Off) for the zone | +| coolingAllowed | Switch | No | Toggle the cfooling allowed of a zone ON/OFF | | valvePosition | Number | Yes | The current position of the valve | -| preHeat | Switch | Yes | Toggle the pre heating of a zone ON/OFF | +| preHeat | Switch | No | Toggle the pre heating of a zone ON/OFF | | coolingState | Switch | Yes | The current cooling state of the boiler | | intendedBoilerTemp | Number:Temperature | Yes | The intended boiler temperature | | flameState | Switch | Yes | The flame state of the boiler | @@ -107,8 +109,6 @@ You must define a Plugwise Home Automation gateway (Bridge) before defining zone | dhwSetpoint | Number:Temperature | Yes | The domestic hot water setpoint | | maxBoilerTemperature | Number:Temperature | Yes | The maximum temperature of the boiler | | dhwComfortMode | Switch | Yes | The domestic hot water confortmode | - | - ## Full Example @@ -131,8 +131,10 @@ Replace `$device_id` accordingly. ``` Number:Temperature living_room_zone_temperature "Zone temperature" {channel="plugwiseha:zone:home:living_room_zone:temperature"} Number:Temperature living_room_zone_temperature_setpoint "Zone temperature setpoint" {channel="plugwiseha:zone:home:living_room_zone:setpointTemperature"} -Number:Temperature living_room_zone_preset_scene "Zone preset scene" {channel="plugwiseha:zone:home:living_room_zone:presetScene"} +String living_room_zone_preset_scene "Zone preset scene" {channel="plugwiseha:zone:home:living_room_zone:presetScene"} Switch living_room_zone_preheat "Zone preheat enabled" {channel="plugwiseha:zone:home:living_room_zone:preHeat"} +String living_room_zone_cooling "Zone cooling enabled" {channel="plugwiseha:zone:home:living_room_zone:coolingAllowd"} +String living_room_zone_regulation_control "Zone regulation control" {channel="plugwiseha:zone:home:living_room_zone:regulationControl"} Number:Temperature living_room_radiator_temperature "Radiator valve temperature" {channel="plugwiseha:appliance_valve:home:living_room_radiator:temperature"} Number:Temperature living_room_radiator_temperature_setpoint "Radiator valve temperature setpoint" {channel="plugwiseha:appliance_valve:home:living_room_radiator:setpointTemperature"} @@ -181,6 +183,8 @@ sitemap plugwiseha label="PlugwiseHA Binding" Setpoint item=living_room_zone_temperature_setpoint label="Living room [%.1f °C]" minValue=5.0 maxValue=25 step=0.5 Text item=living_room_zone_presetScene Switch item=living_room_zone_preheat + Text item=living_room_zone_regulation_control + Switch item=living_room_zone_cooling Text item=living_room_radiator_temperature Setpoint item=living_room_radiator_temperature_setpoint label="Living room [%.1f °C]" minValue=5.0 maxValue=25 step=0.5 diff --git a/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/PlugwiseHABindingConstants.java b/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/PlugwiseHABindingConstants.java index ec97161add12f..b9006832665bd 100644 --- a/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/PlugwiseHABindingConstants.java +++ b/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/PlugwiseHABindingConstants.java @@ -85,10 +85,12 @@ public class PlugwiseHABindingConstants { public static final String LOCATION_PROPERTY_FUNCTIONALITIES = "functionalities"; // List of all Channel IDs + public static final String ZONE_COOLING_CHANNEL = "allowCooling"; public static final String ZONE_SETPOINT_CHANNEL = "setpointTemperature"; public static final String ZONE_TEMPERATURE_CHANNEL = "temperature"; public static final String ZONE_PRESETSCENE_CHANNEL = "presetScene"; public static final String ZONE_PREHEAT_CHANNEL = "preHeat"; + public static final String ZONE_REGULATION_CHANNEL = "regulationControl"; public static final String APPLIANCE_SETPOINT_CHANNEL = "setpointTemperature"; public static final String APPLIANCE_TEMPERATURE_CHANNEL = "temperature"; diff --git a/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/api/model/PlugwiseHAController.java b/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/api/model/PlugwiseHAController.java index 16c3e3ff0016e..8f171798475f7 100644 --- a/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/api/model/PlugwiseHAController.java +++ b/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/api/model/PlugwiseHAController.java @@ -311,76 +311,80 @@ public void setOffsetTemperature(Appliance appliance, Double temperature) throws } } - public void switchRelay(Appliance appliance, String state) throws PlugwiseHAException { - List allowStates = Arrays.asList("on", "off"); - if (allowStates.contains(state.toLowerCase())) { - if (state.toLowerCase().equals("on")) { - switchRelayOn(appliance); - } else { - switchRelayOff(appliance); - } - } + public void setPreHeating(Location location, Boolean state) throws PlugwiseHAException { + PlugwiseHAControllerRequest request = newRequest(Void.class); + Optional thermostat = location.getActuatorFunctionalities().getFunctionalityThermostat(); + + request.setPath("/core/locations"); + request.addPathParameter("id", String.format("%s/thermostat", location.getId())); + request.addPathParameter("id", String.format("%s", thermostat.get().getId())); + request.setBodyParameter(new ActuatorFunctionalityThermostat(state, null, null)); + + executeRequest(request); } - public void setPreHeating(Location location, Boolean state) throws PlugwiseHAException { + public void setAllowCooling(Location location, Boolean state) throws PlugwiseHAException { PlugwiseHAControllerRequest request = newRequest(Void.class); Optional thermostat = location.getActuatorFunctionalities().getFunctionalityThermostat(); request.setPath("/core/locations"); request.addPathParameter("id", String.format("%s/thermostat", location.getId())); request.addPathParameter("id", String.format("%s", thermostat.get().getId())); - request.setBodyParameter(new ActuatorFunctionalityThermostat(state)); + request.setBodyParameter(new ActuatorFunctionalityThermostat(null, state, null)); executeRequest(request); } - public void switchRelayOn(Appliance appliance) throws PlugwiseHAException { + public void setRegulationControl(Location location, String state) throws PlugwiseHAException { + List allowStates = Arrays.asList("active", "passive", "off"); + if (!allowStates.contains(state.toLowerCase())) { + this.logger.warn("Trying to set the regulation control to an invalid state"); + return; + } + PlugwiseHAControllerRequest request = newRequest(Void.class); + Optional thermostat = location.getActuatorFunctionalities().getFunctionalityThermostat(); - request.setPath("/core/appliances"); - request.addPathParameter("id", String.format("%s/relay", appliance.getId())); - request.setBodyParameter(new ActuatorFunctionalityRelay("on")); + request.setPath("/core/locations"); + request.addPathParameter("id", String.format("%s/thermostat", location.getId())); + request.addPathParameter("id", String.format("%s", thermostat.get().getId())); + request.setBodyParameter(new ActuatorFunctionalityThermostat(null, null, state)); executeRequest(request); } - public void switchRelayOff(Appliance appliance) throws PlugwiseHAException { + public void setRelay(Appliance appliance, Boolean state) throws PlugwiseHAException { PlugwiseHAControllerRequest request = newRequest(Void.class); request.setPath("/core/appliances"); request.addPathParameter("id", String.format("%s/relay", appliance.getId())); - request.setBodyParameter(new ActuatorFunctionalityRelay("off")); + request.setBodyParameter(new ActuatorFunctionalityRelay(state ? "on" : "off")); executeRequest(request); } - public void switchRelayLock(Appliance appliance, String state) throws PlugwiseHAException { - List allowStates = Arrays.asList("on", "off"); - if (allowStates.contains(state.toLowerCase())) { - if (state.toLowerCase().equals("on")) { - switchRelayLockOn(appliance); - } else { - switchRelayLockOff(appliance); - } - } - } - - public void switchRelayLockOff(Appliance appliance) throws PlugwiseHAException { + public void setRelayLock(Appliance appliance, Boolean state) throws PlugwiseHAException { PlugwiseHAControllerRequest request = newRequest(Void.class); request.setPath("/core/appliances"); request.addPathParameter("id", String.format("%s/relay", appliance.getId())); - request.setBodyParameter(new ActuatorFunctionalityRelay(null, false)); + request.setBodyParameter(new ActuatorFunctionalityRelay(null, state)); executeRequest(request); } - public void switchRelayLockOn(Appliance appliance) throws PlugwiseHAException { + public void setPresetScene(Location location, String state) throws PlugwiseHAException { + List allowStates = Arrays.asList("home", "asleep", "away", "vacation", "no_frost"); + if (!allowStates.contains(state.toLowerCase())) { + this.logger.warn("Trying to set the preset scene to an invalid state"); + return; + } + PlugwiseHAControllerRequest request = newRequest(Void.class); - request.setPath("/core/appliances"); - request.addPathParameter("id", String.format("%s/relay", appliance.getId())); - request.setBodyParameter(new ActuatorFunctionalityRelay(null, true)); + request.setPath("/core/locations"); + request.addPathParameter("id", String.format("%s", location.getId())); + request.setBodyParameter(new Location(state)); executeRequest(request); } diff --git a/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/api/model/dto/ActuatorFunctionalities.java b/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/api/model/dto/ActuatorFunctionalities.java index 2f9ff67f93948..4d4ec3081adfa 100644 --- a/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/api/model/dto/ActuatorFunctionalities.java +++ b/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/api/model/dto/ActuatorFunctionalities.java @@ -35,6 +35,15 @@ public Optional getRelayLockState() { .map(Boolean::parseBoolean); } + public Optional getRegulationControl() { + return this.getFunctionalityThermostat().flatMap(ActuatorFunctionality::getRegulationControl); + } + + public Optional getCoolingAllowed() { + return this.getFunctionalityThermostat().flatMap(ActuatorFunctionality::getCoolingAllowed) + .map(Boolean::parseBoolean); + } + public Optional getPreHeatState() { return this.getFunctionalityThermostat().flatMap(ActuatorFunctionality::getPreHeatState) .map(Boolean::parseBoolean); diff --git a/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/api/model/dto/ActuatorFunctionality.java b/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/api/model/dto/ActuatorFunctionality.java index ab4013be5fbd7..d42ff7ddef0f5 100644 --- a/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/api/model/dto/ActuatorFunctionality.java +++ b/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/api/model/dto/ActuatorFunctionality.java @@ -35,6 +35,12 @@ public class ActuatorFunctionality extends PlugwiseBaseModel implements Plugwise private String resolution; private String lock; + @XStreamAlias("regulation_control") + private String regulationControl; + + @XStreamAlias("cooling_allowed") + private String coolingAllowed; + @XStreamAlias("preheating_allowed") private String preHeat; @@ -75,6 +81,14 @@ public ZonedDateTime getUpdatedDate() { return updatedDate; } + public Optional getRegulationControl() { + return Optional.ofNullable(regulationControl); + } + + public Optional getCoolingAllowed() { + return Optional.ofNullable(coolingAllowed); + } + public Optional getPreHeatState() { return Optional.ofNullable(preHeat); } diff --git a/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/api/model/dto/ActuatorFunctionalityThermostat.java b/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/api/model/dto/ActuatorFunctionalityThermostat.java index fda093981686e..311be627ab800 100644 --- a/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/api/model/dto/ActuatorFunctionalityThermostat.java +++ b/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/api/model/dto/ActuatorFunctionalityThermostat.java @@ -28,11 +28,22 @@ public class ActuatorFunctionalityThermostat extends ActuatorFunctionality { @XStreamAlias("preheating_allowed") private Boolean preheatingAllowed; + @SuppressWarnings("unused") + @XStreamAlias("cooling_allowed") + private Boolean coolingAllowed; + + @SuppressWarnings("unused") + @XStreamAlias("regulation_control") + private String regulationControl; + public ActuatorFunctionalityThermostat(Double temperature) { this.setpoint = temperature; } - public ActuatorFunctionalityThermostat(Boolean preheatingAllowed) { + public ActuatorFunctionalityThermostat(Boolean preheatingAllowed, Boolean coolingAllowed, + String regulationControl) { this.preheatingAllowed = preheatingAllowed; + this.coolingAllowed = coolingAllowed; + this.regulationControl = regulationControl; } } diff --git a/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/api/model/dto/Location.java b/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/api/model/dto/Location.java index c91e4fc22c06b..521849dc41235 100644 --- a/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/api/model/dto/Location.java +++ b/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/api/model/dto/Location.java @@ -47,6 +47,10 @@ public class Location extends PlugwiseBaseModel implements PlugwiseComparableDat @XStreamImplicit(itemFieldName = "actuator_functionality", keyFieldName = "type") private ActuatorFunctionalities actuatorFunctionalities; + public Location(String presetScene) { + this.preset = presetScene; + } + public String getName() { return name; } @@ -101,6 +105,14 @@ public Optional getPreHeatState() { return this.actuatorFunctionalities.getPreHeatState(); } + public Optional getCoolingAllowed() { + return this.actuatorFunctionalities.getCoolingAllowed(); + } + + public Optional getRegulationControl() { + return this.actuatorFunctionalities.getRegulationControl(); + } + public int applianceCount() { if (this.locationAppliances == null) { return 0; diff --git a/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/handler/PlugwiseHAApplianceHandler.java b/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/handler/PlugwiseHAApplianceHandler.java index b3a1ed174c197..67fc029e4fd14 100644 --- a/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/handler/PlugwiseHAApplianceHandler.java +++ b/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/handler/PlugwiseHAApplianceHandler.java @@ -143,11 +143,7 @@ protected void handleCommand(Appliance entity, ChannelUID channelUID, Command co case APPLIANCE_LOCK_CHANNEL: if (command instanceof OnOffType) { try { - if (command == OnOffType.ON) { - controller.switchRelayLockOn(entity); - } else { - controller.switchRelayLockOff(entity); - } + controller.setRelay(entity, (command == OnOffType.ON)); } catch (PlugwiseHAException e) { logger.warn("Unable to switch relay lock {} for appliance '{}'", (State) command, entity.getName()); @@ -174,11 +170,7 @@ protected void handleCommand(Appliance entity, ChannelUID channelUID, Command co case APPLIANCE_POWER_CHANNEL: if (command instanceof OnOffType) { try { - if (command == OnOffType.ON) { - controller.switchRelayOn(entity); - } else { - controller.switchRelayOff(entity); - } + controller.setRelay(entity, command == OnOffType.ON); } catch (PlugwiseHAException e) { logger.warn("Unable to switch relay {} for appliance '{}'", (State) command, entity.getName()); } diff --git a/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/handler/PlugwiseHAZoneHandler.java b/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/handler/PlugwiseHAZoneHandler.java index d5e9250b33949..15137b80cb890 100644 --- a/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/handler/PlugwiseHAZoneHandler.java +++ b/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/handler/PlugwiseHAZoneHandler.java @@ -119,6 +119,16 @@ protected void handleCommand(Location entity, ChannelUID channelUID, Command com PlugwiseHAController controller = bridge.getController(); if (controller != null) { switch (channelID) { + case ZONE_COOLING_CHANNEL: + if (command instanceof OnOffType) { + try { + controller.setAllowCooling(entity, command == OnOffType.ON); + } catch (PlugwiseHAException e) { + logger.warn("Unable to switch allow cooling {} for zone '{}'", (State) command, + entity.getName()); + } + } + break; case ZONE_SETPOINT_CHANNEL: if (command instanceof QuantityType) { Unit unit = entity.getSetpointTemperatureUnit().orElse(UNIT_CELSIUS) @@ -144,6 +154,26 @@ protected void handleCommand(Location entity, ChannelUID channelUID, Command com } } break; + case ZONE_REGULATION_CHANNEL: + if (command instanceof StringType) { + try { + controller.setRegulationControl(entity, command.toString()); + } catch (PlugwiseHAException e) { + logger.warn("Unable to switch regulation control {} for zone '{}'", (State) command, + entity.getName()); + } + } + break; + case ZONE_PRESETSCENE_CHANNEL: + if (command instanceof StringType) { + try { + controller.setPresetScene(entity, command.toString()); + } catch (PlugwiseHAException e) { + logger.warn("Unable to switch preset scene {} for zone '{}'", (State) command, + entity.getName()); + } + } + break; default: logger.warn("Ignoring unsupported command = {} for channel = {}", command, channelUID); } @@ -154,8 +184,10 @@ protected void handleCommand(Location entity, ChannelUID channelUID, Command com private State getDefaultState(String channelID) { State state = UnDefType.NULL; switch (channelID) { + case ZONE_COOLING_CHANNEL: case ZONE_PREHEAT_CHANNEL: case ZONE_PRESETSCENE_CHANNEL: + case ZONE_REGULATION_CHANNEL: case ZONE_SETPOINT_CHANNEL: case ZONE_TEMPERATURE_CHANNEL: state = UnDefType.NULL; @@ -170,6 +202,12 @@ protected void refreshChannel(Location entity, ChannelUID channelUID) { State state = getDefaultState(channelID); switch (channelID) { + case ZONE_COOLING_CHANNEL: + Optional allowCoolingState = entity.getCoolingAllowed(); + if (allowCoolingState.isPresent()) { + state = OnOffType.from(allowCoolingState.get()); + } + break; case ZONE_PREHEAT_CHANNEL: Optional preHeatState = entity.getPreHeatState(); if (preHeatState.isPresent()) { @@ -186,6 +224,9 @@ protected void refreshChannel(Location entity, ChannelUID channelUID) { state = new QuantityType(entity.getSetpointTemperature().get(), unit); } break; + case ZONE_REGULATION_CHANNEL: + state = new StringType(entity.getRegulationControl().orElse(null)); + break; case ZONE_TEMPERATURE_CHANNEL: if (entity.getTemperature().isPresent()) { Unit unit = entity.getTemperatureUnit().orElse(UNIT_CELSIUS).equals(UNIT_CELSIUS) diff --git a/bundles/org.openhab.binding.plugwiseha/src/main/resources/OH-INF/thing/channels.xml b/bundles/org.openhab.binding.plugwiseha/src/main/resources/OH-INF/thing/channels.xml index 7f57acc9717ab..fb4503281873b 100644 --- a/bundles/org.openhab.binding.plugwiseha/src/main/resources/OH-INF/thing/channels.xml +++ b/bundles/org.openhab.binding.plugwiseha/src/main/resources/OH-INF/thing/channels.xml @@ -35,6 +35,27 @@ switch + + Switch + + Switch the cooling allowed of a zone ON or OFF + switch + + + + String + + Switch the regulation control of a zone to Active, Passive or Off + switch + + + + + + + + + Switch @@ -180,7 +201,15 @@ Gets the preset scene of the zone heating - + + + + + + + + + diff --git a/bundles/org.openhab.binding.plugwiseha/src/main/resources/OH-INF/thing/thing-types.xml b/bundles/org.openhab.binding.plugwiseha/src/main/resources/OH-INF/thing/thing-types.xml index 11d3b11e4b316..53d8754b25f36 100644 --- a/bundles/org.openhab.binding.plugwiseha/src/main/resources/OH-INF/thing/thing-types.xml +++ b/bundles/org.openhab.binding.plugwiseha/src/main/resources/OH-INF/thing/thing-types.xml @@ -58,6 +58,8 @@ + + id From 9e7896667640e55e16496b59bd0a21e96460e33b Mon Sep 17 00:00:00 2001 From: Leo Siepel Date: Wed, 23 Feb 2022 10:22:02 +0100 Subject: [PATCH 2/4] Fix review comments Signed-off-by: Leo Siepel --- bundles/org.openhab.binding.plugwiseha/README.md | 4 ++-- .../plugwiseha/internal/PlugwiseHABindingConstants.java | 2 +- .../src/main/resources/OH-INF/i18n/plugwiseha.properties | 4 ++++ .../src/main/resources/OH-INF/thing/channels.xml | 2 +- 4 files changed, 8 insertions(+), 4 deletions(-) diff --git a/bundles/org.openhab.binding.plugwiseha/README.md b/bundles/org.openhab.binding.plugwiseha/README.md index fd952a06ad921..012216ad44489 100644 --- a/bundles/org.openhab.binding.plugwiseha/README.md +++ b/bundles/org.openhab.binding.plugwiseha/README.md @@ -94,7 +94,7 @@ You must define a Plugwise Home Automation gateway (Bridge) before defining zone | waterPressure | Number:Pressure | Yes | The current water pressure of the boiler | | presetScene | String | No | The current active scene for the zone | | regulationControl | String | No | Toggle current regulation control (Active, Passive, Off) for the zone | -| coolingAllowed | Switch | No | Toggle the cfooling allowed of a zone ON/OFF | +| coolingAllowed | Switch | No | Toggle the cooling allowed of a zone ON/OFF | | valvePosition | Number | Yes | The current position of the valve | | preHeat | Switch | No | Toggle the pre heating of a zone ON/OFF | | coolingState | Switch | Yes | The current cooling state of the boiler | @@ -133,7 +133,7 @@ Number:Temperature living_room_zone_temperature "Zone temperature" {channel="plu Number:Temperature living_room_zone_temperature_setpoint "Zone temperature setpoint" {channel="plugwiseha:zone:home:living_room_zone:setpointTemperature"} String living_room_zone_preset_scene "Zone preset scene" {channel="plugwiseha:zone:home:living_room_zone:presetScene"} Switch living_room_zone_preheat "Zone preheat enabled" {channel="plugwiseha:zone:home:living_room_zone:preHeat"} -String living_room_zone_cooling "Zone cooling enabled" {channel="plugwiseha:zone:home:living_room_zone:coolingAllowd"} +String living_room_zone_cooling "Zone cooling enabled" {channel="plugwiseha:zone:home:living_room_zone:coolingAllowed"} String living_room_zone_regulation_control "Zone regulation control" {channel="plugwiseha:zone:home:living_room_zone:regulationControl"} Number:Temperature living_room_radiator_temperature "Radiator valve temperature" {channel="plugwiseha:appliance_valve:home:living_room_radiator:temperature"} diff --git a/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/PlugwiseHABindingConstants.java b/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/PlugwiseHABindingConstants.java index b9006832665bd..49b77e4370557 100644 --- a/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/PlugwiseHABindingConstants.java +++ b/bundles/org.openhab.binding.plugwiseha/src/main/java/org/openhab/binding/plugwiseha/internal/PlugwiseHABindingConstants.java @@ -85,7 +85,7 @@ public class PlugwiseHABindingConstants { public static final String LOCATION_PROPERTY_FUNCTIONALITIES = "functionalities"; // List of all Channel IDs - public static final String ZONE_COOLING_CHANNEL = "allowCooling"; + public static final String ZONE_COOLING_CHANNEL = "coolingAllowed"; public static final String ZONE_SETPOINT_CHANNEL = "setpointTemperature"; public static final String ZONE_TEMPERATURE_CHANNEL = "temperature"; public static final String ZONE_PRESETSCENE_CHANNEL = "presetScene"; diff --git a/bundles/org.openhab.binding.plugwiseha/src/main/resources/OH-INF/i18n/plugwiseha.properties b/bundles/org.openhab.binding.plugwiseha/src/main/resources/OH-INF/i18n/plugwiseha.properties index dba13ae55db8d..dfbe1462cefdc 100644 --- a/bundles/org.openhab.binding.plugwiseha/src/main/resources/OH-INF/i18n/plugwiseha.properties +++ b/bundles/org.openhab.binding.plugwiseha/src/main/resources/OH-INF/i18n/plugwiseha.properties @@ -49,6 +49,8 @@ channel-type.plugwiseha.boilerTemperature.label = Boiler Temperature channel-type.plugwiseha.boilerTemperature.description = Gets the temperature of this boiler channel-type.plugwiseha.chState.label = Central Heating Active channel-type.plugwiseha.chState.description = Is the boiler active for central heating, On or OFF +channel-type.plugwiseha.coolingAllowed.label = Cooling Allowed +channel-type.plugwiseha.coolingAllowed.description = Switch the cooling allowed of a zone ON or OFF channel-type.plugwiseha.coolingState.label = Cooling State channel-type.plugwiseha.coolingState.description = Is the boiler active for cooling, On or OFF channel-type.plugwiseha.dhwComfortMode.label = Domestic Hot Water Comfort Mode @@ -84,6 +86,8 @@ channel-type.plugwiseha.preHeat.label = Preheat channel-type.plugwiseha.preHeat.description = Switch the preheating of a zone ON or OFF channel-type.plugwiseha.presetScene.label = Preset Scene channel-type.plugwiseha.presetScene.description = Gets the preset scene of the zone +channel-type.plugwiseha.regulationControl.description = Regulation Control +channel-type.plugwiseha.regulationControl.description = Switch the regulation control of a zone to Active, Passive or Off channel-type.plugwiseha.setpointTemperature.label = Setpoint Temperature channel-type.plugwiseha.setpointTemperature.description = Gets or sets the set point of this zone channel-type.plugwiseha.temperature.label = Zone Temperature diff --git a/bundles/org.openhab.binding.plugwiseha/src/main/resources/OH-INF/thing/channels.xml b/bundles/org.openhab.binding.plugwiseha/src/main/resources/OH-INF/thing/channels.xml index fb4503281873b..5c605deca4762 100644 --- a/bundles/org.openhab.binding.plugwiseha/src/main/resources/OH-INF/thing/channels.xml +++ b/bundles/org.openhab.binding.plugwiseha/src/main/resources/OH-INF/thing/channels.xml @@ -199,7 +199,7 @@ String - Gets the preset scene of the zone + Gets or sets the preset scene of the zone heating From 42af1df764a88da092ad82d77cb7261aa421f343 Mon Sep 17 00:00:00 2001 From: Leo Siepel Date: Wed, 23 Feb 2022 10:30:36 +0100 Subject: [PATCH 3/4] Add additional state option translations Signed-off-by: Leo Siepel --- .../src/main/resources/OH-INF/i18n/plugwiseha.properties | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/bundles/org.openhab.binding.plugwiseha/src/main/resources/OH-INF/i18n/plugwiseha.properties b/bundles/org.openhab.binding.plugwiseha/src/main/resources/OH-INF/i18n/plugwiseha.properties index dfbe1462cefdc..542d2da2557bf 100644 --- a/bundles/org.openhab.binding.plugwiseha/src/main/resources/OH-INF/i18n/plugwiseha.properties +++ b/bundles/org.openhab.binding.plugwiseha/src/main/resources/OH-INF/i18n/plugwiseha.properties @@ -86,8 +86,16 @@ channel-type.plugwiseha.preHeat.label = Preheat channel-type.plugwiseha.preHeat.description = Switch the preheating of a zone ON or OFF channel-type.plugwiseha.presetScene.label = Preset Scene channel-type.plugwiseha.presetScene.description = Gets the preset scene of the zone +channel-type.plugwiseha.presetScene.state.option.home = Home +channel-type.plugwiseha.presetScene.state.option.asleep = A Sleep +channel-type.plugwiseha.presetScene.state.option.away = Away +channel-type.plugwiseha.presetScene.state.option.vacation = Vacation +channel-type.plugwiseha.presetScene.state.option.no_frost = No Frost channel-type.plugwiseha.regulationControl.description = Regulation Control channel-type.plugwiseha.regulationControl.description = Switch the regulation control of a zone to Active, Passive or Off +channel-type.plugwiseha.regulationControl.state.option.active = Active +channel-type.plugwiseha.regulationControl.state.option.passive = Passive +channel-type.plugwiseha.regulationControl.state.option.off = Off channel-type.plugwiseha.setpointTemperature.label = Setpoint Temperature channel-type.plugwiseha.setpointTemperature.description = Gets or sets the set point of this zone channel-type.plugwiseha.temperature.label = Zone Temperature From de047e160fc438e64bf9c6e717dfaf67ad47e7c9 Mon Sep 17 00:00:00 2001 From: Leo Siepel Date: Wed, 23 Feb 2022 21:12:06 +0100 Subject: [PATCH 4/4] Fix default translation Signed-off-by: Leo Siepel --- .../src/main/resources/OH-INF/i18n/plugwiseha.properties | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/bundles/org.openhab.binding.plugwiseha/src/main/resources/OH-INF/i18n/plugwiseha.properties b/bundles/org.openhab.binding.plugwiseha/src/main/resources/OH-INF/i18n/plugwiseha.properties index 542d2da2557bf..d45afdc7b3836 100644 --- a/bundles/org.openhab.binding.plugwiseha/src/main/resources/OH-INF/i18n/plugwiseha.properties +++ b/bundles/org.openhab.binding.plugwiseha/src/main/resources/OH-INF/i18n/plugwiseha.properties @@ -85,13 +85,13 @@ channel-type.plugwiseha.powerUsage.label = Power Usage channel-type.plugwiseha.preHeat.label = Preheat channel-type.plugwiseha.preHeat.description = Switch the preheating of a zone ON or OFF channel-type.plugwiseha.presetScene.label = Preset Scene -channel-type.plugwiseha.presetScene.description = Gets the preset scene of the zone +channel-type.plugwiseha.presetScene.description = Gets or sets the preset scene of the zone channel-type.plugwiseha.presetScene.state.option.home = Home channel-type.plugwiseha.presetScene.state.option.asleep = A Sleep channel-type.plugwiseha.presetScene.state.option.away = Away channel-type.plugwiseha.presetScene.state.option.vacation = Vacation channel-type.plugwiseha.presetScene.state.option.no_frost = No Frost -channel-type.plugwiseha.regulationControl.description = Regulation Control +channel-type.plugwiseha.regulationControl.label = Regulation Control channel-type.plugwiseha.regulationControl.description = Switch the regulation control of a zone to Active, Passive or Off channel-type.plugwiseha.regulationControl.state.option.active = Active channel-type.plugwiseha.regulationControl.state.option.passive = Passive