]> git.basschouten.com Git - openhab-addons.git/blob
f79f385d894078529ef9da7f679b949bb68b1d85
[openhab-addons.git] /
1 /**
2  * Copyright (c) 2010-2020 Contributors to the openHAB project
3  *
4  * See the NOTICE file(s) distributed with this work for additional
5  * information.
6  *
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
10  *
11  * SPDX-License-Identifier: EPL-2.0
12  */
13 package org.openhab.binding.powermax.internal.message;
14
15 import org.openhab.binding.powermax.internal.state.PowermaxState;
16 import org.slf4j.Logger;
17 import org.slf4j.LoggerFactory;
18
19 /**
20  * A class for POWERLINK message handling
21  *
22  * @author Laurent Garnier - Initial contribution
23  */
24 public class PowermaxPowerlinkMessage extends PowermaxBaseMessage {
25
26     private final Logger logger = LoggerFactory.getLogger(PowermaxPowerlinkMessage.class);
27
28     /**
29      * Constructor
30      *
31      * @param message
32      *            the received message as a buffer of bytes
33      */
34     public PowermaxPowerlinkMessage(byte[] message) {
35         super(message);
36     }
37
38     @Override
39     public PowermaxState handleMessage(PowermaxCommManager commManager) {
40         super.handleMessage(commManager);
41
42         if (commManager == null) {
43             return null;
44         }
45
46         PowermaxState updatedState = null;
47
48         byte[] message = getRawData();
49         byte subType = message[2];
50
51         if (subType == 0x03) {
52             // keep alive message
53             commManager.sendAck(this, (byte) 0x02);
54             updatedState = commManager.createNewState();
55             updatedState.setLastKeepAlive(System.currentTimeMillis());
56         } else if (subType == 0x0A && message[4] == 0x01) {
57             logger.debug("Powermax alarm binding: Enrolling Powerlink");
58             commManager.enrollPowerlink();
59             updatedState = commManager.createNewState();
60             updatedState.setDownloadSetupRequired(true);
61         } else {
62             commManager.sendAck(this, (byte) 0x02);
63         }
64
65         return updatedState;
66     }
67
68     @Override
69     public String toString() {
70         String str = super.toString();
71
72         byte[] message = getRawData();
73         byte subType = message[2];
74
75         if (subType == 0x03) {
76             str += "\n - sub type = keep alive";
77         } else if (subType == 0x0A) {
78             str += "\n - sub type = enroll";
79             str += "\n - enroll = " + String.format("%02X", message[4]);
80         } else {
81             str += "\n - sub type = " + String.format("%02X", subType);
82         }
83
84         return str;
85     }
86 }