mirror of
https://github.com/openhab/openhab-addons.git
synced 2025-01-25 14:55:55 +01:00
[radiothermostat] Skip clock sync when override is on (#15127)
* Don't sync clock when override is on Signed-off-by: Michael Lobstein <michael.lobstein@gmail.com>
This commit is contained in:
parent
828c895b54
commit
b193493f8e
@ -40,7 +40,8 @@ Click the 'Show advanced' checkbox on the Thing configuration page to display th
|
||||
For both the heating and cooling programs, the 7-day repeating schedule has 4 setpoint periods per day (Morning, Day, Evening, Night).
|
||||
In order for the heating or cooling program to be valid, all time and setpoint fields must be populated.
|
||||
The time is expressed in 24-hour (HH:mm) format and the time value for each successive period within a day must be greater than the previous period.
|
||||
Once the schedule is populated and the configuration saved, the new schedule will be sent to the thermostat during binding initialization, overwriting its existing schedule.
|
||||
Once the schedule is populated and the configuration saved, the new schedule will be sent to the thermostat each time the binding is initialized, overwriting its existing schedule.
|
||||
If the thermostat's current setpoint was overridden, it will be reset to the applicable program setpoint.
|
||||
|
||||
If one or more time or setpoint fields are left blank in a given schedule and the configuration saved, the Thing will display a configuration error until the entries are corrected.
|
||||
A heating or cooling schedule with all fields left blank will be ignored by the binding.
|
||||
@ -61,6 +62,8 @@ curl http://$THERMOSTAT_IP/cloud -d '{"authkey":""}' -X POST
|
||||
- The main caveat for using this binding is to keep in mind that the web server in the thermostat is very slow. Do not over load it with excessive amounts of simultaneous commands.
|
||||
- When changing the thermostat mode, the current temperature set point is cleared and a refresh of the thermostat data is done to get the new mode's set point.
|
||||
- Since retrieving the thermostat's data is the slowest operation, it will take several seconds after changing the mode before the new set point is displayed.
|
||||
- Clock sync will not occur if `override` flag is on (i.e. the program setpoint has been manually overridden) because syncing time will reset the temperature back to the program setpoint.
|
||||
- The `override` flag is not reported correctly on older thermostat versions (i.e. /tstat/model reports v1.09)
|
||||
- The 'Program Mode' command is untested and according to the published API is only available on a CT80 Rev B.
|
||||
- Humidity information is available only when using a CT80 thermostat.
|
||||
|
||||
|
@ -19,7 +19,7 @@ package org.openhab.binding.radiothermostat.internal.dto;
|
||||
* @author Michael Lobstein - Initial contribution
|
||||
*/
|
||||
public class RadioThermostatDTO {
|
||||
private RadioThermostatTstatDTO thermostatData;
|
||||
private RadioThermostatTstatDTO thermostatData = new RadioThermostatTstatDTO();
|
||||
private Integer humidity;
|
||||
private RadioThermostatRuntimeDTO runtime;
|
||||
|
||||
|
@ -106,6 +106,10 @@ public class RadioThermostatTstatDTO {
|
||||
return override;
|
||||
}
|
||||
|
||||
public void setOverride(Integer override) {
|
||||
this.override = override;
|
||||
}
|
||||
|
||||
public Integer getHold() {
|
||||
return hold;
|
||||
}
|
||||
|
@ -235,22 +235,27 @@ public class RadioThermostatHandler extends BaseThingHandler implements RadioThe
|
||||
* Sync the thermostat's clock with the host system clock
|
||||
*/
|
||||
private void syncThermostatClock() {
|
||||
Calendar c = Calendar.getInstance();
|
||||
boolean success = false;
|
||||
|
||||
// The thermostat week starts as Monday = 0, subtract 2 since in standard DoW Monday = 2
|
||||
int thermDayOfWeek = c.get(Calendar.DAY_OF_WEEK) - 2;
|
||||
// Sunday will be -1, so add 7 to make it 6
|
||||
if (thermDayOfWeek < 0) {
|
||||
thermDayOfWeek += 7;
|
||||
// don't sync clock if override is on because it will reset temporary hold
|
||||
final Integer override = rthermData.getThermostatData().getOverride();
|
||||
if (override == null || override.compareTo(0) == 0) {
|
||||
Calendar c = Calendar.getInstance();
|
||||
|
||||
// The thermostat week starts as Monday = 0, subtract 2 since in standard DoW Monday = 2
|
||||
int thermDayOfWeek = c.get(Calendar.DAY_OF_WEEK) - 2;
|
||||
// Sunday will be -1, so add 7 to make it 6
|
||||
if (thermDayOfWeek < 0) {
|
||||
thermDayOfWeek += 7;
|
||||
}
|
||||
|
||||
success = connector.sendCommand(null, null,
|
||||
String.format(JSON_TIME, thermDayOfWeek, c.get(Calendar.HOUR_OF_DAY), c.get(Calendar.MINUTE)),
|
||||
TIME_RESOURCE).contains("success");
|
||||
}
|
||||
|
||||
final String response = connector.sendCommand(null, null,
|
||||
String.format(JSON_TIME, thermDayOfWeek, c.get(Calendar.HOUR_OF_DAY), c.get(Calendar.MINUTE)),
|
||||
TIME_RESOURCE);
|
||||
|
||||
// if sync call was successful run again in one hour, if un-successful try again in one minute
|
||||
this.clockSyncJob = scheduler.schedule(this::syncThermostatClock, (response.contains("success") ? 60 : 1),
|
||||
TimeUnit.MINUTES);
|
||||
this.clockSyncJob = scheduler.schedule(this::syncThermostatClock, (success ? 60 : 1), TimeUnit.MINUTES);
|
||||
}
|
||||
|
||||
/**
|
||||
@ -365,13 +370,15 @@ public class RadioThermostatHandler extends BaseThingHandler implements RadioThe
|
||||
}
|
||||
break;
|
||||
case SET_POINT:
|
||||
String cmdKey = null;
|
||||
String cmdKey;
|
||||
if (rthermData.getThermostatData().getMode() == 1) {
|
||||
cmdKey = this.setpointCmdKeyPrefix + "heat";
|
||||
rthermData.getThermostatData().setHeatTarget(Double.valueOf(cmdInt));
|
||||
rthermData.getThermostatData().setOverride(1);
|
||||
} else if (rthermData.getThermostatData().getMode() == 2) {
|
||||
cmdKey = this.setpointCmdKeyPrefix + "cool";
|
||||
rthermData.getThermostatData().setCoolTarget(Double.valueOf(cmdInt));
|
||||
rthermData.getThermostatData().setOverride(1);
|
||||
} else {
|
||||
// don't do anything if we are not in heat or cool mode
|
||||
break;
|
||||
|
Loading…
Reference in New Issue
Block a user