From aee4d31d5b375b7151bf591fab295692e6bc59ff Mon Sep 17 00:00:00 2001 From: Florian Hotze Date: Sun, 13 Nov 2022 12:54:00 +0100 Subject: [PATCH] [evcc] Fix data type issues in DTO (#13710) * [evcc] Change DTO from double to float as the higher precision is not required * [evcc] Change DTO from int/long to float * [evcc] Update JavaDoc & small improvements * [evcc] `EvccHandler`: Add exception message to the debug log Fixes https://github.com/openhab/openhab-addons/issues/13646. Avoids problems with changed data types in the future by generally using float instead of int. Signed-off-by: Florian Hotze --- .../binding/evcc/internal/EvccHandler.java | 44 ++++++++-------- .../binding/evcc/internal/api/EvccAPI.java | 13 +++-- .../evcc/internal/api/dto/Loadpoint.java | 50 +++++++++---------- .../binding/evcc/internal/api/dto/Result.java | 30 ++++++----- .../binding/evcc/internal/api/dto/Status.java | 2 +- 5 files changed, 68 insertions(+), 71 deletions(-) diff --git a/bundles/org.openhab.binding.evcc/src/main/java/org/openhab/binding/evcc/internal/EvccHandler.java b/bundles/org.openhab.binding.evcc/src/main/java/org/openhab/binding/evcc/internal/EvccHandler.java index f1c394886..438e8181a 100644 --- a/bundles/org.openhab.binding.evcc/src/main/java/org/openhab/binding/evcc/internal/EvccHandler.java +++ b/bundles/org.openhab.binding.evcc/src/main/java/org/openhab/binding/evcc/internal/EvccHandler.java @@ -66,7 +66,7 @@ public class EvccHandler extends BaseThingHandler { private boolean gridConfigured = false; private boolean pvConfigured = false; - private int targetSoC = 100; + private float targetSoC = 100; private boolean targetTimeEnabled = false; private ZonedDateTime targetTimeZDT = ZonedDateTime.now().plusHours(12); @@ -85,7 +85,7 @@ public class EvccHandler extends BaseThingHandler { return; } String channelIdWithoutGroup = channelUID.getIdWithoutGroup(); - int loadpoint = Integer.parseInt(groupId.toString().substring(9)); + int loadpoint = Integer.parseInt(groupId.substring(9)); EvccAPI evccAPI = this.evccAPI; if (evccAPI == null) { return; @@ -117,7 +117,7 @@ public class EvccHandler extends BaseThingHandler { try { evccAPI.setTargetCharge(loadpoint, targetSoC, targetTimeZDT); } catch (DateTimeParseException e) { - logger.debug("Failed to set target charge", e); + logger.debug("Failed to set target charge: ", e); } } } @@ -186,7 +186,7 @@ public class EvccHandler extends BaseThingHandler { */ private void refresh() { logger.debug("Running refresh job ..."); - EvccAPI evccAPI = null; + EvccAPI evccAPI; evccAPI = this.evccAPI; if (evccAPI == null) { return; @@ -194,7 +194,7 @@ public class EvccHandler extends BaseThingHandler { try { this.result = evccAPI.getResult(); } catch (EvccApiException e) { - logger.debug("Failed to get state"); + logger.debug("Failed to get state: ", e); } Result result = this.result; if (result == null) { @@ -309,28 +309,28 @@ public class EvccHandler extends BaseThingHandler { ChannelUID channel; boolean batteryConfigured = this.batteryConfigured; if (batteryConfigured) { - double batteryPower = result.getBatteryPower(); + float batteryPower = result.getBatteryPower(); channel = new ChannelUID(getThing().getUID(), "general", CHANNEL_BATTERY_POWER); updateState(channel, new QuantityType<>(batteryPower, Units.WATT)); - int batterySoC = result.getBatterySoC(); + float batterySoC = result.getBatterySoC(); channel = new ChannelUID(getThing().getUID(), "general", CHANNEL_BATTERY_SOC); updateState(channel, new QuantityType<>(batterySoC, Units.PERCENT)); - int batteryPrioritySoC = result.getBatterySoC(); + float batteryPrioritySoC = result.getBatterySoC(); channel = new ChannelUID(getThing().getUID(), "general", CHANNEL_BATTERY_PRIORITY_SOC); updateState(channel, new QuantityType<>(batteryPrioritySoC, Units.PERCENT)); } boolean gridConfigured = this.gridConfigured; if (gridConfigured) { - double gridPower = result.getGridPower(); + float gridPower = result.getGridPower(); channel = new ChannelUID(getThing().getUID(), "general", CHANNEL_GRID_POWER); updateState(channel, new QuantityType<>(gridPower, Units.WATT)); } - double homePower = result.getHomePower(); + float homePower = result.getHomePower(); channel = new ChannelUID(getThing().getUID(), "general", CHANNEL_HOME_POWER); updateState(channel, new QuantityType<>(homePower, Units.WATT)); boolean pvConfigured = this.pvConfigured; if (pvConfigured) { - double pvPower = result.getPvPower(); + float pvPower = result.getPvPower(); channel = new ChannelUID(getThing().getUID(), "general", CHANNEL_PV_POWER); updateState(channel, new QuantityType<>(pvPower, Units.WATT)); } @@ -347,22 +347,22 @@ public class EvccHandler extends BaseThingHandler { int activePhases = loadpoint.getActivePhases(); channel = new ChannelUID(getThing().getUID(), loadpointName, CHANNEL_LOADPOINT_ACTIVE_PHASES); updateState(channel, new DecimalType(activePhases)); - double chargeCurrent = loadpoint.getChargeCurrent(); + float chargeCurrent = loadpoint.getChargeCurrent(); channel = new ChannelUID(getThing().getUID(), loadpointName, CHANNEL_LOADPOINT_CHARGE_CURRENT); updateState(channel, new QuantityType<>(chargeCurrent, Units.AMPERE)); long chargeDuration = loadpoint.getChargeDuration(); channel = new ChannelUID(getThing().getUID(), loadpointName, CHANNEL_LOADPOINT_CHARGE_DURATION); updateState(channel, new QuantityType<>(chargeDuration, MetricPrefix.NANO(Units.SECOND))); - double chargePower = loadpoint.getChargePower(); + float chargePower = loadpoint.getChargePower(); channel = new ChannelUID(getThing().getUID(), loadpointName, CHANNEL_LOADPOINT_CHARGE_POWER); updateState(channel, new QuantityType<>(chargePower, Units.WATT)); long chargeRemainingDuration = loadpoint.getChargeRemainingDuration(); channel = new ChannelUID(getThing().getUID(), loadpointName, CHANNEL_LOADPOINT_CHARGE_REMAINING_DURATION); updateState(channel, new QuantityType<>(chargeRemainingDuration, MetricPrefix.NANO(Units.SECOND))); - double chargeRemainingEnergy = loadpoint.getChargeRemainingEnergy(); + float chargeRemainingEnergy = loadpoint.getChargeRemainingEnergy(); channel = new ChannelUID(getThing().getUID(), loadpointName, CHANNEL_LOADPOINT_CHARGE_REMAINING_ENERGY); updateState(channel, new QuantityType<>(chargeRemainingEnergy, Units.WATT_HOUR)); - double chargedEnergy = loadpoint.getChargedEnergy(); + float chargedEnergy = loadpoint.getChargedEnergy(); channel = new ChannelUID(getThing().getUID(), loadpointName, CHANNEL_LOADPOINT_CHARGED_ENERGY); updateState(channel, new QuantityType<>(chargedEnergy, Units.WATT_HOUR)); boolean charging = loadpoint.getCharging(); @@ -380,13 +380,13 @@ public class EvccHandler extends BaseThingHandler { boolean hasVehicle = loadpoint.getHasVehicle(); channel = new ChannelUID(getThing().getUID(), loadpointName, CHANNEL_LOADPOINT_HAS_VEHICLE); updateState(channel, OnOffType.from(hasVehicle)); - double maxCurrent = loadpoint.getMaxCurrent(); + float maxCurrent = loadpoint.getMaxCurrent(); channel = new ChannelUID(getThing().getUID(), loadpointName, CHANNEL_LOADPOINT_MAX_CURRENT); updateState(channel, new QuantityType<>(maxCurrent, Units.AMPERE)); - double minCurrent = loadpoint.getMinCurrent(); + float minCurrent = loadpoint.getMinCurrent(); channel = new ChannelUID(getThing().getUID(), loadpointName, CHANNEL_LOADPOINT_MIN_CURRENT); updateState(channel, new QuantityType<>(minCurrent, Units.AMPERE)); - int minSoC = loadpoint.getMinSoC(); + float minSoC = loadpoint.getMinSoC(); channel = new ChannelUID(getThing().getUID(), loadpointName, CHANNEL_LOADPOINT_MIN_SOC); updateState(channel, new QuantityType<>(minSoC, Units.PERCENT)); String mode = loadpoint.getMode(); @@ -414,19 +414,19 @@ public class EvccHandler extends BaseThingHandler { String title = loadpoint.getTitle(); channel = new ChannelUID(getThing().getUID(), loadpointName, CHANNEL_LOADPOINT_TITLE); updateState(channel, new StringType(title)); - double vehicleCapacity = loadpoint.getVehicleCapacity(); + float vehicleCapacity = loadpoint.getVehicleCapacity(); channel = new ChannelUID(getThing().getUID(), loadpointName, CHANNEL_LOADPOINT_VEHICLE_CAPACITY); updateState(channel, new QuantityType<>(vehicleCapacity, Units.WATT_HOUR)); - double vehicleOdometer = loadpoint.getVehicleOdometer(); + float vehicleOdometer = loadpoint.getVehicleOdometer(); channel = new ChannelUID(getThing().getUID(), loadpointName, CHANNEL_LOADPOINT_VEHICLE_ODOMETER); updateState(channel, new QuantityType<>(vehicleOdometer, MetricPrefix.KILO(SIUnits.METRE))); boolean vehiclePresent = loadpoint.getVehiclePresent(); channel = new ChannelUID(getThing().getUID(), loadpointName, CHANNEL_LOADPOINT_VEHICLE_PRESENT); updateState(channel, OnOffType.from(vehiclePresent)); - long vehicleRange = loadpoint.getVehicleRange(); + float vehicleRange = loadpoint.getVehicleRange(); channel = new ChannelUID(getThing().getUID(), loadpointName, CHANNEL_LOADPOINT_VEHICLE_RANGE); updateState(channel, new QuantityType<>(vehicleRange, MetricPrefix.KILO(SIUnits.METRE))); - int vehicleSoC = loadpoint.getVehicleSoC(); + float vehicleSoC = loadpoint.getVehicleSoC(); channel = new ChannelUID(getThing().getUID(), loadpointName, CHANNEL_LOADPOINT_VEHICLE_SOC); updateState(channel, new QuantityType<>(vehicleSoC, Units.PERCENT)); String vehicleTitle = loadpoint.getVehicleTitle(); diff --git a/bundles/org.openhab.binding.evcc/src/main/java/org/openhab/binding/evcc/internal/api/EvccAPI.java b/bundles/org.openhab.binding.evcc/src/main/java/org/openhab/binding/evcc/internal/api/EvccAPI.java index 9cc473340..17c97d42a 100644 --- a/bundles/org.openhab.binding.evcc/src/main/java/org/openhab/binding/evcc/internal/api/EvccAPI.java +++ b/bundles/org.openhab.binding.evcc/src/main/java/org/openhab/binding/evcc/internal/api/EvccAPI.java @@ -38,7 +38,7 @@ import com.google.gson.JsonSyntaxException; public class EvccAPI { private final Logger logger = LoggerFactory.getLogger(EvccAPI.class); private final Gson gson = new Gson(); - private String host = ""; + private String host; public EvccAPI(String host) { this.host = host; @@ -48,9 +48,9 @@ public class EvccAPI { * Make a HTTP request. * * @param url full request URL - * @param method reguest method, e.g. GET, POST + * @param method request method, e.g. GET, POST * @return the response body - * @throws {@link EvccApiException} if HTTP request failed + * @throws EvccApiException if HTTP request failed */ private String httpRequest(String url, String method) throws EvccApiException { try { @@ -67,10 +67,9 @@ public class EvccAPI { // API calls to evcc /** * Get the status from evcc. - * - * @param host hostname of IP address of the evcc instance + * * @return {@link Result} result object from API - * @throws {@link EvccApiException} if status request failed + * @throws EvccApiException if status request failed */ public Result getResult() throws EvccApiException { final String response = httpRequest(this.host + EVCC_REST_API + "state", "GET"); @@ -110,7 +109,7 @@ public class EvccAPI { return httpRequest(this.host + EVCC_REST_API + "loadpoints/" + loadpoint + "/maxcurrent/" + maxCurrent, "POST"); } - public String setTargetCharge(int loadpoint, int targetSoC, ZonedDateTime targetTime) throws EvccApiException { + public String setTargetCharge(int loadpoint, float targetSoC, ZonedDateTime targetTime) throws EvccApiException { DateTimeFormatter formatter = DateTimeFormatter.ISO_LOCAL_DATE_TIME; return httpRequest(this.host + EVCC_REST_API + "loadpoints/" + loadpoint + "/targetcharge/" + targetSoC + "/" + targetTime.toLocalDateTime().format(formatter), "POST"); diff --git a/bundles/org.openhab.binding.evcc/src/main/java/org/openhab/binding/evcc/internal/api/dto/Loadpoint.java b/bundles/org.openhab.binding.evcc/src/main/java/org/openhab/binding/evcc/internal/api/dto/Loadpoint.java index 732af3a1a..cc98dee41 100644 --- a/bundles/org.openhab.binding.evcc/src/main/java/org/openhab/binding/evcc/internal/api/dto/Loadpoint.java +++ b/bundles/org.openhab.binding.evcc/src/main/java/org/openhab/binding/evcc/internal/api/dto/Loadpoint.java @@ -16,7 +16,7 @@ import com.google.gson.annotations.SerializedName; /** * This class represents a loadpoint object of the status response (/api/state). - * This DTO was written for evcc version 0.91. + * This DTO was written for evcc version 0.106.3 * * @author Florian Hotze - Initial contribution */ @@ -28,22 +28,22 @@ public class Loadpoint { private int activePhases; @SerializedName("chargeCurrent") - private double chargeCurrent; + private float chargeCurrent; @SerializedName("chargeDuration") private long chargeDuration; @SerializedName("chargePower") - private double chargePower; + private float chargePower; @SerializedName("chargeRemainingDuration") private long chargeRemainingDuration; @SerializedName("chargeRemainingEnergy") - private double chargeRemainingEnergy; + private float chargeRemainingEnergy; @SerializedName("chargedEnergy") - private double chargedEnergy; + private float chargedEnergy; @SerializedName("charging") private boolean charging; @@ -64,13 +64,13 @@ public class Loadpoint { private int loadpoint; @SerializedName("maxCurrent") - private double maxCurrent; + private float maxCurrent; @SerializedName("minCurrent") - private double minCurrent; + private float minCurrent; @SerializedName("minSoC") - private int minSoC; + private float minSoC; @SerializedName("mode") private String mode; @@ -85,7 +85,7 @@ public class Loadpoint { private long pvRemaining; @SerializedName("targetSoC") - private int targetSoC; + private float targetSoC; @SerializedName("targetTime") private String targetTime; @@ -94,19 +94,19 @@ public class Loadpoint { private String title; @SerializedName("vehicleCapacity") - private long vehicleCapacity; + private float vehicleCapacity; @SerializedName("vehicleOdometer") - private double vehicleOdometer; + private float vehicleOdometer; @SerializedName("vehiclePresent") private boolean vehiclePresent; @SerializedName("vehicleRange") - private long vehicleRange; + private float vehicleRange; @SerializedName("vehicleSoC") - private int vehicleSoC; + private float vehicleSoC; @SerializedName("vehicleTitle") private String vehicleTitle; @@ -121,7 +121,7 @@ public class Loadpoint { /** * @return charge current */ - public double getChargeCurrent() { + public float getChargeCurrent() { return chargeCurrent; } @@ -135,7 +135,7 @@ public class Loadpoint { /** * @return charge power */ - public double getChargePower() { + public float getChargePower() { return chargePower; } @@ -149,14 +149,14 @@ public class Loadpoint { /** * @return charge remaining energy until the target SoC is reached */ - public double getChargeRemainingEnergy() { + public float getChargeRemainingEnergy() { return chargeRemainingEnergy; } /** * @return charged energy */ - public double getChargedEnergy() { + public float getChargedEnergy() { return chargedEnergy; } @@ -205,21 +205,21 @@ public class Loadpoint { /** * @return maximum current */ - public double getMaxCurrent() { + public float getMaxCurrent() { return maxCurrent; } /** * @return minimum current */ - public double getMinCurrent() { + public float getMinCurrent() { return minCurrent; } /** * @return minimum state of charge */ - public int getMinSoC() { + public float getMinSoC() { return minSoC; } @@ -254,7 +254,7 @@ public class Loadpoint { /** * @return target state of charge (SoC) */ - public int getTargetSoC() { + public float getTargetSoC() { return targetSoC; } @@ -275,14 +275,14 @@ public class Loadpoint { /** * @return vehicle's capacity */ - public double getVehicleCapacity() { + public float getVehicleCapacity() { return vehicleCapacity; } /** * @return vehicle's odometer */ - public double getVehicleOdometer() { + public float getVehicleOdometer() { return vehicleOdometer; } @@ -296,14 +296,14 @@ public class Loadpoint { /** * @return vehicle's range */ - public long getVehicleRange() { + public float getVehicleRange() { return vehicleRange; } /** * @return vehicle's state of charge (SoC) */ - public int getVehicleSoC() { + public float getVehicleSoC() { return vehicleSoC; } diff --git a/bundles/org.openhab.binding.evcc/src/main/java/org/openhab/binding/evcc/internal/api/dto/Result.java b/bundles/org.openhab.binding.evcc/src/main/java/org/openhab/binding/evcc/internal/api/dto/Result.java index 6a613e8b2..e1ab2aa6a 100644 --- a/bundles/org.openhab.binding.evcc/src/main/java/org/openhab/binding/evcc/internal/api/dto/Result.java +++ b/bundles/org.openhab.binding.evcc/src/main/java/org/openhab/binding/evcc/internal/api/dto/Result.java @@ -16,7 +16,7 @@ import com.google.gson.annotations.SerializedName; /** * This class represents the result object of the status response (/api/state). - * This DTO was written for evcc version 0.91. + * This DTO was written for evcc version 0.106.3 * * @author Florian Hotze - Initial contribution */ @@ -24,39 +24,37 @@ public class Result { // Data types from https://github.com/evcc-io/evcc/blob/master/api/api.go // and from https://docs.evcc.io/docs/reference/configuration/messaging/#msg - // TO DO LATER - // @SerializedName("auth") - // private Auth auth; + // "auth" is left out because it does not provide any useful information @SerializedName("batteryConfigured") private boolean batteryConfigured; @SerializedName("batteryPower") - private double batteryPower; + private float batteryPower; @SerializedName("batterySoC") - private int batterySoC; + private float batterySoC; @SerializedName("gridConfigured") private boolean gridConfigured; @SerializedName("gridPower") - private double gridPower; + private float gridPower; @SerializedName("homePower") - private double homePower; + private float homePower; @SerializedName("loadpoints") private Loadpoint[] loadpoints; @SerializedName("prioritySoC") - private double batteryPrioritySoC; + private float batteryPrioritySoC; @SerializedName("pvConfigured") private boolean pvConfigured; @SerializedName("pvPower") - private double pvPower; + private float pvPower; @SerializedName("siteTitle") private String siteTitle; @@ -71,21 +69,21 @@ public class Result { /** * @return battery's power */ - public double getBatteryPower() { + public float getBatteryPower() { return batteryPower; } /** * @return battery's priority state of charge */ - public double getBatteryPrioritySoC() { + public float getBatteryPrioritySoC() { return batteryPrioritySoC; } /** * @return battery's state of charge */ - public int getBatterySoC() { + public float getBatterySoC() { return batterySoC; } @@ -99,14 +97,14 @@ public class Result { /** * @return grid's power */ - public double getGridPower() { + public float getGridPower() { return gridPower; } /** * @return home's power */ - public double getHomePower() { + public float getHomePower() { return homePower; } @@ -127,7 +125,7 @@ public class Result { /** * @return pv's power */ - public double getPvPower() { + public float getPvPower() { return pvPower; } diff --git a/bundles/org.openhab.binding.evcc/src/main/java/org/openhab/binding/evcc/internal/api/dto/Status.java b/bundles/org.openhab.binding.evcc/src/main/java/org/openhab/binding/evcc/internal/api/dto/Status.java index b70e1f9e8..ae37608b3 100644 --- a/bundles/org.openhab.binding.evcc/src/main/java/org/openhab/binding/evcc/internal/api/dto/Status.java +++ b/bundles/org.openhab.binding.evcc/src/main/java/org/openhab/binding/evcc/internal/api/dto/Status.java @@ -16,7 +16,7 @@ import com.google.gson.annotations.SerializedName; /** * This class represents the status response (/api/state). - * This DTO was written for evcc version 0.91. + * This DTO was written for evcc version 0.106.3 * * @author Florian Hotze - Initial contribution */