2 * Copyright (c) 2010-2023 Contributors to the openHAB project
4 * See the NOTICE file(s) distributed with this work for additional
7 * This program and the accompanying materials are made available under the
8 * terms of the Eclipse Public License 2.0 which is available at
9 * http://www.eclipse.org/legal/epl-2.0
11 * SPDX-License-Identifier: EPL-2.0
13 package org.openhab.binding.zoneminder.internal.discovery;
15 import static org.openhab.binding.zoneminder.internal.ZmBindingConstants.*;
17 import java.util.HashMap;
20 import java.util.concurrent.Future;
21 import java.util.concurrent.TimeUnit;
23 import org.eclipse.jdt.annotation.NonNullByDefault;
24 import org.eclipse.jdt.annotation.Nullable;
25 import org.openhab.binding.zoneminder.internal.handler.Monitor;
26 import org.openhab.binding.zoneminder.internal.handler.ZmBridgeHandler;
27 import org.openhab.core.config.discovery.AbstractDiscoveryService;
28 import org.openhab.core.config.discovery.DiscoveryResult;
29 import org.openhab.core.config.discovery.DiscoveryResultBuilder;
30 import org.openhab.core.config.discovery.DiscoveryService;
31 import org.openhab.core.thing.ThingTypeUID;
32 import org.openhab.core.thing.ThingUID;
33 import org.openhab.core.thing.binding.ThingHandler;
34 import org.openhab.core.thing.binding.ThingHandlerService;
35 import org.slf4j.Logger;
36 import org.slf4j.LoggerFactory;
39 * The {@link MonitorDiscoveryService} is responsible for discovering the Zoneminder monitors
40 * associated with a Zoneminder server.
42 * @author Mark Hilbush - Initial contribution
45 public class MonitorDiscoveryService extends AbstractDiscoveryService implements DiscoveryService, ThingHandlerService {
47 private final Logger logger = LoggerFactory.getLogger(MonitorDiscoveryService.class);
49 private static final int DISCOVERY_INTERVAL_SECONDS = 300;
50 private static final int DISCOVERY_INITIAL_DELAY_SECONDS = 10;
51 private static final int DISCOVERY_TIMEOUT_SECONDS = 6;
53 private @NonNullByDefault({}) ZmBridgeHandler bridgeHandler;
55 private @Nullable Future<?> discoveryJob;
57 public MonitorDiscoveryService() {
58 super(SUPPORTED_MONITOR_THING_TYPES_UIDS, DISCOVERY_TIMEOUT_SECONDS, true);
62 public void activate() {
67 public void deactivate() {
72 public void setThingHandler(@Nullable ThingHandler handler) {
73 if (handler instanceof ZmBridgeHandler zmBridgeHandler) {
74 bridgeHandler = zmBridgeHandler;
79 public @Nullable ThingHandler getThingHandler() {
84 public Set<ThingTypeUID> getSupportedThingTypes() {
85 return SUPPORTED_MONITOR_THING_TYPES_UIDS;
89 protected void startBackgroundDiscovery() {
90 Future<?> localDiscoveryJob = discoveryJob;
91 if (localDiscoveryJob == null || localDiscoveryJob.isCancelled()) {
92 logger.debug("ZoneminderDiscovery: Starting background discovery job");
93 discoveryJob = scheduler.scheduleWithFixedDelay(this::backgroundDiscoverMonitors,
94 DISCOVERY_INITIAL_DELAY_SECONDS, DISCOVERY_INTERVAL_SECONDS, TimeUnit.SECONDS);
99 protected void stopBackgroundDiscovery() {
100 Future<?> localDiscoveryJob = discoveryJob;
101 if (localDiscoveryJob != null) {
102 logger.debug("ZoneminderDiscovery: Stopping background discovery job");
103 localDiscoveryJob.cancel(true);
109 public void startScan() {
110 logger.debug("ZoneminderDiscovery: Running discovery scan");
114 private void backgroundDiscoverMonitors() {
115 if (!bridgeHandler.isBackgroundDiscoveryEnabled()) {
118 logger.debug("ZoneminderDiscovery: Running background discovery scan");
122 private synchronized void discoverMonitors() {
123 ThingUID bridgeUID = bridgeHandler.getThing().getUID();
124 Integer alarmDuration = bridgeHandler.getDefaultAlarmDuration();
125 Integer imageRefreshInterval = bridgeHandler.getDefaultImageRefreshInterval();
126 for (Monitor monitor : bridgeHandler.getSavedMonitors()) {
127 String id = monitor.getId();
128 String name = monitor.getName();
129 ThingUID thingUID = new ThingUID(UID_MONITOR, bridgeUID, monitor.getId());
130 Map<String, Object> properties = new HashMap<>();
131 properties.put(CONFIG_MONITOR_ID, id);
132 properties.put(CONFIG_ALARM_DURATION, alarmDuration);
133 if (imageRefreshInterval != null) {
134 properties.put(CONFIG_IMAGE_REFRESH_INTERVAL, imageRefreshInterval);
136 thingDiscovered(createDiscoveryResult(thingUID, bridgeUID, id, name, properties));
137 logger.debug("ZoneminderDiscovery: Monitor with id '{}' and name '{}' added to Inbox with UID '{}'",
138 monitor.getId(), monitor.getName(), thingUID);
142 private DiscoveryResult createDiscoveryResult(ThingUID monitorUID, ThingUID bridgeUID, String id, String name,
143 Map<String, Object> properties) {
144 return DiscoveryResultBuilder.create(monitorUID).withProperties(properties).withBridge(bridgeUID)
145 .withLabel(String.format("Zoneminder Monitor %s", name)).withRepresentationProperty(CONFIG_MONITOR_ID)