/** * 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.plex.internal; import java.util.Map.Entry; import java.util.regex.Pattern; import org.openhab.binding.plex.PlexBindingProvider; import org.openhab.core.binding.BindingConfig; import org.openhab.core.items.Item; import org.openhab.core.library.items.DateTimeItem; import org.openhab.core.library.items.DimmerItem; import org.openhab.core.library.items.StringItem; import org.openhab.core.library.items.SwitchItem; 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 is responsible for parsing the Plex binding configuration. * </p> * * <p> * Some valid binding configuration strings: * <ul> * <li><code>{plex="ffffffff-eeee-dddd-cccc-ba9876543210#state"}</code> - State (Stopped, Buffering, Playing or Paused) * of the Plex client * </li> * <li><code>{plex="ffffffff-eeee-dddd-cccc-ba9876543210#playback/progress"}</code> - Progress of the media playing * (percentage) on specific Plex client * </ul> * </p> * * @author Jeroen Idserda * @since 1.7.0 */ public class PlexGenericBindingProvider extends AbstractGenericBindingProvider implements PlexBindingProvider { private static final Logger logger = LoggerFactory.getLogger(PlexGenericBindingProvider.class); private static final Pattern CONFIG_PATTERN = Pattern.compile("^(.)+#(.)+$"); /** * {@inheritDoc} */ @Override public String getBindingType() { return "plex"; } /** * @{inheritDoc} */ @Override public void validateItemType(Item item, String bindingConfig) throws BindingConfigParseException { if (!(item instanceof SwitchItem || item instanceof DimmerItem || item instanceof StringItem || item instanceof DateTimeItem)) { throw new BindingConfigParseException("item '" + item.getName() + "' is of type '" + item.getClass().getSimpleName() + "', only Switch-, Dimmer-, String and DateTimeItems are allowed - please check your *.items configuration"); } } /** * {@inheritDoc} */ @Override public void processBindingConfiguration(String context, Item item, String bindingConfig) throws BindingConfigParseException { super.processBindingConfiguration(context, item, bindingConfig); bindingConfig = bindingConfig.trim(); if (CONFIG_PATTERN.matcher(bindingConfig).matches()) { PlexBindingConfig config = new PlexBindingConfig(); String fields[] = bindingConfig.split("#"); config.setItemName(item.getName()); config.setMachineIdentifier(fields[0]); config.setProperty(fields[1]); logger.info("Plex item {} bound to client {} property {}", config.getItemName(), config.getMachineIdentifier(), config.getProperty()); addBindingConfig(item, config); } else { logger.error("Item config {} does not match <player-id>#<property> pattern", bindingConfig); } } @Override public PlexBindingConfig getConfig(String machineIdentifier, String property) { for (Entry<String, BindingConfig> entry : bindingConfigs.entrySet()) { PlexBindingConfig config = (PlexBindingConfig) entry.getValue(); if (config.getMachineIdentifier().equals(machineIdentifier) && config.getProperty().equals(property)) { return config; } } return null; } @Override public PlexBindingConfig getConfig(String itemName) { for (Entry<String, BindingConfig> entry : bindingConfigs.entrySet()) { PlexBindingConfig config = (PlexBindingConfig) entry.getValue(); if (config.getItemName().equals(itemName)) { return config; } } return null; } }