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.haywardomnilogic.internal.handler;
15 import java.util.ArrayList;
16 import java.util.List;
18 import org.eclipse.jdt.annotation.NonNullByDefault;
19 import org.openhab.binding.haywardomnilogic.internal.HaywardBindingConstants;
20 import org.openhab.binding.haywardomnilogic.internal.HaywardException;
21 import org.openhab.binding.haywardomnilogic.internal.HaywardThingHandler;
22 import org.openhab.core.thing.Bridge;
23 import org.openhab.core.thing.Thing;
24 import org.openhab.core.thing.ThingStatus;
25 import org.openhab.core.thing.ThingStatusDetail;
26 import org.slf4j.Logger;
27 import org.slf4j.LoggerFactory;
30 * The Backyard Handler
32 * @author Matt Myers - Initial contribution
35 public class HaywardBackyardHandler extends HaywardThingHandler {
36 private final Logger logger = LoggerFactory.getLogger(HaywardBackyardHandler.class);
38 public HaywardBackyardHandler(Thing thing) {
43 public void getTelemetry(String xmlResponse) throws HaywardException {
44 List<String> data = new ArrayList<>();
45 List<String> systemIDs = new ArrayList<>();
47 Bridge bridge = getBridge();
49 HaywardBridgeHandler bridgehandler = (HaywardBridgeHandler) bridge.getHandler();
50 if (bridgehandler != null) {
51 systemIDs = bridgehandler.evaluateXPath("//Backyard/@systemId", xmlResponse);
52 String thingSystemID = getThing().getUID().getId();
53 for (int i = 0; i < systemIDs.size(); i++) {
54 if (systemIDs.get(i).equals(thingSystemID)) {
56 data = bridgehandler.evaluateXPath("//Backyard/@airTemp", xmlResponse);
57 updateData(HaywardBindingConstants.CHANNEL_BACKYARD_AIRTEMP, data.get(0));
60 data = bridgehandler.evaluateXPath("//Backyard/@status", xmlResponse);
61 updateData(HaywardBindingConstants.CHANNEL_BACKYARD_STATUS, data.get(0));
64 data = bridgehandler.evaluateXPath("//Backyard/@state", xmlResponse);
65 updateData(HaywardBindingConstants.CHANNEL_BACKYARD_STATE, data.get(0));
68 this.updateStatus(ThingStatus.ONLINE);
70 this.updateStatus(ThingStatus.OFFLINE, ThingStatusDetail.BRIDGE_UNINITIALIZED);
75 public boolean getAlarmList(String systemID) throws HaywardException {
76 List<String> bowID = new ArrayList<>();
77 List<String> parameter1 = new ArrayList<>();
78 List<String> message = new ArrayList<>();
81 Bridge bridge = getBridge();
83 HaywardBridgeHandler bridgehandler = (HaywardBridgeHandler) bridge.getHandler();
84 if (bridgehandler != null) {
85 // *****Request Alarm List from Hayward server
86 String urlParameters = """
87 <?xml version="1.0" encoding="utf-8"?><Request><Name>GetAlarmList</Name><Parameters>\
88 <Parameter name="Token" dataType="String">\
89 """ + bridgehandler.account.token + "</Parameter>"
90 + "<Parameter name=\"MspSystemID\" dataType=\"int\">" + bridgehandler.account.mspSystemID
92 + "<Parameter name=\"CultureInfoName\" dataType=\"String\">en-us</Parameter></Parameters></Request>";
95 String xmlResponse = bridgehandler.httpXmlResponse(urlParameters);
97 if (xmlResponse.isEmpty()) {
98 logger.debug("Hayward getAlarmList XML response was empty");
102 String status = bridgehandler
103 .evaluateXPath("/Response/Parameters//Parameter[@name='Status']/text()", xmlResponse)
106 if (!("0".equals(status))) {
107 logger.trace("Hayward getAlarm XML response: {}", xmlResponse);
111 bowID = bridgehandler.evaluateXPath("//Property[@name='BowID']/text()", xmlResponse);
112 parameter1 = bridgehandler.evaluateXPath("//Property[@name='Parameter1']/text()", xmlResponse);
113 message = bridgehandler.evaluateXPath("//Property[@name='Message']/text()", xmlResponse);
115 for (int i = 0; i < 5; i++) {
116 if (i < bowID.size()) {
117 alarmStr = parameter1.get(i) + ": " + message.get(i);
121 updateData("backyardAlarm" + String.format("%01d", i + 1), alarmStr);
123 this.updateStatus(ThingStatus.ONLINE);
125 } catch (InterruptedException e) {
129 this.updateStatus(ThingStatus.OFFLINE, ThingStatusDetail.BRIDGE_UNINITIALIZED);
133 this.updateStatus(ThingStatus.OFFLINE, ThingStatusDetail.BRIDGE_UNINITIALIZED);