/** * Copyright (c) 2010-2016 by the respective copyright holders. * * 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.converter; import java.util.Map; import org.openhab.binding.zwave.internal.converter.state.BigDecimalDecimalTypeConverter; 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.ZWaveThermostatOperatingStateCommandClass; 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; /** * ZWaveThermostatOperatingStateConverter class. Converter for communication with the * {@link ZWaveThermostatOperatingStateCommandClass}. Implements polling of the operating * state and receiving of operating state events. * * @author Dan Cunningham * @since 1.6.0 */ public class ZWaveThermostatOperatingStateConverter extends ZWaveCommandClassConverter<ZWaveThermostatOperatingStateCommandClass> { private static final Logger logger = LoggerFactory.getLogger(ZWaveThermostatOperatingStateConverter.class); private static final int REFRESH_INTERVAL = 0; // refresh interval in seconds for the thermostat setpoint; /** * Constructor. Creates a new instance of the {@link ZWaveThermostatOperatingStateConverter} class. * * @param controller the {@link ZWaveController} to use for sending messages. * @param eventPublisher the {@link EventPublisher} to use to publish events. */ public ZWaveThermostatOperatingStateConverter(ZWaveController controller, EventPublisher eventPublisher) { super(controller, eventPublisher); this.addStateConverter(new BigDecimalDecimalTypeConverter()); } /** * {@inheritDoc} */ @Override SerialMessage executeRefresh(ZWaveNode node, ZWaveThermostatOperatingStateCommandClass 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); } /** * {@inheritDoc} */ @Override void handleEvent(ZWaveCommandClassValueEvent event, Item item, Map<String, String> arguments) { ZWaveStateConverter<?, ?> converter = this.getStateConverter(item, 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 = converter.convertFromValueToState(event.getValue()); this.getEventPublisher().postUpdate(item.getName(), state); } /** * {@inheritDoc} */ @Override void receiveCommand(Item item, Command command, ZWaveNode node, ZWaveThermostatOperatingStateCommandClass commandClass, int endpointId, Map<String, String> arguments) { logger.warn("NODE {}: We do not take commands: item = {}, endpoint = {}, ignoring.", node.getNodeId(), item.getName(), endpointId); } /** * {@inheritDoc} */ @Override int getRefreshInterval() { return REFRESH_INTERVAL; } }