2 * Copyright (c) 2010-2024 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.freeathomesystem.internal;
15 import static org.openhab.binding.freeathomesystem.internal.FreeAtHomeSystemBindingConstants.*;
17 import org.eclipse.jdt.annotation.NonNullByDefault;
18 import org.eclipse.jdt.annotation.Nullable;
19 import org.eclipse.jetty.client.HttpClient;
20 import org.openhab.binding.freeathomesystem.internal.handler.FreeAtHomeBridgeHandler;
21 import org.openhab.binding.freeathomesystem.internal.handler.FreeAtHomeDeviceHandler;
22 import org.openhab.binding.freeathomesystem.internal.type.FreeAtHomeChannelTypeProvider;
23 import org.openhab.binding.freeathomesystem.internal.type.FreeAtHomeThingTypeProvider;
24 import org.openhab.core.i18n.LocaleProvider;
25 import org.openhab.core.i18n.TranslationProvider;
26 import org.openhab.core.io.net.http.HttpClientFactory;
27 import org.openhab.core.thing.Bridge;
28 import org.openhab.core.thing.Thing;
29 import org.openhab.core.thing.ThingTypeUID;
30 import org.openhab.core.thing.binding.BaseThingHandlerFactory;
31 import org.openhab.core.thing.binding.ThingHandler;
32 import org.openhab.core.thing.binding.ThingHandlerFactory;
33 import org.osgi.service.component.ComponentContext;
34 import org.osgi.service.component.annotations.Activate;
35 import org.osgi.service.component.annotations.Component;
36 import org.osgi.service.component.annotations.Deactivate;
37 import org.osgi.service.component.annotations.Reference;
38 import org.slf4j.Logger;
39 import org.slf4j.LoggerFactory;
42 * The {@link FreeAtHomeSystemHandlerFactory} is responsible for creating things and thing
45 * @author Andras Uhrin - Initial contribution
48 @Component(configurationPid = "binding.freeathomesystem", service = ThingHandlerFactory.class)
49 public class FreeAtHomeSystemHandlerFactory extends BaseThingHandlerFactory {
51 private final Logger logger = LoggerFactory.getLogger(FreeAtHomeSystemHandlerFactory.class);
53 private final HttpClient httpClient;
54 private final FreeAtHomeChannelTypeProvider channelTypeProvider;
55 private final TranslationProvider i18nProvider;
56 private final LocaleProvider localeProvider;
59 public FreeAtHomeSystemHandlerFactory(@Reference FreeAtHomeThingTypeProvider thingTypeProvider,
60 @Reference FreeAtHomeChannelTypeProvider channelTypeProvider, @Reference TranslationProvider i18nProvider,
61 @Reference LocaleProvider localeProvider, @Reference HttpClientFactory httpClientFactory,
62 ComponentContext componentContext) {
63 super.activate(componentContext);
64 this.channelTypeProvider = channelTypeProvider;
65 this.i18nProvider = i18nProvider;
66 this.localeProvider = localeProvider;
69 httpClient = httpClientFactory.createHttpClient(FreeAtHomeSystemBindingConstants.BINDING_ID);
72 httpClient.setFollowRedirects(false);
73 httpClient.setMaxConnectionsPerDestination(1);
74 httpClient.setMaxRequestsQueuedPerDestination(50);
77 httpClient.setIdleTimeout(-1);
78 httpClient.setConnectTimeout(5000);
83 } catch (Exception ex) {
84 logger.error("Could not create HttpClient: {}", ex.getMessage());
86 throw new IllegalStateException("Could not create HttpClient", ex);
91 public void deactivate() {
94 } catch (Exception ex) {
95 logger.warn("Failed to stop HttpClient: {}", ex.getMessage());
100 public boolean supportsThingType(ThingTypeUID thingTypeUID) {
101 return SUPPORTED_THING_TYPES_UIDS.contains(thingTypeUID);
105 protected @Nullable ThingHandler createHandler(Thing thing) {
106 ThingTypeUID thingTypeUID = thing.getThingTypeUID();
108 if (BRIDGE_TYPE_UID.equals(thingTypeUID)) {
109 return new FreeAtHomeBridgeHandler((Bridge) thing, httpClient);
110 } else if (DEVICE_TYPE_UID.equals(thingTypeUID)) {
111 return new FreeAtHomeDeviceHandler(thing, channelTypeProvider, i18nProvider, localeProvider);