2 * Copyright (c) 2010-2021 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.konnected.internal;
15 import static org.openhab.binding.konnected.internal.KonnectedBindingConstants.*;
17 import java.util.Collections;
18 import java.util.Dictionary;
21 import javax.servlet.ServletException;
23 import org.eclipse.jdt.annotation.Nullable;
24 import org.openhab.binding.konnected.internal.handler.KonnectedHandler;
25 import org.openhab.binding.konnected.internal.servlet.KonnectedHTTPServlet;
26 import org.openhab.binding.konnected.internal.servlet.KonnectedWebHookFail;
27 import org.openhab.core.net.HttpServiceUtil;
28 import org.openhab.core.net.NetworkAddressService;
29 import org.openhab.core.thing.Thing;
30 import org.openhab.core.thing.ThingTypeUID;
31 import org.openhab.core.thing.binding.BaseThingHandlerFactory;
32 import org.openhab.core.thing.binding.ThingHandler;
33 import org.openhab.core.thing.binding.ThingHandlerFactory;
34 import org.osgi.service.component.ComponentContext;
35 import org.osgi.service.component.annotations.Component;
36 import org.osgi.service.component.annotations.Reference;
37 import org.osgi.service.http.HttpService;
38 import org.osgi.service.http.NamespaceException;
39 import org.slf4j.Logger;
40 import org.slf4j.LoggerFactory;
43 * The {@link KonnectedHandlerFactory} is responsible for creating things and thing
46 * @author Zachary Christiansen - Initial contribution
48 @Component(configurationPid = "binding.konnected", service = ThingHandlerFactory.class)
49 public class KonnectedHandlerFactory extends BaseThingHandlerFactory {
50 private final Logger logger = LoggerFactory.getLogger(KonnectedHandlerFactory.class);
51 private static final Set<ThingTypeUID> SUPPORTED_THING_TYPES_UIDS = Collections.singleton(THING_TYPE_MODULE);
52 private static final String alias = "/" + BINDING_ID;
54 private HttpService httpService;
55 private String callbackUrl = null;
56 private NetworkAddressService networkAddressService;
57 private KonnectedHTTPServlet servlet;
60 public boolean supportsThingType(ThingTypeUID thingTypeUID) {
61 return SUPPORTED_THING_TYPES_UIDS.contains(thingTypeUID);
65 protected void activate(ComponentContext componentContext) {
66 super.activate(componentContext);
67 Dictionary<String, Object> properties = componentContext.getProperties();
68 callbackUrl = (String) properties.get("callbackUrl");
70 this.servlet = registerWebHookServlet();
71 } catch (KonnectedWebHookFail e) {
72 logger.error("Failed registering Konnected servlet - binding is not functional!", e);
77 protected void deactivate(ComponentContext componentContext) {
78 super.deactivate(componentContext);
79 httpService.unregister(alias);
83 protected @Nullable ThingHandler createHandler(Thing thing) {
84 KonnectedHandler thingHandler = new KonnectedHandler(thing, '/' + BINDING_ID, createCallbackUrl(),
85 createCallbackPort());
86 if (servlet != null) {
87 logger.debug("Adding thinghandler for thing {} to webhook.", thing.getUID().getId());
88 servlet.add(thingHandler);
94 * @param thingHandler thing handler to be removed
97 protected void removeHandler(ThingHandler thingHandler) {
98 servlet.remove((KonnectedHandler) thingHandler);
99 thingHandler.dispose();
100 super.removeHandler(thingHandler);
103 private KonnectedHTTPServlet registerWebHookServlet() throws KonnectedWebHookFail {
104 KonnectedHTTPServlet servlet = new KonnectedHTTPServlet();
106 httpService.registerServlet(alias, servlet, null, httpService.createDefaultHttpContext());
108 } catch (ServletException | NamespaceException e) {
109 throw new KonnectedWebHookFail("Could not start Konnected Webhook servlet: " + e.getMessage(), e);
114 public void setHttpService(HttpService httpService) {
115 this.httpService = httpService;
118 public void unsetHttpService(HttpService httpService) {
119 this.httpService = null;
122 private String createCallbackUrl() {
123 if (callbackUrl != null) {
124 logger.debug("The callback ip address from the OSGI is:{}", callbackUrl);
127 final String ipAddress = networkAddressService.getPrimaryIpv4HostAddress();
128 if (ipAddress == null) {
129 logger.warn("No network interface could be found.");
132 logger.debug("The callback ip address obtained from the Network Address Service was:{}", ipAddress);
137 private String createCallbackPort() {
138 // we do not use SSL as it can cause certificate validation issues.
139 final int port = HttpServiceUtil.getHttpServicePort(bundleContext);
141 logger.warn("Cannot find port of the http service.");
144 logger.debug("the port for the callback is: {}", port);
145 return Integer.toString(port);
149 protected void setNetworkAddressService(NetworkAddressService networkAddressService) {
150 this.networkAddressService = networkAddressService;
153 protected void unsetNetworkAddressService(NetworkAddressService networkAddressService) {
154 this.networkAddressService = null;