From 1b02f98b46b6f16ab81ac8611366e2784c4228f1 Mon Sep 17 00:00:00 2001 From: Bernd Weymann Date: Mon, 30 Dec 2024 13:05:20 +0100 Subject: [PATCH] bugfix discovery and thing properties (#18003) Signed-off-by: Bernd Weymann --- .../internal/handler/AccountHandler.java | 16 +++++++++++----- 1 file changed, 11 insertions(+), 5 deletions(-) diff --git a/bundles/org.openhab.binding.mercedesme/src/main/java/org/openhab/binding/mercedesme/internal/handler/AccountHandler.java b/bundles/org.openhab.binding.mercedesme/src/main/java/org/openhab/binding/mercedesme/internal/handler/AccountHandler.java index ab2d583ad0c..b5d6e8646d8 100644 --- a/bundles/org.openhab.binding.mercedesme/src/main/java/org/openhab/binding/mercedesme/internal/handler/AccountHandler.java +++ b/bundles/org.openhab.binding.mercedesme/src/main/java/org/openhab/binding/mercedesme/internal/handler/AccountHandler.java @@ -271,6 +271,7 @@ public class AccountHandler extends BaseBridgeHandler implements AccessTokenRefr public void registerVin(String vin, VehicleHandler handler) { discoveryService.vehicleRemove(this, vin, handler.getThing().getThingTypeUID().getId()); activeVehicleHandlerMap.put(vin, handler); + discovery(vin); // update properties for added vehicle VEPUpdate updateForVin = vepUpdateMap.get(vin); if (updateForVin != null) { handler.enqueueUpdate(updateForVin); @@ -340,7 +341,6 @@ public class AccountHandler extends BaseBridgeHandler implements AccessTokenRefr PushMessage pm = VehicleEvents.PushMessage.parseFrom(array); if (pm.hasVepUpdates()) { boolean distributed = distributeVepUpdates(pm.getVepUpdates().getUpdatesMap()); - logger.trace("Distributed VEPUpdate {}", distributed); if (distributed) { AcknowledgeVEPUpdatesByVIN ack = AcknowledgeVEPUpdatesByVIN.newBuilder() .setSequenceNumber(pm.getVepUpdates().getSequenceNumber()).build(); @@ -349,7 +349,7 @@ public class AccountHandler extends BaseBridgeHandler implements AccessTokenRefr } } else if (pm.hasAssignedVehicles()) { for (int i = 0; i < pm.getAssignedVehicles().getVinsCount(); i++) { - String vin = pm.getAssignedVehicles().getVins(0); + String vin = pm.getAssignedVehicles().getVins(i); discovery(vin); } AcknowledgeAssignedVehicles ack = AcknowledgeAssignedVehicles.newBuilder().build(); @@ -394,6 +394,7 @@ public class AccountHandler extends BaseBridgeHandler implements AccessTokenRefr } }); notFoundList.forEach(vin -> { + discovery(vin); // add vehicle to discovery logger.trace("No VehicleHandler available for VIN {}", vin); }); return notFoundList.isEmpty(); @@ -410,13 +411,18 @@ public class AccountHandler extends BaseBridgeHandler implements AccessTokenRefr }); } + /** + * Updates properties for existing handlers or delivers discovery result + * + * @param vin of discovered vehicle + */ @SuppressWarnings("null") public void discovery(String vin) { if (activeVehicleHandlerMap.containsKey(vin)) { VehicleHandler vh = activeVehicleHandlerMap.get(vin); - if (vh.getThing().getProperties().isEmpty()) { - vh.getThing().setProperties(getStringCapabilities(vin)); - } + Map properties = getStringCapabilities(vin); + properties.putAll(vh.getThing().getProperties()); + vh.getThing().setProperties(properties); } else { if (!capabilitiesMap.containsKey(vin)) { // only report new discovery if capabilities aren't discovered yet