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 f658f23869b..afacdfe0be6 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 @@ -75,6 +75,7 @@ public class EvccAPI { */ public Result getResult() throws EvccApiException { final String response = httpRequest(this.host + EVCC_REST_API + "state", "GET"); + logger.trace("API Response >> {}", response); try { Status status = gson.fromJson(response, Status.class); if (status == null) { 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 3792e43ce5b..6b9a6f79d89 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 @@ -271,7 +271,7 @@ public class Loadpoint { * @return vehicle's title/name */ public String getVehicleName() { - return vehicleName; + return vehicleName != null ? vehicleName.replace(":", "-") : vehicleName; } /** 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 598ee3f7028..4da0060bd81 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 @@ -12,7 +12,9 @@ */ package org.openhab.binding.evcc.internal.api.dto; +import java.util.HashMap; import java.util.Map; +import java.util.Map.Entry; import com.google.gson.annotations.SerializedName; @@ -219,7 +221,12 @@ public class Result { } public Map getVehicles() { - return vehicles; + Map correctedMap = new HashMap<>(); + for (Entry entry : vehicles.entrySet()) { + // The key from the vehicles map is used as uid, so it should not contain semicolons. + correctedMap.put(entry.getKey().replace(":", "-"), entry.getValue()); + } + return correctedMap; } /**