]> git.basschouten.com Git - openhab-addons.git/blob
260449f3b0ade962b5512fbf02ba58842416f14f
[openhab-addons.git] /
1 /**
2  * Copyright (c) 2010-2021 Contributors to the openHAB project
3  *
4  * See the NOTICE file(s) distributed with this work for additional
5  * information.
6  *
7  * This program and the accompanying materials are made available under the
8  * terms of the Eclipse Public License 2.0 which is available at
9  * http://www.eclipse.org/legal/epl-2.0
10  *
11  * SPDX-License-Identifier: EPL-2.0
12  */
13 package org.openhab.binding.miele.internal.handler;
14
15 import org.openhab.binding.miele.internal.handler.MieleBridgeHandler.DeviceMetaData;
16 import org.openhab.core.types.State;
17 import org.openhab.core.types.Type;
18
19 /**
20  * The {@link ApplianceChannelSelector} class defines a common interface for
21  * all the data structures used by appliance thing handlers. It is used to traverse
22  * the channels that possibly exist for an appliance, and convert data
23  * returned by the appliance to a compatible State
24  *
25  * @author Karel Goderis - Initial contribution
26  * @author Jacob Laursen - Added power/water consumption channels
27  */
28 public interface ApplianceChannelSelector {
29
30     @Override
31     String toString();
32
33     /**
34      * Returns the ChannelID for the given datapoint
35      */
36     String getChannelID();
37
38     /**
39      * Returns the Miele defined ID for the given datapoint
40      */
41     String getMieleID();
42
43     /**
44      * Returns true if the given datapoint is to be considered as a Property
45      * instead of a regular modifiable datapoint
46      */
47     boolean isProperty();
48
49     /**
50      * Returns true if the given channel is extracted from extended
51      * state information
52      */
53     boolean isExtendedState();
54
55     /**
56      *
57      * Returns a State for the given string, taking into
58      * account the metadata provided. The meta data is sent by
59      * the Miele appliance and is used to decide the State type
60      *
61      * @param s - the value to be used to instantiate the State
62      * @param dmd - the device meta data
63      */
64     State getState(String s, DeviceMetaData dmd);
65
66     /**
67      * Returns "compatible" Type for this datapoint
68      */
69     Class<? extends Type> getTypeClass();
70 }