package org.openhab.binding.zwave.internal.converter;
import java.util.Map;
import org.openhab.binding.zwave.internal.converter.command.BinaryOnOffCommandConverter;
import org.openhab.binding.zwave.internal.converter.command.ZWaveCommandConverter;
import org.openhab.binding.zwave.internal.converter.state.IntegerOnOffTypeConverter;
import org.openhab.binding.zwave.internal.converter.state.IntegerOpenClosedTypeConverter;
import org.openhab.binding.zwave.internal.converter.state.StringStringTypeConverter;
import org.openhab.binding.zwave.internal.converter.state.ZWaveStateConverter;
import org.openhab.binding.zwave.internal.protocol.SerialMessage;
import org.openhab.binding.zwave.internal.protocol.ZWaveController;
import org.openhab.binding.zwave.internal.protocol.ZWaveNode;
import org.openhab.binding.zwave.internal.protocol.commandclass.ZWaveBarrierOperatorCommandClass;
import org.openhab.binding.zwave.internal.protocol.commandclass.ZWaveBarrierOperatorCommandClass.BarrierOperatorStateType;
import org.openhab.binding.zwave.internal.protocol.commandclass.ZWaveBarrierOperatorCommandClass.ZWaveBarrierOperatorValueEvent;
import org.openhab.binding.zwave.internal.protocol.event.ZWaveCommandClassValueEvent;
import org.openhab.core.events.EventPublisher;
import org.openhab.core.items.Item;
import org.openhab.core.types.Command;
import org.openhab.core.types.State;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class ZWaveBarrierOperatorConverter extends ZWaveCommandClassConverter<ZWaveBarrierOperatorCommandClass> {
private static final Logger logger = LoggerFactory.getLogger(ZWaveBarrierOperatorConverter.class);
private static final int REFRESH_INTERVAL = 10;
public ZWaveBarrierOperatorConverter(ZWaveController controller, EventPublisher eventPublisher) {
super(controller, eventPublisher);
this.addStateConverter(new StringStringTypeConverter());
this.addStateConverter(new IntegerOpenClosedTypeConverter());
this.addStateConverter(new IntegerOnOffTypeConverter());
this.addCommandConverter(new BinaryOnOffCommandConverter());
}
@Override
SerialMessage executeRefresh(ZWaveNode node, ZWaveBarrierOperatorCommandClass commandClass, int endpointId,
Map<String, String> arguments) {
logger.debug("NODE {}: Generating poll message for {}, endpoint {}", node.getNodeId(),
commandClass.getCommandClass().getLabel(), endpointId);
return node.encapsulate(commandClass.getValueMessage(), commandClass, endpointId);
}
@Override
void handleEvent(ZWaveCommandClassValueEvent event, Item item, Map<String, String> arguments) {
ZWaveStateConverter<?, ?> converter = this.getStateConverter(item, event.getValue());
BarrierOperatorStateType barrierOperatorState = null;
if (event instanceof ZWaveBarrierOperatorValueEvent) {
barrierOperatorState = ((ZWaveBarrierOperatorValueEvent) event).getBarrierState();
if (converter == null) {
converter = this.getStateConverter(item, barrierOperatorState.getLabel());
}
}
logger.debug("NODE {}: Converter for for item = {}, event value = {}", event.getNodeId(), item.getName(),
event.getValue());
if (converter == null) {
logger.warn("NODE {}: No converter found for item = {}, endpoint = {}, ignoring event.", event.getNodeId(),
item.getName(), event.getEndpoint());
return;
}
State state = null;
if (converter instanceof StringStringTypeConverter && barrierOperatorState != null) {
barrierOperatorState = ((ZWaveBarrierOperatorValueEvent) event).getBarrierState();
if (barrierOperatorState == BarrierOperatorStateType.STATE_STOPPED) {
state = converter.convertFromValueToState(
barrierOperatorState.getLabel() + " - " + barrierOperatorState.getValue() + "%");
} else {
state = converter
.convertFromValueToState(((ZWaveBarrierOperatorValueEvent) event).getBarrierState().getLabel());
}
} else {
state = converter.convertFromValueToState(event.getValue());
}
this.getEventPublisher().postUpdate(item.getName(), state);
}
@Override
void receiveCommand(Item item, Command command, ZWaveNode node, ZWaveBarrierOperatorCommandClass commandClass,
int endpointId, Map<String, String> arguments) {
ZWaveCommandConverter<?, ?> converter = this.getCommandConverter(command.getClass());
if (converter == null) {
logger.warn("NODE {}: No converter found for item = {}, endpoint = {}, ignoring command.", node.getNodeId(),
item.getName(), endpointId);
return;
}
SerialMessage serialMessage = node.encapsulate(
commandClass.setValueMessage((Integer) converter.convertFromCommandToValue(item, command)),
commandClass, endpointId);
if (serialMessage == null) {
logger.warn("NODE {}: Generating message failed for command class = {}, endpoint = {}", node.getNodeId(),
commandClass.getCommandClass().getLabel(), endpointId);
return;
}
this.getController().sendData(serialMessage);
if (command instanceof State) {
this.getEventPublisher().postUpdate(item.getName(), (State) command);
}
}
@Override
int getRefreshInterval() {
return REFRESH_INTERVAL;
}
}