Search in sources :

Example 1 with VariableConfig

use of org.openhab.binding.homematic.internal.config.binding.VariableConfig in project openhab1-addons by openhab.

the class HomematicCommunicator method event.

/**
     * Receives a message from the Homematic server and publishes the state to
     * openHAB.
     */
@Override
public void event(String interfaceId, String addressWithChannel, String parameter, Object value) {
    boolean isVariable = "".equals(addressWithChannel);
    HomematicBindingConfig bindingConfig = null;
    if (isVariable) {
        bindingConfig = new VariableConfig(parameter);
    } else {
        bindingConfig = new DatapointConfig(HmInterface.parse(interfaceId), addressWithChannel, parameter);
    }
    String className = value == null ? "Unknown" : value.getClass().getSimpleName();
    logger.debug("Received new ({}) value '{}' for {}", className, value, bindingConfig);
    lastEventTime = System.currentTimeMillis();
    final Event event = new Event(bindingConfig, value);
    if (sentPressEvents.remove(event.getBindingConfig())) {
        logger.debug("Echo PRESS_* event detected, ignoring: {}", event.getBindingConfig());
    } else {
        if (context.getStateHolder().isDatapointReloadInProgress() && !isVariable) {
            context.getStateHolder().addToRefreshCache(event.getBindingConfig(), event.getNewValue());
        }
        event.setHmValueItem(context.getStateHolder().getState(event.getBindingConfig()));
        if (event.getHmValueItem() != null) {
            event.getHmValueItem().setValue(event.getNewValue());
            new ProviderItemIterator().iterate(event.getBindingConfig(), new ProviderItemIteratorCallback() {

                @Override
                public void next(HomematicBindingConfig providerBindingConfig, Item item, Converter<?> converter) {
                    State state = converter.convertFromBinding(event.getHmValueItem());
                    context.getEventPublisher().postUpdate(item.getName(), state);
                    if (state == OnOffType.ON) {
                        executeBindingAction(providerBindingConfig);
                        if (event.isPressValueItem()) {
                            itemDisabler.add(providerBindingConfig);
                        }
                    }
                }
            });
        } else {
            logger.warn("Can't find {}, value is not published to openHAB!", event.getBindingConfig());
        }
    }
}
Also used : VariableConfig(org.openhab.binding.homematic.internal.config.binding.VariableConfig) HmValueItem(org.openhab.binding.homematic.internal.model.HmValueItem) Item(org.openhab.core.items.Item) HomematicBindingConfig(org.openhab.binding.homematic.internal.config.binding.HomematicBindingConfig) State(org.openhab.core.types.State) ProviderItemIteratorCallback(org.openhab.binding.homematic.internal.communicator.ProviderItemIterator.ProviderItemIteratorCallback) DatapointConfig(org.openhab.binding.homematic.internal.config.binding.DatapointConfig)

Example 2 with VariableConfig

use of org.openhab.binding.homematic.internal.config.binding.VariableConfig in project openhab1-addons by openhab.

the class BindingConfigParser method parse.

/**
     * Parses the bindingConfig of an item and returns a HomematicBindingConfig.
     */
