]> git.basschouten.com Git - openhab-addons.git/blob
2fb089d156db793e89d0f60389160f503e481554
[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.PowermaxPanelType;
16 import org.openhab.binding.powermax.internal.state.PowermaxState;
17 import org.slf4j.Logger;
18 import org.slf4j.LoggerFactory;
19
20 /**
21  * A class for INFO message handling
22  *
23  * @author Laurent Garnier - Initial contribution
24  */
25 public class PowermaxInfoMessage extends PowermaxBaseMessage {
26
27     private final Logger logger = LoggerFactory.getLogger(PowermaxInfoMessage.class);
28
29     /**
30      * Constructor
31      *
32      * @param message
33      *            the received message as a buffer of bytes
34      */
35     public PowermaxInfoMessage(byte[] message) {
36         super(message);
37     }
38
39     @Override
40     public PowermaxState handleMessage(PowermaxCommManager commManager) {
41         super.handleMessage(commManager);
42
43         if (commManager == null) {
44             return null;
45         }
46
47         PowermaxState updatedState = commManager.createNewState();
48
49         byte[] message = getRawData();
50
51         PowermaxPanelType panelType = null;
52         try {
53             panelType = PowermaxPanelType.fromCode(message[7]);
54         } catch (IllegalArgumentException e) {
55             logger.debug("Powermax alarm binding: unknwon panel type for code {}", message[7] & 0x000000FF);
56             panelType = null;
57         }
58
59         logger.debug("Reading panel settings");
60         updatedState.setDownloadMode(true);
61         commManager.sendMessage(PowermaxSendType.DL_PANELFW);
62         commManager.sendMessage(PowermaxSendType.DL_SERIAL);
63         commManager.sendMessage(PowermaxSendType.DL_ZONESTR);
64         commManager.sendSetTime();
65         if ((panelType != null) && panelType.isPowerMaster()) {
66             commManager.sendMessage(PowermaxSendType.DL_MR_SIRKEYZON);
67         }
68         commManager.sendMessage(PowermaxSendType.START);
69         commManager.sendMessage(PowermaxSendType.EXIT);
70
71         return updatedState;
72     }
73
74     @Override
75     public String toString() {
76         String str = super.toString();
77
78         byte[] message = getRawData();
79         byte panelTypeNr = message[7];
80
81         str += "\n - panel type number = " + String.format("%02X", panelTypeNr);
82
83         return str;
84     }
85 }