mirror of
https://github.com/openhab/openhab-addons.git
synced 2025-01-25 14:55:55 +01:00
Adapt to core changes (ThingHandlerService) (#16107)
Related to: https://github.com/openhab/openhab-core/pull/3957 Signed-off-by: Jan N. Klug <github@klug.nrw> Signed-off-by: Ciprian Pascu <contact@ciprianpascu.ro>
This commit is contained in:
parent
52b1ad95d6
commit
fc8fa6d119
@ -64,7 +64,6 @@ public class AirQualityHandlerFactory extends BaseThingHandlerFactory {
|
||||
|
||||
return THING_TYPE_STATION.equals(thingTypeUID)
|
||||
? new AirQualityStationHandler(thing, timeZoneProvider, locationProvider)
|
||||
: BRIDGE_TYPE_API.equals(thingTypeUID) ? new AirQualityBridgeHandler((Bridge) thing, locationProvider)
|
||||
: null;
|
||||
: BRIDGE_TYPE_API.equals(thingTypeUID) ? new AirQualityBridgeHandler((Bridge) thing) : null;
|
||||
}
|
||||
}
|
||||
|
@ -18,18 +18,18 @@ import static org.openhab.binding.airquality.internal.config.AirQualityConfigura
|
||||
import java.util.Set;
|
||||
|
||||
import org.eclipse.jdt.annotation.NonNullByDefault;
|
||||
import org.eclipse.jdt.annotation.Nullable;
|
||||
import org.openhab.binding.airquality.internal.handler.AirQualityBridgeHandler;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.config.discovery.DiscoveryService;
|
||||
import org.openhab.core.i18n.LocationProvider;
|
||||
import org.openhab.core.library.types.PointType;
|
||||
import org.openhab.core.thing.ThingTypeUID;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Activate;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.Reference;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -38,40 +38,28 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Gaël L'hopital - Initial Contribution
|
||||
*/
|
||||
@Component(service = DiscoveryService.class, configurationPid = "discovery.airquality")
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = AirQualityDiscoveryService.class, configurationPid = "discovery.airquality")
|
||||
@NonNullByDefault
|
||||
public class AirQualityDiscoveryService extends AbstractDiscoveryService implements ThingHandlerService {
|
||||
public class AirQualityDiscoveryService extends AbstractThingHandlerDiscoveryService<AirQualityBridgeHandler>
|
||||
implements ThingHandlerService {
|
||||
private static final int DISCOVER_TIMEOUT_SECONDS = 2;
|
||||
private static final Set<ThingTypeUID> SUPPORTED_THING_TYPES_UIDS = Set.of(THING_TYPE_STATION);
|
||||
|
||||
private final Logger logger = LoggerFactory.getLogger(AirQualityDiscoveryService.class);
|
||||
|
||||
private @Nullable LocationProvider locationProvider;
|
||||
private @Nullable AirQualityBridgeHandler bridgeHandler;
|
||||
private @NonNullByDefault({}) LocationProvider locationProvider;
|
||||
|
||||
/**
|
||||
* Creates an AirQualityDiscoveryService with enabled autostart.
|
||||
*/
|
||||
@Activate
|
||||
public AirQualityDiscoveryService() {
|
||||
super(SUPPORTED_THING_TYPES_UIDS, DISCOVER_TIMEOUT_SECONDS, false);
|
||||
super(AirQualityBridgeHandler.class, SUPPORTED_THING_TYPES_UIDS, DISCOVER_TIMEOUT_SECONDS, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(@Nullable ThingHandler handler) {
|
||||
if (handler instanceof AirQualityBridgeHandler bridgeHandlerInstance) {
|
||||
this.bridgeHandler = bridgeHandlerInstance;
|
||||
this.locationProvider = bridgeHandler.getLocationProvider();
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return bridgeHandler;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
super.deactivate();
|
||||
@Reference(unbind = "-")
|
||||
public void bindLocationProvider(LocationProvider locationProvider) {
|
||||
this.locationProvider = locationProvider;
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -80,7 +68,7 @@ public class AirQualityDiscoveryService extends AbstractDiscoveryService impleme
|
||||
LocationProvider provider = locationProvider;
|
||||
if (provider != null) {
|
||||
PointType location = provider.getLocation();
|
||||
AirQualityBridgeHandler bridge = this.bridgeHandler;
|
||||
AirQualityBridgeHandler bridge = this.thingHandler;
|
||||
if (location == null || bridge == null) {
|
||||
logger.info("openHAB server location is not defined, will not provide any discovery results");
|
||||
return;
|
||||
|
@ -19,7 +19,6 @@ import org.eclipse.jdt.annotation.NonNullByDefault;
|
||||
import org.eclipse.jdt.annotation.Nullable;
|
||||
import org.openhab.binding.airquality.internal.api.ApiBridge;
|
||||
import org.openhab.binding.airquality.internal.discovery.AirQualityDiscoveryService;
|
||||
import org.openhab.core.i18n.LocationProvider;
|
||||
import org.openhab.core.thing.Bridge;
|
||||
import org.openhab.core.thing.ChannelUID;
|
||||
import org.openhab.core.thing.ThingStatus;
|
||||
@ -36,12 +35,10 @@ import org.openhab.core.types.Command;
|
||||
*/
|
||||
@NonNullByDefault
|
||||
public class AirQualityBridgeHandler extends BaseBridgeHandler {
|
||||
private final LocationProvider locationProvider;
|
||||
private @Nullable ApiBridge apiBridge;
|
||||
|
||||
public AirQualityBridgeHandler(Bridge bridge, LocationProvider locationProvider) {
|
||||
public AirQualityBridgeHandler(Bridge bridge) {
|
||||
super(bridge);
|
||||
this.locationProvider = locationProvider;
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -69,8 +66,4 @@ public class AirQualityBridgeHandler extends BaseBridgeHandler {
|
||||
public Collection<Class<? extends ThingHandlerService>> getServices() {
|
||||
return Set.of(AirQualityDiscoveryService.class);
|
||||
}
|
||||
|
||||
public LocationProvider getLocationProvider() {
|
||||
return locationProvider;
|
||||
}
|
||||
}
|
||||
|
@ -20,6 +20,8 @@ import org.openhab.core.automation.annotation.RuleAction;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -28,6 +30,7 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Bob Adair - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = BridgeActions.class)
|
||||
@ThingActionsScope(name = "alarmdecoder")
|
||||
@NonNullByDefault
|
||||
public class BridgeActions implements ThingActions {
|
||||
|
@ -24,8 +24,11 @@ import org.openhab.core.thing.binding.BaseDynamicStateDescriptionProvider;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.openhab.core.thing.type.ChannelTypeUID;
|
||||
import org.openhab.core.thing.type.DynamicStateDescriptionProvider;
|
||||
import org.openhab.core.types.StateDescription;
|
||||
import org.openhab.core.types.StateOption;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
|
||||
/**
|
||||
* This class provides the list of valid inputs for the input channel of a source.
|
||||
@ -33,6 +36,8 @@ import org.openhab.core.types.StateOption;
|
||||
* @author Kai Kreuzer - Initial contribution
|
||||
*
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = { DynamicStateDescriptionProvider.class,
|
||||
InputStateOptionProvider.class })
|
||||
@NonNullByDefault
|
||||
public class InputStateOptionProvider extends BaseDynamicStateDescriptionProvider implements ThingHandlerService {
|
||||
|
||||
|
@ -24,8 +24,11 @@ import org.openhab.core.thing.binding.BaseDynamicCommandDescriptionProvider;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.openhab.core.thing.type.ChannelTypeUID;
|
||||
import org.openhab.core.thing.type.DynamicCommandDescriptionProvider;
|
||||
import org.openhab.core.types.CommandDescription;
|
||||
import org.openhab.core.types.CommandOption;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
|
||||
/**
|
||||
* This class provides the list of valid commands for the preset channel.
|
||||
@ -33,6 +36,8 @@ import org.openhab.core.types.CommandOption;
|
||||
* @author Kai Kreuzer - Initial contribution
|
||||
*
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = { PresetCommandOptionProvider.class,
|
||||
DynamicCommandDescriptionProvider.class })
|
||||
@NonNullByDefault
|
||||
public class PresetCommandOptionProvider extends BaseDynamicCommandDescriptionProvider implements ThingHandlerService {
|
||||
|
||||
|
@ -30,6 +30,8 @@ import org.openhab.core.audio.UnsupportedAudioStreamException;
|
||||
import org.openhab.core.library.types.PercentType;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -39,6 +41,7 @@ import org.slf4j.LoggerFactory;
|
||||
* @author Kai Kreuzer - Initial contribution
|
||||
*
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = PAAudioSink.class)
|
||||
@NonNullByDefault
|
||||
public class PAAudioSink extends AudioSinkSync implements ThingHandlerService {
|
||||
|
||||
|
@ -16,19 +16,18 @@ import java.util.List;
|
||||
import java.util.Set;
|
||||
|
||||
import org.eclipse.jdt.annotation.NonNullByDefault;
|
||||
import org.eclipse.jdt.annotation.Nullable;
|
||||
import org.openhab.binding.amplipi.internal.AmpliPiBindingConstants;
|
||||
import org.openhab.binding.amplipi.internal.AmpliPiHandler;
|
||||
import org.openhab.binding.amplipi.internal.AmpliPiStatusChangeListener;
|
||||
import org.openhab.binding.amplipi.internal.model.Group;
|
||||
import org.openhab.binding.amplipi.internal.model.Status;
|
||||
import org.openhab.binding.amplipi.internal.model.Zone;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResult;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
|
||||
/**
|
||||
* This class discoveres the available zones and groups of the AmpliPi system.
|
||||
@ -36,30 +35,26 @@ import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
* @author Kai Kreuzer - Initial contribution
|
||||
*
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = AmpliPiZoneAndGroupDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class AmpliPiZoneAndGroupDiscoveryService extends AbstractDiscoveryService
|
||||
implements ThingHandlerService, AmpliPiStatusChangeListener {
|
||||
public class AmpliPiZoneAndGroupDiscoveryService extends AbstractThingHandlerDiscoveryService<AmpliPiHandler>
|
||||
implements AmpliPiStatusChangeListener {
|
||||
|
||||
private static final int TIMEOUT = 10;
|
||||
|
||||
private @Nullable AmpliPiHandler handler;
|
||||
private List<Zone> zones = List.of();
|
||||
private List<Group> groups = List.of();
|
||||
|
||||
public AmpliPiZoneAndGroupDiscoveryService() throws IllegalArgumentException {
|
||||
super(Set.of(AmpliPiBindingConstants.THING_TYPE_GROUP, AmpliPiBindingConstants.THING_TYPE_ZONE), TIMEOUT, true);
|
||||
super(AmpliPiHandler.class,
|
||||
Set.of(AmpliPiBindingConstants.THING_TYPE_GROUP, AmpliPiBindingConstants.THING_TYPE_ZONE), TIMEOUT,
|
||||
true);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(ThingHandler handler) {
|
||||
AmpliPiHandler ampliPiHander = (AmpliPiHandler) handler;
|
||||
ampliPiHander.addStatusChangeListener(this);
|
||||
this.handler = ampliPiHander;
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return handler;
|
||||
public void initialize() {
|
||||
thingHandler.addStatusChangeListener(this);
|
||||
super.initialize();
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -75,33 +70,27 @@ public class AmpliPiZoneAndGroupDiscoveryService extends AbstractDiscoveryServic
|
||||
}
|
||||
|
||||
private void createZone(Zone z) {
|
||||
if (handler != null) {
|
||||
ThingUID bridgeUID = handler.getThing().getUID();
|
||||
ThingUID bridgeUID = thingHandler.getThing().getUID();
|
||||
ThingUID uid = new ThingUID(AmpliPiBindingConstants.THING_TYPE_ZONE, bridgeUID, z.getId().toString());
|
||||
DiscoveryResult result = DiscoveryResultBuilder.create(uid).withLabel("AmpliPi Zone '" + z.getName() + "'")
|
||||
.withProperty(AmpliPiBindingConstants.CFG_PARAM_ID, z.getId()).withBridge(bridgeUID)
|
||||
.withRepresentationProperty(AmpliPiBindingConstants.CFG_PARAM_ID).build();
|
||||
thingDiscovered(result);
|
||||
}
|
||||
}
|
||||
|
||||
private void createGroup(Group g) {
|
||||
if (handler != null) {
|
||||
ThingUID bridgeUID = handler.getThing().getUID();
|
||||
ThingUID bridgeUID = thingHandler.getThing().getUID();
|
||||
ThingUID uid = new ThingUID(AmpliPiBindingConstants.THING_TYPE_GROUP, bridgeUID, g.getId().toString());
|
||||
DiscoveryResult result = DiscoveryResultBuilder.create(uid).withLabel("AmpliPi Group '" + g.getName() + "'")
|
||||
.withProperty(AmpliPiBindingConstants.CFG_PARAM_ID, g.getId()).withBridge(bridgeUID)
|
||||
.withRepresentationProperty(AmpliPiBindingConstants.CFG_PARAM_ID).build();
|
||||
thingDiscovered(result);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
if (handler != null) {
|
||||
handler.removeStatusChangeListener(this);
|
||||
}
|
||||
super.deactivate();
|
||||
public void dispose() {
|
||||
super.dispose();
|
||||
thingHandler.removeStatusChangeListener(this);
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -31,6 +31,8 @@ import org.openhab.core.library.types.QuantityType;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -39,6 +41,7 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Gaël L'hopital - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = AstroActions.class)
|
||||
@ThingActionsScope(name = "astro")
|
||||
@NonNullByDefault
|
||||
public class AstroActions implements ThingActions {
|
||||
|
@ -21,19 +21,19 @@ import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
|
||||
import org.eclipse.jdt.annotation.NonNullByDefault;
|
||||
import org.eclipse.jdt.annotation.Nullable;
|
||||
import org.openhab.binding.asuswrt.internal.structures.AsuswrtClientInfo;
|
||||
import org.openhab.binding.asuswrt.internal.structures.AsuswrtClientList;
|
||||
import org.openhab.binding.asuswrt.internal.structures.AsuswrtInterfaceList;
|
||||
import org.openhab.binding.asuswrt.internal.structures.AsuswrtIpInfo;
|
||||
import org.openhab.binding.asuswrt.internal.things.AsuswrtRouter;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResult;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.thing.Thing;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -42,38 +42,27 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Christian Wild - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = AbstractDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class AsuswrtDiscoveryService extends AbstractDiscoveryService implements ThingHandlerService {
|
||||
public class AsuswrtDiscoveryService extends AbstractThingHandlerDiscoveryService<AsuswrtRouter> {
|
||||
private final Logger logger = LoggerFactory.getLogger(AsuswrtDiscoveryService.class);
|
||||
private String uid = "";
|
||||
protected @NonNullByDefault({}) AsuswrtRouter router;
|
||||
|
||||
public AsuswrtDiscoveryService() {
|
||||
super(SUPPORTED_THING_TYPES_UIDS, DISCOVERY_TIMEOUT_S, false);
|
||||
super(AsuswrtRouter.class, SUPPORTED_THING_TYPES_UIDS, DISCOVERY_TIMEOUT_S, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void activate() {
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
super.deactivate();
|
||||
public void dispose() {
|
||||
super.dispose();
|
||||
removeAllResults();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(@Nullable ThingHandler handler) {
|
||||
if (handler instanceof AsuswrtRouter router) {
|
||||
router.setDiscoveryService(this);
|
||||
this.router = router;
|
||||
this.uid = router.getUID().getAsString();
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return this.router;
|
||||
public void initialize() {
|
||||
thingHandler.setDiscoveryService(this);
|
||||
uid = thingHandler.getThing().getUID().getAsString();
|
||||
super.initialize();
|
||||
}
|
||||
|
||||
/*
|
||||
@ -86,17 +75,15 @@ public class AsuswrtDiscoveryService extends AbstractDiscoveryService implements
|
||||
@Override
|
||||
public void startScan() {
|
||||
logger.trace("{} starting scan", uid);
|
||||
if (router != null) {
|
||||
/* query Data */
|
||||
router.queryDeviceData(false);
|
||||
thingHandler.queryDeviceData(false);
|
||||
/* discover interfaces */
|
||||
AsuswrtInterfaceList ifList = router.getInterfaces();
|
||||
AsuswrtInterfaceList ifList = thingHandler.getInterfaces();
|
||||
handleInterfaceScan(ifList);
|
||||
/* discover clients */
|
||||
AsuswrtClientList clientList = router.getClients();
|
||||
AsuswrtClientList clientList = thingHandler.getClients();
|
||||
handleClientScan(clientList);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void stopScan() {
|
||||
@ -156,17 +143,12 @@ public class AsuswrtDiscoveryService extends AbstractDiscoveryService implements
|
||||
properties.put(Thing.PROPERTY_MAC_ADDRESS, macAddress);
|
||||
|
||||
logger.debug("{} thing discovered: '{}", uid, label);
|
||||
if (this.router != null) {
|
||||
ThingUID bridgeUID = router.getUID();
|
||||
|
||||
ThingUID bridgeUID = thingHandler.getUID();
|
||||
ThingUID thingUID = new ThingUID(THING_TYPE_INTERFACE, bridgeUID, ifName);
|
||||
return DiscoveryResultBuilder.create(thingUID).withProperties(properties)
|
||||
.withRepresentationProperty(NETWORK_REPRESENTATION_PROPERTY).withBridge(bridgeUID).withLabel(label)
|
||||
.build();
|
||||
} else {
|
||||
ThingUID thingUID = new ThingUID(BINDING_ID, ifName);
|
||||
return DiscoveryResultBuilder.create(thingUID).withProperties(properties)
|
||||
.withRepresentationProperty(NETWORK_REPRESENTATION_PROPERTY).withLabel(label).build();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
@ -196,17 +178,10 @@ public class AsuswrtDiscoveryService extends AbstractDiscoveryService implements
|
||||
properties.put(CHANNEL_CLIENT_NICKNAME, nickName);
|
||||
|
||||
logger.debug("{} thing discovered: '{}", uid, label);
|
||||
if (this.router != null) {
|
||||
ThingUID bridgeUID = router.getUID();
|
||||
ThingUID bridgeUID = thingHandler.getUID();
|
||||
ThingUID thingUID = new ThingUID(THING_TYPE_CLIENT, bridgeUID, unformatedMac);
|
||||
return DiscoveryResultBuilder.create(thingUID).withProperties(properties)
|
||||
.withRepresentationProperty(CLIENT_REPRESENTATION_PROPERTY).withTTL(DISCOVERY_AUTOREMOVE_S)
|
||||
.withBridge(bridgeUID).withLabel(label).build();
|
||||
} else {
|
||||
ThingUID thingUID = new ThingUID(BINDING_ID, unformatedMac);
|
||||
return DiscoveryResultBuilder.create(thingUID).withProperties(properties)
|
||||
.withRepresentationProperty(CLIENT_REPRESENTATION_PROPERTY).withTTL(DISCOVERY_AUTOREMOVE_S)
|
||||
.withLabel(label).build();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -21,12 +21,15 @@ import org.openhab.core.automation.annotation.RuleAction;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
/**
|
||||
* @author Markus Pfleger - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = AutomowerActions.class)
|
||||
@ThingActionsScope(name = "automower")
|
||||
@NonNullByDefault
|
||||
public class AutomowerActions implements ThingActions {
|
||||
|
@ -22,19 +22,18 @@ import java.util.stream.Collectors;
|
||||
import java.util.stream.Stream;
|
||||
|
||||
import org.eclipse.jdt.annotation.NonNullByDefault;
|
||||
import org.eclipse.jdt.annotation.Nullable;
|
||||
import org.openhab.binding.avmfritz.internal.dto.AVMFritzBaseModel;
|
||||
import org.openhab.binding.avmfritz.internal.dto.GroupModel;
|
||||
import org.openhab.binding.avmfritz.internal.handler.AVMFritzBaseBridgeHandler;
|
||||
import org.openhab.binding.avmfritz.internal.hardware.FritzAhaStatusListener;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResult;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.config.discovery.DiscoveryService;
|
||||
import org.openhab.core.thing.ThingTypeUID;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -44,66 +43,50 @@ import org.slf4j.LoggerFactory;
|
||||
* @author Robert Bausdorf - Initial contribution
|
||||
* @author Christoph Weitkamp - Added support for groups
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = AVMFritzDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class AVMFritzDiscoveryService extends AbstractDiscoveryService
|
||||
implements FritzAhaStatusListener, DiscoveryService, ThingHandlerService {
|
||||
|
||||
public class AVMFritzDiscoveryService extends AbstractThingHandlerDiscoveryService<AVMFritzBaseBridgeHandler>
|
||||
implements FritzAhaStatusListener, DiscoveryService {
|
||||
private final Logger logger = LoggerFactory.getLogger(AVMFritzDiscoveryService.class);
|
||||
/**
|
||||
* Handler of the bridge of which devices have to be discovered.
|
||||
*/
|
||||
private @NonNullByDefault({}) AVMFritzBaseBridgeHandler bridgeHandler;
|
||||
|
||||
public AVMFritzDiscoveryService() {
|
||||
super(Stream
|
||||
super(AVMFritzBaseBridgeHandler.class, Stream
|
||||
.of(SUPPORTED_LIGHTING_THING_TYPES, SUPPORTED_BUTTON_THING_TYPES_UIDS, SUPPORTED_HEATING_THING_TYPES,
|
||||
SUPPORTED_DEVICE_THING_TYPES_UIDS, SUPPORTED_GROUP_THING_TYPES_UIDS)
|
||||
.flatMap(Set::stream).collect(Collectors.toUnmodifiableSet()), 30);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void activate() {
|
||||
super.activate(null);
|
||||
bridgeHandler.registerStatusListener(this);
|
||||
public void initialize() {
|
||||
thingHandler.registerStatusListener(this);
|
||||
super.initialize();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
bridgeHandler.unregisterStatusListener(this);
|
||||
super.deactivate();
|
||||
public void dispose() {
|
||||
super.dispose();
|
||||
thingHandler.unregisterStatusListener(this);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void startScan() {
|
||||
logger.debug("Start manual scan on bridge {}", bridgeHandler.getThing().getUID());
|
||||
bridgeHandler.handleRefreshCommand();
|
||||
logger.debug("Start manual scan on bridge {}", thingHandler.getThing().getUID());
|
||||
thingHandler.handleRefreshCommand();
|
||||
}
|
||||
|
||||
@Override
|
||||
protected synchronized void stopScan() {
|
||||
logger.debug("Stop manual scan on bridge {}", bridgeHandler.getThing().getUID());
|
||||
logger.debug("Stop manual scan on bridge {}", thingHandler.getThing().getUID());
|
||||
super.stopScan();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(@NonNullByDefault({}) ThingHandler handler) {
|
||||
if (handler instanceof AVMFritzBaseBridgeHandler baseBridgeHandler) {
|
||||
bridgeHandler = baseBridgeHandler;
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return bridgeHandler;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onDeviceAdded(AVMFritzBaseModel device) {
|
||||
String id = bridgeHandler.getThingTypeId(device);
|
||||
String id = thingHandler.getThingTypeId(device);
|
||||
ThingTypeUID thingTypeUID = id.isEmpty() ? null : new ThingTypeUID(BINDING_ID, id);
|
||||
if (thingTypeUID != null && getSupportedThingTypes().contains(thingTypeUID)) {
|
||||
ThingUID thingUID = new ThingUID(thingTypeUID, bridgeHandler.getThing().getUID(),
|
||||
bridgeHandler.getThingName(device));
|
||||
ThingUID thingUID = new ThingUID(thingTypeUID, thingHandler.getThing().getUID(),
|
||||
thingHandler.getThingName(device));
|
||||
onDeviceAddedInternal(thingUID, device);
|
||||
} else {
|
||||
logger.debug("Discovered unsupported device: {}", device);
|
||||
@ -134,7 +117,7 @@ public class AVMFritzDiscoveryService extends AbstractDiscoveryService
|
||||
}
|
||||
|
||||
DiscoveryResult discoveryResult = DiscoveryResultBuilder.create(thingUID).withProperties(properties)
|
||||
.withRepresentationProperty(CONFIG_AIN).withBridge(bridgeHandler.getThing().getUID())
|
||||
.withRepresentationProperty(CONFIG_AIN).withBridge(thingHandler.getThing().getUID())
|
||||
.withLabel(device.getName()).build();
|
||||
|
||||
thingDiscovered(discoveryResult);
|
||||
|
@ -24,12 +24,12 @@ import org.openhab.binding.bondhome.internal.BondException;
|
||||
import org.openhab.binding.bondhome.internal.api.BondDevice;
|
||||
import org.openhab.binding.bondhome.internal.api.BondHttpApi;
|
||||
import org.openhab.binding.bondhome.internal.handler.BondBridgeHandler;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResult;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -38,36 +38,24 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Sara Geleskie Damiano - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = BondDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class BondDiscoveryService extends AbstractDiscoveryService implements ThingHandlerService {
|
||||
public class BondDiscoveryService extends AbstractThingHandlerDiscoveryService<BondBridgeHandler> {
|
||||
private static final long REFRESH_INTERVAL_MINUTES = 60;
|
||||
private final Logger logger = LoggerFactory.getLogger(BondDiscoveryService.class);
|
||||
private @Nullable ScheduledFuture<?> discoveryJob;
|
||||
private @Nullable BondBridgeHandler bridgeHandler;
|
||||
private @Nullable BondHttpApi api;
|
||||
|
||||
public BondDiscoveryService() {
|
||||
super(SUPPORTED_THING_TYPES, 10);
|
||||
super(BondBridgeHandler.class, SUPPORTED_THING_TYPES, 10);
|
||||
this.discoveryJob = null;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
super.deactivate();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(@Nullable ThingHandler handler) {
|
||||
if (handler instanceof BondBridgeHandler localHandler) {
|
||||
bridgeHandler = localHandler;
|
||||
localHandler.setDiscoveryService(this);
|
||||
api = localHandler.getBridgeAPI();
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return bridgeHandler;
|
||||
public void initialize() {
|
||||
thingHandler.setDiscoveryService(this);
|
||||
api = thingHandler.getBridgeAPI();
|
||||
super.initialize();
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -87,6 +75,7 @@ public class BondDiscoveryService extends AbstractDiscoveryService implements Th
|
||||
protected synchronized void startScan() {
|
||||
logger.debug("Start scan for Bond devices.");
|
||||
try {
|
||||
BondBridgeHandler bridgeHandler = thingHandler;
|
||||
final ThingUID bridgeUid = bridgeHandler.getThing().getUID();
|
||||
api = bridgeHandler.getBridgeAPI();
|
||||
List<String> deviceList = api.getDevices();
|
||||
|
@ -19,19 +19,18 @@ import java.util.Collection;
|
||||
import java.util.Set;
|
||||
|
||||
import org.eclipse.jdt.annotation.NonNullByDefault;
|
||||
import org.eclipse.jdt.annotation.Nullable;
|
||||
import org.openhab.binding.boschindego.internal.IndegoTypeDatabase;
|
||||
import org.openhab.binding.boschindego.internal.dto.response.DevicePropertiesResponse;
|
||||
import org.openhab.binding.boschindego.internal.exceptions.IndegoException;
|
||||
import org.openhab.binding.boschindego.internal.handler.BoschAccountHandler;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResult;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.thing.Thing;
|
||||
import org.openhab.core.thing.ThingTypeUID;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -40,29 +39,15 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Jacob Laursen - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = IndegoDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class IndegoDiscoveryService extends AbstractDiscoveryService implements ThingHandlerService {
|
||||
|
||||
public class IndegoDiscoveryService extends AbstractThingHandlerDiscoveryService<BoschAccountHandler> {
|
||||
private static final int TIMEOUT_SECONDS = 60;
|
||||
|
||||
private final Logger logger = LoggerFactory.getLogger(IndegoDiscoveryService.class);
|
||||
|
||||
private @NonNullByDefault({}) BoschAccountHandler accountHandler;
|
||||
|
||||
public IndegoDiscoveryService() {
|
||||
super(Set.of(THING_TYPE_ACCOUNT), TIMEOUT_SECONDS, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return accountHandler;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(ThingHandler handler) {
|
||||
if (handler instanceof BoschAccountHandler accountHandler) {
|
||||
this.accountHandler = accountHandler;
|
||||
}
|
||||
super(BoschAccountHandler.class, Set.of(THING_TYPE_ACCOUNT), TIMEOUT_SECONDS, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -73,9 +58,9 @@ public class IndegoDiscoveryService extends AbstractDiscoveryService implements
|
||||
@Override
|
||||
public void startScan() {
|
||||
try {
|
||||
Collection<DevicePropertiesResponse> devices = accountHandler.getDevices();
|
||||
Collection<DevicePropertiesResponse> devices = thingHandler.getDevices();
|
||||
|
||||
ThingUID bridgeUID = accountHandler.getThing().getUID();
|
||||
ThingUID bridgeUID = thingHandler.getThing().getUID();
|
||||
for (DevicePropertiesResponse device : devices) {
|
||||
ThingUID thingUID = new ThingUID(THING_TYPE_INDEGO, bridgeUID, device.serialNumber);
|
||||
DiscoveryResult discoveryResult = DiscoveryResultBuilder.create(thingUID)
|
||||
@ -97,7 +82,8 @@ public class IndegoDiscoveryService extends AbstractDiscoveryService implements
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
public void dispose() {
|
||||
super.dispose();
|
||||
removeOlderResults(Instant.now().getEpochSecond());
|
||||
}
|
||||
}
|
||||
|
@ -25,12 +25,13 @@ import org.openhab.binding.boschshc.internal.devices.bridge.BridgeHandler;
|
||||
import org.openhab.binding.boschshc.internal.devices.bridge.dto.Device;
|
||||
import org.openhab.binding.boschshc.internal.devices.bridge.dto.Room;
|
||||
import org.openhab.binding.boschshc.internal.devices.bridge.dto.UserDefinedState;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.thing.ThingTypeUID;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -48,12 +49,12 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Gerd Zanker - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = ThingHandlerService.class)
|
||||
@NonNullByDefault
|
||||
public class ThingDiscoveryService extends AbstractDiscoveryService implements ThingHandlerService {
|
||||
public class ThingDiscoveryService extends AbstractThingHandlerDiscoveryService<BridgeHandler> {
|
||||
private static final int SEARCH_TIME = 1;
|
||||
|
||||
private final Logger logger = LoggerFactory.getLogger(ThingDiscoveryService.class);
|
||||
private @Nullable BridgeHandler shcBridgeHandler;
|
||||
|
||||
protected static final Set<ThingTypeUID> SUPPORTED_THING_TYPES = Set.of(
|
||||
BoschSHCBindingConstants.THING_TYPE_INWALL_SWITCH, BoschSHCBindingConstants.THING_TYPE_TWINGUARD,
|
||||
@ -97,37 +98,28 @@ public class ThingDiscoveryService extends AbstractDiscoveryService implements T
|
||||
// @formatter:on
|
||||
|
||||
public ThingDiscoveryService() {
|
||||
super(SUPPORTED_THING_TYPES, SEARCH_TIME);
|
||||
super(BridgeHandler.class, SUPPORTED_THING_TYPES, SEARCH_TIME);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void activate() {
|
||||
logger.trace("activate");
|
||||
final BridgeHandler handler = shcBridgeHandler;
|
||||
if (handler != null) {
|
||||
handler.registerDiscoveryListener(this);
|
||||
}
|
||||
public void initialize() {
|
||||
logger.trace("initialize");
|
||||
thingHandler.registerDiscoveryListener(this);
|
||||
super.initialize();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
logger.trace("deactivate");
|
||||
final BridgeHandler handler = shcBridgeHandler;
|
||||
if (handler != null) {
|
||||
removeOlderResults(new Date().getTime(), handler.getThing().getUID());
|
||||
handler.unregisterDiscoveryListener();
|
||||
}
|
||||
public void dispose() {
|
||||
super.dispose();
|
||||
logger.trace("dispose");
|
||||
removeOlderResults(new Date().getTime(), thingHandler.getThing().getUID());
|
||||
thingHandler.unregisterDiscoveryListener();
|
||||
|
||||
super.deactivate();
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void startScan() {
|
||||
if (shcBridgeHandler == null) {
|
||||
logger.debug("The shcBridgeHandler is empty, no manual scan is currently possible");
|
||||
return;
|
||||
}
|
||||
|
||||
try {
|
||||
doScan();
|
||||
} catch (InterruptedException e) {
|
||||
@ -138,36 +130,19 @@ public class ThingDiscoveryService extends AbstractDiscoveryService implements T
|
||||
|
||||
@Override
|
||||
protected synchronized void stopScan() {
|
||||
logger.debug("Stop manual scan on bridge {}",
|
||||
shcBridgeHandler != null ? shcBridgeHandler.getThing().getUID() : "?");
|
||||
logger.debug("Stop manual scan on bridge {}", thingHandler.getThing().getUID());
|
||||
super.stopScan();
|
||||
final BridgeHandler handler = shcBridgeHandler;
|
||||
if (handler != null) {
|
||||
removeOlderResults(getTimestampOfLastScan(), handler.getThing().getUID());
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(@Nullable ThingHandler handler) {
|
||||
if (handler instanceof BridgeHandler bridgeHandler) {
|
||||
logger.trace("Set bridge handler {}", handler);
|
||||
shcBridgeHandler = bridgeHandler;
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return shcBridgeHandler;
|
||||
removeOlderResults(getTimestampOfLastScan(), thingHandler.getThing().getUID());
|
||||
}
|
||||
|
||||
public void doScan() throws InterruptedException {
|
||||
logger.debug("Start manual scan on bridge {}", shcBridgeHandler.getThing().getUID());
|
||||
logger.debug("Start manual scan on bridge {}", thingHandler.getThing().getUID());
|
||||
// use shcBridgeHandler to getDevices()
|
||||
List<Room> rooms = shcBridgeHandler.getRooms();
|
||||
List<Room> rooms = thingHandler.getRooms();
|
||||
logger.debug("SHC has {} rooms", rooms.size());
|
||||
List<Device> devices = shcBridgeHandler.getDevices();
|
||||
List<Device> devices = thingHandler.getDevices();
|
||||
logger.debug("SHC has {} devices", devices.size());
|
||||
List<UserDefinedState> userStates = shcBridgeHandler.getUserStates();
|
||||
List<UserDefinedState> userStates = thingHandler.getUserStates();
|
||||
logger.debug("SHC has {} user-defined states", userStates.size());
|
||||
|
||||
// Write found devices into openhab.log to support manual configuration
|
||||
@ -195,9 +170,6 @@ public class ThingDiscoveryService extends AbstractDiscoveryService implements T
|
||||
}
|
||||
|
||||
private void addUserState(UserDefinedState userState) {
|
||||
// see startScan for the runtime null check of shcBridgeHandler
|
||||
assert shcBridgeHandler != null;
|
||||
|
||||
logger.trace("Discovering user-defined state {}", userState.getName());
|
||||
logger.trace("- details: id {}, state {}", userState.getId(), userState.isState());
|
||||
|
||||
@ -206,7 +178,7 @@ public class ThingDiscoveryService extends AbstractDiscoveryService implements T
|
||||
|
||||
logger.trace("- got thingTypeID '{}' for user-defined state '{}'", thingTypeUID.getId(), userState.getName());
|
||||
|
||||
ThingUID thingUID = new ThingUID(thingTypeUID, shcBridgeHandler.getThing().getUID(),
|
||||
ThingUID thingUID = new ThingUID(thingTypeUID, thingHandler.getThing().getUID(),
|
||||
userState.getId().replace(':', '_'));
|
||||
|
||||
logger.trace("- got thingUID '{}' for user-defined state: '{}'", thingUID, userState);
|
||||
@ -214,7 +186,7 @@ public class ThingDiscoveryService extends AbstractDiscoveryService implements T
|
||||
DiscoveryResultBuilder discoveryResult = DiscoveryResultBuilder.create(thingUID).withThingType(thingTypeUID)
|
||||
.withProperty("id", userState.getId()).withLabel(userState.getName());
|
||||
|
||||
discoveryResult.withBridge(shcBridgeHandler.getThing().getUID());
|
||||
discoveryResult.withBridge(thingHandler.getThing().getUID());
|
||||
|
||||
thingDiscovered(discoveryResult.build());
|
||||
|
||||
@ -234,8 +206,6 @@ public class ThingDiscoveryService extends AbstractDiscoveryService implements T
|
||||
|
||||
protected void addDevice(Device device, String roomName) {
|
||||
// see startScan for the runtime null check of shcBridgeHandler
|
||||
assert shcBridgeHandler != null;
|
||||
|
||||
logger.trace("Discovering device {}", device.name);
|
||||
logger.trace("- details: id {}, roomId {}, deviceModel {}", device.id, device.roomId, device.deviceModel);
|
||||
|
||||
@ -246,16 +216,13 @@ public class ThingDiscoveryService extends AbstractDiscoveryService implements T
|
||||
|
||||
logger.trace("- got thingTypeID '{}' for deviceModel '{}'", thingTypeUID.getId(), device.deviceModel);
|
||||
|
||||
ThingUID thingUID = new ThingUID(thingTypeUID, shcBridgeHandler.getThing().getUID(),
|
||||
device.id.replace(':', '_'));
|
||||
ThingUID thingUID = new ThingUID(thingTypeUID, thingHandler.getThing().getUID(), device.id.replace(':', '_'));
|
||||
|
||||
logger.trace("- got thingUID '{}' for device: '{}'", thingUID, device);
|
||||
|
||||
DiscoveryResultBuilder discoveryResult = DiscoveryResultBuilder.create(thingUID).withThingType(thingTypeUID)
|
||||
.withProperty("id", device.id).withLabel(getNiceName(device.name, roomName));
|
||||
if (null != shcBridgeHandler) {
|
||||
discoveryResult.withBridge(shcBridgeHandler.getThing().getUID());
|
||||
}
|
||||
discoveryResult.withBridge(thingHandler.getThing().getUID());
|
||||
if (!roomName.isEmpty()) {
|
||||
discoveryResult.withProperty("Location", roomName);
|
||||
}
|
||||
|
@ -24,14 +24,14 @@ import org.eclipse.jdt.annotation.Nullable;
|
||||
import org.openhab.binding.bticinosmarther.internal.account.SmartherAccountHandler;
|
||||
import org.openhab.binding.bticinosmarther.internal.api.dto.Location;
|
||||
import org.openhab.binding.bticinosmarther.internal.api.dto.Module;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResult;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.config.discovery.DiscoveryService;
|
||||
import org.openhab.core.thing.ThingTypeUID;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -41,9 +41,9 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Fabio Possieri - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = SmartherModuleDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class SmartherModuleDiscoveryService extends AbstractDiscoveryService
|
||||
implements DiscoveryService, ThingHandlerService {
|
||||
public class SmartherModuleDiscoveryService extends AbstractThingHandlerDiscoveryService<SmartherAccountHandler> {
|
||||
|
||||
// Only modules can be discovered. A bridge must be manually added.
|
||||
private static final Set<ThingTypeUID> SUPPORTED_THING_TYPES_UIDS = Set.of(THING_TYPE_MODULE);
|
||||
@ -54,14 +54,13 @@ public class SmartherModuleDiscoveryService extends AbstractDiscoveryService
|
||||
|
||||
private final Logger logger = LoggerFactory.getLogger(SmartherModuleDiscoveryService.class);
|
||||
|
||||
private @Nullable SmartherAccountHandler bridgeHandler;
|
||||
private @Nullable ThingUID bridgeUID;
|
||||
|
||||
/**
|
||||
* Constructs a {@code SmartherModuleDiscoveryService}.
|
||||
*/
|
||||
public SmartherModuleDiscoveryService() {
|
||||
super(SUPPORTED_THING_TYPES_UIDS, DISCOVERY_TIME_SECONDS);
|
||||
super(SmartherAccountHandler.class, SUPPORTED_THING_TYPES_UIDS, DISCOVERY_TIME_SECONDS);
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -71,31 +70,25 @@ public class SmartherModuleDiscoveryService extends AbstractDiscoveryService
|
||||
|
||||
@Override
|
||||
public void activate() {
|
||||
logger.debug("Bridge[{}] Activating chronothermostat discovery service", this.bridgeUID);
|
||||
Map<String, Object> properties = new HashMap<>();
|
||||
properties.put(DiscoveryService.CONFIG_PROPERTY_BACKGROUND_DISCOVERY, Boolean.TRUE);
|
||||
super.activate(properties);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
public void initialize() {
|
||||
logger.debug("Bridge[{}] Activating chronothermostat discovery service", this.bridgeUID);
|
||||
this.bridgeUID = thingHandler.getThing().getUID();
|
||||
super.initialize();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void dispose() {
|
||||
super.dispose();
|
||||
logger.debug("Bridge[{}] Deactivating chronothermostat discovery service", this.bridgeUID);
|
||||
removeOlderResults(new Date().getTime());
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(@Nullable ThingHandler handler) {
|
||||
if (handler instanceof SmartherAccountHandler localBridgeHandler) {
|
||||
this.bridgeHandler = localBridgeHandler;
|
||||
this.bridgeUID = localBridgeHandler.getUID();
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return this.bridgeHandler;
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void startBackgroundDiscovery() {
|
||||
logger.debug("Bridge[{}] Performing background discovery scan for chronothermostats", this.bridgeUID);
|
||||
@ -123,13 +116,10 @@ public class SmartherModuleDiscoveryService extends AbstractDiscoveryService
|
||||
* Discovers Chronothermostat devices for the given bridge handler.
|
||||
*/
|
||||
private synchronized void discoverChronothermostats() {
|
||||
final SmartherAccountHandler localBridgeHandler = this.bridgeHandler;
|
||||
if (localBridgeHandler != null) {
|
||||
// If the bridge is not online no other thing devices can be found, so no reason to scan at this moment
|
||||
if (localBridgeHandler.isOnline()) {
|
||||
localBridgeHandler.getLocations()
|
||||
.forEach(l -> localBridgeHandler.getLocationModules(l).forEach(m -> addDiscoveredDevice(l, m)));
|
||||
}
|
||||
if (thingHandler.isOnline()) {
|
||||
thingHandler.getLocations()
|
||||
.forEach(l -> thingHandler.getLocationModules(l).forEach(m -> addDiscoveredDevice(l, m)));
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -19,6 +19,8 @@ import org.openhab.core.automation.annotation.RuleAction;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -28,6 +30,7 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Georgios Moutsos - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = CaddxBridgeActions.class)
|
||||
@ThingActionsScope(name = "caddx")
|
||||
@NonNullByDefault
|
||||
public class CaddxBridgeActions implements ThingActions {
|
||||
|
@ -20,6 +20,8 @@ import org.openhab.core.automation.annotation.RuleAction;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -29,6 +31,7 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Georgios Moutsos - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = CaddxKeypadActions.class)
|
||||
@ThingActionsScope(name = "caddx")
|
||||
@NonNullByDefault
|
||||
public class CaddxKeypadActions implements ThingActions {
|
||||
|
@ -20,6 +20,8 @@ import org.openhab.core.automation.annotation.RuleAction;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -29,6 +31,7 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Georgios Moutsos - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = CaddxPanelActions.class)
|
||||
@ThingActionsScope(name = "caddx")
|
||||
@NonNullByDefault
|
||||
public class CaddxPanelActions implements ThingActions {
|
||||
|
@ -15,7 +15,6 @@ package org.openhab.binding.caddx.internal.discovery;
|
||||
import java.util.Map;
|
||||
|
||||
import org.eclipse.jdt.annotation.NonNullByDefault;
|
||||
import org.eclipse.jdt.annotation.Nullable;
|
||||
import org.openhab.binding.caddx.internal.CaddxBindingConstants;
|
||||
import org.openhab.binding.caddx.internal.CaddxEvent;
|
||||
import org.openhab.binding.caddx.internal.config.CaddxKeypadConfiguration;
|
||||
@ -23,14 +22,13 @@ import org.openhab.binding.caddx.internal.config.CaddxPartitionConfiguration;
|
||||
import org.openhab.binding.caddx.internal.config.CaddxZoneConfiguration;
|
||||
import org.openhab.binding.caddx.internal.handler.CaddxBridgeHandler;
|
||||
import org.openhab.binding.caddx.internal.handler.CaddxThingType;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResult;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.config.discovery.DiscoveryService;
|
||||
import org.openhab.core.thing.Bridge;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -39,14 +37,13 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Georgios Moutsos - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = CaddxDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class CaddxDiscoveryService extends AbstractDiscoveryService implements ThingHandlerService, DiscoveryService {
|
||||
public class CaddxDiscoveryService extends AbstractThingHandlerDiscoveryService<CaddxBridgeHandler> {
|
||||
private final Logger logger = LoggerFactory.getLogger(CaddxDiscoveryService.class);
|
||||
|
||||
private @Nullable CaddxBridgeHandler caddxBridgeHandler = null;
|
||||
|
||||
public CaddxDiscoveryService() {
|
||||
super(CaddxBindingConstants.SUPPORTED_THING_TYPES_UIDS, 15, false);
|
||||
super(CaddxBridgeHandler.class, CaddxBindingConstants.SUPPORTED_THING_TYPES_UIDS, 15, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -133,33 +130,17 @@ public class CaddxDiscoveryService extends AbstractDiscoveryService implements T
|
||||
* Activates the Discovery Service.
|
||||
*/
|
||||
@Override
|
||||
public void activate() {
|
||||
CaddxBridgeHandler handler = caddxBridgeHandler;
|
||||
if (handler != null) {
|
||||
handler.registerDiscoveryService(this);
|
||||
}
|
||||
public void initialize() {
|
||||
thingHandler.registerDiscoveryService(this);
|
||||
super.initialize();
|
||||
}
|
||||
|
||||
/**
|
||||
* Deactivates the Discovery Service.
|
||||
*/
|
||||
@Override
|
||||
public void deactivate() {
|
||||
CaddxBridgeHandler handler = caddxBridgeHandler;
|
||||
if (handler != null) {
|
||||
handler.unregisterDiscoveryService();
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(@Nullable ThingHandler handler) {
|
||||
if (handler instanceof CaddxBridgeHandler bridgeHandler) {
|
||||
caddxBridgeHandler = bridgeHandler;
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return caddxBridgeHandler;
|
||||
public void dispose() {
|
||||
super.dispose();
|
||||
thingHandler.unregisterDiscoveryService();
|
||||
}
|
||||
}
|
||||
|
@ -17,7 +17,6 @@ import static org.openhab.binding.caddx.internal.CaddxBindingConstants.SEND_COMM
|
||||
import java.io.IOException;
|
||||
import java.math.BigDecimal;
|
||||
import java.util.Collection;
|
||||
import java.util.HashSet;
|
||||
import java.util.Map;
|
||||
import java.util.Set;
|
||||
import java.util.TooManyListenersException;
|
||||
@ -451,10 +450,7 @@ public class CaddxBridgeHandler extends BaseBridgeHandler implements CaddxPanelL
|
||||
|
||||
@Override
|
||||
public Collection<Class<? extends ThingHandlerService>> getServices() {
|
||||
Set<Class<? extends ThingHandlerService>> set = new HashSet<Class<? extends ThingHandlerService>>(2);
|
||||
set.add(CaddxDiscoveryService.class);
|
||||
set.add(CaddxBridgeActions.class);
|
||||
return set;
|
||||
return Set.of(CaddxBridgeActions.class, CaddxDiscoveryService.class);
|
||||
}
|
||||
|
||||
public void restart() {
|
||||
|
@ -26,6 +26,8 @@ import org.openhab.core.config.core.ConfigOptionProvider;
|
||||
import org.openhab.core.config.core.ParameterOption;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
|
||||
/**
|
||||
* The {@link ChatGPTModelOptionProvider} provides the available models from OpenAI as options for the channel
|
||||
@ -33,6 +35,7 @@ import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
*
|
||||
* @author Kai Kreuzer - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = { ChatGPTModelOptionProvider.class, ConfigOptionProvider.class })
|
||||
@NonNullByDefault
|
||||
public class ChatGPTModelOptionProvider implements ThingHandlerService, ConfigOptionProvider {
|
||||
|
||||
|
@ -21,6 +21,8 @@ import org.openhab.core.automation.annotation.RuleAction;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -29,6 +31,7 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Scott Hanson - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = ChromecastActions.class)
|
||||
@ThingActionsScope(name = "chromecast")
|
||||
@NonNullByDefault
|
||||
public class ChromecastActions implements ThingActions {
|
||||
|
@ -30,12 +30,15 @@ import org.openhab.core.automation.annotation.RuleAction;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
/**
|
||||
* @author Joan Pujol - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = DBQueryActions.class)
|
||||
@ThingActionsScope(name = "dbquery")
|
||||
@NonNullByDefault
|
||||
public class DBQueryActions implements IDBQueryActions, ThingActions {
|
||||
|
@ -25,6 +25,8 @@ import org.openhab.core.automation.annotation.RuleAction;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -33,6 +35,7 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Jan N. Klug - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = BridgeActions.class)
|
||||
@ThingActionsScope(name = "deconz")
|
||||
@NonNullByDefault
|
||||
public class BridgeActions implements ThingActions {
|
||||
|
@ -31,6 +31,8 @@ import org.openhab.core.automation.annotation.RuleAction;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -43,6 +45,7 @@ import com.google.gson.reflect.TypeToken;
|
||||
*
|
||||
* @author Jan N. Klug - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = GroupActions.class)
|
||||
@ThingActionsScope(name = "deconz")
|
||||
@NonNullByDefault
|
||||
public class GroupActions implements ThingActions {
|
||||
|
@ -35,15 +35,16 @@ import org.openhab.binding.deconz.internal.handler.SensorThermostatThingHandler;
|
||||
import org.openhab.binding.deconz.internal.handler.SensorThingHandler;
|
||||
import org.openhab.binding.deconz.internal.types.GroupType;
|
||||
import org.openhab.binding.deconz.internal.types.LightType;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResult;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.config.discovery.DiscoveryService;
|
||||
import org.openhab.core.thing.Thing;
|
||||
import org.openhab.core.thing.ThingTypeUID;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Activate;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -53,27 +54,27 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author David Graeff - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = ThingDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class ThingDiscoveryService extends AbstractDiscoveryService implements DiscoveryService, ThingHandlerService {
|
||||
public class ThingDiscoveryService extends AbstractThingHandlerDiscoveryService<DeconzBridgeHandler>
|
||||
implements DiscoveryService {
|
||||
private static final Set<ThingTypeUID> SUPPORTED_THING_TYPES_UIDS = Stream
|
||||
.of(LightThingHandler.SUPPORTED_THING_TYPE_UIDS, SensorThingHandler.SUPPORTED_THING_TYPES,
|
||||
SensorThermostatThingHandler.SUPPORTED_THING_TYPES)
|
||||
.flatMap(Set::stream).collect(Collectors.toSet());
|
||||
private final Logger logger = LoggerFactory.getLogger(ThingDiscoveryService.class);
|
||||
|
||||
private @Nullable DeconzBridgeHandler handler;
|
||||
private @Nullable ScheduledFuture<?> scanningJob;
|
||||
private @Nullable ThingUID bridgeUID;
|
||||
|
||||
@Activate
|
||||
public ThingDiscoveryService() {
|
||||
super(SUPPORTED_THING_TYPES_UIDS, 30);
|
||||
super(DeconzBridgeHandler.class, SUPPORTED_THING_TYPES_UIDS, 30);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void startScan() {
|
||||
final DeconzBridgeHandler handler = this.handler;
|
||||
if (handler != null) {
|
||||
handler.getBridgeFullState().thenAccept(fullState -> {
|
||||
thingHandler.getBridgeFullState().thenAccept(fullState -> {
|
||||
stopScan();
|
||||
fullState.ifPresent(state -> {
|
||||
state.sensors.forEach(this::addSensor);
|
||||
@ -83,7 +84,6 @@ public class ThingDiscoveryService extends AbstractDiscoveryService implements D
|
||||
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
protected synchronized void stopScan() {
|
||||
@ -290,26 +290,14 @@ public class ThingDiscoveryService extends AbstractDiscoveryService implements D
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(@Nullable ThingHandler handler) {
|
||||
if (handler instanceof DeconzBridgeHandler bridgeHandler) {
|
||||
this.handler = bridgeHandler;
|
||||
this.bridgeUID = handler.getThing().getUID();
|
||||
}
|
||||
public void initialize() {
|
||||
bridgeUID = thingHandler.getThing().getUID();
|
||||
super.initialize();
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return handler;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void activate() {
|
||||
super.activate(null);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
public void dispose() {
|
||||
super.dispose();
|
||||
removeOlderResults(new Date().getTime());
|
||||
super.deactivate();
|
||||
}
|
||||
}
|
||||
|
@ -93,6 +93,7 @@ public class DeconzTest {
|
||||
.getBridgeFullState();
|
||||
ThingDiscoveryService discoveryService = new ThingDiscoveryService();
|
||||
discoveryService.setThingHandler(bridgeHandler);
|
||||
discoveryService.initialize();
|
||||
discoveryService.addDiscoveryListener(discoveryListener);
|
||||
discoveryService.startScan();
|
||||
Mockito.verify(discoveryListener, times(20)).thingDiscovered(any(), any());
|
||||
|
@ -19,7 +19,6 @@ import java.util.Map;
|
||||
import java.util.Set;
|
||||
|
||||
import org.eclipse.jdt.annotation.NonNullByDefault;
|
||||
import org.eclipse.jdt.annotation.Nullable;
|
||||
import org.openhab.binding.digiplex.internal.communication.AreaLabelRequest;
|
||||
import org.openhab.binding.digiplex.internal.communication.AreaLabelResponse;
|
||||
import org.openhab.binding.digiplex.internal.communication.DigiplexMessageHandler;
|
||||
@ -27,13 +26,12 @@ import org.openhab.binding.digiplex.internal.communication.DigiplexRequest;
|
||||
import org.openhab.binding.digiplex.internal.communication.ZoneLabelRequest;
|
||||
import org.openhab.binding.digiplex.internal.communication.ZoneLabelResponse;
|
||||
import org.openhab.binding.digiplex.internal.handler.DigiplexBridgeHandler;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResult;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.config.discovery.DiscoveryService;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
|
||||
/**
|
||||
* Service for discovering things on Digiplex alarm systems
|
||||
@ -41,41 +39,40 @@ import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
* @author Robert Michalak - Initial contribution
|
||||
*
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = DigiplexDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class DigiplexDiscoveryService extends AbstractDiscoveryService
|
||||
implements DiscoveryService, ThingHandlerService, DigiplexMessageHandler {
|
||||
public class DigiplexDiscoveryService extends AbstractThingHandlerDiscoveryService<DigiplexBridgeHandler>
|
||||
implements DigiplexMessageHandler {
|
||||
|
||||
private static final int MAX_ZONE = 96;
|
||||
private static final int MAX_AREA = 8;
|
||||
|
||||
private static final int DISCOVERY_TIMEOUT = 30;
|
||||
|
||||
private @Nullable DigiplexBridgeHandler bridgeHandler;
|
||||
|
||||
public DigiplexDiscoveryService() {
|
||||
super(Set.of(THING_TYPE_ZONE), DISCOVERY_TIMEOUT, false);
|
||||
super(DigiplexBridgeHandler.class, Set.of(THING_TYPE_ZONE), DISCOVERY_TIMEOUT, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
@SuppressWarnings("null")
|
||||
protected void startScan() {
|
||||
bridgeHandler.registerMessageHandler(this);
|
||||
thingHandler.registerMessageHandler(this);
|
||||
// find zones
|
||||
for (int i = 1; i <= MAX_ZONE; i++) {
|
||||
DigiplexRequest command = new ZoneLabelRequest(i);
|
||||
bridgeHandler.sendRequest(command);
|
||||
thingHandler.sendRequest(command);
|
||||
}
|
||||
// find areas
|
||||
for (int i = 1; i <= MAX_AREA; i++) {
|
||||
DigiplexRequest command = new AreaLabelRequest(i);
|
||||
bridgeHandler.sendRequest(command);
|
||||
thingHandler.sendRequest(command);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
@SuppressWarnings("null")
|
||||
protected synchronized void stopScan() {
|
||||
bridgeHandler.unregisterMessageHandler(this);
|
||||
thingHandler.unregisterMessageHandler(this);
|
||||
super.stopScan();
|
||||
}
|
||||
|
||||
@ -86,8 +83,7 @@ public class DigiplexDiscoveryService extends AbstractDiscoveryService
|
||||
if (isDefaultName(response)) {
|
||||
return;
|
||||
}
|
||||
|
||||
ThingUID bridgeUID = bridgeHandler.getThing().getUID();
|
||||
ThingUID bridgeUID = thingHandler.getThing().getUID();
|
||||
ThingUID thingUID = new ThingUID(THING_TYPE_ZONE, bridgeUID, String.format("zone%d", response.zoneNo));
|
||||
|
||||
Map<String, Object> properties = new HashMap<>(1);
|
||||
@ -112,7 +108,7 @@ public class DigiplexDiscoveryService extends AbstractDiscoveryService
|
||||
return;
|
||||
}
|
||||
|
||||
ThingUID bridgeUID = bridgeHandler.getThing().getUID();
|
||||
ThingUID bridgeUID = thingHandler.getThing().getUID();
|
||||
ThingUID thingUID = new ThingUID(THING_TYPE_AREA, bridgeUID, String.format("area%d", response.areaNo));
|
||||
|
||||
Map<String, Object> properties = new HashMap<>(1);
|
||||
@ -125,25 +121,8 @@ public class DigiplexDiscoveryService extends AbstractDiscoveryService
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(@Nullable ThingHandler handler) {
|
||||
if (handler instanceof DigiplexBridgeHandler digiplexBridgeHandler) {
|
||||
bridgeHandler = digiplexBridgeHandler;
|
||||
bridgeHandler.registerMessageHandler(this);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return bridgeHandler;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void activate() {
|
||||
super.activate(null);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
super.deactivate();
|
||||
public void initialize() {
|
||||
thingHandler.registerMessageHandler(this);
|
||||
super.initialize();
|
||||
}
|
||||
}
|
||||
|
@ -20,6 +20,8 @@ import org.openhab.core.automation.annotation.RuleAction;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -28,6 +30,7 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Jan N. Klug - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = DmxActions.class)
|
||||
@ThingActionsScope(name = "dmx")
|
||||
@NonNullByDefault
|
||||
public class DmxActions implements ThingActions {
|
||||
|
@ -20,6 +20,8 @@ import org.openhab.core.automation.annotation.RuleAction;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -28,6 +30,7 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Mark Hilbush - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = DoorbirdActions.class)
|
||||
@ThingActionsScope(name = "doorbird")
|
||||
@NonNullByDefault
|
||||
public class DoorbirdActions implements ThingActions {
|
||||
|
@ -29,14 +29,13 @@ import org.openhab.binding.draytonwiser.internal.model.RoomDTO;
|
||||
import org.openhab.binding.draytonwiser.internal.model.RoomStatDTO;
|
||||
import org.openhab.binding.draytonwiser.internal.model.SmartPlugDTO;
|
||||
import org.openhab.binding.draytonwiser.internal.model.SmartValveDTO;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResult;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.config.discovery.DiscoveryService;
|
||||
import org.openhab.core.thing.ThingTypeUID;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -45,36 +44,23 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Andrew Schofield - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = DraytonWiserDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class DraytonWiserDiscoveryService extends AbstractDiscoveryService
|
||||
implements DiscoveryService, ThingHandlerService, DraytonWiserRefreshListener {
|
||||
public class DraytonWiserDiscoveryService extends AbstractThingHandlerDiscoveryService<HeatHubHandler>
|
||||
implements DraytonWiserRefreshListener {
|
||||
|
||||
private final Logger logger = LoggerFactory.getLogger(DraytonWiserDiscoveryService.class);
|
||||
|
||||
private @Nullable HeatHubHandler bridgeHandler;
|
||||
private @Nullable ThingUID bridgeUID;
|
||||
|
||||
public DraytonWiserDiscoveryService() {
|
||||
super(SUPPORTED_THING_TYPES_UIDS, 30, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void activate() {
|
||||
super.activate(null);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
super.deactivate();
|
||||
super(HeatHubHandler.class, SUPPORTED_THING_TYPES_UIDS, 30, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void startScan() {
|
||||
final HeatHubHandler handler = bridgeHandler;
|
||||
if (handler != null) {
|
||||
removeOlderResults(getTimestampOfLastScan());
|
||||
handler.setDiscoveryService(this);
|
||||
}
|
||||
thingHandler.setDiscoveryService(this);
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -192,27 +178,13 @@ public class DraytonWiserDiscoveryService extends AbstractDiscoveryService
|
||||
|
||||
@Override
|
||||
public synchronized void stopScan() {
|
||||
final HeatHubHandler handler = bridgeHandler;
|
||||
|
||||
if (handler != null) {
|
||||
handler.unsetDiscoveryService();
|
||||
}
|
||||
thingHandler.unsetDiscoveryService();
|
||||
super.stopScan();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(@Nullable final ThingHandler handler) {
|
||||
if (handler instanceof HeatHubHandler hubHandler) {
|
||||
bridgeHandler = hubHandler;
|
||||
bridgeUID = handler.getThing().getUID();
|
||||
} else {
|
||||
bridgeHandler = null;
|
||||
bridgeUID = null;
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return bridgeHandler;
|
||||
public void initialize() {
|
||||
bridgeUID = thingHandler.getThing().getUID();
|
||||
super.initialize();
|
||||
}
|
||||
}
|
||||
|
@ -100,6 +100,7 @@ public class DraytonWiserDiscoveryServiceTest {
|
||||
}
|
||||
};
|
||||
service.setThingHandler(bridgeHandler);
|
||||
service.initialize();
|
||||
final DomainDTO domain = api.getDomain();
|
||||
|
||||
if (domain == null) {
|
||||
|
@ -1,50 +0,0 @@
|
||||
/**
|
||||
* Copyright (c) 2010-2024 Contributors to the openHAB project
|
||||
*
|
||||
* See the NOTICE file(s) distributed with this work for additional
|
||||
* information.
|
||||
*
|
||||
* This program and the accompanying materials are made available under the
|
||||
* terms of the Eclipse Public License 2.0 which is available at
|
||||
* http://www.eclipse.org/legal/epl-2.0
|
||||
*
|
||||
* SPDX-License-Identifier: EPL-2.0
|
||||
*/
|
||||
package org.openhab.binding.dsmr.internal.discovery;
|
||||
|
||||
import org.eclipse.jdt.annotation.NonNullByDefault;
|
||||
import org.eclipse.jdt.annotation.Nullable;
|
||||
import org.openhab.core.i18n.LocaleProvider;
|
||||
import org.openhab.core.i18n.TranslationProvider;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Activate;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.Deactivate;
|
||||
import org.osgi.service.component.annotations.Reference;
|
||||
|
||||
/**
|
||||
* Tracks the i18n provider dependencies of the {@link DSMRMeterDiscoveryService}. The {@link DSMRMeterDiscoveryService}
|
||||
* is a {@link ThingHandlerService} so its i18n dependencies cannot be injected using service component annotations.
|
||||
*
|
||||
* @author Wouter Born - Initial contribution
|
||||
*/
|
||||
@Component
|
||||
@NonNullByDefault
|
||||
public class DSMRI18nProviderTracker {
|
||||
|
||||
static @Nullable TranslationProvider i18nProvider;
|
||||
static @Nullable LocaleProvider localeProvider;
|
||||
|
||||
@Activate
|
||||
public DSMRI18nProviderTracker(final @Reference TranslationProvider i18nProvider,
|
||||
final @Reference LocaleProvider localeProvider) {
|
||||
DSMRI18nProviderTracker.i18nProvider = i18nProvider;
|
||||
DSMRI18nProviderTracker.localeProvider = localeProvider;
|
||||
}
|
||||
|
||||
@Deactivate
|
||||
public void deactivate() {
|
||||
i18nProvider = null;
|
||||
localeProvider = null;
|
||||
}
|
||||
}
|
@ -30,10 +30,15 @@ import org.openhab.binding.dsmr.internal.handler.DSMRBridgeHandler;
|
||||
import org.openhab.binding.dsmr.internal.handler.DSMRMeterHandler;
|
||||
import org.openhab.binding.dsmr.internal.meter.DSMRMeterDescriptor;
|
||||
import org.openhab.binding.dsmr.internal.meter.DSMRMeterType;
|
||||
import org.openhab.core.i18n.LocaleProvider;
|
||||
import org.openhab.core.i18n.TranslationProvider;
|
||||
import org.openhab.core.library.types.StringType;
|
||||
import org.openhab.core.thing.Thing;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.Reference;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -43,6 +48,7 @@ import org.slf4j.LoggerFactory;
|
||||
* @author M. Volaart - Initial contribution
|
||||
* @author Hilbrand Bouwkamp - Refactored code to detect meters during actual discovery phase.
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = DSMRMeterDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class DSMRMeterDiscoveryService extends DSMRDiscoveryService implements P1TelegramListener, ThingHandlerService {
|
||||
|
||||
@ -53,13 +59,14 @@ public class DSMRMeterDiscoveryService extends DSMRDiscoveryService implements P
|
||||
*/
|
||||
private @NonNullByDefault({}) DSMRBridgeHandler dsmrBridgeHandler;
|
||||
|
||||
/**
|
||||
* Constructs a new {@link DSMRMeterDiscoveryService} attached to the give bridge handler.
|
||||
*/
|
||||
public DSMRMeterDiscoveryService() {
|
||||
super();
|
||||
this.i18nProvider = DSMRI18nProviderTracker.i18nProvider;
|
||||
this.localeProvider = DSMRI18nProviderTracker.localeProvider;
|
||||
@Reference(unbind = "-")
|
||||
public void bindTranslationProvider(TranslationProvider translationProvider) {
|
||||
this.i18nProvider = translationProvider;
|
||||
}
|
||||
|
||||
@Reference(unbind = "-")
|
||||
public void bindLocaleProvider(LocaleProvider localeProvider) {
|
||||
this.localeProvider = localeProvider;
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -21,12 +21,12 @@ import org.openhab.binding.easee.internal.Utils;
|
||||
import org.openhab.binding.easee.internal.command.site.GetSite;
|
||||
import org.openhab.binding.easee.internal.connector.CommunicationStatus;
|
||||
import org.openhab.binding.easee.internal.handler.EaseeSiteHandler;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.thing.ThingTypeUID;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -40,38 +40,25 @@ import com.google.gson.JsonObject;
|
||||
* @author Alexander Friese - initial contribution
|
||||
*
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = EaseeSiteDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class EaseeSiteDiscoveryService extends AbstractDiscoveryService implements ThingHandlerService {
|
||||
public class EaseeSiteDiscoveryService extends AbstractThingHandlerDiscoveryService<EaseeSiteHandler> {
|
||||
|
||||
private final Logger logger = LoggerFactory.getLogger(EaseeSiteDiscoveryService.class);
|
||||
private @NonNullByDefault({}) EaseeSiteHandler bridgeHandler;
|
||||
|
||||
public EaseeSiteDiscoveryService() throws IllegalArgumentException {
|
||||
super(EaseeBindingConstants.SUPPORTED_THING_TYPES_UIDS, 300, false);
|
||||
super(EaseeSiteHandler.class, EaseeBindingConstants.SUPPORTED_THING_TYPES_UIDS, 300, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void startScan() {
|
||||
bridgeHandler.enqueueCommand(new GetSite(bridgeHandler, this::processSiteDiscoveryResult));
|
||||
thingHandler.enqueueCommand(new GetSite(thingHandler, this::processSiteDiscoveryResult));
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(ThingHandler handler) {
|
||||
if (handler instanceof EaseeSiteHandler siteHandler) {
|
||||
this.bridgeHandler = siteHandler;
|
||||
this.bridgeHandler.setDiscoveryService(this);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return bridgeHandler;
|
||||
}
|
||||
|
||||
// method is defined in both implemented interface and inherited class, thus we must define a behaviour here.
|
||||
@Override
|
||||
public void deactivate() {
|
||||
super.deactivate();
|
||||
public void initialize() {
|
||||
thingHandler.setDiscoveryService(this);
|
||||
super.initialize();
|
||||
}
|
||||
|
||||
/**
|
||||
@ -157,7 +144,7 @@ public class EaseeSiteDiscoveryService extends AbstractDiscoveryService implemen
|
||||
*/
|
||||
private DiscoveryResultBuilder initDiscoveryResultBuilder(String deviceType, String deviceId,
|
||||
@Nullable String deviceName) {
|
||||
ThingUID bridgeUID = bridgeHandler.getThing().getUID();
|
||||
ThingUID bridgeUID = thingHandler.getThing().getUID();
|
||||
ThingTypeUID typeUid = new ThingTypeUID(BINDING_ID, deviceType);
|
||||
|
||||
ThingUID thingUID = new ThingUID(typeUid, bridgeUID, deviceId);
|
||||
|
@ -23,90 +23,52 @@ import static org.openhab.binding.echonetlite.internal.EchonetLiteBindingConstan
|
||||
import java.util.Set;
|
||||
|
||||
import org.eclipse.jdt.annotation.NonNullByDefault;
|
||||
import org.eclipse.jdt.annotation.Nullable;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResult;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
/**
|
||||
* @author Michael Barker - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = EchonetDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class EchonetDiscoveryService extends AbstractDiscoveryService
|
||||
implements EchonetDiscoveryListener, ThingHandlerService {
|
||||
public class EchonetDiscoveryService extends AbstractThingHandlerDiscoveryService<EchonetLiteBridgeHandler>
|
||||
implements EchonetDiscoveryListener {
|
||||
|
||||
private final Logger logger = LoggerFactory.getLogger(EchonetDiscoveryService.class);
|
||||
|
||||
@Nullable
|
||||
private EchonetLiteBridgeHandler bridgeHandler;
|
||||
|
||||
public EchonetDiscoveryService() {
|
||||
super(Set.of(THING_TYPE_ECHONET_DEVICE), 10);
|
||||
super(EchonetLiteBridgeHandler.class, Set.of(THING_TYPE_ECHONET_DEVICE), 10);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void startScan() {
|
||||
final EchonetLiteBridgeHandler bridgeHandler = this.bridgeHandler;
|
||||
logger.debug("startScan: {}", bridgeHandler);
|
||||
if (null != bridgeHandler) {
|
||||
bridgeHandler.startDiscovery(this);
|
||||
}
|
||||
logger.debug("startScan: {}", thingHandler);
|
||||
thingHandler.startDiscovery(this);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected synchronized void stopScan() {
|
||||
final EchonetLiteBridgeHandler bridgeHandler = this.bridgeHandler;
|
||||
logger.debug("stopScan: {}", bridgeHandler);
|
||||
if (null != bridgeHandler) {
|
||||
bridgeHandler.stopDiscovery();
|
||||
}
|
||||
logger.debug("stopScan: {}", thingHandler);
|
||||
thingHandler.stopDiscovery();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onDeviceFound(String identifier, InstanceKey instanceKey) {
|
||||
final EchonetLiteBridgeHandler bridgeHandler = this.bridgeHandler;
|
||||
|
||||
if (null == bridgeHandler) {
|
||||
return;
|
||||
}
|
||||
|
||||
final DiscoveryResult discoveryResult = DiscoveryResultBuilder
|
||||
.create(new ThingUID(THING_TYPE_ECHONET_DEVICE, bridgeHandler.getThing().getUID(), identifier))
|
||||
.create(new ThingUID(THING_TYPE_ECHONET_DEVICE, thingHandler.getThing().getUID(), identifier))
|
||||
.withProperty(PROPERTY_NAME_INSTANCE_KEY, instanceKey.representationProperty())
|
||||
.withProperty(PROPERTY_NAME_HOSTNAME, instanceKey.address.getAddress().getHostAddress())
|
||||
.withProperty(PROPERTY_NAME_PORT, instanceKey.address.getPort())
|
||||
.withProperty(PROPERTY_NAME_GROUP_CODE, instanceKey.klass.groupCode())
|
||||
.withProperty(PROPERTY_NAME_CLASS_CODE, instanceKey.klass.classCode())
|
||||
.withProperty(PROPERTY_NAME_INSTANCE, instanceKey.instance)
|
||||
.withBridge(bridgeHandler.getThing().getUID()).withRepresentationProperty(PROPERTY_NAME_INSTANCE_KEY)
|
||||
.build();
|
||||
.withProperty(PROPERTY_NAME_INSTANCE, instanceKey.instance).withBridge(thingHandler.getThing().getUID())
|
||||
.withRepresentationProperty(PROPERTY_NAME_INSTANCE_KEY).build();
|
||||
thingDiscovered(discoveryResult);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
ThingHandlerService.super.deactivate();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void activate() {
|
||||
ThingHandlerService.super.activate();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(ThingHandler thingHandler) {
|
||||
if (thingHandler instanceof EchonetLiteBridgeHandler bridgeHandler) {
|
||||
this.bridgeHandler = bridgeHandler;
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return bridgeHandler;
|
||||
}
|
||||
}
|
||||
|
@ -45,6 +45,8 @@ import org.openhab.core.library.types.QuantityType;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -55,6 +57,7 @@ import org.slf4j.LoggerFactory;
|
||||
* @author Mark Hilbush - Adapted for OH2/3
|
||||
* @author Connor Petty - Proxy method for invoking actions
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = EcobeeActions.class)
|
||||
@ThingActionsScope(name = "ecobee")
|
||||
@NonNullByDefault
|
||||
public class EcobeeActions implements ThingActions {
|
||||
|
@ -27,15 +27,15 @@ import org.openhab.binding.ecobee.internal.dto.thermostat.RemoteSensorDTO;
|
||||
import org.openhab.binding.ecobee.internal.dto.thermostat.ThermostatDTO;
|
||||
import org.openhab.binding.ecobee.internal.handler.EcobeeAccountBridgeHandler;
|
||||
import org.openhab.binding.ecobee.internal.handler.EcobeeThermostatBridgeHandler;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResult;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.thing.Thing;
|
||||
import org.openhab.core.thing.ThingStatus;
|
||||
import org.openhab.core.thing.ThingTypeUID;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -46,39 +46,16 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Mark Hilbush - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = EcobeeDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class EcobeeDiscoveryService extends AbstractDiscoveryService implements ThingHandlerService {
|
||||
public class EcobeeDiscoveryService extends AbstractThingHandlerDiscoveryService<EcobeeAccountBridgeHandler> {
|
||||
|
||||
private final Logger logger = LoggerFactory.getLogger(EcobeeDiscoveryService.class);
|
||||
|
||||
private @NonNullByDefault({}) EcobeeAccountBridgeHandler bridgeHandler;
|
||||
|
||||
private @Nullable Future<?> discoveryJob;
|
||||
|
||||
public EcobeeDiscoveryService() {
|
||||
super(SUPPORTED_THERMOSTAT_AND_SENSOR_THING_TYPES_UIDS, 8, true);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(@Nullable ThingHandler handler) {
|
||||
if (handler instanceof EcobeeAccountBridgeHandler accountBridgeHandler) {
|
||||
this.bridgeHandler = accountBridgeHandler;
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return bridgeHandler;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void activate() {
|
||||
super.activate(null);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
super.deactivate();
|
||||
super(EcobeeAccountBridgeHandler.class, SUPPORTED_THERMOSTAT_AND_SENSOR_THING_TYPES_UIDS, 8, true);
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -113,14 +90,14 @@ public class EcobeeDiscoveryService extends AbstractDiscoveryService implements
|
||||
}
|
||||
|
||||
private void backgroundDiscover() {
|
||||
if (!bridgeHandler.isBackgroundDiscoveryEnabled()) {
|
||||
if (!thingHandler.isBackgroundDiscoveryEnabled()) {
|
||||
return;
|
||||
}
|
||||
discover();
|
||||
}
|
||||
|
||||
private void discover() {
|
||||
if (bridgeHandler.getThing().getStatus() != ThingStatus.ONLINE) {
|
||||
if (thingHandler.getThing().getStatus() != ThingStatus.ONLINE) {
|
||||
logger.debug("EcobeeDiscovery: Skipping discovery because Account Bridge thing is not ONLINE");
|
||||
return;
|
||||
}
|
||||
@ -131,11 +108,11 @@ public class EcobeeDiscoveryService extends AbstractDiscoveryService implements
|
||||
|
||||
private synchronized void discoverThermostats() {
|
||||
logger.debug("EcobeeDiscovery: Discovering thermostats");
|
||||
for (ThermostatDTO thermostat : bridgeHandler.getRegisteredThermostats()) {
|
||||
for (ThermostatDTO thermostat : thingHandler.getRegisteredThermostats()) {
|
||||
String name = thermostat.name;
|
||||
String identifier = thermostat.identifier;
|
||||
if (identifier != null && name != null) {
|
||||
ThingUID thingUID = new ThingUID(UID_THERMOSTAT_BRIDGE, bridgeHandler.getThing().getUID(), identifier);
|
||||
ThingUID thingUID = new ThingUID(UID_THERMOSTAT_BRIDGE, thingHandler.getThing().getUID(), identifier);
|
||||
thingDiscovered(createThermostatDiscoveryResult(thingUID, identifier, name));
|
||||
logger.debug("EcobeeDiscovery: Thermostat '{}' and name '{}' added with UID '{}'", identifier, name,
|
||||
thingUID);
|
||||
@ -144,6 +121,10 @@ public class EcobeeDiscoveryService extends AbstractDiscoveryService implements
|
||||
}
|
||||
|
||||
private DiscoveryResult createThermostatDiscoveryResult(ThingUID thermostatUID, String identifier, String name) {
|
||||
EcobeeAccountBridgeHandler bridgeHandler = thingHandler;
|
||||
if (bridgeHandler == null) {
|
||||
throw new IllegalStateException("thingHandler must not be null");
|
||||
}
|
||||
Map<String, Object> properties = new HashMap<>();
|
||||
properties.put(CONFIG_THERMOSTAT_ID, identifier);
|
||||
return DiscoveryResultBuilder.create(thermostatUID).withProperties(properties)
|
||||
@ -152,7 +133,7 @@ public class EcobeeDiscoveryService extends AbstractDiscoveryService implements
|
||||
}
|
||||
|
||||
private synchronized void discoverSensors() {
|
||||
List<Thing> thermostatThings = bridgeHandler.getThing().getThings();
|
||||
List<Thing> thermostatThings = thingHandler.getThing().getThings();
|
||||
if (thermostatThings.isEmpty()) {
|
||||
logger.debug("EcobeeDiscovery: Skipping sensor discovery because there are no thermostat things");
|
||||
return;
|
||||
|
@ -25,12 +25,15 @@ import org.openhab.core.automation.annotation.RuleAction;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
/**
|
||||
* @author Danny Baumann - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = EcovacsVacuumActions.class)
|
||||
@ThingActionsScope(name = "ecovacs")
|
||||
@NonNullByDefault
|
||||
public class EcovacsVacuumActions implements ThingActions {
|
||||
|
@ -19,21 +19,19 @@ import java.util.Optional;
|
||||
import java.util.Set;
|
||||
|
||||
import org.eclipse.jdt.annotation.NonNullByDefault;
|
||||
import org.eclipse.jdt.annotation.Nullable;
|
||||
import org.openhab.binding.ecovacs.internal.api.EcovacsApi;
|
||||
import org.openhab.binding.ecovacs.internal.api.EcovacsApiException;
|
||||
import org.openhab.binding.ecovacs.internal.api.EcovacsDevice;
|
||||
import org.openhab.binding.ecovacs.internal.api.util.SchedulerTask;
|
||||
import org.openhab.binding.ecovacs.internal.handler.EcovacsApiHandler;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResult;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.config.discovery.DiscoveryService;
|
||||
import org.openhab.core.thing.Thing;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -43,13 +41,11 @@ import org.slf4j.LoggerFactory;
|
||||
* @author Danny Baumann - Initial contribution
|
||||
*/
|
||||
@NonNullByDefault
|
||||
@Component(service = DiscoveryService.class, configurationPid = "discovery.ecovacs")
|
||||
public class EcovacsDeviceDiscoveryService extends AbstractDiscoveryService implements ThingHandlerService {
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = DiscoveryService.class, configurationPid = "discovery.ecovacs")
|
||||
public class EcovacsDeviceDiscoveryService extends AbstractThingHandlerDiscoveryService<EcovacsApiHandler> {
|
||||
private final Logger logger = LoggerFactory.getLogger(EcovacsDeviceDiscoveryService.class);
|
||||
|
||||
private static final int DISCOVER_TIMEOUT_SECONDS = 10;
|
||||
|
||||
private @NonNullByDefault({}) EcovacsApiHandler apiHandler;
|
||||
private Optional<EcovacsApi> api = Optional.empty();
|
||||
private final SchedulerTask onDemandScanTask = new SchedulerTask(scheduler, logger, "OnDemandScan",
|
||||
this::scanForDevices);
|
||||
@ -57,30 +53,13 @@ public class EcovacsDeviceDiscoveryService extends AbstractDiscoveryService impl
|
||||
this::scanForDevices);
|
||||
|
||||
public EcovacsDeviceDiscoveryService() {
|
||||
super(Set.of(THING_TYPE_VACUUM), DISCOVER_TIMEOUT_SECONDS, true);
|
||||
super(EcovacsApiHandler.class, Set.of(THING_TYPE_VACUUM), DISCOVER_TIMEOUT_SECONDS, true);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(@Nullable ThingHandler handler) {
|
||||
if (handler instanceof EcovacsApiHandler ecovacsApiHandler) {
|
||||
this.apiHandler = ecovacsApiHandler;
|
||||
this.apiHandler.setDiscoveryService(this);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return apiHandler;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void activate() {
|
||||
super.activate(null);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
super.deactivate();
|
||||
public void initialize() {
|
||||
thingHandler.setDiscoveryService(this);
|
||||
super.initialize();
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -123,7 +102,7 @@ public class EcovacsDeviceDiscoveryService extends AbstractDiscoveryService impl
|
||||
for (EcovacsDevice device : devices) {
|
||||
deviceDiscovered(device);
|
||||
}
|
||||
for (Thing thing : apiHandler.getThing().getThings()) {
|
||||
for (Thing thing : thingHandler.getThing().getThings()) {
|
||||
String serial = thing.getUID().getId();
|
||||
if (!devices.stream().anyMatch(d -> serial.equals(d.getSerialNumber()))) {
|
||||
thingRemoved(thing.getUID());
|
||||
@ -140,9 +119,9 @@ public class EcovacsDeviceDiscoveryService extends AbstractDiscoveryService impl
|
||||
}
|
||||
|
||||
private void deviceDiscovered(EcovacsDevice device) {
|
||||
ThingUID thingUID = new ThingUID(THING_TYPE_VACUUM, apiHandler.getThing().getUID(), device.getSerialNumber());
|
||||
ThingUID thingUID = new ThingUID(THING_TYPE_VACUUM, thingHandler.getThing().getUID(), device.getSerialNumber());
|
||||
DiscoveryResult discoveryResult = DiscoveryResultBuilder.create(thingUID)
|
||||
.withBridge(apiHandler.getThing().getUID()).withLabel(device.getModelName())
|
||||
.withBridge(thingHandler.getThing().getUID()).withLabel(device.getModelName())
|
||||
.withProperty(Thing.PROPERTY_SERIAL_NUMBER, device.getSerialNumber())
|
||||
.withProperty(Thing.PROPERTY_MODEL_ID, device.getModelName())
|
||||
.withRepresentationProperty(Thing.PROPERTY_SERIAL_NUMBER).build();
|
||||
|
@ -14,18 +14,14 @@ package org.openhab.binding.electroluxair.internal.discovery;
|
||||
|
||||
import static org.openhab.binding.electroluxair.internal.ElectroluxAirBindingConstants.*;
|
||||
|
||||
import java.util.Map;
|
||||
|
||||
import org.eclipse.jdt.annotation.NonNullByDefault;
|
||||
import org.eclipse.jdt.annotation.Nullable;
|
||||
import org.openhab.binding.electroluxair.internal.ElectroluxAirConfiguration;
|
||||
import org.openhab.binding.electroluxair.internal.handler.ElectroluxAirBridgeHandler;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.config.discovery.DiscoveryService;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
|
||||
/**
|
||||
* The {@link ElectroluxAirDiscoveryService} searches for available
|
||||
@ -33,51 +29,26 @@ import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
*
|
||||
* @author Jan Gustafsson - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = ElectroluxAirDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class ElectroluxAirDiscoveryService extends AbstractDiscoveryService
|
||||
implements ThingHandlerService, DiscoveryService {
|
||||
public class ElectroluxAirDiscoveryService extends AbstractThingHandlerDiscoveryService<ElectroluxAirBridgeHandler> {
|
||||
private static final int SEARCH_TIME = 2;
|
||||
private @Nullable ElectroluxAirBridgeHandler handler;
|
||||
|
||||
public ElectroluxAirDiscoveryService() {
|
||||
super(SUPPORTED_THING_TYPES_UIDS, SEARCH_TIME);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(@Nullable ThingHandler handler) {
|
||||
if (handler instanceof ElectroluxAirBridgeHandler bridgeHandler) {
|
||||
this.handler = bridgeHandler;
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return handler;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void activate(@Nullable Map<String, Object> configProperties) {
|
||||
super.activate(configProperties);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
super.deactivate();
|
||||
super(ElectroluxAirBridgeHandler.class, SUPPORTED_THING_TYPES_UIDS, SEARCH_TIME);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void startScan() {
|
||||
ElectroluxAirBridgeHandler bridgeHandler = this.handler;
|
||||
if (bridgeHandler != null) {
|
||||
ThingUID bridgeUID = bridgeHandler.getThing().getUID();
|
||||
bridgeHandler.getElectroluxAirThings().entrySet().stream().forEach(thing -> {
|
||||
ThingUID bridgeUID = thingHandler.getThing().getUID();
|
||||
thingHandler.getElectroluxAirThings().entrySet().stream().forEach(thing -> {
|
||||
thingDiscovered(DiscoveryResultBuilder
|
||||
.create(new ThingUID(THING_TYPE_ELECTROLUX_PURE_A9, bridgeUID, thing.getKey()))
|
||||
.withLabel("Electrolux Pure A9").withBridge(bridgeUID)
|
||||
.withProperty(ElectroluxAirConfiguration.DEVICE_ID_LABEL, thing.getKey())
|
||||
.withRepresentationProperty(ElectroluxAirConfiguration.DEVICE_ID_LABEL).build());
|
||||
});
|
||||
}
|
||||
|
||||
stopScan();
|
||||
}
|
||||
}
|
||||
|
@ -25,12 +25,12 @@ import org.eclipse.jdt.annotation.Nullable;
|
||||
import org.openhab.binding.elroconnects.internal.ElroConnectsBindingConstants;
|
||||
import org.openhab.binding.elroconnects.internal.devices.ElroConnectsConnector;
|
||||
import org.openhab.binding.elroconnects.internal.handler.ElroConnectsAccountHandler;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.thing.Thing;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -39,13 +39,13 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Mark Herwege - Initial Contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = ElroConnectsBridgeDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class ElroConnectsBridgeDiscoveryService extends AbstractDiscoveryService implements ThingHandlerService {
|
||||
public class ElroConnectsBridgeDiscoveryService
|
||||
extends AbstractThingHandlerDiscoveryService<ElroConnectsAccountHandler> {
|
||||
|
||||
private final Logger logger = LoggerFactory.getLogger(ElroConnectsBridgeDiscoveryService.class);
|
||||
|
||||
private @Nullable ElroConnectsAccountHandler accountHandler;
|
||||
|
||||
private volatile @Nullable ScheduledFuture<?> discoveryJob;
|
||||
|
||||
private static final int TIMEOUT_S = 5;
|
||||
@ -54,7 +54,7 @@ public class ElroConnectsBridgeDiscoveryService extends AbstractDiscoveryService
|
||||
private static final int REFRESH_INTERVAL_S = 60;
|
||||
|
||||
public ElroConnectsBridgeDiscoveryService() {
|
||||
super(ElroConnectsBindingConstants.SUPPORTED_CONNECTOR_TYPES_UIDS, TIMEOUT_S);
|
||||
super(ElroConnectsAccountHandler.class, ElroConnectsBindingConstants.SUPPORTED_CONNECTOR_TYPES_UIDS, TIMEOUT_S);
|
||||
logger.debug("Bridge discovery service started");
|
||||
}
|
||||
|
||||
@ -67,14 +67,10 @@ public class ElroConnectsBridgeDiscoveryService extends AbstractDiscoveryService
|
||||
|
||||
private void discoverConnectors() {
|
||||
logger.debug("Starting hub discovery scan");
|
||||
ElroConnectsAccountHandler account = accountHandler;
|
||||
if (account == null) {
|
||||
return;
|
||||
}
|
||||
|
||||
ThingUID bridgeUID = account.getThing().getUID();
|
||||
ThingUID bridgeUID = thingHandler.getThing().getUID();
|
||||
|
||||
Map<String, ElroConnectsConnector> connectors = account.getDevices();
|
||||
Map<String, ElroConnectsConnector> connectors = thingHandler.getDevices();
|
||||
if (connectors == null) {
|
||||
return;
|
||||
}
|
||||
@ -134,21 +130,14 @@ public class ElroConnectsBridgeDiscoveryService extends AbstractDiscoveryService
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
public void dispose() {
|
||||
super.dispose();
|
||||
removeOlderResults(Instant.now().toEpochMilli());
|
||||
super.deactivate();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(@Nullable ThingHandler handler) {
|
||||
if (handler instanceof ElroConnectsAccountHandler accountHandler) {
|
||||
this.accountHandler = accountHandler;
|
||||
accountHandler.setDiscoveryService(this);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return accountHandler;
|
||||
public void initialize() {
|
||||
thingHandler.setDiscoveryService(this);
|
||||
super.initialize();
|
||||
}
|
||||
}
|
||||
|
@ -25,12 +25,12 @@ import org.openhab.binding.elroconnects.internal.ElroConnectsBindingConstants;
|
||||
import org.openhab.binding.elroconnects.internal.ElroConnectsBindingConstants.ElroDeviceType;
|
||||
import org.openhab.binding.elroconnects.internal.devices.ElroConnectsDevice;
|
||||
import org.openhab.binding.elroconnects.internal.handler.ElroConnectsBridgeHandler;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.thing.ThingTypeUID;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -39,20 +39,19 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Mark Herwege - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = ElroConnectsDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class ElroConnectsDiscoveryService extends AbstractDiscoveryService implements ThingHandlerService {
|
||||
public class ElroConnectsDiscoveryService extends AbstractThingHandlerDiscoveryService<ElroConnectsBridgeHandler> {
|
||||
|
||||
private final Logger logger = LoggerFactory.getLogger(ElroConnectsDiscoveryService.class);
|
||||
|
||||
private @Nullable ElroConnectsBridgeHandler bridgeHandler;
|
||||
|
||||
private static final int TIMEOUT_S = 5;
|
||||
private static final int REFRESH_INTERVAL_S = 60;
|
||||
|
||||
private @Nullable ScheduledFuture<?> discoveryJob;
|
||||
|
||||
public ElroConnectsDiscoveryService() {
|
||||
super(ElroConnectsBindingConstants.SUPPORTED_DEVICE_TYPES_UIDS, TIMEOUT_S);
|
||||
super(ElroConnectsBridgeHandler.class, ElroConnectsBindingConstants.SUPPORTED_DEVICE_TYPES_UIDS, TIMEOUT_S);
|
||||
logger.debug("Discovery service started");
|
||||
}
|
||||
|
||||
@ -63,10 +62,8 @@ public class ElroConnectsDiscoveryService extends AbstractDiscoveryService imple
|
||||
|
||||
private void discoverDevices() {
|
||||
logger.debug("Starting device discovery scan");
|
||||
ElroConnectsBridgeHandler bridge = bridgeHandler;
|
||||
if (bridge != null) {
|
||||
Map<Integer, ElroConnectsDevice> devices = bridge.getDevices();
|
||||
ThingUID bridgeUID = bridge.getThing().getUID();
|
||||
Map<Integer, ElroConnectsDevice> devices = thingHandler.getDevices();
|
||||
ThingUID bridgeUID = thingHandler.getThing().getUID();
|
||||
devices.entrySet().forEach(e -> {
|
||||
String deviceId = e.getKey().toString();
|
||||
String deviceName = e.getValue().getDeviceName();
|
||||
@ -76,16 +73,14 @@ public class ElroConnectsDiscoveryService extends AbstractDiscoveryService imple
|
||||
if (type != null) {
|
||||
ThingTypeUID thingTypeUID = THING_TYPE_MAP.get(type);
|
||||
if (thingTypeUID != null) {
|
||||
thingDiscovered(DiscoveryResultBuilder
|
||||
.create(new ThingUID(thingTypeUID, bridgeUID, deviceId)).withLabel(deviceName)
|
||||
.withBridge(bridgeUID).withProperty(CONFIG_DEVICE_ID, deviceId)
|
||||
thingDiscovered(DiscoveryResultBuilder.create(new ThingUID(thingTypeUID, bridgeUID, deviceId))
|
||||
.withLabel(deviceName).withBridge(bridgeUID).withProperty(CONFIG_DEVICE_ID, deviceId)
|
||||
.withRepresentationProperty(CONFIG_DEVICE_ID).build());
|
||||
}
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
protected synchronized void stopScan() {
|
||||
@ -114,21 +109,14 @@ public class ElroConnectsDiscoveryService extends AbstractDiscoveryService imple
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
public void dispose() {
|
||||
super.dispose();
|
||||
removeOlderResults(Instant.now().toEpochMilli());
|
||||
super.deactivate();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(@Nullable ThingHandler handler) {
|
||||
if (handler instanceof ElroConnectsBridgeHandler bridgeHandler) {
|
||||
this.bridgeHandler = bridgeHandler;
|
||||
bridgeHandler.setDiscoveryService(this);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return bridgeHandler;
|
||||
public void initialize() {
|
||||
thingHandler.setDiscoveryService(this);
|
||||
super.initialize();
|
||||
}
|
||||
}
|
||||
|
@ -45,6 +45,8 @@ import org.openhab.core.library.unit.Units;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -53,6 +55,7 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Jacob Laursen - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = EnergiDataServiceActions.class)
|
||||
@ThingActionsScope(name = "energidataservice")
|
||||
@NonNullByDefault
|
||||
public class EnergiDataServiceActions implements ThingActions {
|
||||
|
@ -21,6 +21,8 @@ import org.openhab.core.automation.annotation.RuleAction;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
|
||||
/**
|
||||
* This is the automation engine actions handler service for the
|
||||
@ -28,6 +30,7 @@ import org.openhab.core.thing.binding.ThingHandler;
|
||||
*
|
||||
* @author Guido Dolfen - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = Enigma2Actions.class)
|
||||
@ThingActionsScope(name = "enigma2")
|
||||
@NonNullByDefault
|
||||
public class Enigma2Actions implements ThingActions {
|
||||
|
@ -28,14 +28,13 @@ import org.openhab.binding.enphase.internal.EnphaseBindingConstants.EnphaseDevic
|
||||
import org.openhab.binding.enphase.internal.dto.InventoryJsonDTO.DeviceDTO;
|
||||
import org.openhab.binding.enphase.internal.dto.InverterDTO;
|
||||
import org.openhab.binding.enphase.internal.handler.EnvoyBridgeHandler;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResult;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.config.discovery.DiscoveryService;
|
||||
import org.openhab.core.thing.ThingTypeUID;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -45,49 +44,28 @@ import org.slf4j.LoggerFactory;
|
||||
* @author Thomas Hentschel - Initial contribution
|
||||
* @author Hilbrand Bouwkamp - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = EnphaseDevicesDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class EnphaseDevicesDiscoveryService extends AbstractDiscoveryService
|
||||
implements ThingHandlerService, DiscoveryService {
|
||||
|
||||
public class EnphaseDevicesDiscoveryService extends AbstractThingHandlerDiscoveryService<EnvoyBridgeHandler> {
|
||||
private static final int TIMEOUT_SECONDS = 20;
|
||||
|
||||
private final Logger logger = LoggerFactory.getLogger(EnphaseDevicesDiscoveryService.class);
|
||||
private @Nullable EnvoyBridgeHandler envoyHandler;
|
||||
|
||||
public EnphaseDevicesDiscoveryService() {
|
||||
super(Set.of(THING_TYPE_ENPHASE_INVERTER), TIMEOUT_SECONDS, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(final @Nullable ThingHandler handler) {
|
||||
if (handler instanceof EnvoyBridgeHandler bridgeHandler) {
|
||||
envoyHandler = bridgeHandler;
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return envoyHandler;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
super.deactivate();
|
||||
super(EnvoyBridgeHandler.class, Set.of(THING_TYPE_ENPHASE_INVERTER), TIMEOUT_SECONDS, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void startScan() {
|
||||
removeOlderResults(getTimestampOfLastScan());
|
||||
final EnvoyBridgeHandler envoyHandler = this.envoyHandler;
|
||||
|
||||
if (envoyHandler == null || !envoyHandler.isOnline()) {
|
||||
logger.debug("Envoy handler not available or online: {}", envoyHandler);
|
||||
if (!thingHandler.isOnline()) {
|
||||
logger.debug("Envoy handler not available or online: {}", thingHandler);
|
||||
return;
|
||||
}
|
||||
final ThingUID uid = envoyHandler.getThing().getUID();
|
||||
final ThingUID uid = thingHandler.getThing().getUID();
|
||||
|
||||
scanForInverterThings(envoyHandler, uid);
|
||||
scanForDeviceThings(envoyHandler, uid);
|
||||
scanForInverterThings(thingHandler, uid);
|
||||
scanForDeviceThings(thingHandler, uid);
|
||||
}
|
||||
|
||||
private void scanForInverterThings(final EnvoyBridgeHandler envoyHandler, final ThingUID bridgeID) {
|
||||
|
@ -17,20 +17,18 @@ import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
import org.eclipse.jdt.annotation.NonNullByDefault;
|
||||
import org.eclipse.jdt.annotation.Nullable;
|
||||
import org.openhab.binding.foobot.internal.FoobotApiException;
|
||||
import org.openhab.binding.foobot.internal.FoobotBindingConstants;
|
||||
import org.openhab.binding.foobot.internal.FoobotHandlerFactory;
|
||||
import org.openhab.binding.foobot.internal.handler.FoobotAccountHandler;
|
||||
import org.openhab.binding.foobot.internal.handler.FoobotDeviceHandler;
|
||||
import org.openhab.binding.foobot.internal.json.FoobotDevice;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.config.discovery.DiscoveryService;
|
||||
import org.openhab.core.thing.Thing;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -41,19 +39,18 @@ import org.slf4j.LoggerFactory;
|
||||
* @author George Katsis - Initial contribution
|
||||
* @author Hilbrand Bouwkamp - Completed implementation
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = FoobotAccountDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class FoobotAccountDiscoveryService extends AbstractDiscoveryService
|
||||
implements DiscoveryService, ThingHandlerService {
|
||||
public class FoobotAccountDiscoveryService extends AbstractThingHandlerDiscoveryService<FoobotAccountHandler> {
|
||||
|
||||
private static final int TIMEOUT_SECONDS = 5;
|
||||
|
||||
private final Logger logger = LoggerFactory.getLogger(FoobotAccountDiscoveryService.class);
|
||||
|
||||
private @Nullable FoobotAccountHandler handler;
|
||||
private @NonNullByDefault({}) ThingUID bridgeUID;
|
||||
|
||||
public FoobotAccountDiscoveryService() {
|
||||
super(FoobotHandlerFactory.DISCOVERABLE_THING_TYPE_UIDS, TIMEOUT_SECONDS, false);
|
||||
super(FoobotAccountHandler.class, FoobotHandlerFactory.DISCOVERABLE_THING_TYPE_UIDS, TIMEOUT_SECONDS, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -62,13 +59,10 @@ public class FoobotAccountDiscoveryService extends AbstractDiscoveryService
|
||||
}
|
||||
|
||||
private void retrieveFoobots() {
|
||||
if (handler == null) {
|
||||
return;
|
||||
}
|
||||
try {
|
||||
final List<FoobotDeviceHandler> footbotHandlers = handler.getFootbotHandlers();
|
||||
final List<FoobotDeviceHandler> footbotHandlers = thingHandler.getFootbotHandlers();
|
||||
|
||||
handler.getDeviceList().stream()
|
||||
thingHandler.getDeviceList().stream()
|
||||
.filter(d -> !footbotHandlers.stream().anyMatch(h -> h.getUuid().equals(d.getUuid())))
|
||||
.forEach(this::addThing);
|
||||
} catch (final FoobotApiException e) {
|
||||
@ -77,11 +71,6 @@ public class FoobotAccountDiscoveryService extends AbstractDiscoveryService
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
super.deactivate();
|
||||
}
|
||||
|
||||
private void addThing(final FoobotDevice foobot) {
|
||||
logger.debug("Adding new Foobot '{}' with uuid: {}", foobot.getName(), foobot.getUuid());
|
||||
|
||||
@ -95,16 +84,4 @@ public class FoobotAccountDiscoveryService extends AbstractDiscoveryService
|
||||
thingDiscovered(DiscoveryResultBuilder.create(thingUID).withBridge(bridgeUID).withProperties(properties)
|
||||
.withLabel(foobot.getName()).withRepresentationProperty(foobot.getUuid()).build());
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(@Nullable final ThingHandler handler) {
|
||||
if (handler instanceof FoobotAccountHandler accountHandler) {
|
||||
this.handler = accountHandler;
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return handler;
|
||||
}
|
||||
}
|
||||
|
@ -30,14 +30,14 @@ import org.openhab.binding.freebox.internal.config.FreeboxNetInterfaceConfigurat
|
||||
import org.openhab.binding.freebox.internal.config.FreeboxServerConfiguration;
|
||||
import org.openhab.binding.freebox.internal.handler.FreeboxHandler;
|
||||
import org.openhab.core.config.core.Configuration;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResult;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.thing.Thing;
|
||||
import org.openhab.core.thing.ThingStatus;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -50,17 +50,16 @@ import org.slf4j.LoggerFactory;
|
||||
* @author Laurent Garnier - use new internal API manager
|
||||
* @author Laurent Garnier - use ThingHandlerService
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = FreeboxDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class FreeboxDiscoveryService extends AbstractDiscoveryService
|
||||
implements FreeboxDataListener, ThingHandlerService {
|
||||
public class FreeboxDiscoveryService extends AbstractThingHandlerDiscoveryService<FreeboxHandler>
|
||||
implements FreeboxDataListener {
|
||||
|
||||
private final Logger logger = LoggerFactory.getLogger(FreeboxDiscoveryService.class);
|
||||
|
||||
private static final int SEARCH_TIME = 10;
|
||||
|
||||
private static final String PHONE_ID = "wired";
|
||||
|
||||
private @Nullable FreeboxHandler bridgeHandler;
|
||||
private boolean discoverPhone;
|
||||
private boolean discoverNetDevice;
|
||||
private boolean discoverNetInterface;
|
||||
@ -70,7 +69,7 @@ public class FreeboxDiscoveryService extends AbstractDiscoveryService
|
||||
* Creates a FreeboxDiscoveryService with background discovery disabled.
|
||||
*/
|
||||
public FreeboxDiscoveryService() {
|
||||
super(FreeboxBindingConstants.SUPPORTED_THING_TYPES_UIDS, SEARCH_TIME, false);
|
||||
super(FreeboxHandler.class, FreeboxBindingConstants.SUPPORTED_THING_TYPES_UIDS, SEARCH_TIME, false);
|
||||
this.discoverPhone = true;
|
||||
this.discoverNetDevice = true;
|
||||
this.discoverNetInterface = true;
|
||||
@ -78,23 +77,8 @@ public class FreeboxDiscoveryService extends AbstractDiscoveryService
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(ThingHandler handler) {
|
||||
if (handler instanceof FreeboxHandler freeboxHandler) {
|
||||
bridgeHandler = freeboxHandler;
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return bridgeHandler;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void activate() {
|
||||
super.activate(null);
|
||||
FreeboxHandler handler = bridgeHandler;
|
||||
if (handler != null) {
|
||||
Configuration config = handler.getThing().getConfiguration();
|
||||
public void initialize() {
|
||||
Configuration config = thingHandler.getThing().getConfiguration();
|
||||
Object property = config.get(FreeboxServerConfiguration.DISCOVER_PHONE);
|
||||
discoverPhone = property != null ? ((Boolean) property).booleanValue() : true;
|
||||
property = config.get(FreeboxServerConfiguration.DISCOVER_NET_DEVICE);
|
||||
@ -108,28 +92,24 @@ public class FreeboxDiscoveryService extends AbstractDiscoveryService
|
||||
logger.debug("Freebox discovery - discoverNetInterface : {}", discoverNetInterface);
|
||||
logger.debug("Freebox discovery - discoverAirPlayReceiver : {}", discoverAirPlayReceiver);
|
||||
|
||||
handler.registerDataListener(this);
|
||||
}
|
||||
thingHandler.registerDataListener(this);
|
||||
super.initialize();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
FreeboxHandler handler = bridgeHandler;
|
||||
if (handler != null) {
|
||||
handler.unregisterDataListener(this);
|
||||
}
|
||||
super.deactivate();
|
||||
public void dispose() {
|
||||
super.dispose();
|
||||
thingHandler.unregisterDataListener(this);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void startScan() {
|
||||
logger.debug("Starting Freebox discovery scan");
|
||||
FreeboxHandler handler = bridgeHandler;
|
||||
if (handler != null && handler.getThing().getStatus() == ThingStatus.ONLINE) {
|
||||
if (thingHandler.getThing().getStatus() == ThingStatus.ONLINE) {
|
||||
try {
|
||||
List<FreeboxLanHost> lanHosts = handler.getApiManager().getLanHosts();
|
||||
List<FreeboxAirMediaReceiver> airPlayDevices = handler.getApiManager().getAirMediaReceivers();
|
||||
onDataFetched(handler.getThing().getUID(), lanHosts, airPlayDevices);
|
||||
List<FreeboxLanHost> lanHosts = thingHandler.getApiManager().getLanHosts();
|
||||
List<FreeboxAirMediaReceiver> airPlayDevices = thingHandler.getApiManager().getAirMediaReceivers();
|
||||
onDataFetched(thingHandler.getThing().getUID(), lanHosts, airPlayDevices);
|
||||
} catch (FreeboxException e) {
|
||||
logger.warn("Error while requesting data for things discovery", e);
|
||||
}
|
||||
|
@ -18,6 +18,8 @@ import org.openhab.binding.freeboxos.internal.handler.PlayerHandler;
|
||||
import org.openhab.core.automation.annotation.RuleAction;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -26,6 +28,7 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Gaël L'hopital - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = ActivePlayerActions.class)
|
||||
@ThingActionsScope(name = "freeboxos")
|
||||
@NonNullByDefault
|
||||
public class ActivePlayerActions extends PlayerActions {
|
||||
|
@ -19,6 +19,8 @@ import org.openhab.core.automation.annotation.RuleAction;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -27,6 +29,7 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Gaël L'hopital - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = CallActions.class)
|
||||
@ThingActionsScope(name = "freeboxos")
|
||||
@NonNullByDefault
|
||||
public class CallActions implements ThingActions {
|
||||
|
@ -19,6 +19,8 @@ import org.openhab.core.automation.annotation.RuleAction;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -27,6 +29,7 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Gaël L'hopital - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = FreeplugActions.class)
|
||||
@ThingActionsScope(name = "freeboxos")
|
||||
@NonNullByDefault
|
||||
public class FreeplugActions implements ThingActions {
|
||||
|
@ -19,6 +19,8 @@ import org.openhab.core.automation.annotation.RuleAction;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -27,6 +29,7 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Gaël L'hopital - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = HostActions.class)
|
||||
@ThingActionsScope(name = "freeboxos")
|
||||
@NonNullByDefault
|
||||
public class HostActions implements ThingActions {
|
||||
|
@ -20,6 +20,8 @@ import org.openhab.core.automation.annotation.RuleAction;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -28,6 +30,7 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Gaël L'hopital - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = PlayerActions.class)
|
||||
@ThingActionsScope(name = "freeboxos")
|
||||
@NonNullByDefault
|
||||
public class PlayerActions implements ThingActions {
|
||||
|
@ -19,6 +19,8 @@ import org.openhab.core.automation.annotation.RuleAction;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -27,6 +29,7 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Gaël L'hopital - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = RepeaterActions.class)
|
||||
@ThingActionsScope(name = "freeboxos")
|
||||
@NonNullByDefault
|
||||
public class RepeaterActions implements ThingActions {
|
||||
|
@ -19,6 +19,8 @@ import org.openhab.core.automation.annotation.RuleAction;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -27,6 +29,7 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Gaël L'hopital - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = ServerActions.class)
|
||||
@ThingActionsScope(name = "freeboxos")
|
||||
@NonNullByDefault
|
||||
public class ServerActions implements ThingActions {
|
||||
|
@ -24,7 +24,6 @@ import java.util.stream.Collectors;
|
||||
import java.util.stream.Stream;
|
||||
|
||||
import org.eclipse.jdt.annotation.NonNullByDefault;
|
||||
import org.eclipse.jdt.annotation.Nullable;
|
||||
import org.openhab.binding.freeboxos.internal.api.FreeboxException;
|
||||
import org.openhab.binding.freeboxos.internal.api.PermissionException;
|
||||
import org.openhab.binding.freeboxos.internal.api.rest.APManager;
|
||||
@ -47,15 +46,15 @@ import org.openhab.binding.freeboxos.internal.config.FreeplugConfigurationBuilde
|
||||
import org.openhab.binding.freeboxos.internal.config.NodeConfigurationBuilder;
|
||||
import org.openhab.binding.freeboxos.internal.config.PhoneConfigurationBuilder;
|
||||
import org.openhab.binding.freeboxos.internal.handler.FreeboxOsHandler;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResult;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.thing.Thing;
|
||||
import org.openhab.core.thing.ThingStatus;
|
||||
import org.openhab.core.thing.ThingTypeUID;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -67,50 +66,30 @@ import inet.ipaddr.mac.MACAddress;
|
||||
*
|
||||
* @author Gaël L'hopital - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = FreeboxOsDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class FreeboxOsDiscoveryService extends AbstractDiscoveryService implements ThingHandlerService {
|
||||
public class FreeboxOsDiscoveryService extends AbstractThingHandlerDiscoveryService<FreeboxOsHandler> {
|
||||
private static final int DISCOVERY_TIME_SECONDS = 10;
|
||||
|
||||
private final Logger logger = LoggerFactory.getLogger(FreeboxOsDiscoveryService.class);
|
||||
|
||||
private Optional<ScheduledFuture<?>> backgroundFuture = Optional.empty();
|
||||
private @Nullable FreeboxOsHandler bridgeHandler;
|
||||
|
||||
public FreeboxOsDiscoveryService() {
|
||||
super(Stream.of(THINGS_TYPES_UIDS, HOME_TYPES_UIDS).flatMap(Set::stream).collect(Collectors.toSet()),
|
||||
super(FreeboxOsHandler.class,
|
||||
Stream.of(THINGS_TYPES_UIDS, HOME_TYPES_UIDS).flatMap(Set::stream).collect(Collectors.toSet()),
|
||||
DISCOVERY_TIME_SECONDS);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
super.deactivate();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(@Nullable ThingHandler handler) {
|
||||
if (handler instanceof FreeboxOsHandler freeboxosHandler) {
|
||||
bridgeHandler = freeboxosHandler;
|
||||
activate(null);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return bridgeHandler;
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void startBackgroundDiscovery() {
|
||||
stopBackgroundDiscovery();
|
||||
FreeboxOsHandler handler = bridgeHandler;
|
||||
if (handler != null) {
|
||||
int interval = handler.getConfiguration().discoveryInterval;
|
||||
int interval = thingHandler.getConfiguration().discoveryInterval;
|
||||
if (interval > 0) {
|
||||
backgroundFuture = Optional
|
||||
.of(scheduler.scheduleWithFixedDelay(this::startScan, 1, interval, TimeUnit.MINUTES));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void stopBackgroundDiscovery() {
|
||||
@ -121,23 +100,22 @@ public class FreeboxOsDiscoveryService extends AbstractDiscoveryService implemen
|
||||
@Override
|
||||
protected void startScan() {
|
||||
logger.debug("Starting Freebox discovery scan");
|
||||
FreeboxOsHandler handler = bridgeHandler;
|
||||
if (handler != null && handler.getThing().getStatus() == ThingStatus.ONLINE) {
|
||||
if (thingHandler.getThing().getStatus() == ThingStatus.ONLINE) {
|
||||
try {
|
||||
ThingUID bridgeUID = handler.getThing().getUID();
|
||||
ThingUID bridgeUID = thingHandler.getThing().getUID();
|
||||
|
||||
List<LanHost> lanHosts = new ArrayList<>(handler.getManager(LanBrowserManager.class).getHosts().stream()
|
||||
.filter(LanHost::reachable).toList());
|
||||
List<LanHost> lanHosts = new ArrayList<>(thingHandler.getManager(LanBrowserManager.class).getHosts()
|
||||
.stream().filter(LanHost::reachable).toList());
|
||||
|
||||
discoverServer(handler.getManager(SystemManager.class), bridgeUID);
|
||||
discoverPhone(handler.getManager(PhoneManager.class), bridgeUID);
|
||||
discoverPlugs(handler.getManager(FreeplugManager.class), bridgeUID);
|
||||
discoverRepeater(handler.getManager(RepeaterManager.class), bridgeUID, lanHosts);
|
||||
discoverPlayer(handler.getManager(PlayerManager.class), bridgeUID, lanHosts);
|
||||
discoverVM(handler.getManager(VmManager.class), bridgeUID, lanHosts);
|
||||
discoverHome(handler.getManager(HomeManager.class), bridgeUID);
|
||||
if (handler.getConfiguration().discoverNetDevice) {
|
||||
discoverHosts(handler, bridgeUID, lanHosts);
|
||||
discoverServer(thingHandler.getManager(SystemManager.class), bridgeUID);
|
||||
discoverPhone(thingHandler.getManager(PhoneManager.class), bridgeUID);
|
||||
discoverPlugs(thingHandler.getManager(FreeplugManager.class), bridgeUID);
|
||||
discoverRepeater(thingHandler.getManager(RepeaterManager.class), bridgeUID, lanHosts);
|
||||
discoverPlayer(thingHandler.getManager(PlayerManager.class), bridgeUID, lanHosts);
|
||||
discoverVM(thingHandler.getManager(VmManager.class), bridgeUID, lanHosts);
|
||||
discoverHome(thingHandler.getManager(HomeManager.class), bridgeUID);
|
||||
if (thingHandler.getConfiguration().discoverNetDevice) {
|
||||
discoverHosts(thingHandler, bridgeUID, lanHosts);
|
||||
}
|
||||
} catch (FreeboxException e) {
|
||||
logger.warn("Error while requesting data for things discovery: {}", e.getMessage());
|
||||
|
@ -28,15 +28,14 @@ import org.openhab.binding.gardena.internal.handler.GardenaAccountHandler;
|
||||
import org.openhab.binding.gardena.internal.model.dto.Device;
|
||||
import org.openhab.binding.gardena.internal.util.PropertyUtils;
|
||||
import org.openhab.binding.gardena.internal.util.UidUtils;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResult;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.config.discovery.DiscoveryService;
|
||||
import org.openhab.core.thing.Thing;
|
||||
import org.openhab.core.thing.ThingTypeUID;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -45,45 +44,24 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Gerhard Riegler - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = GardenaDeviceDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class GardenaDeviceDiscoveryService extends AbstractDiscoveryService
|
||||
implements DiscoveryService, ThingHandlerService {
|
||||
public class GardenaDeviceDiscoveryService extends AbstractThingHandlerDiscoveryService<GardenaAccountHandler> {
|
||||
|
||||
private final Logger logger = LoggerFactory.getLogger(GardenaDeviceDiscoveryService.class);
|
||||
private static final int DISCOVER_TIMEOUT_SECONDS = 5;
|
||||
|
||||
private @NonNullByDefault({}) GardenaAccountHandler accountHandler;
|
||||
private @Nullable Future<?> scanFuture;
|
||||
|
||||
public GardenaDeviceDiscoveryService() {
|
||||
super(Collections.unmodifiableSet(Stream.of(new ThingTypeUID(BINDING_ID, "-")).collect(Collectors.toSet())),
|
||||
super(GardenaAccountHandler.class,
|
||||
Collections.unmodifiableSet(Stream.of(new ThingTypeUID(BINDING_ID, "-")).collect(Collectors.toSet())),
|
||||
DISCOVER_TIMEOUT_SECONDS, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(@Nullable ThingHandler handler) {
|
||||
if (handler instanceof GardenaAccountHandler gardenaAccountHandler) {
|
||||
this.accountHandler = gardenaAccountHandler;
|
||||
this.accountHandler.setDiscoveryService(this);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return accountHandler;
|
||||
}
|
||||
|
||||
/**
|
||||
* Called on component activation.
|
||||
*/
|
||||
@Override
|
||||
public void activate() {
|
||||
super.activate(null);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
super.deactivate();
|
||||
public void initialize() {
|
||||
thingHandler.setDiscoveryService(this);
|
||||
super.initialize();
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -108,13 +86,13 @@ public class GardenaDeviceDiscoveryService extends AbstractDiscoveryService
|
||||
private void loadDevices() {
|
||||
if (scanFuture == null) {
|
||||
scanFuture = scheduler.submit(() -> {
|
||||
GardenaSmart gardena = accountHandler.getGardenaSmart();
|
||||
GardenaSmart gardena = thingHandler.getGardenaSmart();
|
||||
if (gardena != null) {
|
||||
for (Device device : gardena.getAllDevices()) {
|
||||
deviceDiscovered(device);
|
||||
}
|
||||
|
||||
for (Thing thing : accountHandler.getThing().getThings()) {
|
||||
for (Thing thing : thingHandler.getThing().getThings()) {
|
||||
try {
|
||||
gardena.getDevice(UidUtils.getGardenaDeviceId(thing));
|
||||
} catch (GardenaException ex) {
|
||||
@ -155,8 +133,8 @@ public class GardenaDeviceDiscoveryService extends AbstractDiscoveryService
|
||||
*/
|
||||
public void deviceDiscovered(Device device) {
|
||||
if (device.active) {
|
||||
ThingUID accountUID = accountHandler.getThing().getUID();
|
||||
ThingUID thingUID = UidUtils.generateThingUID(device, accountHandler.getThing());
|
||||
ThingUID accountUID = thingHandler.getThing().getUID();
|
||||
ThingUID thingUID = UidUtils.generateThingUID(device, thingHandler.getThing());
|
||||
|
||||
try {
|
||||
DiscoveryResult discoveryResult = DiscoveryResultBuilder.create(thingUID).withBridge(accountUID)
|
||||
|
@ -20,6 +20,8 @@ import org.openhab.core.automation.annotation.RuleAction;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -28,6 +30,7 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Gaël L'hopital - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = Ipx800Actions.class)
|
||||
@ThingActionsScope(name = "gce")
|
||||
@NonNullByDefault
|
||||
public class Ipx800Actions implements ThingActions {
|
||||
|
@ -25,14 +25,13 @@ import org.openhab.binding.groupepsa.internal.GroupePSABindingConstants;
|
||||
import org.openhab.binding.groupepsa.internal.bridge.GroupePSABridgeHandler;
|
||||
import org.openhab.binding.groupepsa.internal.rest.api.dto.Vehicle;
|
||||
import org.openhab.binding.groupepsa.internal.rest.exceptions.GroupePSACommunicationException;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResult;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.thing.ThingTypeUID;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -42,48 +41,25 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Arjan Mels - Initial contribution
|
||||
*/
|
||||
@Component(service = ThingHandlerService.class)
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = GroupePSADiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class GroupePSADiscoveryService extends AbstractDiscoveryService implements ThingHandlerService {
|
||||
public class GroupePSADiscoveryService extends AbstractThingHandlerDiscoveryService<GroupePSABridgeHandler> {
|
||||
private final Logger logger = LoggerFactory.getLogger(GroupePSADiscoveryService.class);
|
||||
|
||||
private @Nullable GroupePSABridgeHandler bridgeHandler;
|
||||
|
||||
public GroupePSADiscoveryService() {
|
||||
super(Set.of(THING_TYPE_VEHICLE), 10, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(@Nullable ThingHandler handler) {
|
||||
if (handler instanceof GroupePSABridgeHandler bridgeHandler) {
|
||||
this.bridgeHandler = bridgeHandler;
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return bridgeHandler;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
super.deactivate();
|
||||
super(GroupePSABridgeHandler.class, Set.of(THING_TYPE_VEHICLE), 10, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void startScan() {
|
||||
try {
|
||||
GroupePSABridgeHandler localBridgeHandler = bridgeHandler;
|
||||
if (localBridgeHandler == null) {
|
||||
return;
|
||||
}
|
||||
List<Vehicle> vehicles = localBridgeHandler.getVehicles();
|
||||
List<Vehicle> vehicles = thingHandler.getVehicles();
|
||||
if (vehicles == null || vehicles.isEmpty()) {
|
||||
logger.warn("No vehicles found");
|
||||
return;
|
||||
}
|
||||
for (Vehicle vehicle : vehicles) {
|
||||
ThingUID bridgeUID = localBridgeHandler.getThing().getUID();
|
||||
ThingUID bridgeUID = thingHandler.getThing().getUID();
|
||||
ThingTypeUID thingTypeUID = THING_TYPE_VEHICLE;
|
||||
String id = vehicle.getId();
|
||||
if (id != null) {
|
||||
|
@ -27,14 +27,13 @@ import org.openhab.binding.haywardomnilogic.internal.HaywardBindingConstants;
|
||||
import org.openhab.binding.haywardomnilogic.internal.HaywardException;
|
||||
import org.openhab.binding.haywardomnilogic.internal.HaywardTypeToRequest;
|
||||
import org.openhab.binding.haywardomnilogic.internal.handler.HaywardBridgeHandler;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResult;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.config.discovery.DiscoveryService;
|
||||
import org.openhab.core.thing.ThingTypeUID;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -43,34 +42,20 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Matt Myers - Initial contribution
|
||||
*/
|
||||
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = HaywardDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class HaywardDiscoveryService extends AbstractDiscoveryService implements DiscoveryService, ThingHandlerService {
|
||||
public class HaywardDiscoveryService extends AbstractThingHandlerDiscoveryService<HaywardBridgeHandler> {
|
||||
private final Logger logger = LoggerFactory.getLogger(HaywardDiscoveryService.class);
|
||||
private @Nullable HaywardBridgeHandler discoveryBridgehandler;
|
||||
|
||||
public HaywardDiscoveryService() {
|
||||
super(THING_TYPES_UIDS, 0, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void activate() {
|
||||
super.activate(null);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
super.deactivate();
|
||||
super(HaywardBridgeHandler.class, THING_TYPES_UIDS, 0, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void startScan() {
|
||||
HaywardBridgeHandler bridgehandler = discoveryBridgehandler;
|
||||
try {
|
||||
if (bridgehandler != null) {
|
||||
String xmlResults = bridgehandler.getMspConfig();
|
||||
String xmlResults = thingHandler.getMspConfig();
|
||||
mspConfigDiscovery(xmlResults);
|
||||
}
|
||||
} catch (HaywardException e) {
|
||||
logger.warn("Exception during discovery scan: {}", e.getMessage());
|
||||
} catch (InterruptedException e) {
|
||||
@ -83,36 +68,30 @@ public class HaywardDiscoveryService extends AbstractDiscoveryService implements
|
||||
List<String> names = new ArrayList<>();
|
||||
Map<String, Object> backyardProperties = new HashMap<>();
|
||||
Map<String, Object> bowProperties = new HashMap<>();
|
||||
HaywardBridgeHandler bridgehandler = discoveryBridgehandler;
|
||||
|
||||
if (bridgehandler == null) {
|
||||
return;
|
||||
}
|
||||
|
||||
// Find Backyard
|
||||
names = bridgehandler.evaluateXPath("//Backyard/Name/text()", xmlResponse);
|
||||
names = thingHandler.evaluateXPath("//Backyard/Name/text()", xmlResponse);
|
||||
|
||||
for (int i = 0; i < names.size(); i++) {
|
||||
backyardProperties.put(HaywardBindingConstants.PROPERTY_TYPE, HaywardTypeToRequest.BACKYARD);
|
||||
backyardProperties.put(HaywardBindingConstants.PROPERTY_SYSTEM_ID, bridgehandler.account.mspSystemID);
|
||||
backyardProperties.put(HaywardBindingConstants.PROPERTY_SYSTEM_ID, thingHandler.account.mspSystemID);
|
||||
|
||||
onDeviceDiscovered(HaywardBindingConstants.THING_TYPE_BACKYARD, names.get(i), backyardProperties);
|
||||
}
|
||||
|
||||
// Find Bodies of Water
|
||||
systemIDs = bridgehandler.evaluateXPath("//Body-of-water/System-Id/text()", xmlResponse);
|
||||
names = bridgehandler.evaluateXPath("//Body-of-water/Name/text()", xmlResponse);
|
||||
systemIDs = thingHandler.evaluateXPath("//Body-of-water/System-Id/text()", xmlResponse);
|
||||
names = thingHandler.evaluateXPath("//Body-of-water/Name/text()", xmlResponse);
|
||||
|
||||
final List<String> bowProperty1 = bridgehandler.evaluateXPath("//Body-of-water/Type/text()", xmlResponse);
|
||||
final List<String> bowProperty2 = bridgehandler.evaluateXPath("//Body-of-water/Shared-Type/text()",
|
||||
final List<String> bowProperty1 = thingHandler.evaluateXPath("//Body-of-water/Type/text()", xmlResponse);
|
||||
final List<String> bowProperty2 = thingHandler.evaluateXPath("//Body-of-water/Shared-Type/text()", xmlResponse);
|
||||
final List<String> bowProperty3 = thingHandler.evaluateXPath("//Body-of-water/Shared-Priority/text()",
|
||||
xmlResponse);
|
||||
final List<String> bowProperty3 = bridgehandler.evaluateXPath("//Body-of-water/Shared-Priority/text()",
|
||||
xmlResponse);
|
||||
final List<String> bowProperty4 = bridgehandler
|
||||
final List<String> bowProperty4 = thingHandler
|
||||
.evaluateXPath("//Body-of-water/Shared-Equipment-System-ID/text()", xmlResponse);
|
||||
final List<String> bowProperty5 = bridgehandler.evaluateXPath("//Body-of-water/Supports-Spillover/text()",
|
||||
final List<String> bowProperty5 = thingHandler.evaluateXPath("//Body-of-water/Supports-Spillover/text()",
|
||||
xmlResponse);
|
||||
final List<String> bowProperty6 = bridgehandler.evaluateXPath("//Body-of-water/Size-In-Gallons/text()",
|
||||
final List<String> bowProperty6 = thingHandler.evaluateXPath("//Body-of-water/Size-In-Gallons/text()",
|
||||
xmlResponse);
|
||||
|
||||
for (int i = 0; i < systemIDs.size(); i++) {
|
||||
@ -129,16 +108,16 @@ public class HaywardDiscoveryService extends AbstractDiscoveryService implements
|
||||
}
|
||||
|
||||
// Find Chlorinators
|
||||
final List<String> chlorinatorProperty1 = bridgehandler
|
||||
final List<String> chlorinatorProperty1 = thingHandler
|
||||
.evaluateXPath("//Body-of-water/Chlorinator/Shared-Type/text()", xmlResponse);
|
||||
final List<String> chlorinatorProperty2 = bridgehandler.evaluateXPath("//Body-of-water/Chlorinator/Mode/text()",
|
||||
final List<String> chlorinatorProperty2 = thingHandler.evaluateXPath("//Body-of-water/Chlorinator/Mode/text()",
|
||||
xmlResponse);
|
||||
final List<String> chlorinatorProperty3 = bridgehandler
|
||||
final List<String> chlorinatorProperty3 = thingHandler
|
||||
.evaluateXPath("//Body-of-water/Chlorinator/Cell-Type/text()", xmlResponse);
|
||||
final List<String> chlorinatorProperty4 = bridgehandler
|
||||
final List<String> chlorinatorProperty4 = thingHandler
|
||||
.evaluateXPath("//Body-of-water/Chlorinator/Dispenser-Type/text()", xmlResponse);
|
||||
|
||||
discoverDevices(bridgehandler, xmlResponse, "Chlorinator", HaywardTypeToRequest.CHLORINATOR,
|
||||
discoverDevices(thingHandler, xmlResponse, "Chlorinator", HaywardTypeToRequest.CHLORINATOR,
|
||||
HaywardBindingConstants.THING_TYPE_CHLORINATOR, (props, i) -> {
|
||||
props.put(HaywardBindingConstants.PROPERTY_CHLORINATOR_SHAREDTYPE, chlorinatorProperty1.get(i));
|
||||
props.put(HaywardBindingConstants.PROPERTY_CHLORINATOR_MODE, chlorinatorProperty2.get(i));
|
||||
@ -147,41 +126,41 @@ public class HaywardDiscoveryService extends AbstractDiscoveryService implements
|
||||
});
|
||||
|
||||
// Find ColorLogic Lights
|
||||
final List<String> colorLogicProperty1 = bridgehandler.evaluateXPath("//Backyard//ColorLogic-Light/Type/text()",
|
||||
final List<String> colorLogicProperty1 = thingHandler.evaluateXPath("//Backyard//ColorLogic-Light/Type/text()",
|
||||
xmlResponse);
|
||||
|
||||
discoverDevices(bridgehandler, xmlResponse, "ColorLogic-Light", HaywardTypeToRequest.COLORLOGIC,
|
||||
discoverDevices(thingHandler, xmlResponse, "ColorLogic-Light", HaywardTypeToRequest.COLORLOGIC,
|
||||
HaywardBindingConstants.THING_TYPE_COLORLOGIC, (props, i) -> {
|
||||
props.put(HaywardBindingConstants.PROPERTY_COLORLOGIC_TYPE, colorLogicProperty1.get(i));
|
||||
});
|
||||
|
||||
// Find Filters
|
||||
final List<String> filterProperty1 = bridgehandler.evaluateXPath("//Body-of-water/Filter/Shared-Type/text()",
|
||||
final List<String> filterProperty1 = thingHandler.evaluateXPath("//Body-of-water/Filter/Shared-Type/text()",
|
||||
xmlResponse);
|
||||
final List<String> filterProperty2 = bridgehandler.evaluateXPath("//Body-of-water/Filter/Filter-Type/text()",
|
||||
final List<String> filterProperty2 = thingHandler.evaluateXPath("//Body-of-water/Filter/Filter-Type/text()",
|
||||
xmlResponse);
|
||||
final List<String> filterProperty3 = bridgehandler
|
||||
.evaluateXPath("//Body-of-water/Filter/Priming-Enabled/text()", xmlResponse);
|
||||
final List<String> filterProperty4 = bridgehandler.evaluateXPath("//Body-of-water/Filter/Min-Pump-Speed/text()",
|
||||
final List<String> filterProperty3 = thingHandler.evaluateXPath("//Body-of-water/Filter/Priming-Enabled/text()",
|
||||
xmlResponse);
|
||||
final List<String> filterProperty5 = bridgehandler.evaluateXPath("//Body-of-water/Filter/Max-Pump-Speed/text()",
|
||||
final List<String> filterProperty4 = thingHandler.evaluateXPath("//Body-of-water/Filter/Min-Pump-Speed/text()",
|
||||
xmlResponse);
|
||||
final List<String> filterProperty6 = bridgehandler.evaluateXPath("//Body-of-water/Filter/Min-Pump-RPM/text()",
|
||||
final List<String> filterProperty5 = thingHandler.evaluateXPath("//Body-of-water/Filter/Max-Pump-Speed/text()",
|
||||
xmlResponse);
|
||||
final List<String> filterProperty7 = bridgehandler.evaluateXPath("//Body-of-water/Filter/Max-Pump-RPM/text()",
|
||||
final List<String> filterProperty6 = thingHandler.evaluateXPath("//Body-of-water/Filter/Min-Pump-RPM/text()",
|
||||
xmlResponse);
|
||||
final List<String> filterProperty8 = bridgehandler
|
||||
final List<String> filterProperty7 = thingHandler.evaluateXPath("//Body-of-water/Filter/Max-Pump-RPM/text()",
|
||||
xmlResponse);
|
||||
final List<String> filterProperty8 = thingHandler
|
||||
.evaluateXPath("//Body-of-water/Filter/Vsp-Low-Pump-Speed/text()", xmlResponse);
|
||||
final List<String> filterProperty9 = bridgehandler
|
||||
final List<String> filterProperty9 = thingHandler
|
||||
.evaluateXPath("//Body-of-water/Filter/Vsp-Medium-Pump-Speed/text()", xmlResponse);
|
||||
final List<String> filterProperty10 = bridgehandler
|
||||
final List<String> filterProperty10 = thingHandler
|
||||
.evaluateXPath("//Body-of-water/Filter/Vsp-High-Pump-Speed/text()", xmlResponse);
|
||||
final List<String> filterProperty11 = bridgehandler
|
||||
final List<String> filterProperty11 = thingHandler
|
||||
.evaluateXPath("//Body-of-water/Filter/Vsp-Custom-Pump-Speed/text()", xmlResponse);
|
||||
final List<String> filterProperty12 = bridgehandler
|
||||
final List<String> filterProperty12 = thingHandler
|
||||
.evaluateXPath("//Body-of-water/Filter/Freeze-Protect-Override-Interval/text()", xmlResponse);
|
||||
|
||||
discoverDevices(bridgehandler, xmlResponse, "Filter", HaywardTypeToRequest.FILTER,
|
||||
discoverDevices(thingHandler, xmlResponse, "Filter", HaywardTypeToRequest.FILTER,
|
||||
HaywardBindingConstants.THING_TYPE_FILTER, (props, i) -> {
|
||||
props.put(HaywardBindingConstants.PROPERTY_FILTER_SHAREDTYPE, filterProperty1.get(i));
|
||||
props.put(HaywardBindingConstants.PROPERTY_FILTER_FILTERTYPE, filterProperty2.get(i));
|
||||
@ -199,14 +178,14 @@ public class HaywardDiscoveryService extends AbstractDiscoveryService implements
|
||||
});
|
||||
|
||||
// Find Heaters
|
||||
final List<String> heaterProperty1 = bridgehandler
|
||||
final List<String> heaterProperty1 = thingHandler
|
||||
.evaluateXPath("//Body-of-water/Heater/Operation/Heater-Equipment/Type/text()", xmlResponse);
|
||||
final List<String> heaterProperty2 = bridgehandler
|
||||
final List<String> heaterProperty2 = thingHandler
|
||||
.evaluateXPath("//Body-of-water/Heater/Operation/Heater-Equipment/Heater-Type/text()", xmlResponse);
|
||||
final List<String> heaterProperty3 = bridgehandler.evaluateXPath(
|
||||
final List<String> heaterProperty3 = thingHandler.evaluateXPath(
|
||||
"//Body-of-water/Heater/Operation/Heater-Equipment/Shared-Equipment-System-ID/text()", xmlResponse);
|
||||
|
||||
discoverDevices(bridgehandler, xmlResponse, "Heater-Equipment", HaywardTypeToRequest.HEATER,
|
||||
discoverDevices(thingHandler, xmlResponse, "Heater-Equipment", HaywardTypeToRequest.HEATER,
|
||||
HaywardBindingConstants.THING_TYPE_HEATER, (props, i) -> {
|
||||
props.put(HaywardBindingConstants.PROPERTY_HEATER_TYPE, heaterProperty1.get(i));
|
||||
props.put(HaywardBindingConstants.PROPERTY_HEATER_HEATERTYPE, heaterProperty2.get(i));
|
||||
@ -214,29 +193,29 @@ public class HaywardDiscoveryService extends AbstractDiscoveryService implements
|
||||
});
|
||||
|
||||
// Find Pumps
|
||||
final List<String> pumpProperty1 = bridgehandler.evaluateXPath("//Body-of-water/Pump/Type/text()", xmlResponse);
|
||||
final List<String> pumpProperty2 = bridgehandler.evaluateXPath("//Body-of-water/Pump/Function/text()",
|
||||
final List<String> pumpProperty1 = thingHandler.evaluateXPath("//Body-of-water/Pump/Type/text()", xmlResponse);
|
||||
final List<String> pumpProperty2 = thingHandler.evaluateXPath("//Body-of-water/Pump/Function/text()",
|
||||
xmlResponse);
|
||||
final List<String> pumpProperty3 = bridgehandler.evaluateXPath("//Body-of-water/Pump/Priming-Enabled/text()",
|
||||
final List<String> pumpProperty3 = thingHandler.evaluateXPath("//Body-of-water/Pump/Priming-Enabled/text()",
|
||||
xmlResponse);
|
||||
final List<String> pumpProperty4 = bridgehandler.evaluateXPath("//Body-of-water/Pump/Min-Pump-Speed/text()",
|
||||
final List<String> pumpProperty4 = thingHandler.evaluateXPath("//Body-of-water/Pump/Min-Pump-Speed/text()",
|
||||
xmlResponse);
|
||||
final List<String> pumpProperty5 = bridgehandler.evaluateXPath("//Body-of-water/Pump/Max-Pump-Speed/text()",
|
||||
final List<String> pumpProperty5 = thingHandler.evaluateXPath("//Body-of-water/Pump/Max-Pump-Speed/text()",
|
||||
xmlResponse);
|
||||
final List<String> pumpProperty6 = bridgehandler.evaluateXPath("//Body-of-water/Pump/Min-Pump-RPM/text()",
|
||||
final List<String> pumpProperty6 = thingHandler.evaluateXPath("//Body-of-water/Pump/Min-Pump-RPM/text()",
|
||||
xmlResponse);
|
||||
final List<String> pumpProperty7 = bridgehandler.evaluateXPath("//Body-of-water/Pump/Max-Pump-RPM/text()",
|
||||
final List<String> pumpProperty7 = thingHandler.evaluateXPath("//Body-of-water/Pump/Max-Pump-RPM/text()",
|
||||
xmlResponse);
|
||||
final List<String> pumpProperty8 = bridgehandler.evaluateXPath("//Body-of-water/Pump/Vsp-Low-Pump-Speed/text()",
|
||||
final List<String> pumpProperty8 = thingHandler.evaluateXPath("//Body-of-water/Pump/Vsp-Low-Pump-Speed/text()",
|
||||
xmlResponse);
|
||||
final List<String> pumpProperty9 = bridgehandler
|
||||
final List<String> pumpProperty9 = thingHandler
|
||||
.evaluateXPath("//Body-of-water/Pump/Vsp-Medium-Pump-Speed/text()", xmlResponse);
|
||||
final List<String> pumpProperty10 = bridgehandler
|
||||
final List<String> pumpProperty10 = thingHandler
|
||||
.evaluateXPath("//Body-of-water/Pump/Vsp-High-Pump-Speed/text()", xmlResponse);
|
||||
final List<String> pumpProperty11 = bridgehandler
|
||||
final List<String> pumpProperty11 = thingHandler
|
||||
.evaluateXPath("//Body-of-water/Pump/Vsp-Custom-Pump-Speed/text()", xmlResponse);
|
||||
|
||||
discoverDevices(bridgehandler, xmlResponse, "Pump", HaywardTypeToRequest.PUMP,
|
||||
discoverDevices(thingHandler, xmlResponse, "Pump", HaywardTypeToRequest.PUMP,
|
||||
HaywardBindingConstants.THING_TYPE_PUMP, (props, i) -> {
|
||||
props.put(HaywardBindingConstants.PROPERTY_PUMP_TYPE, pumpProperty1.get(i));
|
||||
props.put(HaywardBindingConstants.PROPERTY_PUMP_FUNCTION, pumpProperty2.get(i));
|
||||
@ -252,27 +231,27 @@ public class HaywardDiscoveryService extends AbstractDiscoveryService implements
|
||||
});
|
||||
|
||||
// Find Relays
|
||||
final List<String> relayProperty1 = bridgehandler.evaluateXPath("//Backyard//Relay/Type/text()", xmlResponse);
|
||||
final List<String> relayProperty2 = bridgehandler.evaluateXPath("//Backyard//Relay/Function/text()",
|
||||
final List<String> relayProperty1 = thingHandler.evaluateXPath("//Backyard//Relay/Type/text()", xmlResponse);
|
||||
final List<String> relayProperty2 = thingHandler.evaluateXPath("//Backyard//Relay/Function/text()",
|
||||
xmlResponse);
|
||||
|
||||
discoverDevices(bridgehandler, xmlResponse, "Relay", HaywardTypeToRequest.RELAY,
|
||||
discoverDevices(thingHandler, xmlResponse, "Relay", HaywardTypeToRequest.RELAY,
|
||||
HaywardBindingConstants.THING_TYPE_RELAY, (props, i) -> {
|
||||
props.put(HaywardBindingConstants.PROPERTY_RELAY_TYPE, relayProperty1.get(i));
|
||||
props.put(HaywardBindingConstants.PROPERTY_RELAY_FUNCTION, relayProperty2.get(i));
|
||||
});
|
||||
|
||||
// Find Virtual Heaters
|
||||
final List<String> virtualHeaterProperty1 = bridgehandler
|
||||
final List<String> virtualHeaterProperty1 = thingHandler
|
||||
.evaluateXPath("//Body-of-water/Heater/Shared-Type/text()", xmlResponse);
|
||||
final List<String> virtualHeaterProperty2 = bridgehandler
|
||||
final List<String> virtualHeaterProperty2 = thingHandler
|
||||
.evaluateXPath("//Body-of-water/Heater/Min-Settable-Water-Temp/text()", xmlResponse);
|
||||
final List<String> virtualHeaterProperty3 = bridgehandler
|
||||
final List<String> virtualHeaterProperty3 = thingHandler
|
||||
.evaluateXPath("//Body-of-water/Heater/Max-Settable-Water-Temp/text()", xmlResponse);
|
||||
final List<String> virtualHeaterProperty4 = bridgehandler
|
||||
final List<String> virtualHeaterProperty4 = thingHandler
|
||||
.evaluateXPath("//Body-of-water/Heater/Max-Water-Temp/text()", xmlResponse);
|
||||
|
||||
discoverDevices(bridgehandler, xmlResponse, "Heater", HaywardTypeToRequest.VIRTUALHEATER,
|
||||
discoverDevices(thingHandler, xmlResponse, "Heater", HaywardTypeToRequest.VIRTUALHEATER,
|
||||
HaywardBindingConstants.THING_TYPE_VIRTUALHEATER, (props, i) -> {
|
||||
props.put(HaywardBindingConstants.PROPERTY_VIRTUALHEATER_SHAREDTYPE, virtualHeaterProperty1.get(i));
|
||||
props.put(HaywardBindingConstants.PROPERTY_VIRTUALHEATER_MINSETTABLEWATERTEMP,
|
||||
@ -333,7 +312,7 @@ public class HaywardDiscoveryService extends AbstractDiscoveryService implements
|
||||
}
|
||||
|
||||
public void onDeviceDiscovered(ThingTypeUID thingType, String label, Map<String, Object> properties) {
|
||||
HaywardBridgeHandler bridgehandler = discoveryBridgehandler;
|
||||
HaywardBridgeHandler bridgehandler = thingHandler;
|
||||
String systemID = (String) properties.get(HaywardBindingConstants.PROPERTY_SYSTEM_ID);
|
||||
if (bridgehandler != null) {
|
||||
if (systemID != null) {
|
||||
@ -346,16 +325,4 @@ public class HaywardDiscoveryService extends AbstractDiscoveryService implements
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(@Nullable ThingHandler handler) {
|
||||
if (handler instanceof HaywardBridgeHandler bridgeHandler) {
|
||||
this.discoveryBridgehandler = bridgeHandler;
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return discoveryBridgehandler;
|
||||
}
|
||||
}
|
||||
|
@ -25,6 +25,8 @@ import org.openhab.core.automation.annotation.RuleAction;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -33,6 +35,7 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Martin van Wingerden - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = HeosActions.class)
|
||||
@ThingActionsScope(name = "heos")
|
||||
@NonNullByDefault
|
||||
public class HeosActions implements ThingActions {
|
||||
|
@ -24,14 +24,13 @@ import org.openhab.binding.homeconnect.internal.client.exception.AuthorizationEx
|
||||
import org.openhab.binding.homeconnect.internal.client.exception.CommunicationException;
|
||||
import org.openhab.binding.homeconnect.internal.client.model.HomeAppliance;
|
||||
import org.openhab.binding.homeconnect.internal.handler.HomeConnectBridgeHandler;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResult;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.config.discovery.DiscoveryService;
|
||||
import org.openhab.core.thing.ThingTypeUID;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -40,43 +39,27 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Jonas Brüstel - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = HomeConnectDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class HomeConnectDiscoveryService extends AbstractDiscoveryService
|
||||
implements DiscoveryService, ThingHandlerService {
|
||||
public class HomeConnectDiscoveryService extends AbstractThingHandlerDiscoveryService<HomeConnectBridgeHandler> {
|
||||
|
||||
private static final int SEARCH_TIME_SEC = 20;
|
||||
|
||||
private final Logger logger = LoggerFactory.getLogger(HomeConnectDiscoveryService.class);
|
||||
|
||||
private @Nullable HomeConnectBridgeHandler bridgeHandler;
|
||||
|
||||
/**
|
||||
* Construct a {@link HomeConnectDiscoveryService}.
|
||||
*
|
||||
*/
|
||||
public HomeConnectDiscoveryService() {
|
||||
super(DISCOVERABLE_DEVICE_THING_TYPES_UIDS, SEARCH_TIME_SEC, true);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(ThingHandler handler) {
|
||||
if (handler instanceof HomeConnectBridgeHandler homeConnectBridgeHandler) {
|
||||
this.bridgeHandler = homeConnectBridgeHandler;
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return bridgeHandler;
|
||||
super(HomeConnectBridgeHandler.class, DISCOVERABLE_DEVICE_THING_TYPES_UIDS, SEARCH_TIME_SEC, true);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void startScan() {
|
||||
logger.debug("Starting device scan.");
|
||||
|
||||
var bridgeHandler = this.bridgeHandler;
|
||||
if (bridgeHandler != null) {
|
||||
HomeConnectApiClient apiClient = bridgeHandler.getApiClient();
|
||||
HomeConnectApiClient apiClient = thingHandler.getApiClient();
|
||||
|
||||
try {
|
||||
List<HomeAppliance> appliances = apiClient.getHomeAppliances();
|
||||
@ -91,15 +74,13 @@ public class HomeConnectDiscoveryService extends AbstractDiscoveryService
|
||||
logger.debug("Found {} ({}).", appliance.getHaId(), appliance.getType().toUpperCase());
|
||||
|
||||
Map<String, Object> properties = Map.of(HA_ID, appliance.getHaId());
|
||||
String name = appliance.getBrand() + " " + appliance.getName() + " (" + appliance.getHaId()
|
||||
+ ")";
|
||||
String name = appliance.getBrand() + " " + appliance.getName() + " (" + appliance.getHaId() + ")";
|
||||
|
||||
DiscoveryResult discoveryResult = DiscoveryResultBuilder
|
||||
.create(new ThingUID(BINDING_ID, appliance.getType(),
|
||||
bridgeHandler.getThing().getUID().getId(), appliance.getHaId()))
|
||||
.withThingType(thingTypeUID).withProperties(properties)
|
||||
.withRepresentationProperty(HA_ID).withBridge(bridgeHandler.getThing().getUID())
|
||||
.withLabel(name).build();
|
||||
thingHandler.getThing().getUID().getId(), appliance.getHaId()))
|
||||
.withThingType(thingTypeUID).withProperties(properties).withRepresentationProperty(HA_ID)
|
||||
.withBridge(thingHandler.getThing().getUID()).withLabel(name).build();
|
||||
thingDiscovered(discoveryResult);
|
||||
} else {
|
||||
logger.debug("Ignoring unsupported device {} of type {}.", appliance.getHaId(),
|
||||
@ -109,26 +90,20 @@ public class HomeConnectDiscoveryService extends AbstractDiscoveryService
|
||||
} catch (CommunicationException | AuthorizationException e) {
|
||||
logger.debug("Exception during scan.", e);
|
||||
}
|
||||
}
|
||||
|
||||
logger.debug("Finished device scan.");
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
super.deactivate();
|
||||
var bridgeHandler = this.bridgeHandler;
|
||||
if (bridgeHandler != null) {
|
||||
removeOlderResults(System.currentTimeMillis(), bridgeHandler.getThing().getUID());
|
||||
}
|
||||
public void dispose() {
|
||||
super.dispose();
|
||||
removeOlderResults(System.currentTimeMillis(), thingHandler.getThing().getUID());
|
||||
}
|
||||
|
||||
@Override
|
||||
protected synchronized void stopScan() {
|
||||
super.stopScan();
|
||||
var bridgeHandler = this.bridgeHandler;
|
||||
if (bridgeHandler != null) {
|
||||
removeOlderResults(getTimestampOfLastScan(), bridgeHandler.getThing().getUID());
|
||||
}
|
||||
removeOlderResults(getTimestampOfLastScan(), thingHandler.getThing().getUID());
|
||||
}
|
||||
|
||||
private @Nullable ThingTypeUID getThingTypeUID(HomeAppliance appliance) {
|
||||
|
@ -18,23 +18,21 @@ import java.util.Set;
|
||||
import java.util.concurrent.ExecutionException;
|
||||
import java.util.concurrent.Future;
|
||||
|
||||
import org.eclipse.jdt.annotation.NonNullByDefault;
|
||||
import org.eclipse.jdt.annotation.Nullable;
|
||||
import org.eclipse.jdt.annotation.NonNull;
|
||||
import org.openhab.binding.homematic.internal.common.HomematicConfig;
|
||||
import org.openhab.binding.homematic.internal.communicator.HomematicGateway;
|
||||
import org.openhab.binding.homematic.internal.handler.HomematicBridgeHandler;
|
||||
import org.openhab.binding.homematic.internal.model.HmDevice;
|
||||
import org.openhab.binding.homematic.internal.type.UidUtils;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResult;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.config.discovery.DiscoveryService;
|
||||
import org.openhab.core.thing.Thing;
|
||||
import org.openhab.core.thing.ThingStatus;
|
||||
import org.openhab.core.thing.ThingTypeUID;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -43,44 +41,24 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Gerhard Riegler - Initial contribution
|
||||
*/
|
||||
public class HomematicDeviceDiscoveryService extends AbstractDiscoveryService
|
||||
implements DiscoveryService, ThingHandlerService {
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = HomematicDeviceDiscoveryService.class)
|
||||
public class HomematicDeviceDiscoveryService
|
||||
extends AbstractThingHandlerDiscoveryService<@NonNull HomematicBridgeHandler> {
|
||||
private final Logger logger = LoggerFactory.getLogger(HomematicDeviceDiscoveryService.class);
|
||||
private static final int DISCOVER_TIMEOUT_SECONDS = 300;
|
||||
|
||||
private @NonNullByDefault({}) HomematicBridgeHandler bridgeHandler;
|
||||
private Future<?> loadDevicesFuture;
|
||||
private volatile boolean isInInstallMode = false;
|
||||
private volatile Object installModeSync = new Object();
|
||||
|
||||
public HomematicDeviceDiscoveryService() {
|
||||
super(Set.of(new ThingTypeUID(BINDING_ID, "-")), DISCOVER_TIMEOUT_SECONDS, false);
|
||||
super(HomematicBridgeHandler.class, Set.of(new ThingTypeUID(BINDING_ID, "-")), DISCOVER_TIMEOUT_SECONDS, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(@Nullable ThingHandler handler) {
|
||||
if (handler instanceof HomematicBridgeHandler homematicBridgeHandler) {
|
||||
this.bridgeHandler = homematicBridgeHandler;
|
||||
this.bridgeHandler.setDiscoveryService(this);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return bridgeHandler;
|
||||
}
|
||||
|
||||
/**
|
||||
* Called on component activation.
|
||||
*/
|
||||
@Override
|
||||
public void activate() {
|
||||
super.activate(null);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
super.deactivate();
|
||||
public void initialize() {
|
||||
thingHandler.setDiscoveryService(this);
|
||||
super.initialize();
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -96,13 +74,10 @@ public class HomematicDeviceDiscoveryService extends AbstractDiscoveryService
|
||||
*/
|
||||
private void enableInstallMode() {
|
||||
try {
|
||||
HomematicGateway gateway = bridgeHandler.getGateway();
|
||||
ThingStatus bridgeStatus = null;
|
||||
HomematicGateway gateway = thingHandler.getGateway();
|
||||
Thing bridge = thingHandler.getThing();
|
||||
ThingStatus bridgeStatus = bridge.getStatus();
|
||||
|
||||
if (bridgeHandler != null) {
|
||||
Thing bridge = bridgeHandler.getThing();
|
||||
bridgeStatus = bridge.getStatus();
|
||||
}
|
||||
if (ThingStatus.ONLINE == bridgeStatus) {
|
||||
gateway.setInstallMode(true, getInstallModeDuration());
|
||||
|
||||
@ -122,10 +97,7 @@ public class HomematicDeviceDiscoveryService extends AbstractDiscoveryService
|
||||
}
|
||||
|
||||
private int getInstallModeDuration() {
|
||||
if (bridgeHandler != null) {
|
||||
return bridgeHandler.getThing().getConfiguration().as(HomematicConfig.class).getInstallModeDuration();
|
||||
}
|
||||
return HomematicConfig.DEFAULT_INSTALL_MODE_DURATION;
|
||||
return thingHandler.getThing().getConfiguration().as(HomematicConfig.class).getInstallModeDuration();
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -136,10 +108,8 @@ public class HomematicDeviceDiscoveryService extends AbstractDiscoveryService
|
||||
@Override
|
||||
public synchronized void stopScan() {
|
||||
logger.debug("Stopping Homematic discovery scan");
|
||||
if (bridgeHandler != null && bridgeHandler.getGateway() != null) {
|
||||
disableInstallMode();
|
||||
bridgeHandler.getGateway().cancelLoadAllDeviceMetadata();
|
||||
}
|
||||
thingHandler.getGateway().cancelLoadAllDeviceMetadata();
|
||||
waitForScanFinishing();
|
||||
super.stopScan();
|
||||
}
|
||||
@ -150,7 +120,7 @@ public class HomematicDeviceDiscoveryService extends AbstractDiscoveryService
|
||||
if (isInInstallMode) {
|
||||
isInInstallMode = false;
|
||||
installModeSync.notify();
|
||||
bridgeHandler.getGateway().setInstallMode(false, 0);
|
||||
thingHandler.getGateway().setInstallMode(false, 0);
|
||||
}
|
||||
}
|
||||
|
||||
@ -192,6 +162,7 @@ public class HomematicDeviceDiscoveryService extends AbstractDiscoveryService
|
||||
} catch (Exception ex) {
|
||||
logger.error("Error waiting for device discovery scan: {}", ex.getMessage(), ex);
|
||||
}
|
||||
HomematicBridgeHandler bridgeHandler = thingHandler;
|
||||
String gatewayId = bridgeHandler != null && bridgeHandler.getGateway() != null
|
||||
? bridgeHandler.getGateway().getId()
|
||||
: "UNKNOWN";
|
||||
@ -202,17 +173,17 @@ public class HomematicDeviceDiscoveryService extends AbstractDiscoveryService
|
||||
* Starts a thread which loads all Homematic devices connected to the gateway.
|
||||
*/
|
||||
public void loadDevices() {
|
||||
if (loadDevicesFuture == null && bridgeHandler.getGateway() != null) {
|
||||
if (loadDevicesFuture == null && thingHandler.getGateway() != null) {
|
||||
loadDevicesFuture = scheduler.submit(() -> {
|
||||
try {
|
||||
final HomematicGateway gateway = bridgeHandler.getGateway();
|
||||
final HomematicGateway gateway = thingHandler.getGateway();
|
||||
gateway.loadAllDeviceMetadata();
|
||||
bridgeHandler.getTypeGenerator().validateFirmwares();
|
||||
thingHandler.getTypeGenerator().validateFirmwares();
|
||||
} catch (Throwable ex) {
|
||||
logger.error("{}", ex.getMessage(), ex);
|
||||
} finally {
|
||||
loadDevicesFuture = null;
|
||||
bridgeHandler.setOfflineStatus();
|
||||
thingHandler.setOfflineStatus();
|
||||
removeOlderResults(getTimestampOfLastScan());
|
||||
}
|
||||
});
|
||||
@ -225,7 +196,7 @@ public class HomematicDeviceDiscoveryService extends AbstractDiscoveryService
|
||||
* Removes the Homematic device.
|
||||
*/
|
||||
public void deviceRemoved(HmDevice device) {
|
||||
ThingUID thingUID = UidUtils.generateThingUID(device, bridgeHandler.getThing());
|
||||
ThingUID thingUID = UidUtils.generateThingUID(device, thingHandler.getThing());
|
||||
thingRemoved(thingUID);
|
||||
}
|
||||
|
||||
@ -233,12 +204,11 @@ public class HomematicDeviceDiscoveryService extends AbstractDiscoveryService
|
||||
* Generates the DiscoveryResult from a Homematic device.
|
||||
*/
|
||||
public void deviceDiscovered(HmDevice device) {
|
||||
ThingUID bridgeUID = bridgeHandler.getThing().getUID();
|
||||
ThingUID bridgeUID = thingHandler.getThing().getUID();
|
||||
ThingTypeUID typeUid = UidUtils.generateThingTypeUID(device);
|
||||
ThingUID thingUID = new ThingUID(typeUid, bridgeUID, device.getAddress());
|
||||
String label = device.getName() != null ? device.getName() : device.getAddress();
|
||||
long timeToLive = bridgeHandler.getThing().getConfiguration().as(HomematicConfig.class)
|
||||
.getDiscoveryTimeToLive();
|
||||
long timeToLive = thingHandler.getThing().getConfiguration().as(HomematicConfig.class).getDiscoveryTimeToLive();
|
||||
|
||||
DiscoveryResult discoveryResult = DiscoveryResultBuilder.create(thingUID).withBridge(bridgeUID).withLabel(label)
|
||||
.withProperty(Thing.PROPERTY_SERIAL_NUMBER, device.getAddress())
|
||||
|
@ -24,6 +24,8 @@ import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.types.Command;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -33,6 +35,7 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Andrew Fiddian-Green - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = DynamicsActions.class)
|
||||
@ThingActionsScope(name = "hue")
|
||||
@NonNullByDefault
|
||||
public class DynamicsActions implements ThingActions {
|
||||
|
@ -22,6 +22,8 @@ import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.types.Command;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -30,6 +32,7 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Jochen Leopold - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = LightActions.class)
|
||||
@ThingActionsScope(name = "hue")
|
||||
@NonNullByDefault
|
||||
public class LightActions implements ThingActions {
|
||||
|
@ -33,14 +33,14 @@ import org.openhab.binding.hue.internal.api.dto.clip2.enums.ResourceType;
|
||||
import org.openhab.binding.hue.internal.exceptions.ApiException;
|
||||
import org.openhab.binding.hue.internal.exceptions.AssetNotLoadedException;
|
||||
import org.openhab.binding.hue.internal.handler.Clip2BridgeHandler;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.thing.Thing;
|
||||
import org.openhab.core.thing.ThingStatus;
|
||||
import org.openhab.core.thing.ThingTypeUID;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -49,9 +49,9 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Andrew Fiddian-Green - Initial Contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = Clip2ThingDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class Clip2ThingDiscoveryService extends AbstractDiscoveryService implements ThingHandlerService {
|
||||
|
||||
public class Clip2ThingDiscoveryService extends AbstractThingHandlerDiscoveryService<Clip2BridgeHandler> {
|
||||
private final Logger logger = LoggerFactory.getLogger(Clip2ThingDiscoveryService.class);
|
||||
|
||||
private static final int DISCOVERY_TIMEOUT_SECONDS = 20;
|
||||
@ -66,31 +66,24 @@ public class Clip2ThingDiscoveryService extends AbstractDiscoveryService impleme
|
||||
ResourceType.ZONE, THING_TYPE_ZONE, //
|
||||
ResourceType.BRIDGE_HOME, THING_TYPE_ZONE);
|
||||
|
||||
private @Nullable Clip2BridgeHandler bridgeHandler;
|
||||
private @Nullable ScheduledFuture<?> discoveryTask;
|
||||
|
||||
public Clip2ThingDiscoveryService() {
|
||||
super(Set.of(THING_TYPE_DEVICE, THING_TYPE_ROOM, THING_TYPE_ZONE), DISCOVERY_TIMEOUT_SECONDS, true);
|
||||
super(Clip2BridgeHandler.class, Set.of(THING_TYPE_DEVICE, THING_TYPE_ROOM, THING_TYPE_ZONE),
|
||||
DISCOVERY_TIMEOUT_SECONDS, true);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void activate() {
|
||||
Clip2BridgeHandler bridgeHandler = this.bridgeHandler;
|
||||
if (Objects.nonNull(bridgeHandler)) {
|
||||
bridgeHandler.registerDiscoveryService(this);
|
||||
}
|
||||
super.activate(null);
|
||||
public void initialize() {
|
||||
thingHandler.registerDiscoveryService(this);
|
||||
super.initialize();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
super.deactivate();
|
||||
Clip2BridgeHandler bridgeHandler = this.bridgeHandler;
|
||||
if (Objects.nonNull(bridgeHandler)) {
|
||||
bridgeHandler.unregisterDiscoveryService();
|
||||
removeOlderResults(new Date().getTime(), bridgeHandler.getThing().getBridgeUID());
|
||||
this.bridgeHandler = null;
|
||||
}
|
||||
public void dispose() {
|
||||
super.dispose();
|
||||
thingHandler.unregisterDiscoveryService();
|
||||
removeOlderResults(new Date().getTime(), thingHandler.getThing().getBridgeUID());
|
||||
}
|
||||
|
||||
/**
|
||||
@ -98,12 +91,11 @@ public class Clip2ThingDiscoveryService extends AbstractDiscoveryService impleme
|
||||
* as OH things, and announce those respective things by calling the core 'thingDiscovered()' method.
|
||||
*/
|
||||
private synchronized void discoverThings() {
|
||||
Clip2BridgeHandler bridgeHandler = this.bridgeHandler;
|
||||
if (Objects.nonNull(bridgeHandler) && bridgeHandler.getThing().getStatus() == ThingStatus.ONLINE) {
|
||||
if (thingHandler.getThing().getStatus() == ThingStatus.ONLINE) {
|
||||
try {
|
||||
ThingUID bridgeUID = bridgeHandler.getThing().getUID();
|
||||
ThingUID bridgeUID = thingHandler.getThing().getUID();
|
||||
for (Entry<ResourceType, ThingTypeUID> entry : DISCOVERY_TYPES.entrySet()) {
|
||||
for (Resource resource : bridgeHandler.getResources(new ResourceReference().setType(entry.getKey()))
|
||||
for (Resource resource : thingHandler.getResources(new ResourceReference().setType(entry.getKey()))
|
||||
.getResources()) {
|
||||
|
||||
MetaData metaData = resource.getMetaData();
|
||||
@ -122,10 +114,10 @@ public class Clip2ThingDiscoveryService extends AbstractDiscoveryService impleme
|
||||
|
||||
// special zone 'all lights'
|
||||
if (resource.getType() == ResourceType.BRIDGE_HOME) {
|
||||
thingLabel = bridgeHandler.getLocalizedText(ALL_LIGHTS_KEY);
|
||||
thingLabel = thingHandler.getLocalizedText(ALL_LIGHTS_KEY);
|
||||
}
|
||||
|
||||
Optional<Thing> legacyThingOptional = bridgeHandler.getLegacyThing(idv1);
|
||||
Optional<Thing> legacyThingOptional = thingHandler.getLegacyThing(idv1);
|
||||
if (legacyThingOptional.isPresent()) {
|
||||
Thing legacyThing = legacyThingOptional.get();
|
||||
legacyThingUID = legacyThing.getUID().getAsString();
|
||||
@ -157,18 +149,6 @@ public class Clip2ThingDiscoveryService extends AbstractDiscoveryService impleme
|
||||
stopScan();
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return bridgeHandler;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(ThingHandler handler) {
|
||||
if (handler instanceof Clip2BridgeHandler) {
|
||||
bridgeHandler = (Clip2BridgeHandler) handler;
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void startBackgroundDiscovery() {
|
||||
ScheduledFuture<?> discoveryTask = this.discoveryTask;
|
||||
|
@ -39,14 +39,17 @@ import org.openhab.binding.hue.internal.handler.sensors.LightLevelHandler;
|
||||
import org.openhab.binding.hue.internal.handler.sensors.PresenceHandler;
|
||||
import org.openhab.binding.hue.internal.handler.sensors.TapSwitchHandler;
|
||||
import org.openhab.binding.hue.internal.handler.sensors.TemperatureHandler;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResult;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.i18n.LocaleProvider;
|
||||
import org.openhab.core.i18n.TranslationProvider;
|
||||
import org.openhab.core.thing.Thing;
|
||||
import org.openhab.core.thing.ThingTypeUID;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.Reference;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -64,9 +67,9 @@ import org.slf4j.LoggerFactory;
|
||||
* @author Meng Yiqi - Added support for CLIP sensor
|
||||
* @author Laurent Garnier - Added support for groups
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = HueDeviceDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class HueDeviceDiscoveryService extends AbstractDiscoveryService implements ThingHandlerService {
|
||||
|
||||
public class HueDeviceDiscoveryService extends AbstractThingHandlerDiscoveryService<HueBridgeHandler> {
|
||||
public static final Set<ThingTypeUID> SUPPORTED_THING_TYPES = Stream
|
||||
.of(HueLightHandler.SUPPORTED_THING_TYPES.stream(), DimmerSwitchHandler.SUPPORTED_THING_TYPES.stream(),
|
||||
TapSwitchHandler.SUPPORTED_THING_TYPES.stream(), PresenceHandler.SUPPORTED_THING_TYPES.stream(),
|
||||
@ -98,44 +101,34 @@ public class HueDeviceDiscoveryService extends AbstractDiscoveryService implemen
|
||||
|
||||
private final Logger logger = LoggerFactory.getLogger(HueDeviceDiscoveryService.class);
|
||||
|
||||
private @Nullable HueBridgeHandler hueBridgeHandler;
|
||||
private @Nullable ThingUID bridgeUID;
|
||||
|
||||
public HueDeviceDiscoveryService() {
|
||||
super(SUPPORTED_THING_TYPES, SEARCH_TIME);
|
||||
super(HueBridgeHandler.class, SUPPORTED_THING_TYPES, SEARCH_TIME);
|
||||
}
|
||||
|
||||
@Reference(unbind = "-")
|
||||
public void bindTranslationProvider(TranslationProvider translationProvider) {
|
||||
this.i18nProvider = translationProvider;
|
||||
}
|
||||
|
||||
@Reference(unbind = "-")
|
||||
public void bindLocaleProvider(LocaleProvider localeProvider) {
|
||||
this.localeProvider = localeProvider;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(@Nullable ThingHandler handler) {
|
||||
if (handler instanceof HueBridgeHandler) {
|
||||
HueBridgeHandler localHandler = (HueBridgeHandler) handler;
|
||||
hueBridgeHandler = localHandler;
|
||||
bridgeUID = handler.getThing().getUID();
|
||||
i18nProvider = localHandler.getI18nProvider();
|
||||
localeProvider = localHandler.getLocaleProvider();
|
||||
}
|
||||
public void initialize() {
|
||||
bridgeUID = thingHandler.getThing().getUID();
|
||||
thingHandler.registerDiscoveryListener(this);
|
||||
super.initialize();
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return hueBridgeHandler;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void activate() {
|
||||
final HueBridgeHandler handler = hueBridgeHandler;
|
||||
if (handler != null) {
|
||||
handler.registerDiscoveryListener(this);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
public void dispose() {
|
||||
super.dispose();
|
||||
removeOlderResults(new Date().getTime(), bridgeUID);
|
||||
final HueBridgeHandler handler = hueBridgeHandler;
|
||||
if (handler != null) {
|
||||
handler.unregisterDiscoveryListener();
|
||||
}
|
||||
thingHandler.unregisterDiscoveryListener();
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -145,32 +138,26 @@ public class HueDeviceDiscoveryService extends AbstractDiscoveryService implemen
|
||||
|
||||
@Override
|
||||
public void startScan() {
|
||||
final HueBridgeHandler handler = hueBridgeHandler;
|
||||
if (handler != null) {
|
||||
List<FullLight> lights = handler.getFullLights();
|
||||
List<FullLight> lights = thingHandler.getFullLights();
|
||||
for (FullLight l : lights) {
|
||||
addLightDiscovery(l);
|
||||
}
|
||||
List<FullSensor> sensors = handler.getFullSensors();
|
||||
List<FullSensor> sensors = thingHandler.getFullSensors();
|
||||
for (FullSensor s : sensors) {
|
||||
addSensorDiscovery(s);
|
||||
}
|
||||
List<FullGroup> groups = handler.getFullGroups();
|
||||
List<FullGroup> groups = thingHandler.getFullGroups();
|
||||
for (FullGroup g : groups) {
|
||||
addGroupDiscovery(g);
|
||||
}
|
||||
// search for unpaired lights
|
||||
handler.startSearch();
|
||||
}
|
||||
thingHandler.startSearch();
|
||||
}
|
||||
|
||||
@Override
|
||||
protected synchronized void stopScan() {
|
||||
super.stopScan();
|
||||
final HueBridgeHandler handler = hueBridgeHandler;
|
||||
if (handler != null) {
|
||||
removeOlderResults(getTimestampOfLastScan(), handler.getThing().getUID());
|
||||
}
|
||||
removeOlderResults(getTimestampOfLastScan(), thingHandler.getThing().getUID());
|
||||
}
|
||||
|
||||
public void addLightDiscovery(FullLight light) {
|
||||
|
@ -191,7 +191,7 @@ public class HueThingHandlerFactory extends BaseThingHandlerFactory {
|
||||
itemChannelLinkRegistry);
|
||||
} else if (HueBridgeHandler.SUPPORTED_THING_TYPES.contains(thingTypeUID)) {
|
||||
return new HueBridgeHandler((Bridge) thing, httpClientFactory.getCommonHttpClient(),
|
||||
stateDescriptionProvider, i18nProvider, localeProvider);
|
||||
stateDescriptionProvider);
|
||||
} else if (HueLightHandler.SUPPORTED_THING_TYPES.contains(thingTypeUID)) {
|
||||
return new HueLightHandler(thing, stateDescriptionProvider);
|
||||
} else if (DimmerSwitchHandler.SUPPORTED_THING_TYPES.contains(thingTypeUID)) {
|
||||
|
@ -59,8 +59,6 @@ import org.openhab.core.config.core.Configuration;
|
||||
import org.openhab.core.config.core.status.ConfigStatusMessage;
|
||||
import org.openhab.core.i18n.CommunicationException;
|
||||
import org.openhab.core.i18n.ConfigurationException;
|
||||
import org.openhab.core.i18n.LocaleProvider;
|
||||
import org.openhab.core.i18n.TranslationProvider;
|
||||
import org.openhab.core.io.net.http.TlsTrustManagerProvider;
|
||||
import org.openhab.core.library.types.HSBType;
|
||||
import org.openhab.core.library.types.OnOffType;
|
||||
@ -109,8 +107,6 @@ public class HueBridgeHandler extends ConfigStatusBridgeHandler implements HueCl
|
||||
private @Nullable ServiceRegistration<?> serviceRegistration;
|
||||
private final HttpClient httpClient;
|
||||
private final HueStateDescriptionProvider stateDescriptionOptionProvider;
|
||||
private final TranslationProvider i18nProvider;
|
||||
private final LocaleProvider localeProvider;
|
||||
|
||||
private final Map<String, FullLight> lastLightStates = new ConcurrentHashMap<>();
|
||||
private final Map<String, FullSensor> lastSensorStates = new ConcurrentHashMap<>();
|
||||
@ -424,13 +420,10 @@ public class HueBridgeHandler extends ConfigStatusBridgeHandler implements HueCl
|
||||
private List<String> consoleScenesList = new ArrayList<>();
|
||||
|
||||
public HueBridgeHandler(Bridge bridge, HttpClient httpClient,
|
||||
HueStateDescriptionProvider stateDescriptionOptionProvider, TranslationProvider i18nProvider,
|
||||
LocaleProvider localeProvider) {
|
||||
HueStateDescriptionProvider stateDescriptionOptionProvider) {
|
||||
super(bridge);
|
||||
this.httpClient = httpClient;
|
||||
this.stateDescriptionOptionProvider = stateDescriptionOptionProvider;
|
||||
this.i18nProvider = i18nProvider;
|
||||
this.localeProvider = localeProvider;
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -1079,12 +1072,4 @@ public class HueBridgeHandler extends ConfigStatusBridgeHandler implements HueCl
|
||||
return List.of();
|
||||
}
|
||||
}
|
||||
|
||||
public TranslationProvider getI18nProvider() {
|
||||
return i18nProvider;
|
||||
}
|
||||
|
||||
public LocaleProvider getLocaleProvider() {
|
||||
return localeProvider;
|
||||
}
|
||||
}
|
||||
|
@ -17,18 +17,17 @@ import java.util.List;
|
||||
import java.util.Set;
|
||||
|
||||
import org.eclipse.jdt.annotation.NonNullByDefault;
|
||||
import org.eclipse.jdt.annotation.Nullable;
|
||||
import org.openhab.binding.hydrawise.internal.HydrawiseBindingConstants;
|
||||
import org.openhab.binding.hydrawise.internal.HydrawiseControllerListener;
|
||||
import org.openhab.binding.hydrawise.internal.api.graphql.dto.Controller;
|
||||
import org.openhab.binding.hydrawise.internal.api.graphql.dto.Customer;
|
||||
import org.openhab.binding.hydrawise.internal.handler.HydrawiseAccountHandler;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
|
||||
/**
|
||||
*
|
||||
@ -37,44 +36,33 @@ import org.osgi.service.component.annotations.Component;
|
||||
*/
|
||||
|
||||
@NonNullByDefault
|
||||
@Component(service = ThingHandlerService.class)
|
||||
public class HydrawiseCloudControllerDiscoveryService extends AbstractDiscoveryService
|
||||
implements HydrawiseControllerListener, ThingHandlerService {
|
||||
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = ThingHandlerService.class)
|
||||
public class HydrawiseCloudControllerDiscoveryService
|
||||
extends AbstractThingHandlerDiscoveryService<HydrawiseAccountHandler> implements HydrawiseControllerListener {
|
||||
private static final int TIMEOUT = 5;
|
||||
@Nullable
|
||||
HydrawiseAccountHandler handler;
|
||||
|
||||
public HydrawiseCloudControllerDiscoveryService() {
|
||||
super(Set.of(HydrawiseBindingConstants.THING_TYPE_CONTROLLER), TIMEOUT, true);
|
||||
super(HydrawiseAccountHandler.class, Set.of(HydrawiseBindingConstants.THING_TYPE_CONTROLLER), TIMEOUT, true);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void startScan() {
|
||||
HydrawiseAccountHandler localHandler = this.handler;
|
||||
if (localHandler != null) {
|
||||
Customer data = localHandler.lastData();
|
||||
Customer data = thingHandler.lastData();
|
||||
if (data != null) {
|
||||
data.controllers.forEach(controller -> addDiscoveryResults(controller));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
HydrawiseAccountHandler localHandler = this.handler;
|
||||
if (localHandler != null) {
|
||||
removeOlderResults(new Date().getTime(), localHandler.getThing().getUID());
|
||||
}
|
||||
public void dispose() {
|
||||
super.dispose();
|
||||
removeOlderResults(new Date().getTime(), thingHandler.getThing().getUID());
|
||||
}
|
||||
|
||||
@Override
|
||||
protected synchronized void stopScan() {
|
||||
super.stopScan();
|
||||
HydrawiseAccountHandler localHandler = this.handler;
|
||||
if (localHandler != null) {
|
||||
removeOlderResults(getTimestampOfLastScan(), localHandler.getThing().getUID());
|
||||
}
|
||||
removeOlderResults(getTimestampOfLastScan(), thingHandler.getThing().getUID());
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -83,27 +71,19 @@ public class HydrawiseCloudControllerDiscoveryService extends AbstractDiscoveryS
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(ThingHandler handler) {
|
||||
this.handler = (HydrawiseAccountHandler) handler;
|
||||
this.handler.addControllerListeners(this);
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return handler;
|
||||
public void initialize() {
|
||||
thingHandler.addControllerListeners(this);
|
||||
super.initialize();
|
||||
}
|
||||
|
||||
private void addDiscoveryResults(Controller controller) {
|
||||
HydrawiseAccountHandler localHandler = this.handler;
|
||||
if (localHandler != null) {
|
||||
String label = String.format("Hydrawise Controller %s", controller.name);
|
||||
int id = controller.id;
|
||||
ThingUID bridgeUID = localHandler.getThing().getUID();
|
||||
ThingUID bridgeUID = thingHandler.getThing().getUID();
|
||||
ThingUID thingUID = new ThingUID(HydrawiseBindingConstants.THING_TYPE_CONTROLLER, bridgeUID,
|
||||
String.valueOf(id));
|
||||
thingDiscovered(DiscoveryResultBuilder.create(thingUID).withLabel(label).withBridge(bridgeUID)
|
||||
.withProperty(HydrawiseBindingConstants.CONFIG_CONTROLLER_ID, id)
|
||||
.withRepresentationProperty(HydrawiseBindingConstants.CONFIG_CONTROLLER_ID).build());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -20,6 +20,8 @@ import org.openhab.core.automation.annotation.RuleAction;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -28,7 +30,7 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Matthew Skinner - Initial contribution
|
||||
*/
|
||||
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = IpCameraActions.class)
|
||||
@ThingActionsScope(name = "ipcamera")
|
||||
@NonNullByDefault
|
||||
public class IpCameraActions implements ThingActions {
|
||||
|
@ -25,14 +25,13 @@ import org.eclipse.jdt.annotation.NonNullByDefault;
|
||||
import org.eclipse.jdt.annotation.Nullable;
|
||||
import org.openhab.binding.jablotron.internal.handler.JablotronBridgeHandler;
|
||||
import org.openhab.binding.jablotron.internal.model.JablotronDiscoveredService;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.config.discovery.DiscoveryService;
|
||||
import org.openhab.core.thing.ThingStatus;
|
||||
import org.openhab.core.thing.ThingTypeUID;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -42,39 +41,25 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Ondrej Pecta - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = JablotronDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class JablotronDiscoveryService extends AbstractDiscoveryService
|
||||
implements DiscoveryService, ThingHandlerService {
|
||||
public class JablotronDiscoveryService extends AbstractThingHandlerDiscoveryService<JablotronBridgeHandler> {
|
||||
private final Logger logger = LoggerFactory.getLogger(JablotronDiscoveryService.class);
|
||||
|
||||
private @Nullable JablotronBridgeHandler bridgeHandler;
|
||||
|
||||
private @Nullable ScheduledFuture<?> discoveryJob = null;
|
||||
|
||||
public JablotronDiscoveryService() {
|
||||
super(DISCOVERY_TIMEOUT_SEC);
|
||||
super(JablotronBridgeHandler.class, DISCOVERY_TIMEOUT_SEC);
|
||||
logger.debug("Creating discovery service");
|
||||
}
|
||||
|
||||
private void startDiscovery() {
|
||||
JablotronBridgeHandler localBridgeHandler = bridgeHandler;
|
||||
JablotronBridgeHandler localBridgeHandler = thingHandler;
|
||||
if (localBridgeHandler != null && ThingStatus.ONLINE == localBridgeHandler.getThing().getStatus()) {
|
||||
discoverServices();
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(@Nullable ThingHandler thingHandler) {
|
||||
if (thingHandler instanceof JablotronBridgeHandler bridgeHandler) {
|
||||
this.bridgeHandler = bridgeHandler;
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return bridgeHandler;
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void stopBackgroundDiscovery() {
|
||||
super.stopBackgroundDiscovery();
|
||||
@ -93,16 +78,6 @@ public class JablotronDiscoveryService extends AbstractDiscoveryService
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void activate() {
|
||||
super.activate(null);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
super.deactivate();
|
||||
}
|
||||
|
||||
@Override
|
||||
public Set<ThingTypeUID> getSupportedThingTypes() {
|
||||
return SUPPORTED_THING_TYPES_UIDS;
|
||||
@ -115,7 +90,7 @@ public class JablotronDiscoveryService extends AbstractDiscoveryService
|
||||
}
|
||||
|
||||
public void oasisDiscovered(String label, String serviceId) {
|
||||
JablotronBridgeHandler localBridgeHandler = bridgeHandler;
|
||||
JablotronBridgeHandler localBridgeHandler = thingHandler;
|
||||
if (localBridgeHandler != null) {
|
||||
ThingUID thingUID = new ThingUID(THING_TYPE_OASIS, localBridgeHandler.getThing().getUID(), serviceId);
|
||||
|
||||
@ -130,7 +105,7 @@ public class JablotronDiscoveryService extends AbstractDiscoveryService
|
||||
}
|
||||
|
||||
public void ja100Discovered(String label, String serviceId) {
|
||||
JablotronBridgeHandler localBridgeHandler = bridgeHandler;
|
||||
JablotronBridgeHandler localBridgeHandler = thingHandler;
|
||||
if (localBridgeHandler != null) {
|
||||
ThingUID thingUID = new ThingUID(THING_TYPE_JA100, localBridgeHandler.getThing().getUID(), serviceId);
|
||||
Map<String, Object> properties = new HashMap<>();
|
||||
@ -144,7 +119,7 @@ public class JablotronDiscoveryService extends AbstractDiscoveryService
|
||||
}
|
||||
|
||||
public void ja100fDiscovered(String label, String serviceId) {
|
||||
JablotronBridgeHandler localBridgeHandler = bridgeHandler;
|
||||
JablotronBridgeHandler localBridgeHandler = thingHandler;
|
||||
if (localBridgeHandler != null) {
|
||||
ThingUID thingUID = new ThingUID(THING_TYPE_JA100F, localBridgeHandler.getThing().getUID(), serviceId);
|
||||
Map<String, Object> properties = new HashMap<>();
|
||||
@ -158,7 +133,7 @@ public class JablotronDiscoveryService extends AbstractDiscoveryService
|
||||
}
|
||||
|
||||
private synchronized void discoverServices() {
|
||||
JablotronBridgeHandler localBridgeHandler = bridgeHandler;
|
||||
JablotronBridgeHandler localBridgeHandler = thingHandler;
|
||||
if (localBridgeHandler != null) {
|
||||
List<JablotronDiscoveredService> services = localBridgeHandler.discoverServices();
|
||||
|
||||
|
@ -21,19 +21,18 @@ import java.util.Map;
|
||||
import java.util.Set;
|
||||
|
||||
import org.eclipse.jdt.annotation.NonNullByDefault;
|
||||
import org.eclipse.jdt.annotation.Nullable;
|
||||
import org.jellyfin.sdk.api.client.exception.ApiClientException;
|
||||
import org.jellyfin.sdk.api.client.exception.InvalidStatusException;
|
||||
import org.jellyfin.sdk.model.api.SessionInfo;
|
||||
import org.openhab.binding.jellyfin.internal.handler.JellyfinServerHandler;
|
||||
import org.openhab.binding.jellyfin.internal.util.SyncCallback;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.thing.Thing;
|
||||
import org.openhab.core.thing.ThingStatus;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -42,29 +41,24 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Miguel Alvarez - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = JellyfinClientDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class JellyfinClientDiscoveryService extends AbstractDiscoveryService implements ThingHandlerService {
|
||||
public class JellyfinClientDiscoveryService extends AbstractThingHandlerDiscoveryService<JellyfinServerHandler> {
|
||||
private final Logger logger = LoggerFactory.getLogger(JellyfinClientDiscoveryService.class);
|
||||
private @Nullable JellyfinServerHandler bridgeHandler;
|
||||
|
||||
public JellyfinClientDiscoveryService() throws IllegalArgumentException {
|
||||
super(Set.of(THING_TYPE_SERVER), 60);
|
||||
super(JellyfinServerHandler.class, Set.of(THING_TYPE_SERVER), 60);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void startScan() {
|
||||
var bridgeHandler = this.bridgeHandler;
|
||||
if (bridgeHandler == null) {
|
||||
logger.warn("missing bridge aborting");
|
||||
if (!thingHandler.getThing().getStatus().equals(ThingStatus.ONLINE)) {
|
||||
logger.warn("Server handler {} is not online.", thingHandler.getThing().getLabel());
|
||||
return;
|
||||
}
|
||||
if (!bridgeHandler.getThing().getStatus().equals(ThingStatus.ONLINE)) {
|
||||
logger.warn("Server handler {} is not online.", bridgeHandler.getThing().getLabel());
|
||||
return;
|
||||
}
|
||||
logger.debug("Searching devices for server {}", bridgeHandler.getThing().getLabel());
|
||||
logger.debug("Searching devices for server {}", thingHandler.getThing().getLabel());
|
||||
try {
|
||||
bridgeHandler.getControllableSessions().forEach(this::discoverDevice);
|
||||
thingHandler.getControllableSessions().forEach(this::discoverDevice);
|
||||
} catch (SyncCallback.SyncCallbackError syncCallbackError) {
|
||||
logger.error("Unexpected error: {}", syncCallbackError.getMessage());
|
||||
} catch (InvalidStatusException e) {
|
||||
@ -80,13 +74,8 @@ public class JellyfinClientDiscoveryService extends AbstractDiscoveryService imp
|
||||
logger.warn("missing device id aborting");
|
||||
return;
|
||||
}
|
||||
var bridgeHandler = this.bridgeHandler;
|
||||
if (bridgeHandler == null) {
|
||||
logger.warn("missing bridge aborting");
|
||||
return;
|
||||
}
|
||||
logger.debug("Client discovered: [{}] {}", id, info.getDeviceName());
|
||||
var bridgeUID = bridgeHandler.getThing().getUID();
|
||||
var bridgeUID = thingHandler.getThing().getUID();
|
||||
Map<String, Object> properties = new HashMap<>();
|
||||
properties.put(Thing.PROPERTY_SERIAL_NUMBER, id);
|
||||
var appVersion = info.getApplicationVersion();
|
||||
@ -102,26 +91,4 @@ public class JellyfinClientDiscoveryService extends AbstractDiscoveryService imp
|
||||
.withTTL(DISCOVERY_RESULT_TTL_SEC).withRepresentationProperty(Thing.PROPERTY_SERIAL_NUMBER)
|
||||
.withProperties(properties).withLabel(info.getDeviceName()).build());
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(ThingHandler thingHandler) {
|
||||
if (thingHandler instanceof JellyfinServerHandler bridgeHandler) {
|
||||
this.bridgeHandler = bridgeHandler;
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return null;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void activate() {
|
||||
activate(new HashMap<>());
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
super.deactivate();
|
||||
}
|
||||
}
|
||||
|
@ -14,20 +14,17 @@ package org.openhab.binding.juicenet.internal.discovery;
|
||||
|
||||
import static org.openhab.binding.juicenet.internal.JuiceNetBindingConstants.*;
|
||||
|
||||
import java.util.Objects;
|
||||
import java.util.Set;
|
||||
|
||||
import org.eclipse.jdt.annotation.NonNullByDefault;
|
||||
import org.eclipse.jdt.annotation.Nullable;
|
||||
import org.openhab.binding.juicenet.internal.handler.JuiceNetBridgeHandler;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResult;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.config.discovery.DiscoveryService;
|
||||
import org.openhab.core.thing.ThingTypeUID;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -38,53 +35,24 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Jeff James - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = JuiceNetDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class JuiceNetDiscoveryService extends AbstractDiscoveryService
|
||||
implements DiscoveryService, ThingHandlerService {
|
||||
public class JuiceNetDiscoveryService extends AbstractThingHandlerDiscoveryService<JuiceNetBridgeHandler> {
|
||||
private final Logger logger = LoggerFactory.getLogger(JuiceNetDiscoveryService.class);
|
||||
|
||||
private @Nullable JuiceNetBridgeHandler bridgeHandler;
|
||||
|
||||
private static final Set<ThingTypeUID> DISCOVERABLE_THING_TYPES_UIDS = Set.of(DEVICE_THING_TYPE);
|
||||
|
||||
public JuiceNetDiscoveryService() {
|
||||
super(DISCOVERABLE_THING_TYPES_UIDS, 0, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void activate() {
|
||||
super.activate(null);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
super.deactivate();
|
||||
super(JuiceNetBridgeHandler.class, DISCOVERABLE_THING_TYPES_UIDS, 0, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected synchronized void startScan() {
|
||||
Objects.requireNonNull(bridgeHandler).iterateApiDevices();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(@Nullable ThingHandler handler) {
|
||||
if (handler instanceof JuiceNetBridgeHandler bridgeHandler) {
|
||||
bridgeHandler.setDiscoveryService(this);
|
||||
this.bridgeHandler = bridgeHandler;
|
||||
} else {
|
||||
this.bridgeHandler = null;
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return this.bridgeHandler;
|
||||
thingHandler.iterateApiDevices();
|
||||
}
|
||||
|
||||
public void notifyDiscoveryDevice(String id, String name) {
|
||||
JuiceNetBridgeHandler bridgeHandler = this.bridgeHandler;
|
||||
Objects.requireNonNull(bridgeHandler, "Discovery with null bridgehandler.");
|
||||
ThingUID bridgeUID = bridgeHandler.getThing().getUID();
|
||||
ThingUID bridgeUID = thingHandler.getThing().getUID();
|
||||
|
||||
ThingUID uid = new ThingUID(DEVICE_THING_TYPE, bridgeUID, id);
|
||||
|
||||
|
@ -20,6 +20,8 @@ import org.openhab.core.automation.annotation.RuleAction;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -28,6 +30,7 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Michael Lobstein - initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = KaleidescapeThingActions.class)
|
||||
@ThingActionsScope(name = "kaleidescape")
|
||||
@NonNullByDefault
|
||||
public class KaleidescapeThingActions implements ThingActions {
|
||||
|
@ -28,6 +28,8 @@ import org.openhab.core.automation.annotation.RuleAction;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -36,6 +38,7 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Fabian Wolter - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = LcnModuleActions.class)
|
||||
@ThingActionsScope(name = "lcn")
|
||||
@NonNullByDefault
|
||||
public class LcnModuleActions implements ThingActions {
|
||||
|
@ -31,14 +31,13 @@ import org.openhab.binding.lcn.internal.common.LcnAddrMod;
|
||||
import org.openhab.binding.lcn.internal.connection.Connection;
|
||||
import org.openhab.binding.lcn.internal.subhandler.LcnModuleMetaAckSubHandler;
|
||||
import org.openhab.binding.lcn.internal.subhandler.LcnModuleMetaFirmwareSubHandler;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.config.discovery.DiscoveryService;
|
||||
import org.openhab.core.thing.Thing;
|
||||
import org.openhab.core.thing.ThingTypeUID;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -55,9 +54,9 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Fabian Wolter - Initial Contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = LcnModuleDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class LcnModuleDiscoveryService extends AbstractDiscoveryService
|
||||
implements DiscoveryService, ThingHandlerService {
|
||||
public class LcnModuleDiscoveryService extends AbstractThingHandlerDiscoveryService<PckGatewayHandler> {
|
||||
private final Logger logger = LoggerFactory.getLogger(LcnModuleDiscoveryService.class);
|
||||
private static final Pattern NAME_PATTERN = Pattern
|
||||
.compile("=M(?<segId>\\d{3})(?<modId>\\d{3}).N(?<part>[1-2]{1})(?<name>.*)");
|
||||
@ -67,7 +66,6 @@ public class LcnModuleDiscoveryService extends AbstractDiscoveryService
|
||||
private static final int DISCOVERY_TIMEOUT_SEC = 90;
|
||||
private static final int ACK_TIMEOUT_MS = 1000;
|
||||
private static final Set<ThingTypeUID> SUPPORTED_THING_TYPES_UIDS = Set.of(LcnBindingConstants.THING_TYPE_MODULE);
|
||||
private @Nullable PckGatewayHandler bridgeHandler;
|
||||
private final Map<LcnAddrMod, @Nullable Map<Integer, String>> moduleNames = new HashMap<>();
|
||||
private final Map<LcnAddrMod, DiscoveryResultBuilder> discoveryResultBuilders = new ConcurrentHashMap<>();
|
||||
private final List<LcnAddrMod> successfullyDiscovered = new LinkedList<>();
|
||||
@ -77,57 +75,39 @@ public class LcnModuleDiscoveryService extends AbstractDiscoveryService
|
||||
private @Nullable ScheduledFuture<?> builderTask;
|
||||
|
||||
public LcnModuleDiscoveryService() {
|
||||
super(SUPPORTED_THING_TYPES_UIDS, DISCOVERY_TIMEOUT_SEC, false);
|
||||
super(PckGatewayHandler.class, SUPPORTED_THING_TYPES_UIDS, DISCOVERY_TIMEOUT_SEC, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(@Nullable ThingHandler handler) {
|
||||
if (handler instanceof PckGatewayHandler gatewayHandler) {
|
||||
this.bridgeHandler = gatewayHandler;
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return bridgeHandler;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
public void dispose() {
|
||||
super.dispose();
|
||||
stopScan();
|
||||
super.deactivate();
|
||||
}
|
||||
|
||||
@Override
|
||||
@SuppressWarnings("PMD.CompareObjectsWithEquals")
|
||||
protected void startScan() {
|
||||
synchronized (this) {
|
||||
PckGatewayHandler localBridgeHandler = bridgeHandler;
|
||||
if (localBridgeHandler == null) {
|
||||
logger.warn("Bridge handler not set");
|
||||
return;
|
||||
}
|
||||
|
||||
ScheduledFuture<?> localBuilderTask = builderTask;
|
||||
if (localBridgeHandler.getConnection() == null && localBuilderTask != null) {
|
||||
if (thingHandler.getConnection() == null && localBuilderTask != null) {
|
||||
localBuilderTask.cancel(true);
|
||||
}
|
||||
|
||||
localBridgeHandler.registerPckListener(data -> {
|
||||
thingHandler.registerPckListener(data -> {
|
||||
Matcher matcher;
|
||||
|
||||
if ((matcher = LcnModuleMetaAckSubHandler.PATTERN_POS.matcher(data)).matches()
|
||||
|| (matcher = LcnModuleMetaFirmwareSubHandler.PATTERN.matcher(data)).matches()
|
||||
|| (matcher = NAME_PATTERN.matcher(data)).matches()) {
|
||||
synchronized (LcnModuleDiscoveryService.this) {
|
||||
Connection connection = localBridgeHandler.getConnection();
|
||||
Connection connection = thingHandler.getConnection();
|
||||
|
||||
if (connection == null) {
|
||||
return;
|
||||
}
|
||||
|
||||
LcnAddrMod addr = new LcnAddrMod(
|
||||
localBridgeHandler.toLogicalSegmentId(Integer.parseInt(matcher.group("segId"))),
|
||||
thingHandler.toLogicalSegmentId(Integer.parseInt(matcher.group("segId"))),
|
||||
Integer.parseInt(matcher.group("modId")));
|
||||
|
||||
if (matcher.pattern() == LcnModuleMetaAckSubHandler.PATTERN_POS) {
|
||||
@ -148,7 +128,7 @@ public class LcnModuleDiscoveryService extends AbstractDiscoveryService
|
||||
} else if (matcher.pattern() == LcnModuleMetaFirmwareSubHandler.PATTERN) {
|
||||
// Received a firmware version info frame
|
||||
|
||||
ThingUID bridgeUid = localBridgeHandler.getThing().getUID();
|
||||
ThingUID bridgeUid = thingHandler.getThing().getUID();
|
||||
String serialNumber = matcher.group("sn");
|
||||
|
||||
String thingID = String.format("S%03dM%03d", addr.getSegmentId(), addr.getModuleId());
|
||||
@ -210,7 +190,7 @@ public class LcnModuleDiscoveryService extends AbstractDiscoveryService
|
||||
}
|
||||
}, 500, 500, TimeUnit.MILLISECONDS);
|
||||
|
||||
localBridgeHandler.sendModuleDiscoveryCommand();
|
||||
thingHandler.sendModuleDiscoveryCommand();
|
||||
}
|
||||
}
|
||||
|
||||
@ -221,23 +201,20 @@ public class LcnModuleDiscoveryService extends AbstractDiscoveryService
|
||||
localQueueProcessor.cancel(true);
|
||||
}
|
||||
queueProcessor = scheduler.scheduleWithFixedDelay(() -> {
|
||||
PckGatewayHandler localBridgeHandler = bridgeHandler;
|
||||
if (localBridgeHandler != null) {
|
||||
LcnAddrMod serial = serialNumberRequestQueue.poll();
|
||||
if (serial != null) {
|
||||
localBridgeHandler.sendSerialNumberRequest(serial);
|
||||
thingHandler.sendSerialNumberRequest(serial);
|
||||
}
|
||||
|
||||
LcnAddrMod name = moduleNameRequestQueue.poll();
|
||||
if (name != null) {
|
||||
localBridgeHandler.sendModuleNameRequest(name);
|
||||
thingHandler.sendModuleNameRequest(name);
|
||||
}
|
||||
|
||||
// stop scan when all LCN modules have been requested
|
||||
if (serial == null && name == null) {
|
||||
scheduler.schedule(this::stopScan, ACK_TIMEOUT_MS, TimeUnit.MILLISECONDS);
|
||||
}
|
||||
}
|
||||
}, ACK_TIMEOUT_MS, ACK_TIMEOUT_MS, TimeUnit.MILLISECONDS);
|
||||
}
|
||||
|
||||
@ -251,10 +228,7 @@ public class LcnModuleDiscoveryService extends AbstractDiscoveryService
|
||||
if (localQueueProcessor != null) {
|
||||
localQueueProcessor.cancel(true);
|
||||
}
|
||||
PckGatewayHandler localBridgeHandler = bridgeHandler;
|
||||
if (localBridgeHandler != null) {
|
||||
localBridgeHandler.removeAllPckListeners();
|
||||
}
|
||||
thingHandler.removeAllPckListeners();
|
||||
successfullyDiscovered.clear();
|
||||
moduleNames.clear();
|
||||
|
||||
|
@ -41,6 +41,8 @@ import org.openhab.core.automation.annotation.RuleAction;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -54,6 +56,7 @@ import com.google.gson.JsonParser;
|
||||
* @author Sebastian Prehn - Initial contribution
|
||||
* @author Laurent Garnier - new method invokeMethodOf + interface ILGWebOSActions
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = LGWebOSActions.class)
|
||||
@ThingActionsScope(name = "lgwebos")
|
||||
@NonNullByDefault
|
||||
public class LGWebOSActions implements ThingActions {
|
||||
|
@ -21,18 +21,16 @@ import java.util.Optional;
|
||||
import java.util.Set;
|
||||
|
||||
import org.eclipse.jdt.annotation.NonNullByDefault;
|
||||
import org.eclipse.jdt.annotation.Nullable;
|
||||
import org.openhab.binding.livisismarthome.internal.LivisiBindingConstants;
|
||||
import org.openhab.binding.livisismarthome.internal.client.api.entity.device.DeviceDTO;
|
||||
import org.openhab.binding.livisismarthome.internal.handler.LivisiBridgeHandler;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResult;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.config.discovery.DiscoveryService;
|
||||
import org.openhab.core.thing.ThingTypeUID;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -42,21 +40,19 @@ import org.slf4j.LoggerFactory;
|
||||
* @author Oliver Kuhl - Initial contribution
|
||||
* @author Sven Strohschein - Renamed from Innogy to Livisi
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = LivisiDeviceDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class LivisiDeviceDiscoveryService extends AbstractDiscoveryService
|
||||
implements DiscoveryService, ThingHandlerService {
|
||||
public class LivisiDeviceDiscoveryService extends AbstractThingHandlerDiscoveryService<LivisiBridgeHandler> {
|
||||
|
||||
private static final int SEARCH_TIME_SECONDS = 60;
|
||||
|
||||
private final Logger logger = LoggerFactory.getLogger(LivisiDeviceDiscoveryService.class);
|
||||
|
||||
private @Nullable LivisiBridgeHandler bridgeHandler;
|
||||
|
||||
/**
|
||||
* Construct a {@link LivisiDeviceDiscoveryService}.
|
||||
*/
|
||||
public LivisiDeviceDiscoveryService() {
|
||||
super(SEARCH_TIME_SECONDS);
|
||||
super(LivisiBridgeHandler.class, SEARCH_TIME_SECONDS);
|
||||
}
|
||||
|
||||
/**
|
||||
@ -67,7 +63,8 @@ public class LivisiDeviceDiscoveryService extends AbstractDiscoveryService
|
||||
* @see org.openhab.core.config.discovery.AbstractDiscoveryService#deactivate()
|
||||
*/
|
||||
@Override
|
||||
public void deactivate() {
|
||||
public void dispose() {
|
||||
super.dispose();
|
||||
removeOlderResults(new Date().getTime());
|
||||
}
|
||||
|
||||
@ -79,13 +76,10 @@ public class LivisiDeviceDiscoveryService extends AbstractDiscoveryService
|
||||
@Override
|
||||
protected void startScan() {
|
||||
logger.debug("SCAN for new LIVISI SmartHome devices started...");
|
||||
final LivisiBridgeHandler bridgeHandlerNonNullable = bridgeHandler;
|
||||
if (bridgeHandlerNonNullable != null) {
|
||||
for (final DeviceDTO d : bridgeHandlerNonNullable.loadDevices()) {
|
||||
for (final DeviceDTO d : thingHandler.loadDevices()) {
|
||||
onDeviceAdded(d);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
protected synchronized void stopScan() {
|
||||
@ -94,9 +88,7 @@ public class LivisiDeviceDiscoveryService extends AbstractDiscoveryService
|
||||
}
|
||||
|
||||
public void onDeviceAdded(DeviceDTO device) {
|
||||
final LivisiBridgeHandler bridgeHandlerNonNullable = bridgeHandler;
|
||||
if (bridgeHandlerNonNullable != null) {
|
||||
final ThingUID bridgeUID = bridgeHandlerNonNullable.getThing().getUID();
|
||||
final ThingUID bridgeUID = thingHandler.getThing().getUID();
|
||||
final Optional<ThingUID> thingUID = getThingUID(bridgeUID, device);
|
||||
final Optional<ThingTypeUID> thingTypeUID = getThingTypeUID(device);
|
||||
|
||||
@ -126,7 +118,6 @@ public class LivisiDeviceDiscoveryService extends AbstractDiscoveryService
|
||||
device.getConfig().getName(), device.getId());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the {@link ThingUID} for the given {@link DeviceDTO} or empty, if the device type is not available.
|
||||
@ -157,16 +148,4 @@ public class LivisiDeviceDiscoveryService extends AbstractDiscoveryService
|
||||
}
|
||||
return Optional.empty();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(@Nullable ThingHandler handler) {
|
||||
if (handler instanceof LivisiBridgeHandler livisiBridgeHandler) {
|
||||
bridgeHandler = livisiBridgeHandler;
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return bridgeHandler;
|
||||
}
|
||||
}
|
||||
|
@ -24,6 +24,8 @@ import org.openhab.core.automation.annotation.RuleAction;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -32,6 +34,7 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Bob Adair - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = DimmerActions.class)
|
||||
@ThingActionsScope(name = "lutron")
|
||||
@NonNullByDefault
|
||||
public class DimmerActions implements ThingActions {
|
||||
|
@ -25,14 +25,13 @@ import org.openhab.binding.lutron.internal.handler.LeapBridgeHandler;
|
||||
import org.openhab.binding.lutron.internal.protocol.leap.dto.Area;
|
||||
import org.openhab.binding.lutron.internal.protocol.leap.dto.Device;
|
||||
import org.openhab.binding.lutron.internal.protocol.leap.dto.OccupancyGroup;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResult;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.config.discovery.DiscoveryService;
|
||||
import org.openhab.core.thing.ThingTypeUID;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -41,9 +40,9 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Bob Adair - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = LeapDeviceDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class LeapDeviceDiscoveryService extends AbstractDiscoveryService
|
||||
implements DiscoveryService, ThingHandlerService {
|
||||
public class LeapDeviceDiscoveryService extends AbstractThingHandlerDiscoveryService<LeapBridgeHandler> {
|
||||
|
||||
private static final int DISCOVERY_SERVICE_TIMEOUT = 0; // seconds
|
||||
|
||||
@ -53,29 +52,20 @@ public class LeapDeviceDiscoveryService extends AbstractDiscoveryService
|
||||
private @Nullable Map<Integer, String> areaMap;
|
||||
private @Nullable List<OccupancyGroup> oGroupList;
|
||||
|
||||
private @NonNullByDefault({}) LeapBridgeHandler bridgeHandler;
|
||||
|
||||
public LeapDeviceDiscoveryService() {
|
||||
super(LutronHandlerFactory.DISCOVERABLE_DEVICE_TYPES_UIDS, DISCOVERY_SERVICE_TIMEOUT);
|
||||
super(LeapBridgeHandler.class, LutronHandlerFactory.DISCOVERABLE_DEVICE_TYPES_UIDS, DISCOVERY_SERVICE_TIMEOUT);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(ThingHandler handler) {
|
||||
if (handler instanceof LeapBridgeHandler leapBridgeHandler) {
|
||||
bridgeHandler = leapBridgeHandler;
|
||||
bridgeHandler.setDiscoveryService(this);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return bridgeHandler;
|
||||
public void initialize() {
|
||||
thingHandler.setDiscoveryService(this);
|
||||
super.initialize();
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void startScan() {
|
||||
logger.debug("Active discovery scan started");
|
||||
bridgeHandler.queryDiscoveryData();
|
||||
thingHandler.queryDiscoveryData();
|
||||
}
|
||||
|
||||
public void processDeviceDefinitions(List<Device> deviceList) {
|
||||
@ -198,10 +188,10 @@ public class LeapDeviceDiscoveryService extends AbstractDiscoveryService
|
||||
private void notifyDiscovery(ThingTypeUID thingTypeUID, @Nullable Integer integrationId, String label,
|
||||
@Nullable String propName, @Nullable Object propValue) {
|
||||
if (integrationId == null) {
|
||||
logger.debug("Discovered {} with no integration ID", label);
|
||||
logger.debug("Discovered {} with no integration ID or thinghandler", label);
|
||||
return;
|
||||
}
|
||||
ThingUID bridgeUID = this.bridgeHandler.getThing().getUID();
|
||||
ThingUID bridgeUID = thingHandler.getThing().getUID();
|
||||
ThingUID uid = new ThingUID(thingTypeUID, bridgeUID, integrationId.toString());
|
||||
|
||||
Map<String, Object> properties = new HashMap<>();
|
||||
@ -220,9 +210,4 @@ public class LeapDeviceDiscoveryService extends AbstractDiscoveryService
|
||||
private void notifyDiscovery(ThingTypeUID thingTypeUID, Integer integrationId, String label) {
|
||||
notifyDiscovery(thingTypeUID, integrationId, label, null, null);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
super.deactivate();
|
||||
}
|
||||
}
|
||||
|
@ -83,7 +83,6 @@ import org.slf4j.LoggerFactory;
|
||||
*/
|
||||
@NonNullByDefault
|
||||
public class LutronDeviceDiscoveryService extends AbstractDiscoveryService {
|
||||
|
||||
private static final int DECLARATION_MAX_LEN = 80;
|
||||
private static final long HTTP_REQUEST_TIMEOUT = 60; // seconds
|
||||
private static final int DISCOVERY_SERVICE_TIMEOUT = 90; // seconds
|
||||
|
@ -16,16 +16,12 @@ import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
import java.util.concurrent.atomic.AtomicBoolean;
|
||||
|
||||
import org.eclipse.jdt.annotation.NonNullByDefault;
|
||||
import org.eclipse.jdt.annotation.Nullable;
|
||||
import org.eclipse.jdt.annotation.NonNull;
|
||||
import org.openhab.binding.lutron.internal.LutronHandlerFactory;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResult;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.config.discovery.DiscoveryService;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -38,38 +34,19 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Andrew Shilliday - Initial contribution
|
||||
*/
|
||||
public class HwDiscoveryService extends AbstractDiscoveryService implements DiscoveryService, ThingHandlerService {
|
||||
public class HwDiscoveryService extends AbstractThingHandlerDiscoveryService<@NonNull HwSerialBridgeHandler> {
|
||||
private Logger logger = LoggerFactory.getLogger(HwDiscoveryService.class);
|
||||
|
||||
private final AtomicBoolean isScanning = new AtomicBoolean(false);
|
||||
|
||||
private @NonNullByDefault({}) HwSerialBridgeHandler handler;
|
||||
|
||||
public HwDiscoveryService() {
|
||||
super(LutronHandlerFactory.HW_DISCOVERABLE_DEVICE_TYPES_UIDS, 10);
|
||||
super(HwSerialBridgeHandler.class, LutronHandlerFactory.HW_DISCOVERABLE_DEVICE_TYPES_UIDS, 10);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(@Nullable ThingHandler handler) {
|
||||
if (handler instanceof HwSerialBridgeHandler bridgeHandler) {
|
||||
this.handler = bridgeHandler;
|
||||
this.handler.setDiscoveryService(this);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return handler;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void activate() {
|
||||
super.activate(null);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
super.deactivate();
|
||||
public void initialize() {
|
||||
thingHandler.setDiscoveryService(this);
|
||||
super.initialize();
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -81,7 +58,7 @@ public class HwDiscoveryService extends AbstractDiscoveryService implements Disc
|
||||
for (int m = 1; m <= 8; m++) { // Modules
|
||||
for (int o = 1; o <= 4; o++) { // Outputs
|
||||
String address = String.format("[01:01:00:%02d:%02d]", m, o);
|
||||
handler.sendCommand("RDL, " + address);
|
||||
thingHandler.sendCommand("RDL, " + address);
|
||||
Thread.sleep(5);
|
||||
}
|
||||
}
|
||||
@ -99,11 +76,11 @@ public class HwDiscoveryService extends AbstractDiscoveryService implements Disc
|
||||
*/
|
||||
public void declareUnknownDimmer(String address) {
|
||||
if (address == null) {
|
||||
logger.info("Discovered HomeWorks dimmer with no address");
|
||||
logger.info("Discovered HomeWorks dimmer with no address or thing handler");
|
||||
return;
|
||||
}
|
||||
String addressUid = address.replaceAll("[\\[\\]]", "").replace(":", "-");
|
||||
ThingUID bridgeUID = this.handler.getThing().getUID();
|
||||
ThingUID bridgeUID = thingHandler.getThing().getUID();
|
||||
ThingUID uid = new ThingUID(HwConstants.THING_TYPE_HWDIMMER, bridgeUID, addressUid);
|
||||
|
||||
Map<String, Object> props = new HashMap<>();
|
||||
|
@ -31,6 +31,8 @@ import org.openhab.core.automation.annotation.RuleAction;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -39,6 +41,7 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Jan N. Klug - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = SendMailActions.class)
|
||||
@ThingActionsScope(name = "mail")
|
||||
@NonNullByDefault
|
||||
public class SendMailActions implements ThingActions {
|
||||
|
@ -20,6 +20,8 @@ import org.openhab.core.automation.annotation.RuleAction;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -28,6 +30,7 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Christoph Weitkamp - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = MaxCubeActions.class)
|
||||
@ThingActionsScope(name = "max-cube")
|
||||
@NonNullByDefault
|
||||
public class MaxCubeActions implements ThingActions {
|
||||
|
@ -20,6 +20,8 @@ import org.openhab.core.automation.annotation.RuleAction;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -28,6 +30,7 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Christoph Weitkamp - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = MaxDevicesActions.class)
|
||||
@ThingActionsScope(name = "max-devices")
|
||||
@NonNullByDefault
|
||||
public class MaxDevicesActions implements ThingActions {
|
||||
|
@ -16,21 +16,19 @@ import java.util.Date;
|
||||
import java.util.Set;
|
||||
|
||||
import org.eclipse.jdt.annotation.NonNullByDefault;
|
||||
import org.eclipse.jdt.annotation.Nullable;
|
||||
import org.openhab.binding.max.internal.MaxBindingConstants;
|
||||
import org.openhab.binding.max.internal.device.Device;
|
||||
import org.openhab.binding.max.internal.handler.DeviceStatusListener;
|
||||
import org.openhab.binding.max.internal.handler.MaxCubeBridgeHandler;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResult;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.config.discovery.DiscoveryService;
|
||||
import org.openhab.core.thing.Bridge;
|
||||
import org.openhab.core.thing.Thing;
|
||||
import org.openhab.core.thing.ThingTypeUID;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -40,46 +38,29 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Marcel Verpaalen - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = MaxDeviceDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class MaxDeviceDiscoveryService extends AbstractDiscoveryService
|
||||
implements DeviceStatusListener, DiscoveryService, ThingHandlerService {
|
||||
public class MaxDeviceDiscoveryService extends AbstractThingHandlerDiscoveryService<MaxCubeBridgeHandler>
|
||||
implements DeviceStatusListener {
|
||||
|
||||
private static final int SEARCH_TIME = 60;
|
||||
private final Logger logger = LoggerFactory.getLogger(MaxDeviceDiscoveryService.class);
|
||||
|
||||
private @Nullable MaxCubeBridgeHandler maxCubeBridgeHandler;
|
||||
|
||||
public MaxDeviceDiscoveryService() {
|
||||
super(MaxBindingConstants.SUPPORTED_DEVICE_THING_TYPES_UIDS, SEARCH_TIME, true);
|
||||
super(MaxCubeBridgeHandler.class, MaxBindingConstants.SUPPORTED_DEVICE_THING_TYPES_UIDS, SEARCH_TIME, true);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(@NonNullByDefault({}) ThingHandler handler) {
|
||||
if (handler instanceof MaxCubeBridgeHandler maxCubeBridgeHandler) {
|
||||
this.maxCubeBridgeHandler = maxCubeBridgeHandler;
|
||||
}
|
||||
public void initialize() {
|
||||
thingHandler.registerDeviceStatusListener(this);
|
||||
super.initialize();
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return maxCubeBridgeHandler;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void activate() {
|
||||
MaxCubeBridgeHandler localMaxCubeBridgeHandler = maxCubeBridgeHandler;
|
||||
if (localMaxCubeBridgeHandler != null) {
|
||||
localMaxCubeBridgeHandler.registerDeviceStatusListener(this);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
MaxCubeBridgeHandler localMaxCubeBridgeHandler = maxCubeBridgeHandler;
|
||||
if (localMaxCubeBridgeHandler != null) {
|
||||
localMaxCubeBridgeHandler.unregisterDeviceStatusListener(this);
|
||||
removeOlderResults(new Date().getTime(), localMaxCubeBridgeHandler.getThing().getUID());
|
||||
}
|
||||
public void dispose() {
|
||||
super.dispose();
|
||||
thingHandler.unregisterDeviceStatusListener(this);
|
||||
removeOlderResults(new Date().getTime(), thingHandler.getThing().getUID());
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -133,11 +114,8 @@ public class MaxDeviceDiscoveryService extends AbstractDiscoveryService
|
||||
|
||||
@Override
|
||||
protected void startScan() {
|
||||
MaxCubeBridgeHandler localMaxCubeBridgeHandler = maxCubeBridgeHandler;
|
||||
if (localMaxCubeBridgeHandler != null) {
|
||||
localMaxCubeBridgeHandler.clearDeviceList();
|
||||
localMaxCubeBridgeHandler.deviceInclusion();
|
||||
}
|
||||
thingHandler.clearDeviceList();
|
||||
thingHandler.deviceInclusion();
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -14,17 +14,17 @@ package org.openhab.binding.meater.internal.discovery;
|
||||
|
||||
import static org.openhab.binding.meater.internal.MeaterBindingConstants.*;
|
||||
|
||||
import java.util.Map;
|
||||
|
||||
import org.eclipse.jdt.annotation.NonNullByDefault;
|
||||
import org.eclipse.jdt.annotation.Nullable;
|
||||
import org.openhab.binding.meater.internal.MeaterConfiguration;
|
||||
import org.openhab.binding.meater.internal.handler.MeaterBridgeHandler;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.i18n.LocaleProvider;
|
||||
import org.openhab.core.i18n.TranslationProvider;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.Reference;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
|
||||
/**
|
||||
* The {@link MeaterDiscoveryService} searches for available
|
||||
@ -32,45 +32,29 @@ import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
*
|
||||
* @author Jan Gustafsson - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = MeaterDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class MeaterDiscoveryService extends AbstractDiscoveryService implements ThingHandlerService {
|
||||
public class MeaterDiscoveryService extends AbstractThingHandlerDiscoveryService<MeaterBridgeHandler> {
|
||||
private static final int SEARCH_TIME = 2;
|
||||
private @Nullable MeaterBridgeHandler handler;
|
||||
|
||||
public MeaterDiscoveryService() {
|
||||
super(SUPPORTED_THING_TYPES_UIDS, SEARCH_TIME);
|
||||
super(MeaterBridgeHandler.class, SUPPORTED_THING_TYPES_UIDS, SEARCH_TIME);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(@Nullable ThingHandler handler) {
|
||||
if (handler instanceof MeaterBridgeHandler bridgeHandler) {
|
||||
this.handler = bridgeHandler;
|
||||
i18nProvider = bridgeHandler.getI18nProvider();
|
||||
localeProvider = bridgeHandler.getLocaleProvider();
|
||||
}
|
||||
@Reference(unbind = "-")
|
||||
public void bindTranslationProvider(TranslationProvider translationProvider) {
|
||||
this.i18nProvider = translationProvider;
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return handler;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void activate(@Nullable Map<String, Object> configProperties) {
|
||||
super.activate(configProperties);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
super.deactivate();
|
||||
@Reference(unbind = "-")
|
||||
public void bindLocaleProvider(LocaleProvider localeProvider) {
|
||||
this.localeProvider = localeProvider;
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void startScan() {
|
||||
MeaterBridgeHandler bridgeHandler = this.handler;
|
||||
if (bridgeHandler != null) {
|
||||
ThingUID bridgeUID = bridgeHandler.getThing().getUID();
|
||||
bridgeHandler.getMeaterThings().entrySet().stream().forEach(thing -> {
|
||||
ThingUID bridgeUID = thingHandler.getThing().getUID();
|
||||
thingHandler.getMeaterThings().entrySet().stream().forEach(thing -> {
|
||||
thingDiscovered(
|
||||
DiscoveryResultBuilder.create(new ThingUID(THING_TYPE_MEATER_PROBE, bridgeUID, thing.getKey()))
|
||||
.withLabel("@text/discovery.probe.label").withBridge(bridgeUID)
|
||||
@ -78,5 +62,4 @@ public class MeaterDiscoveryService extends AbstractDiscoveryService implements
|
||||
.withRepresentationProperty(MeaterConfiguration.DEVICE_ID_LABEL).build());
|
||||
});
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -29,7 +29,6 @@ import org.openhab.binding.meater.internal.api.MeaterRestAPI;
|
||||
import org.openhab.binding.meater.internal.discovery.MeaterDiscoveryService;
|
||||
import org.openhab.binding.meater.internal.dto.MeaterProbeDTO;
|
||||
import org.openhab.core.i18n.LocaleProvider;
|
||||
import org.openhab.core.i18n.TranslationProvider;
|
||||
import org.openhab.core.thing.Bridge;
|
||||
import org.openhab.core.thing.ChannelUID;
|
||||
import org.openhab.core.thing.ThingStatus;
|
||||
@ -59,7 +58,6 @@ public class MeaterBridgeHandler extends BaseBridgeHandler {
|
||||
|
||||
private final Gson gson;
|
||||
private final HttpClient httpClient;
|
||||
private final TranslationProvider i18nProvider;
|
||||
private final LocaleProvider localeProvider;
|
||||
private final Map<String, MeaterProbeDTO.Device> meaterProbeThings = new ConcurrentHashMap<>();
|
||||
|
||||
@ -67,12 +65,10 @@ public class MeaterBridgeHandler extends BaseBridgeHandler {
|
||||
private @Nullable MeaterRestAPI api;
|
||||
private @Nullable ScheduledFuture<?> refreshJob;
|
||||
|
||||
public MeaterBridgeHandler(Bridge bridge, HttpClient httpClient, Gson gson, TranslationProvider i18nProvider,
|
||||
LocaleProvider localeProvider) {
|
||||
public MeaterBridgeHandler(Bridge bridge, HttpClient httpClient, Gson gson, LocaleProvider localeProvider) {
|
||||
super(bridge);
|
||||
this.httpClient = httpClient;
|
||||
this.gson = gson;
|
||||
this.i18nProvider = i18nProvider;
|
||||
this.localeProvider = localeProvider;
|
||||
}
|
||||
|
||||
@ -154,12 +150,4 @@ public class MeaterBridgeHandler extends BaseBridgeHandler {
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public TranslationProvider getI18nProvider() {
|
||||
return i18nProvider;
|
||||
}
|
||||
|
||||
public LocaleProvider getLocaleProvider() {
|
||||
return localeProvider;
|
||||
}
|
||||
}
|
||||
|
@ -21,7 +21,6 @@ import org.eclipse.jdt.annotation.Nullable;
|
||||
import org.eclipse.jetty.client.HttpClient;
|
||||
import org.openhab.core.i18n.LocaleProvider;
|
||||
import org.openhab.core.i18n.TimeZoneProvider;
|
||||
import org.openhab.core.i18n.TranslationProvider;
|
||||
import org.openhab.core.io.net.http.HttpClientFactory;
|
||||
import org.openhab.core.thing.Bridge;
|
||||
import org.openhab.core.thing.Thing;
|
||||
@ -51,15 +50,12 @@ public class MeaterHandlerFactory extends BaseThingHandlerFactory {
|
||||
private final Gson gson;
|
||||
private final HttpClient httpClient;
|
||||
private final TimeZoneProvider timeZoneProvider;
|
||||
private final TranslationProvider i18nProvider;
|
||||
private final LocaleProvider localeProvider;
|
||||
|
||||
@Activate
|
||||
public MeaterHandlerFactory(@Reference TimeZoneProvider timeZoneProvider,
|
||||
final @Reference TranslationProvider i18nProvider, @Reference LocaleProvider localeProvider,
|
||||
public MeaterHandlerFactory(@Reference TimeZoneProvider timeZoneProvider, @Reference LocaleProvider localeProvider,
|
||||
@Reference HttpClientFactory httpClientFactory) {
|
||||
this.timeZoneProvider = timeZoneProvider;
|
||||
this.i18nProvider = i18nProvider;
|
||||
this.localeProvider = localeProvider;
|
||||
this.httpClient = httpClientFactory.getCommonHttpClient();
|
||||
this.gson = new Gson();
|
||||
@ -77,7 +73,7 @@ public class MeaterHandlerFactory extends BaseThingHandlerFactory {
|
||||
if (THING_TYPE_MEATER_PROBE.equals(thingTypeUID)) {
|
||||
return new MeaterHandler(thing, timeZoneProvider);
|
||||
} else if (THING_TYPE_BRIDGE.equals(thingTypeUID)) {
|
||||
return new MeaterBridgeHandler((Bridge) thing, httpClient, gson, i18nProvider, localeProvider);
|
||||
return new MeaterBridgeHandler((Bridge) thing, httpClient, gson, localeProvider);
|
||||
}
|
||||
|
||||
return null;
|
||||
|
@ -20,21 +20,19 @@ import java.util.Map;
|
||||
import java.util.concurrent.ScheduledFuture;
|
||||
import java.util.concurrent.TimeUnit;
|
||||
|
||||
import org.eclipse.jdt.annotation.Nullable;
|
||||
import org.eclipse.jdt.annotation.NonNull;
|
||||
import org.openhab.binding.melcloud.internal.MelCloudBindingConstants;
|
||||
import org.openhab.binding.melcloud.internal.api.json.Device;
|
||||
import org.openhab.binding.melcloud.internal.exceptions.MelCloudCommException;
|
||||
import org.openhab.binding.melcloud.internal.exceptions.MelCloudLoginException;
|
||||
import org.openhab.binding.melcloud.internal.handler.MelCloudAccountHandler;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.config.discovery.DiscoveryService;
|
||||
import org.openhab.core.thing.Thing;
|
||||
import org.openhab.core.thing.ThingTypeUID;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Modified;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -45,38 +43,21 @@ import org.slf4j.LoggerFactory;
|
||||
* @author Pauli Anttila - Refactoring
|
||||
* @author Wietse van Buitenen - Check device type, added heatpump device
|
||||
*/
|
||||
public class MelCloudDiscoveryService extends AbstractDiscoveryService
|
||||
implements DiscoveryService, ThingHandlerService {
|
||||
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = MelCloudDiscoveryService.class)
|
||||
public class MelCloudDiscoveryService extends AbstractThingHandlerDiscoveryService<@NonNull MelCloudAccountHandler> {
|
||||
private final Logger logger = LoggerFactory.getLogger(MelCloudDiscoveryService.class);
|
||||
|
||||
private static final String PROPERTY_DEVICE_ID = "deviceID";
|
||||
private static final int DISCOVER_TIMEOUT_SECONDS = 10;
|
||||
|
||||
private MelCloudAccountHandler melCloudHandler;
|
||||
private ScheduledFuture<?> scanTask;
|
||||
|
||||
/**
|
||||
* Creates a MelCloudDiscoveryService with enabled autostart.
|
||||
*/
|
||||
public MelCloudDiscoveryService() {
|
||||
super(MelCloudBindingConstants.DISCOVERABLE_THING_TYPE_UIDS, DISCOVER_TIMEOUT_SECONDS, true);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void activate(Map<String, Object> configProperties) {
|
||||
super.activate(configProperties);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
super.deactivate();
|
||||
}
|
||||
|
||||
@Override
|
||||
@Modified
|
||||
protected void modified(Map<String, Object> configProperties) {
|
||||
super.modified(configProperties);
|
||||
super(MelCloudAccountHandler.class, MelCloudBindingConstants.DISCOVERABLE_THING_TYPE_UIDS,
|
||||
DISCOVER_TIMEOUT_SECONDS, true);
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -104,15 +85,13 @@ public class MelCloudDiscoveryService extends AbstractDiscoveryService
|
||||
|
||||
private void discoverDevices() {
|
||||
logger.debug("Discover devices");
|
||||
|
||||
if (melCloudHandler != null) {
|
||||
try {
|
||||
List<Device> deviceList = melCloudHandler.getDeviceList();
|
||||
List<Device> deviceList = thingHandler.getDeviceList();
|
||||
|
||||
if (deviceList == null) {
|
||||
logger.debug("No devices found");
|
||||
} else {
|
||||
ThingUID bridgeUID = melCloudHandler.getThing().getUID();
|
||||
ThingUID bridgeUID = thingHandler.getThing().getUID();
|
||||
|
||||
deviceList.forEach(device -> {
|
||||
ThingTypeUID thingTypeUid = null;
|
||||
@ -125,7 +104,7 @@ public class MelCloudDiscoveryService extends AbstractDiscoveryService
|
||||
device.getType());
|
||||
return;
|
||||
}
|
||||
ThingUID deviceThing = new ThingUID(thingTypeUid, melCloudHandler.getThing().getUID(),
|
||||
ThingUID deviceThing = new ThingUID(thingTypeUid, thingHandler.getThing().getUID(),
|
||||
device.getDeviceID().toString());
|
||||
|
||||
Map<String, Object> deviceProperties = new HashMap<>();
|
||||
@ -138,9 +117,9 @@ public class MelCloudDiscoveryService extends AbstractDiscoveryService
|
||||
String label = createLabel(device);
|
||||
logger.debug("Found device: {} : {}", label, deviceProperties);
|
||||
|
||||
thingDiscovered(DiscoveryResultBuilder.create(deviceThing).withLabel(label)
|
||||
.withProperties(deviceProperties).withRepresentationProperty(PROPERTY_DEVICE_ID)
|
||||
.withBridge(bridgeUID).build());
|
||||
thingDiscovered(
|
||||
DiscoveryResultBuilder.create(deviceThing).withLabel(label).withProperties(deviceProperties)
|
||||
.withRepresentationProperty(PROPERTY_DEVICE_ID).withBridge(bridgeUID).build());
|
||||
});
|
||||
}
|
||||
} catch (MelCloudLoginException e) {
|
||||
@ -149,7 +128,6 @@ public class MelCloudDiscoveryService extends AbstractDiscoveryService
|
||||
logger.debug("Error occurred during device list fetch, reason {}. ", e.getMessage(), e);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private String createLabel(Device device) {
|
||||
StringBuilder sb = new StringBuilder();
|
||||
@ -164,16 +142,4 @@ public class MelCloudDiscoveryService extends AbstractDiscoveryService
|
||||
sb.append(device.getDeviceName());
|
||||
return sb.toString();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(@Nullable ThingHandler handler) {
|
||||
if (handler instanceof MelCloudAccountHandler accountHandler) {
|
||||
melCloudHandler = accountHandler;
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return melCloudHandler;
|
||||
}
|
||||
}
|
||||
|
@ -15,6 +15,7 @@ package org.openhab.binding.mielecloud.internal.discovery;
|
||||
import static org.openhab.binding.mielecloud.internal.MieleCloudBindingConstants.*;
|
||||
import static org.openhab.binding.mielecloud.internal.handler.MieleHandlerFactory.SUPPORTED_THING_TYPES;
|
||||
|
||||
import java.util.Map;
|
||||
import java.util.Optional;
|
||||
|
||||
import org.eclipse.jdt.annotation.NonNullByDefault;
|
||||
@ -22,15 +23,15 @@ import org.eclipse.jdt.annotation.Nullable;
|
||||
import org.openhab.binding.mielecloud.internal.handler.MieleBridgeHandler;
|
||||
import org.openhab.binding.mielecloud.internal.webservice.api.DeviceState;
|
||||
import org.openhab.binding.mielecloud.internal.webservice.api.json.DeviceType;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResult;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.config.discovery.DiscoveryService;
|
||||
import org.openhab.core.thing.Thing;
|
||||
import org.openhab.core.thing.ThingTypeUID;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -40,13 +41,11 @@ import org.slf4j.LoggerFactory;
|
||||
* @author Roland Edelhoff - Initial contribution
|
||||
* @author Björn Lange - Do not directly listen to webservice events
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = ThingDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class ThingDiscoveryService extends AbstractDiscoveryService implements DiscoveryService, ThingHandlerService {
|
||||
public class ThingDiscoveryService extends AbstractThingHandlerDiscoveryService<MieleBridgeHandler> {
|
||||
private static final int BACKGROUND_DISCOVERY_TIMEOUT_IN_SECONDS = 5;
|
||||
|
||||
@Nullable
|
||||
private MieleBridgeHandler bridgeHandler;
|
||||
|
||||
private final Logger logger = LoggerFactory.getLogger(this.getClass());
|
||||
|
||||
private boolean discoveringDevices = false;
|
||||
@ -55,12 +54,12 @@ public class ThingDiscoveryService extends AbstractDiscoveryService implements D
|
||||
* Creates a new {@link ThingDiscoveryService}.
|
||||
*/
|
||||
public ThingDiscoveryService() {
|
||||
super(SUPPORTED_THING_TYPES, BACKGROUND_DISCOVERY_TIMEOUT_IN_SECONDS);
|
||||
super(MieleBridgeHandler.class, SUPPORTED_THING_TYPES, BACKGROUND_DISCOVERY_TIMEOUT_IN_SECONDS);
|
||||
}
|
||||
|
||||
@Nullable
|
||||
private ThingUID getBridgeUid() {
|
||||
var bridgeHandler = this.bridgeHandler;
|
||||
var bridgeHandler = this.thingHandler;
|
||||
if (bridgeHandler == null) {
|
||||
return null;
|
||||
} else {
|
||||
@ -74,12 +73,12 @@ public class ThingDiscoveryService extends AbstractDiscoveryService implements D
|
||||
|
||||
@Override
|
||||
public void activate() {
|
||||
startBackgroundDiscovery();
|
||||
super.activate(Map.of(DiscoveryService.CONFIG_PROPERTY_BACKGROUND_DISCOVERY, true));
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
stopBackgroundDiscovery();
|
||||
public void dispose() {
|
||||
super.dispose();
|
||||
removeOlderResults(System.currentTimeMillis(), getBridgeUid());
|
||||
}
|
||||
|
||||
@ -100,16 +99,11 @@ public class ThingDiscoveryService extends AbstractDiscoveryService implements D
|
||||
}
|
||||
|
||||
private void createDiscoveryResult(DeviceState deviceState, ThingTypeUID thingTypeUid) {
|
||||
MieleBridgeHandler bridgeHandler = this.bridgeHandler;
|
||||
if (bridgeHandler == null) {
|
||||
return;
|
||||
}
|
||||
|
||||
ThingUID thingUid = new ThingUID(thingTypeUid, bridgeHandler.getThing().getUID(),
|
||||
ThingUID thingUid = new ThingUID(thingTypeUid, thingHandler.getThing().getUID(),
|
||||
deviceState.getDeviceIdentifier());
|
||||
|
||||
DiscoveryResultBuilder discoveryResultBuilder = DiscoveryResultBuilder.create(thingUid)
|
||||
.withBridge(bridgeHandler.getThing().getUID()).withRepresentationProperty(Thing.PROPERTY_SERIAL_NUMBER)
|
||||
.withBridge(thingHandler.getThing().getUID()).withRepresentationProperty(Thing.PROPERTY_SERIAL_NUMBER)
|
||||
.withLabel(getLabel(deviceState));
|
||||
|
||||
ThingInformationExtractor.extractProperties(thingTypeUid, deviceState).entrySet()
|
||||
@ -199,15 +193,8 @@ public class ThingDiscoveryService extends AbstractDiscoveryService implements D
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(ThingHandler handler) {
|
||||
if (handler instanceof MieleBridgeHandler bridgeHandler) {
|
||||
bridgeHandler.setDiscoveryService(this);
|
||||
this.bridgeHandler = bridgeHandler;
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return bridgeHandler;
|
||||
public void initialize() {
|
||||
thingHandler.setDiscoveryService(this);
|
||||
super.initialize();
|
||||
}
|
||||
}
|
||||
|
@ -25,6 +25,8 @@ import org.openhab.core.automation.annotation.RuleAction;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -33,6 +35,7 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Bernhard Bauer - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = HeliosEasyControlsActions.class)
|
||||
@ThingActionsScope(name = "modbus.helioseasycontrols")
|
||||
@NonNullByDefault
|
||||
public class HeliosEasyControlsActions implements ThingActions {
|
||||
|
@ -22,6 +22,8 @@ import org.openhab.binding.modbus.discovery.ModbusDiscoveryParticipant;
|
||||
import org.openhab.binding.modbus.handler.ModbusEndpointThingHandler;
|
||||
import org.openhab.core.config.discovery.DiscoveryResult;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -35,6 +37,7 @@ import org.slf4j.LoggerFactory;
|
||||
* @author Nagy Attila Gabor - initial contribution
|
||||
*
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = ModbusEndpointDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class ModbusEndpointDiscoveryService implements ModbusThingHandlerDiscoveryService {
|
||||
|
||||
|
@ -20,6 +20,8 @@ import org.openhab.core.automation.annotation.RuleAction;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -28,6 +30,7 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Stefan Röllin - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = MPDActions.class)
|
||||
@ThingActionsScope(name = "mpd")
|
||||
@NonNullByDefault
|
||||
public class MPDActions implements ThingActions {
|
||||
|
@ -21,6 +21,8 @@ import org.openhab.core.io.transport.mqtt.MqttBrokerConnection;
|
||||
import org.openhab.core.thing.binding.ThingActions;
|
||||
import org.openhab.core.thing.binding.ThingActionsScope;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -29,6 +31,7 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author David Graeff - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = MQTTActions.class)
|
||||
@ThingActionsScope(name = "mqtt")
|
||||
@NonNullByDefault
|
||||
public class MQTTActions implements ThingActions {
|
||||
|
@ -19,7 +19,6 @@ import java.util.Optional;
|
||||
|
||||
import org.eclipse.jdt.annotation.NonNull;
|
||||
import org.eclipse.jdt.annotation.NonNullByDefault;
|
||||
import org.eclipse.jdt.annotation.Nullable;
|
||||
import org.openhab.binding.mybmw.internal.MyBMWConstants;
|
||||
import org.openhab.binding.mybmw.internal.dto.vehicle.Vehicle;
|
||||
import org.openhab.binding.mybmw.internal.dto.vehicle.VehicleAttributes;
|
||||
@ -31,12 +30,12 @@ import org.openhab.binding.mybmw.internal.handler.enums.RemoteService;
|
||||
import org.openhab.binding.mybmw.internal.utils.Constants;
|
||||
import org.openhab.binding.mybmw.internal.utils.VehicleStatusUtils;
|
||||
import org.openhab.core.config.core.Configuration;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.thing.Thing;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -47,34 +46,26 @@ import org.slf4j.LoggerFactory;
|
||||
* @author Bernd Weymann - Initial contribution
|
||||
* @author Martin Grassl - refactoring
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = VehicleDiscovery.class)
|
||||
@NonNullByDefault
|
||||
public class VehicleDiscovery extends AbstractDiscoveryService implements ThingHandlerService {
|
||||
public class VehicleDiscovery extends AbstractThingHandlerDiscoveryService<MyBMWBridgeHandler> {
|
||||
|
||||
private final Logger logger = LoggerFactory.getLogger(VehicleDiscovery.class);
|
||||
|
||||
private static final int DISCOVERY_TIMEOUT = 10;
|
||||
|
||||
private Optional<MyBMWBridgeHandler> bridgeHandler = Optional.empty();
|
||||
private Optional<MyBMWProxy> myBMWProxy = Optional.empty();
|
||||
private Optional<ThingUID> bridgeUid = Optional.empty();
|
||||
private @NonNullByDefault({}) ThingUID bridgeUid;
|
||||
|
||||
public VehicleDiscovery() {
|
||||
super(MyBMWConstants.SUPPORTED_THING_SET, DISCOVERY_TIMEOUT, false);
|
||||
super(MyBMWBridgeHandler.class, MyBMWConstants.SUPPORTED_THING_SET, DISCOVERY_TIMEOUT, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(ThingHandler handler) {
|
||||
if (handler instanceof MyBMWBridgeHandler bmwBridgeHandler) {
|
||||
logger.trace("VehicleDiscovery.setThingHandler for MybmwBridge");
|
||||
bridgeHandler = Optional.of(bmwBridgeHandler);
|
||||
bridgeHandler.get().setVehicleDiscovery(this);
|
||||
bridgeUid = Optional.of(bridgeHandler.get().getThing().getUID());
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return bridgeHandler.orElse(null);
|
||||
public void initialize() {
|
||||
thingHandler.setVehicleDiscovery(this);
|
||||
bridgeUid = thingHandler.getThing().getUID();
|
||||
super.initialize();
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -83,17 +74,10 @@ public class VehicleDiscovery extends AbstractDiscoveryService implements ThingH
|
||||
discoverVehicles();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
logger.trace("VehicleDiscovery.deactivate");
|
||||
|
||||
super.deactivate();
|
||||
}
|
||||
|
||||
public void discoverVehicles() {
|
||||
logger.trace("VehicleDiscovery.discoverVehicles");
|
||||
|
||||
myBMWProxy = bridgeHandler.get().getMyBmwProxy();
|
||||
myBMWProxy = thingHandler.getMyBmwProxy();
|
||||
|
||||
try {
|
||||
Optional<List<@NonNull Vehicle>> vehicleList = myBMWProxy.map(prox -> {
|
||||
@ -104,11 +88,11 @@ public class VehicleDiscovery extends AbstractDiscoveryService implements ThingH
|
||||
}
|
||||
});
|
||||
vehicleList.ifPresentOrElse(vehicles -> {
|
||||
bridgeHandler.ifPresent(bridge -> bridge.vehicleDiscoverySuccess());
|
||||
thingHandler.vehicleDiscoverySuccess();
|
||||
processVehicles(vehicles);
|
||||
}, () -> bridgeHandler.ifPresent(bridge -> bridge.vehicleDiscoveryError()));
|
||||
}, () -> thingHandler.vehicleDiscoveryError());
|
||||
} catch (IllegalStateException ex) {
|
||||
bridgeHandler.ifPresent(bridge -> bridge.vehicleDiscoveryError());
|
||||
thingHandler.vehicleDiscoveryError();
|
||||
}
|
||||
}
|
||||
|
||||
@ -131,13 +115,13 @@ public class VehicleDiscovery extends AbstractDiscoveryService implements ThingH
|
||||
.toString();
|
||||
MyBMWConstants.SUPPORTED_THING_SET.forEach(entry -> {
|
||||
if (entry.getId().equals(vehicleType)) {
|
||||
ThingUID uid = new ThingUID(entry, vehicle.getVehicleBase().getVin(), bridgeUid.get().getId());
|
||||
ThingUID uid = new ThingUID(entry, vehicle.getVehicleBase().getVin(), bridgeUid.getId());
|
||||
|
||||
Map<String, String> properties = generateProperties(vehicle);
|
||||
|
||||
boolean thingFound = false;
|
||||
// Update Properties for already created Things
|
||||
List<Thing> vehicleThings = bridgeHandler.get().getThing().getThings();
|
||||
List<Thing> vehicleThings = thingHandler.getThing().getThings();
|
||||
for (Thing vehicleThing : vehicleThings) {
|
||||
Configuration configuration = vehicleThing.getConfiguration();
|
||||
|
||||
@ -161,7 +145,7 @@ public class VehicleDiscovery extends AbstractDiscoveryService implements ThingH
|
||||
Integer.toString(MyBMWConstants.DEFAULT_REFRESH_INTERVAL_MINUTES));
|
||||
|
||||
String vehicleLabel = vehicleAttributes.getBrand() + " " + vehicleAttributes.getModel();
|
||||
thingDiscovered(DiscoveryResultBuilder.create(uid).withBridge(bridgeUid.get())
|
||||
thingDiscovered(DiscoveryResultBuilder.create(uid).withBridge(bridgeUid)
|
||||
.withRepresentationProperty(MyBMWConstants.VIN).withLabel(vehicleLabel)
|
||||
.withProperties(convertedProperties).build());
|
||||
}
|
||||
|
@ -83,6 +83,7 @@ public class VehicleDiscoveryTest {
|
||||
when(bridgeHandler.getMyBmwProxy()).thenReturn(Optional.of(myBMWProxy));
|
||||
|
||||
vehicleDiscovery.setThingHandler(bridgeHandler);
|
||||
vehicleDiscovery.initialize();
|
||||
assertNotNull(vehicleDiscovery.getThingHandler());
|
||||
|
||||
DiscoveryListener listener = mock(DiscoveryListener.class);
|
||||
|
@ -15,21 +15,19 @@ package org.openhab.binding.mynice.internal.discovery;
|
||||
import static org.openhab.binding.mynice.internal.MyNiceBindingConstants.*;
|
||||
|
||||
import java.util.List;
|
||||
import java.util.Optional;
|
||||
import java.util.Set;
|
||||
|
||||
import org.eclipse.jdt.annotation.NonNullByDefault;
|
||||
import org.eclipse.jdt.annotation.Nullable;
|
||||
import org.openhab.binding.mynice.internal.handler.It4WifiHandler;
|
||||
import org.openhab.binding.mynice.internal.handler.MyNiceDataListener;
|
||||
import org.openhab.binding.mynice.internal.xml.dto.CommandType;
|
||||
import org.openhab.binding.mynice.internal.xml.dto.Device;
|
||||
import org.openhab.core.config.discovery.AbstractDiscoveryService;
|
||||
import org.openhab.core.config.discovery.AbstractThingHandlerDiscoveryService;
|
||||
import org.openhab.core.config.discovery.DiscoveryResult;
|
||||
import org.openhab.core.config.discovery.DiscoveryResultBuilder;
|
||||
import org.openhab.core.thing.ThingUID;
|
||||
import org.openhab.core.thing.binding.ThingHandler;
|
||||
import org.openhab.core.thing.binding.ThingHandlerService;
|
||||
import org.osgi.service.component.annotations.Component;
|
||||
import org.osgi.service.component.annotations.ServiceScope;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
@ -39,51 +37,36 @@ import org.slf4j.LoggerFactory;
|
||||
*
|
||||
* @author Gaël L'hopital - Initial contribution
|
||||
*/
|
||||
@Component(scope = ServiceScope.PROTOTYPE, service = MyNiceDiscoveryService.class)
|
||||
@NonNullByDefault
|
||||
public class MyNiceDiscoveryService extends AbstractDiscoveryService
|
||||
implements MyNiceDataListener, ThingHandlerService {
|
||||
public class MyNiceDiscoveryService extends AbstractThingHandlerDiscoveryService<It4WifiHandler>
|
||||
implements MyNiceDataListener {
|
||||
|
||||
private static final int SEARCH_TIME = 5;
|
||||
private final Logger logger = LoggerFactory.getLogger(MyNiceDiscoveryService.class);
|
||||
|
||||
private Optional<It4WifiHandler> bridgeHandler = Optional.empty();
|
||||
|
||||
/**
|
||||
* Creates a MyNiceDiscoveryService with background discovery disabled.
|
||||
*/
|
||||
public MyNiceDiscoveryService() {
|
||||
super(Set.of(THING_TYPE_SWING, THING_TYPE_SLIDING), SEARCH_TIME, false);
|
||||
super(It4WifiHandler.class, Set.of(THING_TYPE_SWING, THING_TYPE_SLIDING), SEARCH_TIME, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setThingHandler(ThingHandler handler) {
|
||||
if (handler instanceof It4WifiHandler it4Handler) {
|
||||
bridgeHandler = Optional.of(it4Handler);
|
||||
}
|
||||
public void initialize() {
|
||||
thingHandler.registerDataListener(this);
|
||||
super.initialize();
|
||||
}
|
||||
|
||||
@Override
|
||||
public @Nullable ThingHandler getThingHandler() {
|
||||
return bridgeHandler.orElse(null);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void activate() {
|
||||
super.activate(null);
|
||||
bridgeHandler.ifPresent(h -> h.registerDataListener(this));
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deactivate() {
|
||||
bridgeHandler.ifPresent(h -> h.unregisterDataListener(this));
|
||||
bridgeHandler = Optional.empty();
|
||||
super.deactivate();
|
||||
public void dispose() {
|
||||
super.dispose();
|
||||
thingHandler.unregisterDataListener(this);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onDataFetched(List<Device> devices) {
|
||||
bridgeHandler.ifPresent(handler -> {
|
||||
ThingUID bridgeUID = handler.getThing().getUID();
|
||||
ThingUID bridgeUID = thingHandler.getThing().getUID();
|
||||
devices.stream().filter(device -> device.type != null).forEach(device -> {
|
||||
ThingUID thingUID = switch (device.type) {
|
||||
case SWING -> new ThingUID(THING_TYPE_SWING, bridgeUID, device.id);
|
||||
@ -100,11 +83,10 @@ public class MyNiceDiscoveryService extends AbstractDiscoveryService
|
||||
logger.info("`{}` type of device is not yet supported", device.type);
|
||||
}
|
||||
});
|
||||
});
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void startScan() {
|
||||
bridgeHandler.ifPresent(h -> h.sendCommand(CommandType.INFO));
|
||||
thingHandler.sendCommand(CommandType.INFO);
|
||||
}
|
||||
}
|
||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user