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.qolsysiq.internal.handler;
15 import java.util.HashMap;
18 import org.eclipse.jdt.annotation.NonNullByDefault;
19 import org.eclipse.jdt.annotation.Nullable;
20 import org.openhab.binding.qolsysiq.internal.QolsysIQBindingConstants;
21 import org.openhab.binding.qolsysiq.internal.client.dto.event.ZoneActiveEvent;
22 import org.openhab.binding.qolsysiq.internal.client.dto.event.ZoneUpdateEvent;
23 import org.openhab.binding.qolsysiq.internal.client.dto.model.Zone;
24 import org.openhab.binding.qolsysiq.internal.client.dto.model.ZoneStatus;
25 import org.openhab.binding.qolsysiq.internal.config.QolsysIQZoneConfiguration;
26 import org.openhab.core.library.types.DecimalType;
27 import org.openhab.core.library.types.OpenClosedType;
28 import org.openhab.core.library.types.StringType;
29 import org.openhab.core.thing.Bridge;
30 import org.openhab.core.thing.ChannelUID;
31 import org.openhab.core.thing.Thing;
32 import org.openhab.core.thing.ThingStatus;
33 import org.openhab.core.thing.ThingStatusDetail;
34 import org.openhab.core.thing.ThingStatusInfo;
35 import org.openhab.core.thing.binding.BaseThingHandler;
36 import org.openhab.core.thing.binding.BridgeHandler;
37 import org.openhab.core.types.Command;
38 import org.slf4j.Logger;
39 import org.slf4j.LoggerFactory;
42 * The {@link QolsysIQZoneHandler} manages security zones.
44 * @author Dan Cunningham - Initial contribution
47 public class QolsysIQZoneHandler extends BaseThingHandler {
48 private final Logger logger = LoggerFactory.getLogger(QolsysIQZoneHandler.class);
52 public QolsysIQZoneHandler(Thing thing) {
57 public void initialize() {
58 logger.debug("initialize");
59 zoneId = getConfigAs(QolsysIQZoneConfiguration.class).id;
64 public void bridgeStatusChanged(ThingStatusInfo bridgeStatusChanged) {
65 logger.debug("bridgeStatusChanged {}", bridgeStatusChanged);
70 public void handleCommand(ChannelUID channelUID, Command command) {
73 public int getZoneId() {
77 protected void updateZone(Zone zone) {
78 logger.debug("updateZone {}", zone.zoneId);
79 updateState(QolsysIQBindingConstants.CHANNEL_ZONE_STATE, new DecimalType(zone.state));
80 updateZoneStatus(zone.status);
81 Map<String, String> props = new HashMap<String, String>();
82 props.put("type", zone.type);
83 props.put("name", zone.name);
84 props.put("group", zone.group);
85 props.put("zoneID", zone.id);
86 props.put("zonePhysicalType", String.valueOf(zone.zonePhysicalType));
87 props.put("zoneAlarmType", String.valueOf(zone.zoneAlarmType));
88 props.put("zoneType", zone.zoneType.toString());
89 props.put("partitionId", String.valueOf(zone.partitionId));
90 getThing().setProperties(props);
93 protected void zoneActiveEvent(ZoneActiveEvent event) {
94 if (event.zone.zoneId == getZoneId()) {
95 updateZoneStatus(event.zone.status);
99 protected void zoneUpdateEvent(ZoneUpdateEvent event) {
100 if (event.zone.zoneId == getZoneId()) {
101 updateZone(event.zone);
105 private void initializeZone() {
106 Bridge bridge = getBridge();
107 BridgeHandler handler = bridge == null ? null : bridge.getHandler();
108 if (bridge != null && handler instanceof QolsysIQPartitionHandler partitionHandler) {
109 if (handler.getThing().getStatus() != ThingStatus.ONLINE) {
110 updateStatus(ThingStatus.OFFLINE, ThingStatusDetail.BRIDGE_OFFLINE);
113 Zone z = partitionHandler.getZone(getZoneId());
115 updateStatus(ThingStatus.OFFLINE, ThingStatusDetail.CONFIGURATION_ERROR, "Zone not found in partition");
119 updateStatus(ThingStatus.ONLINE);
121 updateStatus(ThingStatus.OFFLINE, ThingStatusDetail.BRIDGE_UNINITIALIZED);
125 private void updateZoneStatus(@Nullable ZoneStatus status) {
126 if (status != null) {
127 updateState(QolsysIQBindingConstants.CHANNEL_ZONE_STATUS, new StringType(status.toString()));
128 updateState(QolsysIQBindingConstants.CHANNEL_ZONE_CONTACT,
129 status == ZoneStatus.CLOSED || status == ZoneStatus.IDlE ? OpenClosedType.CLOSED
130 : OpenClosedType.OPEN);
132 logger.debug("updateZoneStatus: null status");