2 * Copyright (c) 2010-2020 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.wemo.internal.discovery;
15 import org.jupnp.UpnpService;
16 import org.jupnp.model.message.header.RootDeviceHeader;
17 import org.openhab.core.config.discovery.AbstractDiscoveryService;
18 import org.openhab.core.config.discovery.DiscoveryService;
19 import org.osgi.service.component.annotations.Component;
20 import org.osgi.service.component.annotations.Reference;
21 import org.slf4j.Logger;
22 import org.slf4j.LoggerFactory;
25 * The {@link WemoDiscoveryService} is a {@link DiscoveryService} implementation, which can find WeMo UPnP devices in
28 * @author Hans-Jörg Merk - Initial contribution
31 @Component(service = DiscoveryService.class, immediate = true, configurationPid = "discovery.wemo")
32 public class WemoDiscoveryService extends AbstractDiscoveryService {
34 private Logger logger = LoggerFactory.getLogger(WemoDiscoveryService.class);
36 public WemoDiscoveryService() {
40 private UpnpService upnpService;
43 protected void setUpnpService(UpnpService upnpService) {
44 this.upnpService = upnpService;
47 protected void unsetUpnpService(UpnpService upnpService) {
48 this.upnpService = null;
51 public void activate() {
52 logger.debug("Starting WeMo UPnP discovery...");
57 public void deactivate() {
58 logger.debug("Stopping WeMo UPnP discovery...");
63 protected void startScan() {
64 logger.debug("Starting UPnP RootDevice search...");
65 if (upnpService != null) {
66 upnpService.getControlPoint().search(new RootDeviceHeader());
68 logger.debug("upnpService not set");
73 protected synchronized void stopScan() {
74 removeOlderResults(getTimestampOfLastScan());