2 * Copyright (c) 2010-2023 Contributors to the openHAB project
4 * See the NOTICE file(s) distributed with this work for additional
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
11 * SPDX-License-Identifier: EPL-2.0
13 package org.openhab.binding.echonetlite.internal;
15 import static org.openhab.binding.echonetlite.internal.EchonetLiteBindingConstants.PROPERTY_NAME_CLASS_CODE;
16 import static org.openhab.binding.echonetlite.internal.EchonetLiteBindingConstants.PROPERTY_NAME_GROUP_CODE;
17 import static org.openhab.binding.echonetlite.internal.EchonetLiteBindingConstants.PROPERTY_NAME_HOSTNAME;
18 import static org.openhab.binding.echonetlite.internal.EchonetLiteBindingConstants.PROPERTY_NAME_INSTANCE;
19 import static org.openhab.binding.echonetlite.internal.EchonetLiteBindingConstants.PROPERTY_NAME_INSTANCE_KEY;
20 import static org.openhab.binding.echonetlite.internal.EchonetLiteBindingConstants.PROPERTY_NAME_PORT;
21 import static org.openhab.binding.echonetlite.internal.EchonetLiteBindingConstants.THING_TYPE_ECHONET_DEVICE;
25 import org.eclipse.jdt.annotation.NonNullByDefault;
26 import org.eclipse.jdt.annotation.Nullable;
27 import org.openhab.core.config.discovery.AbstractDiscoveryService;
28 import org.openhab.core.config.discovery.DiscoveryResult;
29 import org.openhab.core.config.discovery.DiscoveryResultBuilder;
30 import org.openhab.core.thing.ThingUID;
31 import org.openhab.core.thing.binding.ThingHandler;
32 import org.openhab.core.thing.binding.ThingHandlerService;
33 import org.slf4j.Logger;
34 import org.slf4j.LoggerFactory;
37 * @author Michael Barker - Initial contribution
40 public class EchonetDiscoveryService extends AbstractDiscoveryService
41 implements EchonetDiscoveryListener, ThingHandlerService {
43 private final Logger logger = LoggerFactory.getLogger(EchonetDiscoveryService.class);
46 private EchonetLiteBridgeHandler bridgeHandler;
48 public EchonetDiscoveryService() {
49 super(Set.of(THING_TYPE_ECHONET_DEVICE), 10);
53 protected void startScan() {
54 final EchonetLiteBridgeHandler bridgeHandler = this.bridgeHandler;
55 logger.debug("startScan: {}", bridgeHandler);
56 if (null != bridgeHandler) {
57 bridgeHandler.startDiscovery(this);
62 protected synchronized void stopScan() {
63 final EchonetLiteBridgeHandler bridgeHandler = this.bridgeHandler;
64 logger.debug("stopScan: {}", bridgeHandler);
65 if (null != bridgeHandler) {
66 bridgeHandler.stopDiscovery();
71 public void onDeviceFound(String identifier, InstanceKey instanceKey) {
72 final EchonetLiteBridgeHandler bridgeHandler = this.bridgeHandler;
74 if (null == bridgeHandler) {
78 final DiscoveryResult discoveryResult = DiscoveryResultBuilder
79 .create(new ThingUID(THING_TYPE_ECHONET_DEVICE, bridgeHandler.getThing().getUID(), identifier))
80 .withProperty(PROPERTY_NAME_INSTANCE_KEY, instanceKey.representationProperty())
81 .withProperty(PROPERTY_NAME_HOSTNAME, instanceKey.address.getAddress().getHostAddress())
82 .withProperty(PROPERTY_NAME_PORT, instanceKey.address.getPort())
83 .withProperty(PROPERTY_NAME_GROUP_CODE, instanceKey.klass.groupCode())
84 .withProperty(PROPERTY_NAME_CLASS_CODE, instanceKey.klass.classCode())
85 .withProperty(PROPERTY_NAME_INSTANCE, instanceKey.instance)
86 .withBridge(bridgeHandler.getThing().getUID()).withRepresentationProperty(PROPERTY_NAME_INSTANCE_KEY)
88 thingDiscovered(discoveryResult);
92 public void deactivate() {
93 ThingHandlerService.super.deactivate();
97 public void activate() {
98 ThingHandlerService.super.activate();
102 public void setThingHandler(ThingHandler thingHandler) {
103 if (thingHandler instanceof EchonetLiteBridgeHandler) {
104 this.bridgeHandler = (EchonetLiteBridgeHandler) thingHandler;
109 public @Nullable ThingHandler getThingHandler() {
110 return bridgeHandler;