/** * 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.novelanheatpump.internal; import java.util.HashSet; import java.util.Map.Entry; import java.util.Set; import org.openhab.binding.novelanheatpump.HeatPumpBindingProvider; import org.openhab.binding.novelanheatpump.HeatpumpCommandType; import org.openhab.core.binding.BindingConfig; import org.openhab.core.items.Item; import org.openhab.core.library.items.NumberItem; import org.openhab.core.library.items.StringItem; import org.openhab.model.item.binding.AbstractGenericBindingProvider; import org.openhab.model.item.binding.BindingConfigParseException; import org.slf4j.Logger; import org.slf4j.LoggerFactory; /** * <p> * This class can parse information from the generic binding format and * provides Heatpump binding information from it. It registers as a * {@link HeatpumpBindingProvider} service as well. * </p> * * <p> * Here are some examples for valid binding configuration strings: * <ul> * <li><code>{ novelanheatpump="temperature_outside"}</code> - receives status of the external thermometer</li> * <li><code>{ novelanheatpump="temperature_return"}</code> - receives status updates of the return temperature of the * floor heating</li> * <li><code>{ novelanheatpump="temperature_reference_return" }</code> - receives status updates the reference * temperature of the floor heating</li> * <li><code>{ novelanheatpump="temperature_supplay" }</code> - receives status updates the temperature supplayed by * the floor heating</li> * <li><code>{ novelanheatpump="temperature_servicewater_reference" }</code> - receives status updates the reference * temperature of the servicewater</li> * <li><code>{ novelanheatpump="temperature_servicewater" }</code> - receives status updates on the temperature of the * servicewater</li> * <li><code>{ novelanheatpump="temperature_solar_collector" }</code> - receives status updates of the sensor in the * solar collector</li> * <li><code>{ novelanheatpump="temperature_solar_storage" }</code> - receives status updates of the solar storage</li> * <li><code>{ novelanheatpump="state" }</code> - receives status updates of the state (what and since when)</li> * </ul> * </p> * * @author Jan-Philipp Bolle * * @since 1.0.0 */ public class HeatPumpGenericBindingProvider extends AbstractGenericBindingProvider implements HeatPumpBindingProvider { static final Logger logger = LoggerFactory.getLogger(HeatPumpGenericBindingProvider.class); @Override public String getBindingType() { return "novelanheatpump"; } /** * @{inheritDoc} */ @Override public void validateItemType(Item item, String bindingConfig) throws BindingConfigParseException { if (!(item instanceof NumberItem || item instanceof StringItem)) { throw new BindingConfigParseException( "item '" + item.getName() + "' is of type '" + item.getClass().getSimpleName() + "', only Number- and StringItems are allowed - please check your *.items configuration"); } } /** * {@inheritDoc} */ @Override public void processBindingConfiguration(String context, Item item, String heatpumpCommand) throws BindingConfigParseException { super.processBindingConfiguration(context, item, heatpumpCommand); if (heatpumpCommand != null) { HeatPumpBindingConfig config = parseBindingConfig(item, HeatpumpCommandType.fromString(heatpumpCommand)); addBindingConfig(item, config); } else { logger.warn("bindingConfig is NULL (item={}) -> processing bindingConfig aborted!", item); } } /** * Checks if the bindingConfig contains a valid binding type and returns an appropriate instance. * * @param item * @param bindingConfig * * @throws BindingConfigParseException if bindingConfig is no valid binding type */ protected HeatPumpBindingConfig parseBindingConfig(Item item, HeatpumpCommandType bindingConfig) throws BindingConfigParseException { if (HeatpumpCommandType.validateBinding(bindingConfig, item.getClass())) { return new HeatPumpBindingConfig(bindingConfig); } else { throw new BindingConfigParseException("'" + bindingConfig + "' is no valid binding type"); } } @Override public String[] getItemNamesForType(HeatpumpCommandType eventType) { Set<String> itemNames = new HashSet<String>(); for (Entry<String, BindingConfig> entry : bindingConfigs.entrySet()) { HeatPumpBindingConfig heatpumpConfig = (HeatPumpBindingConfig) entry.getValue(); if (heatpumpConfig.getType().equals(eventType)) { itemNames.add(entry.getKey()); } } return itemNames.toArray(new String[itemNames.size()]); } public HeatPumpBindingConfig getHeatPumpBindingConfig(String itemName) { return (HeatPumpBindingConfig) bindingConfigs.get(itemName); } static class HeatPumpBindingConfig implements BindingConfig { final private HeatpumpCommandType type; public HeatPumpBindingConfig(HeatpumpCommandType type) { this.type = type; } public HeatpumpCommandType getType() { return type; } } }