/** * Copyright (c) 2010-2017 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.cups.internal; import org.apache.commons.lang.StringUtils; import org.cups4j.WhichJobsEnum; import org.openhab.binding.cups.CupsBindingProvider; import org.openhab.core.binding.BindingConfig; import org.openhab.core.items.Item; import org.openhab.core.library.items.NumberItem; import org.openhab.model.item.binding.AbstractGenericBindingProvider; import org.openhab.model.item.binding.BindingConfigParseException; import org.slf4j.Logger; import org.slf4j.LoggerFactory; /** * This class can parse information from the generic binding format and * provides Cups binding information from it. It registers as a * {@link CupsBindingProvider} service as well. * * The syntax of the binding configuration strings accepted is the following: * * <code> * cups="printerName" * </code> * * @author Tobias Bräutigam * @since 1.1.0 */ public class CupsGenericBindingProvider extends AbstractGenericBindingProvider implements CupsBindingProvider { private static final Logger logger = LoggerFactory.getLogger(CupsGenericBindingProvider.class); /** * {@inheritDoc} */ @Override public String getBindingType() { return "cups"; } /** * {@inheritDoc} */ @Override public void validateItemType(Item item, String bindingConfig) throws BindingConfigParseException { if (!(item instanceof NumberItem)) { throw new BindingConfigParseException( "Item '" + item.getName() + "' is of type '" + item.getClass().getSimpleName() + "'. Only NumberItems are allowed - please check your *.items configuration"); } } /** * {@inheritDoc} */ @Override public void processBindingConfiguration(String context, Item item, String bindingConfig) throws BindingConfigParseException { CupsBindingConfig config = new CupsBindingConfig(); String[] parts = bindingConfig.trim().split("#"); config.printerName = parts[0]; if (parts.length == 2) { try { config.whichJobs = Enum.valueOf(WhichJobsEnum.class, parts[1].toUpperCase()); } catch (IllegalArgumentException e) { throw new BindingConfigParseException("WhichJobs Part '" + parts[1] + "' is unknown. Use one of " + StringUtils.join(WhichJobsEnum.values(), ", ") + "."); } catch (NullPointerException e) { // empty WhichJobs-Part -> use default config.whichJobs = WhichJobsEnum.NOT_COMPLETED; } } addBindingConfig(item, config); } /** * {@inheritDoc} */ @Override public String getPrinterName(String itemName) { CupsBindingConfig config = (CupsBindingConfig) bindingConfigs.get(itemName); return config != null ? config.printerName : null; } /** * {@inheritDoc} */ @Override public WhichJobsEnum getWhichJobs(String itemName) { CupsBindingConfig config = (CupsBindingConfig) bindingConfigs.get(itemName); return config != null ? config.whichJobs : WhichJobsEnum.NOT_COMPLETED; } /** * This is an internal data structure to store information from the binding * config strings and use it to answer the requests to the Cups binding * provider. * * @author Tobias Bräutigam */ static private class CupsBindingConfig implements BindingConfig { public String printerName; public WhichJobsEnum whichJobs = WhichJobsEnum.NOT_COMPLETED; } }