]> git.basschouten.com Git - openhab-addons.git/blob
7a49db4e15b4fe7f2ff9ed4c7bd36362ec238c8e
[openhab-addons.git] /
1 /**
2  * Copyright (c) 2010-2023 Contributors to the openHAB project
3  *
4  * See the NOTICE file(s) distributed with this work for additional
5  * information.
6  *
7  * This program and the accompanying materials are made available under the
8  * terms of the Eclipse Public License 2.0 which is available at
9  * http://www.eclipse.org/legal/epl-2.0
10  *
11  * SPDX-License-Identifier: EPL-2.0
12  */
13 package org.openhab.binding.rfxcom.internal.discovery;
14
15 import static org.openhab.binding.rfxcom.internal.messages.RFXComBaseMessage.ID_DELIMITER;
16
17 import java.util.Set;
18
19 import org.eclipse.jdt.annotation.NonNullByDefault;
20 import org.eclipse.jdt.annotation.Nullable;
21 import org.openhab.binding.rfxcom.internal.DeviceMessageListener;
22 import org.openhab.binding.rfxcom.internal.RFXComBindingConstants;
23 import org.openhab.binding.rfxcom.internal.exceptions.RFXComException;
24 import org.openhab.binding.rfxcom.internal.handler.RFXComBridgeHandler;
25 import org.openhab.binding.rfxcom.internal.messages.RFXComDeviceMessage;
26 import org.openhab.core.config.discovery.AbstractDiscoveryService;
27 import org.openhab.core.config.discovery.DiscoveryResultBuilder;
28 import org.openhab.core.thing.ThingTypeUID;
29 import org.openhab.core.thing.ThingUID;
30 import org.openhab.core.thing.binding.ThingHandler;
31 import org.openhab.core.thing.binding.ThingHandlerService;
32 import org.slf4j.Logger;
33 import org.slf4j.LoggerFactory;
34
35 /**
36  * The {@link RFXComDeviceDiscoveryService} class is used to discover RFXCOM
37  * devices that send messages to RFXCOM bridge.
38  *
39  * @author Pauli Anttila - Initial contribution
40  * @author Laurent Garnier - use ThingHandlerService
41  */
42 @NonNullByDefault
43 public class RFXComDeviceDiscoveryService extends AbstractDiscoveryService
44         implements DeviceMessageListener, ThingHandlerService {
45     private final Logger logger = LoggerFactory.getLogger(RFXComDeviceDiscoveryService.class);
46     private final int DISCOVERY_TTL = 3600;
47
48     private @Nullable RFXComBridgeHandler bridgeHandler;
49
50     public RFXComDeviceDiscoveryService() {
51         super(null, 1, false);
52     }
53
54     @Override
55     public void setThingHandler(ThingHandler handler) {
56         if (handler instanceof RFXComBridgeHandler) {
57             bridgeHandler = (RFXComBridgeHandler) handler;
58         }
59     }
60
61     @Override
62     public @Nullable ThingHandler getThingHandler() {
63         return bridgeHandler;
64     }
65
66     @Override
67     public void activate() {
68         super.activate(null);
69         RFXComBridgeHandler handler = bridgeHandler;
70         if (handler != null) {
71             handler.registerDeviceStatusListener(this);
72         }
73     }
74
75     @Override
76     public void deactivate() {
77         RFXComBridgeHandler handler = bridgeHandler;
78         if (handler != null) {
79             handler.unregisterDeviceStatusListener(this);
80         }
81         super.deactivate();
82     }
83
84     @Override
85     public Set<ThingTypeUID> getSupportedThingTypes() {
86         return RFXComBindingConstants.SUPPORTED_DEVICE_THING_TYPES_UIDS;
87     }
88
89     @Override
90     protected void startScan() {
91         // this can be ignored here as we discover devices from received messages
92     }
93
94     @Override
95     public void onDeviceMessageReceived(ThingUID bridge, RFXComDeviceMessage message) throws RFXComException {
96         logger.trace("Received: bridge: {} message: {}", bridge, message);
97
98         String id = message.getDeviceId();
99         ThingTypeUID uid = RFXComBindingConstants.PACKET_TYPE_THING_TYPE_UID_MAP.get(message.getPacketType());
100         if (uid == null) {
101             logger.debug("cannot find uid for message {}", message);
102             return;
103         }
104         ThingUID thingUID = new ThingUID(uid, bridge, id.replace(ID_DELIMITER, "_"));
105
106         RFXComBridgeHandler handler = bridgeHandler;
107         if (handler == null) {
108             logger.trace("Ignoring RFXCOM {} with id '{}' - bridge handler is null", thingUID, id);
109         } else if (!handler.getConfiguration().disableDiscovery) {
110             logger.trace("Adding new RFXCOM {} with id '{}' to inbox", thingUID, id);
111             DiscoveryResultBuilder discoveryResultBuilder = DiscoveryResultBuilder.create(thingUID).withBridge(bridge)
112                     .withTTL(DISCOVERY_TTL);
113             message.addDevicePropertiesTo(discoveryResultBuilder);
114
115             thingDiscovered(discoveryResultBuilder.build());
116         } else {
117             logger.trace("Ignoring RFXCOM {} with id '{}' - discovery disabled", thingUID, id);
118         }
119     }
120 }