Package org.openhab.binding.zwave.internal.protocol.serialmessage

Source Code of org.openhab.binding.zwave.internal.protocol.serialmessage.DeleteReturnRouteMessageClass

/**
* Copyright (c) 2010-2014, openHAB.org and others.
*
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*/
package org.openhab.binding.zwave.internal.protocol.serialmessage;

import org.openhab.binding.zwave.internal.protocol.SerialMessage;
import org.openhab.binding.zwave.internal.protocol.ZWaveController;
import org.openhab.binding.zwave.internal.protocol.SerialMessage.SerialMessageClass;
import org.openhab.binding.zwave.internal.protocol.SerialMessage.SerialMessagePriority;
import org.openhab.binding.zwave.internal.protocol.SerialMessage.SerialMessageType;
import org.openhab.binding.zwave.internal.protocol.event.ZWaveNetworkEvent;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
* This class processes a serial message from the zwave controller
* @author Chris Jackson
* @since 1.5.0
*/
public class DeleteReturnRouteMessageClass extends ZWaveCommandProcessor {
  private static final Logger logger = LoggerFactory.getLogger(DeleteReturnRouteMessageClass.class);

  public SerialMessage doRequest(int nodeId) {
    logger.debug("NODE {}: Deleting return routes", nodeId);

    // Queue the request
    SerialMessage newMessage = new SerialMessage(SerialMessageClass.DeleteReturnRoute, SerialMessageType.Request,
        SerialMessageClass.DeleteReturnRoute, SerialMessagePriority.High);
    byte[] newPayload = { (byte) nodeId };
    newMessage.setMessagePayload(newPayload);

      return newMessage;
  }
 
  @Override
  public boolean handleResponse(ZWaveController zController, SerialMessage lastSentMessage, SerialMessage incomingMessage) {
    int nodeId = lastSentMessage.getMessagePayloadByte(0);

    logger.debug("NODE {}: Got DeleteReturnRoute response.", nodeId);
    if(incomingMessage.getMessagePayloadByte(0) != 0x00) {
      logger.debug("NODE {}: DeleteReturnRoute command in progress.", nodeId);
    } else {
      logger.error("NODE {}: DeleteReturnRoute command failed.");
      zController.notifyEventListeners(new ZWaveNetworkEvent(ZWaveNetworkEvent.Type.DeleteReturnRoute, nodeId,
          ZWaveNetworkEvent.State.Failure));
    }
   
    return false;
  }

  @Override
  public boolean handleRequest(ZWaveController zController, SerialMessage lastSentMessage, SerialMessage incomingMessage) {
    int nodeId = lastSentMessage.getMessagePayloadByte(0);

    logger.debug("NODE {}: Got DeleteReturnRoute request.", nodeId);
    if(incomingMessage.getMessagePayloadByte(1) != 0x00) {
      logger.error("NODE {}: Delete return routes failed with error 0x{}.", nodeId, Integer.toHexString(incomingMessage.getMessagePayloadByte(0)));

      zController.notifyEventListeners(new ZWaveNetworkEvent(ZWaveNetworkEvent.Type.DeleteReturnRoute, nodeId,
          ZWaveNetworkEvent.State.Failure));
    }
    else {
      zController.notifyEventListeners(new ZWaveNetworkEvent(ZWaveNetworkEvent.Type.DeleteReturnRoute, nodeId,
          ZWaveNetworkEvent.State.Success));
    }
   
    return false;
  }
}
TOP

Related Classes of org.openhab.binding.zwave.internal.protocol.serialmessage.DeleteReturnRouteMessageClass

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.