2 * Copyright (c) 2010-2021 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.powermax.internal.message;
15 import org.openhab.binding.powermax.internal.message.PowermaxMessageConstants.PowermaxSysEvent;
16 import org.openhab.binding.powermax.internal.state.PowermaxState;
19 * A class for PANEL message handling
21 * @author Laurent Garnier - Initial contribution
23 public class PowermaxPanelMessage extends PowermaxBaseMessage {
29 * the received message as a buffer of bytes
31 public PowermaxPanelMessage(byte[] message) {
36 protected PowermaxState handleMessageInternal(PowermaxCommManager commManager) {
37 if (commManager == null) {
41 PowermaxState updatedState = commManager.createNewState();
43 byte[] message = getRawData();
44 int msgCnt = message[2] & 0x000000FF;
46 debug("Event count", msgCnt);
48 for (int i = 1; i <= msgCnt; i++) {
49 byte eventZone = message[2 + 2 * i];
50 byte logEvent = message[3 + 2 * i];
51 int eventType = logEvent & 0x0000007F;
52 PowermaxSysEvent sysEvent = PowermaxMessageConstants.getSystemEvent(eventType);
53 String logEventStr = sysEvent.toString();
54 String logUserStr = commManager.getPanelSettings().getZoneOrUserName(eventZone & 0x000000FF);
56 debug("Event " + i + " zone code", eventZone, logUserStr);
57 debug("Event " + i + " event code", eventType, logEventStr);
59 if (sysEvent.isAlarm() || sysEvent.isSilentAlarm() || sysEvent.isAlert() || sysEvent.isPanic()
60 || sysEvent.isTrouble()) {
61 updatedState.addActiveAlert(eventZone, eventType);
64 if (sysEvent.isAlarm() || (sysEvent.isPanic() && !commManager.getPanelSettings().isSilentPanic())) {
65 updatedState.ringing.setValue(true);
66 updatedState.ringingSince.setValue(System.currentTimeMillis());
69 if (sysEvent.isCancel() || sysEvent.isGeneralRestore() || sysEvent.isReset()) {
70 updatedState.ringing.setValue(false);
73 if (sysEvent.isRestore()) {
74 updatedState.clearActiveAlert(eventZone, sysEvent.getRestoreFor());
77 if (sysEvent.isGeneralRestore() || sysEvent.isReset()) {
78 updatedState.clearAllActiveAlerts();
81 if (sysEvent.isReset()) {
82 updatedState.clearAllActiveAlerts();
83 updatedState.downloadSetupRequired.setValue(true);