public HomematicBindingConfig parse(Item item, String bindingConfig) throws BindingConfigParseException {
    bindingConfig = StringUtils.trimToEmpty(bindingConfig);
    bindingConfig = StringUtils.removeStart(bindingConfig, "{");
    bindingConfig = StringUtils.removeEnd(bindingConfig, "}");
    String[] entries = bindingConfig.split("[,]");
    HomematicBindingConfigHelper helper = new HomematicBindingConfigHelper();
    for (String entry : entries) {
        String[] entryParts = StringUtils.trimToEmpty(entry).split("[=]");
        if (entryParts.length != 2) {
            throw new BindingConfigParseException("Each entry must have a key and a value");
        }
        String key = StringUtils.trim(entryParts[0]);
        // convert entry id to device if necessary
        if ("id".equalsIgnoreCase(key)) {
            logger.info("Please change the Homematic binding with the attribute 'id' to 'address' in entry: " + entry + " -> " + StringUtils.replace(entry, "id=", "address="));
            key = "address";
        }
        String value = StringUtils.trim(entryParts[1]);
        value = StringUtils.removeStart(value, "\"");
        value = StringUtils.removeEnd(value, "\"");
        try {
            helper.getClass().getDeclaredField(key).set(helper, value);
        } catch (Exception e) {
            throw new BindingConfigParseException("Could not set value " + value + " for attribute " + key);
        }
    }
    Converter<?> converter = null;
    // if (helper.isValidDatapoint() || helper.isValidVariable()) {
    // converter = instantiateConverter(helper.converter);
    // }
    BindingAction bindingAction = getBindingAction(item, helper.action);
    if (helper.isValidDatapoint()) {
        return new DatapointConfig(helper.address, helper.channel, helper.parameter, converter, bindingAction, helper.isForceUpdate(), NumberUtils.toDouble(helper.delay));
    } else if (helper.isValidVariable()) {
        return new VariableConfig(helper.variable, converter, bindingAction, helper.isForceUpdate(), NumberUtils.toDouble(helper.delay));
    } else if (helper.isValidProgram()) {
        if (!acceptsOnOffType(item)) {
            throw new BindingConfigParseException("Programs can only be attached to items which accepts OnOffType commands, ignoring item " + item.getName());
        }
        return new ProgramConfig(helper.program, bindingAction);
    } else if (bindingAction != null) {
        return new ActionConfig(bindingAction);
    } else {
        throw new BindingConfigParseException("Invalid binding: " + bindingConfig);
    }
}
Also used : VariableConfig(org.openhab.binding.homematic.internal.config.binding.VariableConfig) ActionConfig(org.openhab.binding.homematic.internal.config.binding.ActionConfig) BindingConfigParseException(org.openhab.model.item.binding.BindingConfigParseException) DatapointConfig(org.openhab.binding.homematic.internal.config.binding.DatapointConfig) BindingAction(org.openhab.binding.homematic.internal.config.BindingAction) ProgramConfig(org.openhab.binding.homematic.internal.config.binding.ProgramConfig) BindingConfigParseException(org.openhab.model.item.binding.BindingConfigParseException)

Example 3 with VariableConfig

use of org.openhab.binding.homematic.internal.config.binding.VariableConfig in project openhab1-addons by openhab.

the class CcuClient method iterateAllVariables.

/**
     * {@inheritDoc}
     */
@Override
public void iterateAllVariables(HmValueItemIteratorCallback callback) throws HomematicClientException {
    List<HmVariable> variables = sendScriptByName("getAllVariables", HmVariableList.class).getVariables();
    for (HmVariable variable : variables) {
        VariableConfig bindingConfig = new VariableConfig(variable.getName());
        callback.iterate(bindingConfig, variable);
    }
}
Also used : VariableConfig(org.openhab.binding.homematic.internal.config.binding.VariableConfig) HmVariableList(org.openhab.binding.homematic.internal.model.HmVariableList) HmVariable(org.openhab.binding.homematic.internal.model.HmVariable)

Example 4 with VariableConfig

use of org.openhab.binding.homematic.internal.config.binding.VariableConfig in project openhab1-addons by openhab.

the class HomegearClient method iterateAllVariables.

/**
     * {@inheritDoc}
     */
@Override
public void iterateAllVariables(HmValueItemIteratorCallback callback) throws HomematicClientException {
    Map<String, ?> result = rpcClient.getAllSystemVariables(getDefaultInterface());
    for (String variableName : result.keySet()) {
        HmVariable variable = createVariable(variableName, result.get(variableName));
        VariableConfig bindingConfig = new VariableConfig(variable.getName());
        callback.iterate(bindingConfig, variable);
    }
}
Also used : VariableConfig(org.openhab.binding.homematic.internal.config.binding.VariableConfig) HmVariable(org.openhab.binding.homematic.internal.model.HmVariable)

Aggregations

VariableConfig (org.openhab.binding.homematic.internal.config.binding.VariableConfig)4 DatapointConfig (org.openhab.binding.homematic.internal.config.binding.DatapointConfig)2 HmVariable (org.openhab.binding.homematic.internal.model.HmVariable)2 ProviderItemIteratorCallback (org.openhab.binding.homematic.internal.communicator.ProviderItemIterator.ProviderItemIteratorCallback)1 BindingAction (org.openhab.binding.homematic.internal.config.BindingAction)1 ActionConfig (org.openhab.binding.homematic.internal.config.binding.ActionConfig)1 HomematicBindingConfig (org.openhab.binding.homematic.internal.config.binding.HomematicBindingConfig)1 ProgramConfig (org.openhab.binding.homematic.internal.config.binding.ProgramConfig)1 HmValueItem (org.openhab.binding.homematic.internal.model.HmValueItem)1 HmVariableList (org.openhab.binding.homematic.internal.model.HmVariableList)1 Item (org.openhab.core.items.Item)1 State (org.openhab.core.types.State)1 BindingConfigParseException (org.openhab.model.item.binding.BindingConfigParseException)1