diff --git a/addons/binding/org.openhab.binding.networkhealth/.classpath b/addons/binding/org.openhab.binding.network/.classpath similarity index 100% rename from addons/binding/org.openhab.binding.networkhealth/.classpath rename to addons/binding/org.openhab.binding.network/.classpath diff --git a/addons/binding/org.openhab.binding.networkhealth/.project b/addons/binding/org.openhab.binding.network/.project similarity index 93% rename from addons/binding/org.openhab.binding.networkhealth/.project rename to addons/binding/org.openhab.binding.network/.project index 9c8b1faefa3c3..699a57154798c 100644 --- a/addons/binding/org.openhab.binding.networkhealth/.project +++ b/addons/binding/org.openhab.binding.network/.project @@ -1,6 +1,6 @@ - org.openhab.binding.networkhealth + org.openhab.binding.network diff --git a/addons/binding/org.openhab.binding.networkhealth/ESH-INF/binding/binding.xml b/addons/binding/org.openhab.binding.network/ESH-INF/binding/binding.xml similarity index 66% rename from addons/binding/org.openhab.binding.networkhealth/ESH-INF/binding/binding.xml rename to addons/binding/org.openhab.binding.network/ESH-INF/binding/binding.xml index 98b8b55ab9ab0..aadc4d55dfe7d 100644 --- a/addons/binding/org.openhab.binding.networkhealth/ESH-INF/binding/binding.xml +++ b/addons/binding/org.openhab.binding.network/ESH-INF/binding/binding.xml @@ -1,11 +1,11 @@ - - NetworkHealth Binding - The Network Health Binding checks if a Device is currently on the Network or not + Network Binding + The Network Binding checks if a Device is currently on the Network or not Marc Mettke diff --git a/addons/binding/org.openhab.binding.network/ESH-INF/i18n/network_de.properties b/addons/binding/org.openhab.binding.network/ESH-INF/i18n/network_de.properties new file mode 100644 index 0000000000000..908e76006b71f --- /dev/null +++ b/addons/binding/org.openhab.binding.network/ESH-INF/i18n/network_de.properties @@ -0,0 +1,23 @@ +# binding +binding.network.name = Network Binding +binding.network.description = Das Network Binding überprüft, ob sich ein Geräte aktuell im Netzwerk befindet oder nicht. + +# thing types +thing-type.network.device.label = Netzgerät +thing-type.network.device.description = Das Netzwerkgerät muss mit dem gleichen Netzwerk verbunden sein wie OpenHAB +thing-type.config.network.device.hostname.label = Hostname oder IP +thing-type.config.network.device.hostname.description = Hostname oder IP des Netzwerkgerätes +thing-type.config.network.device.port.label = Port +thing-type.config.network.device.port.description = Der Port an dem das Gerät erreichbar ist. +thing-type.config.network.device.retry.label = Wiederholen +thing-type.config.network.device.retry.description = Gibt an, wie oft der PING wiederholt werden soll, bevor das Gerät als offline markiert wird. +thing-type.config.network.device.timeout.label = Zeitlimit +thing-type.config.network.device.timeout.description = Gibt an, wie lange maximal gewartet werden soll (in ms), bis ein Gerät als nicht vorhanden gekenntzeichnet wird. +thing-type.config.network.device.refresh_interval.label = Aktualisierungsintervall +thing-type.config.network.device.refresh_interval.description = Spezifiziert den Aktualisierungsintervall (in ms) +thing-type.config.network.device.use_system_ping.label = System Ping +thing-type.config.network.device.use_system_ping.description = Nutzt das Ping Programm des Systems + +# channel types +channel-type.network.online.label = Online +channel-type.network.online.description = Gibt an ob das Gerät aktuell Online oder Offline ist. diff --git a/addons/binding/org.openhab.binding.networkhealth/ESH-INF/thing/thing-types.xml b/addons/binding/org.openhab.binding.network/ESH-INF/thing/thing-types.xml similarity index 63% rename from addons/binding/org.openhab.binding.networkhealth/ESH-INF/thing/thing-types.xml rename to addons/binding/org.openhab.binding.network/ESH-INF/thing/thing-types.xml index 01a7f17fa1f2e..123e9abdb4284 100644 --- a/addons/binding/org.openhab.binding.networkhealth/ESH-INF/thing/thing-types.xml +++ b/addons/binding/org.openhab.binding.network/ESH-INF/thing/thing-types.xml @@ -1,8 +1,8 @@ - + xsi:schemaLocation="http://eclipse.org/smarthome/schemas/thing-description/v1.0.0 http://eclipse.org/smarthome/schemas/thing-description-1.0.0.xsd"> Device which must be connected to the same Network as OpenHAB @@ -11,10 +11,9 @@ - + Hostname or IP of the Device - true @@ -23,17 +22,29 @@ 0 + + + Defines how many times a ping shall occur, before the device is stated as offline + 1 + + - States how long to wait, if a connection can not be established + States how long to wait (in ms), if a connection can not be established. If system ping is used, only full seconds are valid. 5000 - States how often a refresh shall occur + States how often a refresh shall occur (in ms) 60000 - + + + + + Uses the Ping Program from the System + false + @@ -45,6 +56,7 @@ Network Device + diff --git a/addons/binding/org.openhab.binding.networkhealth/META-INF/MANIFEST.MF b/addons/binding/org.openhab.binding.network/META-INF/MANIFEST.MF similarity index 72% rename from addons/binding/org.openhab.binding.networkhealth/META-INF/MANIFEST.MF rename to addons/binding/org.openhab.binding.network/META-INF/MANIFEST.MF index 5a74e57595adf..7f371e405229c 100644 --- a/addons/binding/org.openhab.binding.networkhealth/META-INF/MANIFEST.MF +++ b/addons/binding/org.openhab.binding.network/META-INF/MANIFEST.MF @@ -1,7 +1,7 @@ Manifest-Version: 1.0 Bundle-ManifestVersion: 2 -Bundle-Name: NetworkHealth Binding -Bundle-SymbolicName: org.openhab.binding.networkhealth;singleton:=true +Bundle-Name: Network Binding +Bundle-SymbolicName: org.openhab.binding.network;singleton:=true Bundle-Vendor: openHAB Bundle-Version: 2.0.0.qualifier Bundle-RequiredExecutionEnvironment: JavaSE-1.7 @@ -17,5 +17,6 @@ Import-Package: com.google.common.collect, org.eclipse.smarthome.io.net.actions, org.slf4j Service-Component: OSGI-INF/* -Export-Package: org.openhab.binding.networkhealth, - org.openhab.binding.networkhealth.handler +Export-Package: org.openhab.binding.network, + org.openhab.binding.network.handler +Require-Bundle: org.apache.commons.lang diff --git a/addons/binding/org.openhab.binding.networkhealth/OSGI-INF/NetworkHealthDiscovery.xml b/addons/binding/org.openhab.binding.network/OSGI-INF/NetworkDiscovery.xml similarity index 65% rename from addons/binding/org.openhab.binding.networkhealth/OSGI-INF/NetworkHealthDiscovery.xml rename to addons/binding/org.openhab.binding.network/OSGI-INF/NetworkDiscovery.xml index 267bd01407a6f..8853c4132297d 100644 --- a/addons/binding/org.openhab.binding.networkhealth/OSGI-INF/NetworkHealthDiscovery.xml +++ b/addons/binding/org.openhab.binding.network/OSGI-INF/NetworkDiscovery.xml @@ -1,6 +1,6 @@ - - + + diff --git a/addons/binding/org.openhab.binding.networkhealth/OSGI-INF/NetworkHealthHandlerFactory.xml b/addons/binding/org.openhab.binding.network/OSGI-INF/NetworkHandlerFactory.xml similarity index 74% rename from addons/binding/org.openhab.binding.networkhealth/OSGI-INF/NetworkHealthHandlerFactory.xml rename to addons/binding/org.openhab.binding.network/OSGI-INF/NetworkHandlerFactory.xml index 13de06036f753..002cad1c798ca 100644 --- a/addons/binding/org.openhab.binding.networkhealth/OSGI-INF/NetworkHealthHandlerFactory.xml +++ b/addons/binding/org.openhab.binding.network/OSGI-INF/NetworkHandlerFactory.xml @@ -8,9 +8,9 @@ http://www.eclipse.org/legal/epl-v10.html --> - + - + diff --git a/addons/binding/org.openhab.binding.networkhealth/build.properties b/addons/binding/org.openhab.binding.network/build.properties similarity index 100% rename from addons/binding/org.openhab.binding.networkhealth/build.properties rename to addons/binding/org.openhab.binding.network/build.properties diff --git a/addons/binding/org.openhab.binding.networkhealth/pom.xml b/addons/binding/org.openhab.binding.network/pom.xml similarity index 69% rename from addons/binding/org.openhab.binding.networkhealth/pom.xml rename to addons/binding/org.openhab.binding.network/pom.xml index 8476678ffc7e4..74b71302d965b 100644 --- a/addons/binding/org.openhab.binding.networkhealth/pom.xml +++ b/addons/binding/org.openhab.binding.network/pom.xml @@ -10,15 +10,15 @@ - org.openhab.binding.networkhealth - org.openhab.binding.networkhealth + org.openhab.binding.network + org.openhab.binding.network org.openhab.binding - org.openhab.binding.networkhealth + org.openhab.binding.network 2.0.0-SNAPSHOT - NetworkHealth Binding + Network Binding eclipse-plugin diff --git a/addons/binding/org.openhab.binding.networkhealth/src/main/java/org/openhab/binding/networkhealth/NetworkHealthBindingConstants.java b/addons/binding/org.openhab.binding.network/src/main/java/org/openhab/binding/network/NetworkBindingConstants.java similarity index 76% rename from addons/binding/org.openhab.binding.networkhealth/src/main/java/org/openhab/binding/networkhealth/NetworkHealthBindingConstants.java rename to addons/binding/org.openhab.binding.network/src/main/java/org/openhab/binding/network/NetworkBindingConstants.java index 68f7daf3b6982..3f2e43c0d1565 100644 --- a/addons/binding/org.openhab.binding.networkhealth/src/main/java/org/openhab/binding/networkhealth/NetworkHealthBindingConstants.java +++ b/addons/binding/org.openhab.binding.network/src/main/java/org/openhab/binding/network/NetworkBindingConstants.java @@ -5,7 +5,7 @@ * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/epl-v10.html */ -package org.openhab.binding.networkhealth; +package org.openhab.binding.network; import java.util.Collections; import java.util.Set; @@ -13,14 +13,14 @@ import org.eclipse.smarthome.core.thing.ThingTypeUID; /** - * The {@link NetworkHealthBindingConstants} class defines common constants, which are + * The {@link NetworkBindingConstants} class defines common constants, which are * used across the whole binding. * * @author Marc Mettke - Initial contribution */ -public class NetworkHealthBindingConstants { +public class NetworkBindingConstants { - public static final String BINDING_ID = "networkhealth"; + public static final String BINDING_ID = "network"; // List of all Thing Type UIDs public final static ThingTypeUID THING_TYPE_DEVICE = new ThingTypeUID(BINDING_ID, "device"); @@ -31,8 +31,10 @@ public class NetworkHealthBindingConstants { // List of all Parameters public final static String PARAMETER_HOSTNAME = "hostname"; public final static String PARAMETER_PORT = "port"; + public final static String PARAMETER_RETRY = "retry"; public final static String PARAMETER_TIMEOUT = "timeout"; public final static String PARAMETER_REFRESH_INTERVAL = "refresh_interval"; + public final static String PARAMETER_USE_SYSTEM_PING = "use_system_ping"; public final static Set SUPPORTED_THING_TYPES_UIDS = Collections.singleton(THING_TYPE_DEVICE); diff --git a/addons/binding/org.openhab.binding.network/src/main/java/org/openhab/binding/network/discovery/NetworkDiscoveryService.java b/addons/binding/org.openhab.binding.network/src/main/java/org/openhab/binding/network/discovery/NetworkDiscoveryService.java new file mode 100644 index 0000000000000..422f477b9c6b9 --- /dev/null +++ b/addons/binding/org.openhab.binding.network/src/main/java/org/openhab/binding/network/discovery/NetworkDiscoveryService.java @@ -0,0 +1,75 @@ +/** + * Copyright (c) 2014 openHAB UG (haftungsbeschraenkt) and others. + * 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.network.discovery; + +import static org.openhab.binding.network.NetworkBindingConstants.*; + +import java.util.HashMap; +import java.util.Map; +import java.util.Set; + +import org.openhab.binding.network.service.DiscoveryCallback; +import org.eclipse.smarthome.core.thing.ThingTypeUID; +import org.eclipse.smarthome.core.thing.ThingUID; +import org.eclipse.smarthome.config.discovery.AbstractDiscoveryService; +import org.eclipse.smarthome.config.discovery.DiscoveryResult; +import org.eclipse.smarthome.config.discovery.DiscoveryResultBuilder; +import org.openhab.binding.network.service.NetworkService; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; + +/** + * The {@link NetworkDiscoveryService} is responsible for discovering devices on + * the current Network. It uses every Network Interface which is connect to a Network + * + * @author Marc Mettke - Initial contribution + */ +public class NetworkDiscoveryService extends AbstractDiscoveryService { + private final Logger logger = LoggerFactory.getLogger(NetworkDiscoveryService.class); + + public NetworkDiscoveryService() { + super(SUPPORTED_THING_TYPES_UIDS, 300, false); + } + + public Set getSupportedThingTypes() { + return SUPPORTED_THING_TYPES_UIDS; + } + + @Override + protected void startScan() { + logger.debug("Starting Discovery"); + NetworkService.discoverNetwork(new DiscoveryCallback() { + @Override + public void newDevice(String ip) { + submitDiscoveryResults(ip); + } + }, scheduler); + } + + /** + * Submit the discovered Devices to the Smarthome inbox, + * + * @param ip The Device IP + */ + private void submitDiscoveryResults(String ip) { + + // uid must not contains dots + ThingUID uid = new ThingUID(THING_TYPE_DEVICE, ip.replace('.', '_') ); + + if(uid!=null) { + Map properties = new HashMap<>(1); + properties.put(PARAMETER_HOSTNAME ,ip); + DiscoveryResult result = DiscoveryResultBuilder.create(uid) + .withProperties(properties) + .withLabel("Network Device (" + ip +")").build(); + thingDiscovered(result); + } + + } + +} diff --git a/addons/binding/org.openhab.binding.network/src/main/java/org/openhab/binding/network/handler/NetworkHandler.java b/addons/binding/org.openhab.binding.network/src/main/java/org/openhab/binding/network/handler/NetworkHandler.java new file mode 100644 index 0000000000000..27a652c509157 --- /dev/null +++ b/addons/binding/org.openhab.binding.network/src/main/java/org/openhab/binding/network/handler/NetworkHandler.java @@ -0,0 +1,119 @@ +/** + * Copyright (c) 2014 openHAB UG (haftungsbeschraenkt) and others. + * 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.network.handler; + +import static org.openhab.binding.network.NetworkBindingConstants.*; + +import java.util.concurrent.ScheduledFuture; +import java.util.concurrent.TimeUnit; + +import org.eclipse.smarthome.config.core.Configuration; +import org.eclipse.smarthome.core.library.types.OnOffType; +import org.eclipse.smarthome.core.thing.ChannelUID; +import org.eclipse.smarthome.core.thing.Thing; +import org.eclipse.smarthome.core.thing.ThingStatus; +import org.eclipse.smarthome.core.thing.binding.BaseThingHandler; +import org.eclipse.smarthome.core.types.Command; +import org.eclipse.smarthome.core.types.RefreshType; +import org.eclipse.smarthome.core.types.State; +import org.openhab.binding.network.service.InvalidConfigurationException; +import org.openhab.binding.network.service.NetworkService; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; + +/** + * The {@link NetworkHandler} is responsible for handling commands, which are + * sent to one of the channels. + * + * @author Marc Mettke - Initial contribution + */ +public class NetworkHandler extends BaseThingHandler { + private Logger logger = LoggerFactory.getLogger(NetworkHandler.class); + private ScheduledFuture refreshJob; + private NetworkService networkService; + + public NetworkHandler(Thing thing) { + super(thing); + } + + + @Override + public void dispose() { + refreshJob.cancel(true); + } + + @Override + public void handleCommand(ChannelUID channelUID, Command command) { + if (command instanceof RefreshType) { + switch (channelUID.getId()) { + case CHANNEL_ONLINE: + try { + State state = networkService.updateDeviceState() ? OnOffType.ON : OnOffType.OFF; + updateState(CHANNEL_ONLINE, state); + } catch( InvalidConfigurationException invalidConfigurationException) { + getThing().setStatus(ThingStatus.OFFLINE); + } + break; + default: + logger.debug("Command received for an unknown channel: {}", channelUID.getId()); + break; + } + } else { + logger.debug("Command {} is not supported for channel: {}", command, channelUID.getId()); + } + } + + @Override + public void initialize() { + logger.debug("Initializing Network handler."); + this.networkService = new NetworkService(); + Configuration conf = this.getConfig(); + + super.initialize(); + + networkService.setHostname(String.valueOf(conf.get(PARAMETER_HOSTNAME))); + + try { + networkService.setPort(Integer.parseInt(String.valueOf(conf.get(PARAMETER_PORT)))); + } catch (Exception ex) {} + + try { + networkService.setRetry(Integer.parseInt(String.valueOf(conf.get(PARAMETER_RETRY)))); + } catch (Exception ex) {} + + try { + networkService.setRefreshInterval(Long.parseLong(String.valueOf(conf.get(PARAMETER_REFRESH_INTERVAL)))); + } catch (Exception ex) {} + + try { + networkService.setTimeout(Integer.parseInt(String.valueOf(conf.get(PARAMETER_TIMEOUT)))); + } catch (Exception ex) {} + + try { + networkService.setUseSystemPing(Boolean.parseBoolean(String.valueOf(conf.get(PARAMETER_USE_SYSTEM_PING)))); + } catch (Exception ex) {} + + startAutomaticRefresh(); + } + + private void startAutomaticRefresh() { + Runnable runnable = new Runnable() { + public void run() { + try { + State state = networkService.updateDeviceState() ? OnOffType.ON : OnOffType.OFF; + updateState(CHANNEL_ONLINE, state); + } catch( InvalidConfigurationException invalidConfigurationException) { + getThing().setStatus(ThingStatus.OFFLINE); + } + } + }; + + refreshJob = scheduler.scheduleAtFixedRate(runnable, 0, networkService.getRefreshInterval(), TimeUnit.MILLISECONDS); + } + +} diff --git a/addons/binding/org.openhab.binding.networkhealth/src/main/java/org/openhab/binding/networkhealth/internal/NetworkHealthHandlerFactory.java b/addons/binding/org.openhab.binding.network/src/main/java/org/openhab/binding/network/internal/NetworkHandlerFactory.java similarity index 70% rename from addons/binding/org.openhab.binding.networkhealth/src/main/java/org/openhab/binding/networkhealth/internal/NetworkHealthHandlerFactory.java rename to addons/binding/org.openhab.binding.network/src/main/java/org/openhab/binding/network/internal/NetworkHandlerFactory.java index f2e204fcbf499..75f184c50f07b 100644 --- a/addons/binding/org.openhab.binding.networkhealth/src/main/java/org/openhab/binding/networkhealth/internal/NetworkHealthHandlerFactory.java +++ b/addons/binding/org.openhab.binding.network/src/main/java/org/openhab/binding/network/internal/NetworkHandlerFactory.java @@ -5,24 +5,23 @@ * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/epl-v10.html */ -package org.openhab.binding.networkhealth.internal; +package org.openhab.binding.network.internal; -import static org.openhab.binding.networkhealth.NetworkHealthBindingConstants.*; - -import org.openhab.binding.networkhealth.handler.NetworkHealthHandler; +import static org.openhab.binding.network.NetworkBindingConstants.*; +import org.openhab.binding.network.handler.NetworkHandler; import org.eclipse.smarthome.core.thing.Thing; import org.eclipse.smarthome.core.thing.ThingTypeUID; import org.eclipse.smarthome.core.thing.binding.BaseThingHandlerFactory; import org.eclipse.smarthome.core.thing.binding.ThingHandler; /** - * The {@link NetworkHealthHandlerFactory} is responsible for creating things and thing + * The {@link NetworkHandlerFactory} is responsible for creating things and thing * handlers. * * @author Marc Mettke */ -public class NetworkHealthHandlerFactory extends BaseThingHandlerFactory { +public class NetworkHandlerFactory extends BaseThingHandlerFactory { @Override public boolean supportsThingType(ThingTypeUID thingTypeUID) { @@ -35,10 +34,9 @@ protected ThingHandler createHandler(Thing thing) { ThingTypeUID thingTypeUID = thing.getThingTypeUID(); if (thingTypeUID.equals(THING_TYPE_DEVICE)) { - return new NetworkHealthHandler(thing); + return new NetworkHandler(thing); } return null; } } - diff --git a/addons/binding/org.openhab.binding.network/src/main/java/org/openhab/binding/network/service/DiscoveryCallback.java b/addons/binding/org.openhab.binding.network/src/main/java/org/openhab/binding/network/service/DiscoveryCallback.java new file mode 100644 index 0000000000000..16a95ba83d424 --- /dev/null +++ b/addons/binding/org.openhab.binding.network/src/main/java/org/openhab/binding/network/service/DiscoveryCallback.java @@ -0,0 +1,9 @@ +package org.openhab.binding.network.service; + +/** + * Callback for a new Device to be committed to Homematic + * @author Marc Mettke - Initial contribution + */ +public interface DiscoveryCallback { + public void newDevice(String ip); +} diff --git a/addons/binding/org.openhab.binding.network/src/main/java/org/openhab/binding/network/service/DiscoveryThread.java b/addons/binding/org.openhab.binding.network/src/main/java/org/openhab/binding/network/service/DiscoveryThread.java new file mode 100644 index 0000000000000..a75796d90c54c --- /dev/null +++ b/addons/binding/org.openhab.binding.network/src/main/java/org/openhab/binding/network/service/DiscoveryThread.java @@ -0,0 +1,35 @@ +package org.openhab.binding.network.service; + +import java.io.IOException; +import java.net.SocketTimeoutException; + +import org.eclipse.smarthome.io.net.actions.Ping; + +/** + * Runs a Ping in its own Thread + * @author Marc Mettke - Initial contribution + */ +class DiscoveryThread extends Thread { + private final static int PING_TIMEOUT_IN_MS = 1000; + + private DiscoveryCallback discoveryCallback; + private String ip; + + public DiscoveryThread(String ip, DiscoveryCallback discoveryCallback) { + this.ip = ip; + this.discoveryCallback = discoveryCallback; + } + + @Override + public void run() { + try { + if( Ping.checkVitality(this.ip, 0, PING_TIMEOUT_IN_MS) ) { + this.discoveryCallback.newDevice(this.ip); + } + } + catch (SocketTimeoutException se) { + } + catch (IOException ioe) { + } + } +} diff --git a/addons/binding/org.openhab.binding.network/src/main/java/org/openhab/binding/network/service/InvalidConfigurationException.java b/addons/binding/org.openhab.binding.network/src/main/java/org/openhab/binding/network/service/InvalidConfigurationException.java new file mode 100644 index 0000000000000..95d704aadabe0 --- /dev/null +++ b/addons/binding/org.openhab.binding.network/src/main/java/org/openhab/binding/network/service/InvalidConfigurationException.java @@ -0,0 +1,9 @@ +package org.openhab.binding.network.service; + +public class InvalidConfigurationException extends Exception { + private static final long serialVersionUID = -4913760031378662737L; + + public InvalidConfigurationException(String message) { + super(message); + } +} diff --git a/addons/binding/org.openhab.binding.network/src/main/java/org/openhab/binding/network/service/NetworkService.java b/addons/binding/org.openhab.binding.network/src/main/java/org/openhab/binding/network/service/NetworkService.java new file mode 100644 index 0000000000000..9648577a62c15 --- /dev/null +++ b/addons/binding/org.openhab.binding.network/src/main/java/org/openhab/binding/network/service/NetworkService.java @@ -0,0 +1,269 @@ +package org.openhab.binding.network.service; + +import java.io.IOException; +import java.net.InterfaceAddress; +import java.net.NetworkInterface; +import java.net.SocketException; +import java.net.SocketTimeoutException; +import java.util.Enumeration; +import java.util.Iterator; +import java.util.Queue; +import java.util.TreeSet; +import java.util.concurrent.LinkedBlockingQueue; +import java.util.concurrent.ScheduledExecutorService; +import java.util.concurrent.ScheduledFuture; +import java.util.concurrent.TimeUnit; + +import org.apache.commons.lang.SystemUtils; +import org.apache.commons.net.util.SubnetUtils; +import org.eclipse.smarthome.io.net.actions.Ping; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; + +/** + * The {@link NetworkService} handles the connection to the Device + * + * @author Marc Mettke + */ +public class NetworkService { + private final static Object lockObject = new Object(); + private final static int TASK_CREATING_TIME_IN_MS = 1; + + private static ScheduledFuture discoveryJob; + private static Logger logger = LoggerFactory.getLogger(NetworkService.class); + + private String hostname; + private int port; + private int retry; + private long refreshInterval; + private int timeout; + private boolean useSystemPing; + + + public NetworkService() { + this("", 0, 1, 60000, 5000, false); + } + + public NetworkService(String hostname, int port, int retry, + long refreshInterval, int timeout, boolean useSystemPing) { + super(); + this.hostname = hostname; + this.port = port; + this.retry = retry; + this.refreshInterval = refreshInterval; + this.timeout = timeout; + this.useSystemPing = useSystemPing; + } + + + public String getHostname() { + return hostname; + } + + public int getPort() { + return port; + } + + public int getRetry() { + return retry; + } + + public long getRefreshInterval() { + return refreshInterval; + } + + public int getTimeout() { + return timeout; + } + + public boolean isUseSystemPing() { + return useSystemPing; + } + + public void setHostname(String hostname) { + this.hostname = hostname; + } + + public void setPort(int port) { + this.port = port; + } + + public void setRetry(int retry) { + this.retry = retry; + } + + public void setRefreshInterval(long refreshInterval) { + this.refreshInterval = refreshInterval; + } + + public void setTimeout(int timeout) { + this.timeout = timeout; + } + + public void setUseSystemPing(boolean useSystemPing) { + this.useSystemPing = useSystemPing; + } + + /** + * Updates one device to a new status + */ + public boolean updateDeviceState() throws InvalidConfigurationException { + int currentTry = 0; + boolean result; + + do { + result = updateDeviceState(getHostname(), getPort(), getTimeout(), isUseSystemPing()); + currentTry++; + } while( !result && currentTry < this.retry); + + return result; + } + + /** + * Try's to reach the Device by Ping + */ + private static boolean updateDeviceState(String hostname, int port, int timeout, boolean useSystemPing) throws InvalidConfigurationException { + boolean success = false; + + try { + if( !useSystemPing ) { + success = Ping.checkVitality(hostname, port, timeout); + } else { + Process proc; + if( SystemUtils.IS_OS_UNIX ) { + proc = new ProcessBuilder("ping", "-t", String.valueOf((int)(timeout / 1000)), "-c", "1", hostname).start(); + } else if( SystemUtils.IS_OS_WINDOWS) { + proc = new ProcessBuilder("ping", "-w", String.valueOf(timeout), "-n", "1", hostname).start(); + } else { + logger.error("The System Ping is not supported on this Operating System"); + throw new InvalidConfigurationException("System Ping not supported"); + } + + int exitValue = proc.waitFor(); + success = exitValue == 0; + if( exitValue != 2 && exitValue != 0 ) { + logger.debug("Ping stopped with Error Number: " + exitValue + + " on Command :" + "ping" + + (SystemUtils.IS_OS_UNIX ? " -t " : " -w ") + + String.valueOf(timeout) + + (SystemUtils.IS_OS_UNIX ? " -c" : " -n") + + " 1 " + hostname); + return false; + } + } + + logger.debug("established connection [host '{}' port '{}' timeout '{}']", new Object[] {hostname, port, timeout}); + } + catch (SocketTimeoutException se) { + logger.debug("timed out while connecting to host '{}' port '{}' timeout '{}'", new Object[] {hostname, port, timeout}); + } + catch (IOException ioe) { + logger.debug("couldn't establish network connection [host '{}' port '{}' timeout '{}']", new Object[] {hostname, port, timeout}); + } catch (InterruptedException e) { + logger.debug("ping program was interrupted"); + } + + return success ? true : false; + + } + + /** + * Handles the whole Discovery + */ + public static void discoverNetwork(DiscoveryCallback discoveryCallback, ScheduledExecutorService scheduledExecutorService) { + TreeSet interfaceIPs; + Queue networkIPs; + + logger.debug("Starting Device Discovery"); + interfaceIPs = getInterfaceIPs(); + networkIPs = getNetworkIPs(interfaceIPs); + startDiscovery(networkIPs, discoveryCallback, scheduledExecutorService); + } + + /** + * Gets every IPv4 Address on each Interface except the loopback + * The Address format is ip/subnet + * @return The collected IPv4 Addresses + */ + private static TreeSet getInterfaceIPs() { + TreeSet interfaceIPs = new TreeSet(); + + try { + // For each interface ... + for (Enumeration en = NetworkInterface + .getNetworkInterfaces(); en.hasMoreElements();) { + NetworkInterface networkInterface = en.nextElement(); + if (!networkInterface.isLoopback()) { + + // .. and for each address ... + for (Iterator it = networkInterface + .getInterfaceAddresses().iterator(); it.hasNext();) { + + // ... get IP and Subnet + InterfaceAddress interfaceAddress = it.next(); + interfaceIPs.add(interfaceAddress.getAddress() + .getHostAddress() + + "/" + + interfaceAddress.getNetworkPrefixLength()); + } + } + } + } catch (SocketException e) { + } + + return interfaceIPs; + } + + /** + * Takes the interfaceIPs and fetches every IP which can be assigned on their network + * @param networkIPs The IPs which are assigned to the Network Interfaces + * @return Every single IP which can be assigned on the Networks the computer is connected to + */ + private static Queue getNetworkIPs(TreeSet interfaceIPs) { + Queue networkIPs = new LinkedBlockingQueue(); + + for (Iterator it = interfaceIPs.iterator(); it.hasNext();) { + try { + // gets every ip which can be assigned on the given network + SubnetUtils utils = new SubnetUtils(it.next()); + String[] addresses = utils.getInfo().getAllAddresses(); + for (int i = 0; i < addresses.length; i++) { + networkIPs.add(addresses[i]); + } + + } catch (Exception ex) { + } + } + + return networkIPs; + } + + /** + * Starts the DiscoveryThread for each IP on the Networks + * @param allNetworkIPs + */ + private static void startDiscovery(final Queue networkIPs, final DiscoveryCallback discoveryCallback, ScheduledExecutorService scheduledExecutorService) { + + Runnable runnable = new Runnable() { + public void run() { + DiscoveryThread discoveryThread = null; + + // ensures that only one thread at a time access the queue + synchronized (lockObject) { + if( networkIPs.isEmpty()) { + discoveryJob.cancel(false); + } else { + discoveryThread = new DiscoveryThread(networkIPs.remove(), discoveryCallback); + } + } + + if( discoveryThread != null ) + discoveryThread.start(); + } + }; + + /* Every milisecond a new thread will be created. Due to the fact that the PING has a timeout of 1 sec, + * only about 1000 Threads will be create at max */ + discoveryJob = scheduledExecutorService.scheduleAtFixedRate(runnable, 0, TASK_CREATING_TIME_IN_MS, TimeUnit.MILLISECONDS); + } +} diff --git a/addons/binding/org.openhab.binding.networkhealth/ESH-INF/i18n/networkhealth_de.properties b/addons/binding/org.openhab.binding.networkhealth/ESH-INF/i18n/networkhealth_de.properties deleted file mode 100644 index d9112140f2b28..0000000000000 --- a/addons/binding/org.openhab.binding.networkhealth/ESH-INF/i18n/networkhealth_de.properties +++ /dev/null @@ -1,19 +0,0 @@ -# binding -binding.networkhealth.name = Network Health Binding -binding.networkhealth.description = Das Network Health Binding überprüft, ob sich ein Geräte aktuell im Netzwerk befindet oder nicht. - -# thing types -thing-type.networkhealth.DEVICE.label = Netzgerät -thing-type.networkhealth.DEVICE.description = Das Netzwerkgerät muss mit dem gleichen Netzwerk verbunden sein wie OpenHAB -thing-type.config.networkhealth.DEVICE.HOSTNAME.label = Hostname oder IP -thing-type.config.networkhealth.DEVICE.HOSTNAME.description = Hostname oder IP des Netzwerkgerätes -thing-type.config.networkhealth.DEVICE.PORT.label = Port -thing-type.config.networkhealth.DEVICE.PORT.description = Der Port an dem das Gerät erreichbar ist. -thing-type.config.networkhealth.DEVICE.TIMEOUT.label = Zeitlimit -thing-type.config.networkhealth.DEVICE.TIMEOUT.description = Gibt an, wie lange maximal gewartet werden soll, bis ein Gerät als nicht vorhanden gekenntzeichnet wird. -thing-type.config.networkhealth.DEVICE.REFRESH_INTERVAL.label = Aktualisierungsintervall -thing-type.config.networkhealth.DEVICE.REFRESH_INTERVAL.description = Spezifiziert den Aktualisierungsintervall in Millisekunden - -# channel types -channel-type.networkhealth.ONLINE.label = Online -channel-type.networkhealth.ONLINE.description = Gibt an ob das Gerät aktuell Online oder Offline ist. diff --git a/addons/binding/org.openhab.binding.networkhealth/src/main/java/org/openhab/binding/networkhealth/discovery/NetworkHealthDiscoveryService.java b/addons/binding/org.openhab.binding.networkhealth/src/main/java/org/openhab/binding/networkhealth/discovery/NetworkHealthDiscoveryService.java deleted file mode 100644 index 32d3c5ef299bf..0000000000000 --- a/addons/binding/org.openhab.binding.networkhealth/src/main/java/org/openhab/binding/networkhealth/discovery/NetworkHealthDiscoveryService.java +++ /dev/null @@ -1,239 +0,0 @@ -/** - * Copyright (c) 2014 openHAB UG (haftungsbeschraenkt) and others. - * 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.networkhealth.discovery; - -import static org.openhab.binding.networkhealth.NetworkHealthBindingConstants.*; - -import java.io.IOException; -import java.net.InterfaceAddress; -import java.net.NetworkInterface; -import java.net.SocketException; -import java.net.SocketTimeoutException; -import java.util.Enumeration; -import java.util.HashMap; -import java.util.Iterator; -import java.util.Map; -import java.util.Queue; -import java.util.Set; -import java.util.TreeSet; -import java.util.concurrent.LinkedBlockingQueue; -import java.util.concurrent.ScheduledFuture; -import java.util.concurrent.TimeUnit; -import org.apache.commons.net.util.SubnetUtils; -import org.eclipse.smarthome.core.thing.ThingTypeUID; -import org.eclipse.smarthome.core.thing.ThingUID; -import org.eclipse.smarthome.config.discovery.AbstractDiscoveryService; -import org.eclipse.smarthome.config.discovery.DiscoveryResult; -import org.eclipse.smarthome.config.discovery.DiscoveryResultBuilder; -import org.eclipse.smarthome.io.net.actions.Ping; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - -/** - * The {@link NetworkHealthDiscoveryService} is responsible for discovering devices on - * the current Network. It uses every Network Interface which is connect to a Network - * - * @author Marc Mettke - Initial contribution - */ - -public class NetworkHealthDiscoveryService extends AbstractDiscoveryService { - private final static int TASK_CREATING_TIME_IN_MS = 1; - private final static Object lockObject = new Object(); - - private ScheduledFuture discoveryJob; - private final Logger logger = LoggerFactory.getLogger(NetworkHealthDiscoveryService.class); - - - public NetworkHealthDiscoveryService() { - super(SUPPORTED_THING_TYPES_UIDS, 300); - } - - /** - * Handles the whole Discovery - */ - private void discoverNetwork() { - TreeSet interfaceIPs; - Queue networkIPs; - - logger.debug("Starting Device Discovery"); - interfaceIPs = getInterfaceIPs(); - networkIPs = getNetworkIPs(interfaceIPs); - startDiscovery(networkIPs); - } - - /** - * Gets every IPv4 Address on each Interface except the loopback - * The Address format is ip/subnet - * @return The collected IPv4 Addresses - */ - private TreeSet getInterfaceIPs() { - TreeSet interfaceIPs = new TreeSet(); - - try { - // For each interface ... - for (Enumeration en = NetworkInterface - .getNetworkInterfaces(); en.hasMoreElements();) { - NetworkInterface networkInterface = en.nextElement(); - if (!networkInterface.isLoopback()) { - - // .. and for each address ... - for (Iterator it = networkInterface - .getInterfaceAddresses().iterator(); it.hasNext();) { - - // ... get IP and Subnet - InterfaceAddress interfaceAddress = it.next(); - interfaceIPs.add(interfaceAddress.getAddress() - .getHostAddress() - + "/" - + interfaceAddress.getNetworkPrefixLength()); - } - } - } - } catch (SocketException e) { - } - - return interfaceIPs; - } - - /** - * Takes the interfaceIPs and fetches every IP which can be assigned on their network - * @param networkIPs The IPs which are assigned to the Network Interfaces - * @return Every single IP which can be assigned on the Networks the computer is connected to - */ - private Queue getNetworkIPs(TreeSet interfaceIPs) { - Queue networkIPs = new LinkedBlockingQueue(); - - for (Iterator it = interfaceIPs.iterator(); it.hasNext();) { - try { - // gets every ip which can be assigned on the given network - SubnetUtils utils = new SubnetUtils(it.next()); - String[] addresses = utils.getInfo().getAllAddresses(); - for (int i = 0; i < addresses.length; i++) { - networkIPs.add(addresses[i]); - } - - } catch (Exception ex) { - } - } - - return networkIPs; - } - - public Set getSupportedThingTypes() { - return SUPPORTED_THING_TYPES_UIDS; - } - - @Override - protected void startBackgroundDiscovery() { - new Thread(new Runnable() { - @Override - public void run() { - /* Devices are only discovered on users request */ - } - }).start(); - } - - /** - * Starts the DiscoveryThread for each IP on the Networks - * @param allNetworkIPs - */ - private void startDiscovery(final Queue networkIPs) { - - Runnable runnable = new Runnable() { - public void run() { - DiscoveryThread discoveryThread = null; - DiscoveryThreadResult discoveryThreadResult = new DiscoveryThreadResult() { - @Override - public void newDevice(String ip) { - submitDiscoveryResults(ip); - } - }; - - // ensures that only one thread at a time access the queue - synchronized (lockObject) { - if( networkIPs.isEmpty()) { - discoveryJob.cancel(false); - } else { - discoveryThread = new DiscoveryThread(networkIPs.remove(), discoveryThreadResult); - } - } - - if( discoveryThread != null ) - discoveryThread.start(); - } - }; - - /* Every milisecond a new thread will be created. Due to the fact that the PING has a timeout of 1 sec, - * only about 1000 Threads will be create at max */ - discoveryJob = scheduler.scheduleAtFixedRate(runnable, 0, TASK_CREATING_TIME_IN_MS, TimeUnit.MILLISECONDS); - } - - @Override - protected void startScan() { - discoverNetwork(); - } - - /** - * Submit the discovered Devices to the Smarthome inbox, - * - * @param ip The Device IP - */ - private void submitDiscoveryResults(String ip) { - - // uid must not contains dots - ThingUID uid = new ThingUID(THING_TYPE_DEVICE, ip.replace('.', '_') ); - - if(uid!=null) { - Map properties = new HashMap<>(1); - properties.put(PARAMETER_HOSTNAME ,ip); - DiscoveryResult result = DiscoveryResultBuilder.create(uid) - .withProperties(properties) - .withLabel("Network Device (" + ip +")").build(); - thingDiscovered(result); - } - - } - -} - -/** - * Runs a Ping in its own Thread - * @author Marc Mettke - Initial contribution - */ -class DiscoveryThread extends Thread { - private final static int PING_TIMEOUT_IN_MS = 1000; - - private DiscoveryThreadResult discoveryResult; - private String ip; - - public DiscoveryThread(String ip, DiscoveryThreadResult discoveryResult) { - this.ip = ip; - this.discoveryResult = discoveryResult; - } - - @Override - public void run() { - try { - if( Ping.checkVitality(this.ip, 0, PING_TIMEOUT_IN_MS) ) { - this.discoveryResult.newDevice(this.ip); - } - } - catch (SocketTimeoutException se) { - } - catch (IOException ioe) { - } - } -} - -/** - * Callback for a new Device to be committed to Homematic - * @author Marc Mettke - Initial contribution - */ -interface DiscoveryThreadResult { - public void newDevice(String ip); -} diff --git a/addons/binding/org.openhab.binding.networkhealth/src/main/java/org/openhab/binding/networkhealth/handler/NetworkHealthHandler.java b/addons/binding/org.openhab.binding.networkhealth/src/main/java/org/openhab/binding/networkhealth/handler/NetworkHealthHandler.java deleted file mode 100644 index 08cf59ea98235..0000000000000 --- a/addons/binding/org.openhab.binding.networkhealth/src/main/java/org/openhab/binding/networkhealth/handler/NetworkHealthHandler.java +++ /dev/null @@ -1,128 +0,0 @@ -/** - * Copyright (c) 2014 openHAB UG (haftungsbeschraenkt) and others. - * 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.networkhealth.handler; - -import static org.openhab.binding.networkhealth.NetworkHealthBindingConstants.*; - -import java.io.IOException; -import java.net.SocketTimeoutException; -import java.util.concurrent.ScheduledFuture; -import java.util.concurrent.TimeUnit; - -import org.eclipse.smarthome.config.core.Configuration; -import org.eclipse.smarthome.core.library.types.OnOffType; -import org.eclipse.smarthome.core.thing.ChannelUID; -import org.eclipse.smarthome.core.thing.Thing; -import org.eclipse.smarthome.core.thing.binding.BaseThingHandler; -import org.eclipse.smarthome.core.types.Command; -import org.eclipse.smarthome.core.types.RefreshType; -import org.eclipse.smarthome.io.net.actions.Ping; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - -/** - * The {@link NetworkHealthHandler} is responsible for handling commands, which are - * sent to one of the channels. - * - * @author Marc Mettke - Initial contribution - */ -public class NetworkHealthHandler extends BaseThingHandler { - private Logger logger = LoggerFactory.getLogger(NetworkHealthHandler.class); - - public String hostname; - public int port; - private long refreshInterval; - ScheduledFuture refreshJob; - - public int timeout; - - - public NetworkHealthHandler(Thing thing) { - super(thing); - } - - - @Override - public void dispose() { - refreshJob.cancel(true); - } - - private void getDeviceState() { - boolean success = false; - - try { - success = Ping.checkVitality(this.hostname, this.port, this.timeout); - - logger.debug("established connection [host '{}' port '{}' timeout '{}']", new Object[] {hostname, port, timeout}); - } - catch (SocketTimeoutException se) { - logger.debug("timed out while connecting to host '{}' port '{}' timeout '{}'", new Object[] {hostname, port, timeout}); - } - catch (IOException ioe) { - logger.debug("couldn't establish network connection [host '{}' port '{}' timeout '{}']", new Object[] {hostname, port, timeout}); - } - - updateState(CHANNEL_ONLINE, success ? OnOffType.ON : OnOffType.OFF); - } - - @Override - public void handleCommand(ChannelUID channelUID, Command command) { - if (command instanceof RefreshType) { - switch (channelUID.getId()) { - case CHANNEL_ONLINE: - getDeviceState(); - break; - default: - logger.debug("Command received for an unknown channel: {}", channelUID.getId()); - break; - } - } else { - logger.debug("Command {} is not supported for channel: {}", command, channelUID.getId()); - } - } - - @Override - public void initialize() { - logger.debug("Initializing NetworkHealth handler."); - Configuration conf = this.getConfig(); - super.initialize(); - - this.hostname = String.valueOf(conf.get(PARAMETER_HOSTNAME)); - - try { - this.port = Integer.parseInt(String.valueOf(conf.get(PARAMETER_PORT))); - } catch (Exception ex) { - this.port = 0; - } - - try { - this.timeout = Integer.parseInt(String.valueOf(conf.get(PARAMETER_TIMEOUT))); - } catch (Exception ex) { - this.timeout = 5000; - } - - try { - this.refreshInterval = Long.parseLong(String.valueOf(conf.get(PARAMETER_REFRESH_INTERVAL))); - } catch (Exception ex) { - this.refreshInterval = 60000; - } - - startAutomaticRefresh(); - } - - private void startAutomaticRefresh() { - Runnable runnable = new Runnable() { - public void run() { - getDeviceState(); - } - }; - - refreshJob = scheduler.scheduleAtFixedRate(runnable, 0, refreshInterval, TimeUnit.MILLISECONDS); - } - -} diff --git a/addons/binding/org.openhab.binding.sonos/ESH-INF/thing/thing-types.xml b/addons/binding/org.openhab.binding.sonos/ESH-INF/thing/thing-types.xml index b14c669fa130e..f7dc175dc2eee 100644 --- a/addons/binding/org.openhab.binding.sonos/ESH-INF/thing/thing-types.xml +++ b/addons/binding/org.openhab.binding.sonos/ESH-INF/thing/thing-types.xml @@ -25,6 +25,8 @@ + + @@ -150,6 +152,18 @@ Play the given playlist. The playlist has to predefined in the Sonos Controller app + + Switch + + Play the songs from the current queue + + + + Number + + Play the given track number from the current queue + + String diff --git a/addons/binding/org.openhab.binding.sonos/src/main/java/org/openhab/binding/sonos/SonosBindingConstants.java b/addons/binding/org.openhab.binding.sonos/src/main/java/org/openhab/binding/sonos/SonosBindingConstants.java index ad1338d8c4b70..5234f51528775 100644 --- a/addons/binding/org.openhab.binding.sonos/src/main/java/org/openhab/binding/sonos/SonosBindingConstants.java +++ b/addons/binding/org.openhab.binding.sonos/src/main/java/org/openhab/binding/sonos/SonosBindingConstants.java @@ -39,6 +39,8 @@ public class SonosBindingConstants { public final static String MUTE = "mute"; public final static String PLAYLINEIN = "playlinein"; public final static String PLAYLIST = "playlist"; + public final static String PLAYQUEUE = "playqueue"; + public final static String PLAYTRACK = "playtrack"; public final static String PLAYURI = "playuri"; public final static String PUBLICADDRESS = "publicaddress"; public final static String RADIO = "radio"; diff --git a/addons/binding/org.openhab.binding.sonos/src/main/java/org/openhab/binding/sonos/handler/ZonePlayerHandler.java b/addons/binding/org.openhab.binding.sonos/src/main/java/org/openhab/binding/sonos/handler/ZonePlayerHandler.java index 708f305f9f2a0..66664b234a9e5 100644 --- a/addons/binding/org.openhab.binding.sonos/src/main/java/org/openhab/binding/sonos/handler/ZonePlayerHandler.java +++ b/addons/binding/org.openhab.binding.sonos/src/main/java/org/openhab/binding/sonos/handler/ZonePlayerHandler.java @@ -104,7 +104,6 @@ public class ZonePlayerHandler extends BaseThingHandler implements @Override public void run() { try { - updateCurrentURIFormatted(); updateZoneInfo(); updateRunningAlarmProperties(); updateLed(); @@ -166,21 +165,25 @@ public void initialize() { @Override public void thingDiscovered(DiscoveryService source, DiscoveryResult result) { - if (getThing().getConfiguration().get(UDN) - .equals(result.getProperties().get(UDN))) { - logger.debug("Discovered UDN '{}' for thing '{}'", result - .getProperties().get(UDN), getThing().getUID()); - getThing().setStatus(ThingStatus.ONLINE); - onSubscription(); - onUpdate(); + if(result.getThingUID().equals(this.getThing().getUID())) { + if (getThing().getConfiguration().get(UDN) + .equals(result.getProperties().get(UDN))) { + logger.debug("Discovered UDN '{}' for thing '{}'", result + .getProperties().get(UDN), getThing().getUID()); + getThing().setStatus(ThingStatus.ONLINE); + onSubscription(); + onUpdate(); + } } } @Override public void thingRemoved(DiscoveryService source, ThingUID thingUID) { - logger.debug("Setting status for thing '{}' to OFFLINE", getThing() - .getUID()); - getThing().setStatus(ThingStatus.OFFLINE); + if(thingUID.equals(this.getThing().getUID())) { + logger.debug("Setting status for thing '{}' to OFFLINE", getThing() + .getUID()); + getThing().setStatus(ThingStatus.OFFLINE); + } } @Override @@ -234,6 +237,12 @@ public void handleCommand(ChannelUID channelUID, Command command) { case PLAYLIST: playPlayList(command); break; + case PLAYQUEUE: + playQueue(command); + break; + case PLAYTRACK: + playTrack(command); + break; case PLAYURI: playURI(command); break; @@ -452,6 +461,14 @@ public void onValueReceived(String variable, String value, String service) { stateMap.get("CurrentAlbum")) : UnDefType.UNDEF); break; } + case "CurrentTrackMetaData": { + updateTrackMetaData(); + break; + } + case "CurrentURI": { + updateCurrentURIFormatted(value); + break; + } } } @@ -587,30 +604,72 @@ public boolean isCoordinator() { return getUDN().equals(getCoordinator()); } - protected void updateCurrentURIFormatted() { + protected void updateTrackMetaData() { + + String coordinator = getCoordinator(); + ZonePlayerHandler coordinatorHandler = getHandlerByName(coordinator); + SonosMetaData currentTrack = getTrackMetadata(); + + if (coordinatorHandler != null && coordinatorHandler != this) { + coordinatorHandler.updateMediaInfo(); + currentTrack = coordinatorHandler.getTrackMetadata(); + } + + if (currentTrack != null) { - String currentURI = null; + String artist = null; + if (currentTrack.getAlbumArtist().equals("")) { + artist = currentTrack.getCreator(); + } else { + artist = currentTrack.getAlbumArtist(); + } + + String album = currentTrack.getAlbum(); + String title = null; + if(!currentTrack.getTitle().contains("x-sonosapi-stream")) { + title = currentTrack.getTitle(); + } + + // update individual variables + this.onValueReceived("CurrentArtist", (artist != null) ? artist + : "", "AVTransport"); + if(title!=null) { + this.onValueReceived("CurrentTitle", (title != null) ? title : "", + "AVTransport"); + } + this.onValueReceived("CurrentAlbum", (album != null) ? album : "", + "AVTransport"); + + updateMediaInfo(); + + } + + } + + protected void updateCurrentURIFormatted(String URI) { + + String currentURI = URI; SonosMetaData currentTrack = null; String coordinator = getCoordinator(); ZonePlayerHandler coordinatorHandler = getHandlerByName(coordinator); - if (!isGroupCoordinator() && coordinatorHandler != null) { + if (coordinatorHandler != null && coordinatorHandler != this) { + if(currentURI.contains("x-rincon-stream")) { + coordinatorHandler.updateMediaInfo(); + } currentURI = coordinatorHandler.getCurrentURI(); currentTrack = coordinatorHandler.getTrackMetadata(); } else { - currentURI = getCurrentURI(); + // currentURI = getCurrentURI(); currentTrack = getTrackMetadata(); } if (currentURI != null) { - - String resultString = null; - String artist = null; - String album = null; - String title = null; + String title = stateMap.get("CurrentTitle"); + String resultString = stateMap.get("CurrentURIFormatted"); + boolean needsUpdating = false; if (opmlPartnerID != null && currentURI.contains("x-sonosapi-stream")) { - String stationID = StringUtils.substringBetween(currentURI, ":s", "?sid"); String previousStationID = stateMap.get("StationID"); @@ -657,47 +716,44 @@ protected void updateCurrentURIFormatted() { resultString = resultString + " - "; } } + + needsUpdating = true; } } - } else { - resultString = stateMap.get("CurrentURIFormatted"); - title = stateMap.get("CurrentTitle"); } + } + + if(currentURI.contains("x-rincon-stream")) { + if(currentTrack != null) { + resultString = stateMap.get("CurrentTitle"); + needsUpdating = true; + } + } - } else { - if (currentTrack != null) { - if (!currentTrack.getTitle().contains("x-sonosapi-stream")) { - if (currentTrack.getAlbumArtist().equals("")) { - resultString = currentTrack.getCreator() + " - " - + currentTrack.getAlbum() + " - " - + currentTrack.getTitle(); - artist = currentTrack.getCreator(); - } else { - resultString = currentTrack.getAlbumArtist() - + " - " + currentTrack.getAlbum() + " - " - + currentTrack.getTitle(); - artist = currentTrack.getAlbumArtist(); - } - album = currentTrack.getAlbum(); - title = currentTrack.getTitle(); + if (!currentURI.contains("x-rincon-mp3") && !currentURI.contains("x-rincon-stream") && !currentURI.contains("x-sonosapi")) { + if(currentTrack != null) { + if (currentTrack.getAlbumArtist().equals("")) { + resultString = currentTrack.getCreator() + " - " + + currentTrack.getAlbum() + " - " + + currentTrack.getTitle(); + } else { + resultString = currentTrack.getAlbumArtist() + + " - " + currentTrack.getAlbum() + " - " + + currentTrack.getTitle(); } - } else { - resultString = ""; + needsUpdating = true; } } - this.onValueReceived("CurrentURIFormatted", resultString, - "AVTransport"); - // update individual variables - this.onValueReceived("CurrentArtist", (artist != null) ? artist - : " ", "AVTransport"); - this.onValueReceived("CurrentTitle", (title != null) ? title : " ", - "AVTransport"); - this.onValueReceived("CurrentAlbum", (album != null) ? album : " ", - "AVTransport"); + if(needsUpdating) { + this.onValueReceived("CurrentURIFormatted", (resultString != null) ? resultString : "", + "AVTransport"); + this.onValueReceived("CurrentTitle", (title != null) ? title : "", + "AVTransport"); + } } } @@ -716,7 +772,6 @@ public String getUDN() { } public String getCurrentURI() { - updateMediaInfo(); return stateMap.get("CurrentURI"); } @@ -1160,6 +1215,10 @@ public void setPositionTrack(long tracknr) { seek("TRACK_NR", Long.toString(tracknr)); } + public void setPositionTrack(String tracknr) { + seek("TRACK_NR", tracknr); + } + protected void seek(String unit, String target) { if (unit != null && target != null) { @@ -1594,6 +1653,19 @@ public void playURI(Command command) { } + public void playQueue(Command command) { + ZonePlayerHandler coordinator = getHandlerByName(getCoordinator()); + + // set the current playlist to our new queue + coordinator.setCurrentURI("x-rincon-queue:" + getUDN() + "#0", ""); + + // take the system off mute + coordinator.setMute(OnOffType.OFF); + + // start jammin' + coordinator.play(); + } + public void setLed(Command command) { if (command != null) { if (command instanceof OnOffType @@ -1678,6 +1750,25 @@ public void playRadio(Command command) { } + public void playTrack(Command command) { + + if(command != null && command instanceof DecimalType) { + ZonePlayerHandler coordinator = getHandlerByName(getCoordinator()); + + String trackNumber = command.toString(); + + // seek the track - warning, we do not check if the tracknumber falls in the boundary of the queue + setPositionTrack(trackNumber); + + // take the system off mute + coordinator.setMute(OnOffType.OFF); + + // start jammin' + coordinator.play(); + } + + } + public void playPlayList(Command command) { List playlists = getPlayLists(); SonosEntry theEntry = null; @@ -1746,8 +1837,14 @@ public String getCurrentZoneName() { } public String getCurrentURIFormatted() { - updateCurrentURIFormatted(); + updateCurrentURIFormatted(getCurrentURI()); return stateMap.get("CurrentURIFormatted"); } + @Override + public void onStatusChanged(boolean status) { + // TODO Auto-generated method stub + + } + } diff --git a/addons/binding/pom.xml b/addons/binding/pom.xml index 16cb1afb8aa76..a28ff677bea3c 100644 --- a/addons/binding/pom.xml +++ b/addons/binding/pom.xml @@ -19,8 +19,8 @@ org.openhab.binding.sonos org.openhab.binding.max org.openhab.binding.max.test - org.openhab.binding.networkhealth + org.openhab.binding.network org.openhab.binding.zigbee - \ No newline at end of file + diff --git a/bundles/core/org.openhab.core.compat1x/META-INF/MANIFEST.MF b/bundles/core/org.openhab.core.compat1x/META-INF/MANIFEST.MF index 4bd2a33b4de43..2baaa40db92b1 100644 --- a/bundles/core/org.openhab.core.compat1x/META-INF/MANIFEST.MF +++ b/bundles/core/org.openhab.core.compat1x/META-INF/MANIFEST.MF @@ -9,6 +9,7 @@ Bundle-RequiredExecutionEnvironment: JavaSE-1.7 Import-Package: com.google.common.base, javax.servlet, javax.servlet.http, + javax.sound.sampled, org.apache.commons.collections, org.apache.commons.exec;version="1.1.0", org.apache.commons.httpclient;version="3.1.0", @@ -18,8 +19,11 @@ Import-Package: com.google.common.base, org.apache.commons.io;version="2.0.1", org.apache.commons.lang, org.apache.commons.net.util, + org.eclipse.emf.common.util, + org.eclipse.emf.ecore, org.eclipse.emf.ecore.resource, org.eclipse.smarthome.core.autoupdate, + org.eclipse.smarthome.core.common.registry, org.eclipse.smarthome.core.events, org.eclipse.smarthome.core.items, org.eclipse.smarthome.core.library.items, @@ -31,6 +35,9 @@ Import-Package: com.google.common.base, org.eclipse.smarthome.core.types, org.eclipse.smarthome.io.multimedia.tts, org.eclipse.smarthome.model.item, + org.eclipse.smarthome.model.sitemap, + org.eclipse.smarthome.ui.chart, + org.eclipse.smarthome.ui.items, org.openhab.io.multimedia.actions, org.openhab.library.tel.types, org.osgi.framework, @@ -58,7 +65,9 @@ Export-Package: org.openhab.core.autoupdate, org.openhab.io.net.http, org.openhab.library.tel.items, org.openhab.library.tel.types, - org.openhab.model.item.binding + org.openhab.model.item.binding, + org.openhab.ui.chart, + org.openhab.ui.items Bundle-ClassPath: lib/jl1.0.1.jar, . -Service-Component: OSGI-INF/* +Service-Component: OSGI-INF/*.xml diff --git a/bundles/core/org.openhab.core.compat1x/OSGI-INF/chartproviderfactory.xml b/bundles/core/org.openhab.core.compat1x/OSGI-INF/chartproviderfactory.xml new file mode 100644 index 0000000000000..005406d4d87c9 --- /dev/null +++ b/bundles/core/org.openhab.core.compat1x/OSGI-INF/chartproviderfactory.xml @@ -0,0 +1,5 @@ + + + + + diff --git a/bundles/core/org.openhab.core.compat1x/OSGI-INF/itemuiregistry.xml b/bundles/core/org.openhab.core.compat1x/OSGI-INF/itemuiregistry.xml new file mode 100644 index 0000000000000..0e23fdfb13724 --- /dev/null +++ b/bundles/core/org.openhab.core.compat1x/OSGI-INF/itemuiregistry.xml @@ -0,0 +1,9 @@ + + + + + + + + + diff --git a/bundles/core/org.openhab.core.compat1x/build.properties b/bundles/core/org.openhab.core.compat1x/build.properties index 52fd2a4448dc6..4a1f00dae8ebb 100644 --- a/bundles/core/org.openhab.core.compat1x/build.properties +++ b/bundles/core/org.openhab.core.compat1x/build.properties @@ -7,5 +7,7 @@ bin.includes = META-INF/,\ OSGI-INF/eventbridge.xml,\ OSGI-INF/eventpublisherdelegate.xml,\ OSGI-INF/bindingconfigreaderfactory.xml,\ - OSGI-INF/actionservicefactory.xml + OSGI-INF/actionservicefactory.xml,\ + OSGI-INF/itemuiregistry.xml,\ + OSGI-INF/chartproviderfactory.xml source.. = src/main/java/ diff --git a/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/core/binding/internal/BindingConfigReaderDelegate.java b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/core/binding/internal/BindingConfigReaderDelegate.java index b93c58bfd9bed..16ded5ce357b4 100644 --- a/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/core/binding/internal/BindingConfigReaderDelegate.java +++ b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/core/binding/internal/BindingConfigReaderDelegate.java @@ -54,12 +54,6 @@ public void processBindingConfiguration(String context, String itemType, String } - @Override - public void removeConfigurations(String context) { - reader.removeConfigurations(context); - - } - private org.openhab.core.items.Item getOpenHABItem(String itemType) throws BindingConfigParseException { return getOpenHABItem(itemType, "itemName"); } @@ -81,4 +75,13 @@ private org.openhab.core.items.Item getOpenHABItem(String itemType, throw new BindingConfigParseException("cannot process unknown item type " + itemType); } + @Override + public void startConfigurationUpdate(String context) { + reader.removeConfigurations(context); + } + + @Override + public void stopConfigurationUpdate(String context) { + } + } diff --git a/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/core/compat1x/internal/ItemMapper.java b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/core/compat1x/internal/ItemMapper.java index d9e93198c1aa0..7de31288823b2 100644 --- a/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/core/compat1x/internal/ItemMapper.java +++ b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/core/compat1x/internal/ItemMapper.java @@ -8,6 +8,7 @@ */ package org.openhab.core.compat1x.internal; +import org.eclipse.smarthome.core.items.GroupItem; import org.eclipse.smarthome.core.items.Item; import org.eclipse.smarthome.core.library.items.ColorItem; import org.eclipse.smarthome.core.library.items.ContactItem; @@ -34,7 +35,25 @@ public static org.openhab.core.items.Item mapToOpenHABItem(Item item) { if(item instanceof ColorItem) result = new org.openhab.core.library.items.ColorItem(item.getName()); if(item instanceof DateTimeItem) result = new org.openhab.core.library.items.DateTimeItem(item.getName()); if(item instanceof ESHCallItem) result = new org.openhab.library.tel.items.CallItem(item.getName()); - + + if(item instanceof GroupItem) { + GroupItem gItem = (GroupItem) item; + org.openhab.core.items.Item baseItem = ItemMapper.mapToOpenHABItem(gItem.getBaseItem()); + org.openhab.core.items.GroupItem ohgItem; + if(baseItem instanceof GenericItem) { + ohgItem = new org.openhab.core.items.GroupItem(item.getName(), (GenericItem) baseItem); + } else { + ohgItem = new org.openhab.core.items.GroupItem(item.getName()); + } + for(Item member : gItem.getMembers()) { + org.openhab.core.items.Item ohMember = ItemMapper.mapToOpenHABItem(member); + if(ohMember != null) { + ohgItem.addMember(ohMember); + } + } + result = ohgItem; + } + if(result instanceof org.openhab.core.items.GenericItem) { org.openhab.core.items.GenericItem genericItem = (GenericItem) result; if(item.getState()!=null) { diff --git a/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/core/items/internal/ItemUIRegistryDelegate.java b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/core/items/internal/ItemUIRegistryDelegate.java new file mode 100644 index 0000000000000..8390d259700f4 --- /dev/null +++ b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/core/items/internal/ItemUIRegistryDelegate.java @@ -0,0 +1,194 @@ +package org.openhab.core.items.internal; + +import java.util.Collection; +import java.util.HashSet; +import java.util.Set; + +import org.eclipse.emf.common.util.EList; +import org.eclipse.smarthome.core.common.registry.RegistryChangeListener; +import org.openhab.core.compat1x.internal.ItemMapper; +import org.openhab.core.items.Item; +import org.openhab.core.items.ItemNotFoundException; +import org.openhab.core.items.ItemNotUniqueException; +import org.openhab.core.items.ItemRegistryChangeListener; +import org.openhab.core.types.State; +import org.openhab.model.sitemap.LinkableWidget; +import org.openhab.model.sitemap.Sitemap; +import org.openhab.model.sitemap.Widget; +import org.openhab.ui.items.ItemUIRegistry; + +public class ItemUIRegistryDelegate implements ItemUIRegistry, RegistryChangeListener { + + private org.eclipse.smarthome.ui.items.ItemUIRegistry itemUIRegistry; + private Set listeners = new HashSet<>(); + + protected void setItemUIRegistry(org.eclipse.smarthome.ui.items.ItemUIRegistry itemUIRegistry) { + this.itemUIRegistry = itemUIRegistry; + itemUIRegistry.addRegistryChangeListener(this); + } + + protected void unsetItemUIRegistry(org.eclipse.smarthome.core.items.ItemRegistry itemUIRegistry) { + this.itemUIRegistry = null; + } + + @Override + public Item getItem(String name) throws ItemNotFoundException { + org.eclipse.smarthome.core.items.Item eshItem = itemUIRegistry.get(name); + return ItemMapper.mapToOpenHABItem(eshItem); + } + + @Override + public Item getItemByPattern(String name) throws ItemNotFoundException, ItemNotUniqueException { + org.eclipse.smarthome.core.items.Item eshItem; + try { + eshItem = itemUIRegistry.getItemByPattern(name); + } catch (org.eclipse.smarthome.core.items.ItemNotFoundException e) { + throw new ItemNotFoundException(name); + } catch (org.eclipse.smarthome.core.items.ItemNotUniqueException e) { + throw new ItemNotUniqueException(name, null); + } + return ItemMapper.mapToOpenHABItem(eshItem); + } + + @Override + public Collection getItems() { + Collection eshItems = itemUIRegistry.getItems(); + Collection ohItems = new HashSet(eshItems.size()); + + for(org.eclipse.smarthome.core.items.Item eshItem : eshItems) { + ohItems.add(ItemMapper.mapToOpenHABItem(eshItem)); + } + return ohItems; + } + + @Override + public Collection getItems(String pattern) { + Collection eshItems = itemUIRegistry.getItems(pattern); + Collection ohItems = new HashSet(eshItems.size()); + + for(org.eclipse.smarthome.core.items.Item eshItem : eshItems) { + ohItems.add(ItemMapper.mapToOpenHABItem(eshItem)); + } + return ohItems; + } + + @Override + public boolean isValidItemName(String itemName) { + return itemUIRegistry.isValidItemName(itemName); + } + + @Override + public void addItemRegistryChangeListener(ItemRegistryChangeListener listener) { + this.listeners.add(listener); + } + + @Override + public void removeItemRegistryChangeListener(ItemRegistryChangeListener listener) { + this.listeners.remove(listener); + } + + @Override + public void added(org.eclipse.smarthome.core.items.Item element) { + Item ohItem = ItemMapper.mapToOpenHABItem(element); + for(ItemRegistryChangeListener listener : listeners) { + listener.itemAdded(ohItem); + } + } + + @Override + public void removed(org.eclipse.smarthome.core.items.Item element) { + Item ohItem = ItemMapper.mapToOpenHABItem(element); + for(ItemRegistryChangeListener listener : listeners) { + listener.itemRemoved(ohItem); + } + } + + @Override + public void updated(org.eclipse.smarthome.core.items.Item oldElement, org.eclipse.smarthome.core.items.Item element) { + Item ohItem = ItemMapper.mapToOpenHABItem(element); + for(ItemRegistryChangeListener listener : listeners) { + listener.itemRemoved(ohItem); + listener.itemAdded(ohItem); + } + } + + @Override + public String getIcon(String itemName) { + return itemUIRegistry.getIcon(itemName); + } + + @Override + public String getLabel(String itemName) { + return itemUIRegistry.getLabel(itemName); + } + + @Override + public Widget getDefaultWidget(Class itemType, String itemName) { + return null; + } + + @Override + public Widget getWidget(String itemName) { + return null; + } + + @Override + public String getLabel(Widget w) { + return itemUIRegistry.getLabel(w.getItem()); + } + + @Override + public String getIcon(Widget w) { + return itemUIRegistry.getIcon(w.getItem()); + } + + @Override + public State getState(Widget w) { + return null; + } + + @Override + public Widget getWidget(Sitemap sitemap, String id) { + return null; + } + + @Override + public String getWidgetId(Widget w) { + return null; + } + + @Override + public EList getChildren(LinkableWidget w) { + return null; + } + + @Override + public boolean iconExists(String icon) { + return itemUIRegistry.iconExists(icon); + } + + @Override + public String getLabelColor(Widget w) { + return null; + } + + @Override + public String getValueColor(Widget w) { + return null; + } + + @Override + public boolean getVisiblity(Widget w) { + return true; + } + + @Override + public State getItemState(String itemName) { + try { + return getItem(itemName).getState(); + } catch (ItemNotFoundException e) { + return null; + } + } + +} diff --git a/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/io/net/actions/Ping.java b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/io/net/actions/Ping.java index 5d939feea7f0e..bbc5294bbb118 100644 --- a/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/io/net/actions/Ping.java +++ b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/io/net/actions/Ping.java @@ -50,9 +50,11 @@ public static boolean checkVitality(String host, int port, int timeout) throws I } else { SocketAddress socketAddress = new InetSocketAddress(host, port); - - Socket socket = new Socket(); - socket.connect(socketAddress, timeout); + + try (Socket socket = new Socket()) { + socket.connect(socketAddress, timeout); + } + success = true; } } diff --git a/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/io/net/http/SecureHttpContext.java b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/io/net/http/SecureHttpContext.java new file mode 100644 index 0000000000000..8132a2179a4c8 --- /dev/null +++ b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/io/net/http/SecureHttpContext.java @@ -0,0 +1,60 @@ +/** + * Copyright (c) 2010-2014, openHAB.org and others. + * + * 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.io.net.http; + +import java.io.IOException; +import java.net.URL; + +import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletResponse; + +import org.osgi.service.http.HttpContext; + + +/** + * Implementation of {@link HttpContext} which adds Basic-Authentication + * functionality to openHAB. + * + * @author Thomas.Eichstaedt-Engelen + * @since 0.9.0 + */ +public class SecureHttpContext implements HttpContext { + + private HttpContext defaultContext = null; + + public SecureHttpContext() { + } + + public SecureHttpContext(HttpContext defaultContext, final String realm) { + this.defaultContext = defaultContext; + } + + + /** + *

@{inheritDoc}

+ *

Delegates to defaultContext.getMimeType() + */ + public String getMimeType(String name) { + return this.defaultContext.getMimeType(name); + } + + /** + *

@{inheritDoc}

+ *

Delegates to defaultContext.getResource() + */ + public URL getResource(String name) { + return this.defaultContext.getResource(name); + } + + @Override + public boolean handleSecurity(HttpServletRequest request, HttpServletResponse response) throws IOException { + return true; + } + +} diff --git a/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Chart.java b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Chart.java new file mode 100644 index 0000000000000..b0f21c3e29b77 --- /dev/null +++ b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Chart.java @@ -0,0 +1,104 @@ +/** + */ +package org.openhab.model.sitemap; + + +/** + * + * A representation of the model object 'Chart'. + * + * + *

+ * The following features are supported: + *

    + *
  • {@link org.openhab.model.sitemap.Chart#getService Service}
  • + *
  • {@link org.openhab.model.sitemap.Chart#getRefresh Refresh}
  • + *
  • {@link org.openhab.model.sitemap.Chart#getPeriod Period}
  • + *
+ *

+ * + * @see org.openhab.model.sitemap.SitemapPackage#getChart() + * @model + * @generated + */ +public interface Chart extends NonLinkableWidget +{ + /** + * Returns the value of the 'Service' attribute. + * + *

+ * If the meaning of the 'Service' attribute isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Service' attribute. + * @see #setService(String) + * @see org.openhab.model.sitemap.SitemapPackage#getChart_Service() + * @model + * @generated + */ + String getService(); + + /** + * Sets the value of the '{@link org.openhab.model.sitemap.Chart#getService Service}' attribute. + * + * + * @param value the new value of the 'Service' attribute. + * @see #getService() + * @generated + */ + void setService(String value); + + /** + * Returns the value of the 'Refresh' attribute. + * + *

+ * If the meaning of the 'Refresh' attribute isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Refresh' attribute. + * @see #setRefresh(int) + * @see org.openhab.model.sitemap.SitemapPackage#getChart_Refresh() + * @model + * @generated + */ + int getRefresh(); + + /** + * Sets the value of the '{@link org.openhab.model.sitemap.Chart#getRefresh Refresh}' attribute. + * + * + * @param value the new value of the 'Refresh' attribute. + * @see #getRefresh() + * @generated + */ + void setRefresh(int value); + + /** + * Returns the value of the 'Period' attribute. + * + *

+ * If the meaning of the 'Period' attribute isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Period' attribute. + * @see #setPeriod(String) + * @see org.openhab.model.sitemap.SitemapPackage#getChart_Period() + * @model + * @generated + */ + String getPeriod(); + + /** + * Sets the value of the '{@link org.openhab.model.sitemap.Chart#getPeriod Period}' attribute. + * + * + * @param value the new value of the 'Period' attribute. + * @see #getPeriod() + * @generated + */ + void setPeriod(String value); + +} // Chart diff --git a/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/ColorArray.java b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/ColorArray.java new file mode 100644 index 0000000000000..8d4b59727f375 --- /dev/null +++ b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/ColorArray.java @@ -0,0 +1,159 @@ +/** + */ +package org.openhab.model.sitemap; + +import org.eclipse.emf.ecore.EObject; + +/** + * + * A representation of the model object 'Color Array'. + * + * + *

+ * The following features are supported: + *

    + *
  • {@link org.openhab.model.sitemap.ColorArray#getItem Item}
  • + *
  • {@link org.openhab.model.sitemap.ColorArray#getCondition Condition}
  • + *
  • {@link org.openhab.model.sitemap.ColorArray#getSign Sign}
  • + *
  • {@link org.openhab.model.sitemap.ColorArray#getState State}
  • + *
  • {@link org.openhab.model.sitemap.ColorArray#getArg Arg}
  • + *
+ *

+ * + * @see org.openhab.model.sitemap.SitemapPackage#getColorArray() + * @model + * @generated + */ +public interface ColorArray extends EObject +{ + /** + * Returns the value of the 'Item' attribute. + * + *

+ * If the meaning of the 'Item' attribute isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Item' attribute. + * @see #setItem(String) + * @see org.openhab.model.sitemap.SitemapPackage#getColorArray_Item() + * @model + * @generated + */ + String getItem(); + + /** + * Sets the value of the '{@link org.openhab.model.sitemap.ColorArray#getItem Item}' attribute. + * + * + * @param value the new value of the 'Item' attribute. + * @see #getItem() + * @generated + */ + void setItem(String value); + + /** + * Returns the value of the 'Condition' attribute. + * + *

+ * If the meaning of the 'Condition' attribute isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Condition' attribute. + * @see #setCondition(String) + * @see org.openhab.model.sitemap.SitemapPackage#getColorArray_Condition() + * @model + * @generated + */ + String getCondition(); + + /** + * Sets the value of the '{@link org.openhab.model.sitemap.ColorArray#getCondition Condition}' attribute. + * + * + * @param value the new value of the 'Condition' attribute. + * @see #getCondition() + * @generated + */ + void setCondition(String value); + + /** + * Returns the value of the 'Sign' attribute. + * + *

+ * If the meaning of the 'Sign' attribute isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Sign' attribute. + * @see #setSign(String) + * @see org.openhab.model.sitemap.SitemapPackage#getColorArray_Sign() + * @model + * @generated + */ + String getSign(); + + /** + * Sets the value of the '{@link org.openhab.model.sitemap.ColorArray#getSign Sign}' attribute. + * + * + * @param value the new value of the 'Sign' attribute. + * @see #getSign() + * @generated + */ + void setSign(String value); + + /** + * Returns the value of the 'State' attribute. + * + *

+ * If the meaning of the 'State' attribute isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'State' attribute. + * @see #setState(String) + * @see org.openhab.model.sitemap.SitemapPackage#getColorArray_State() + * @model + * @generated + */ + String getState(); + + /** + * Sets the value of the '{@link org.openhab.model.sitemap.ColorArray#getState State}' attribute. + * + * + * @param value the new value of the 'State' attribute. + * @see #getState() + * @generated + */ + void setState(String value); + + /** + * Returns the value of the 'Arg' attribute. + * + *

+ * If the meaning of the 'Arg' attribute isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Arg' attribute. + * @see #setArg(String) + * @see org.openhab.model.sitemap.SitemapPackage#getColorArray_Arg() + * @model + * @generated + */ + String getArg(); + + /** + * Sets the value of the '{@link org.openhab.model.sitemap.ColorArray#getArg Arg}' attribute. + * + * + * @param value the new value of the 'Arg' attribute. + * @see #getArg() + * @generated + */ + void setArg(String value); + +} // ColorArray diff --git a/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Colorpicker.java b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Colorpicker.java new file mode 100644 index 0000000000000..a3ec46013c6d1 --- /dev/null +++ b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Colorpicker.java @@ -0,0 +1,50 @@ +/** + */ +package org.openhab.model.sitemap; + + +/** + * + * A representation of the model object 'Colorpicker'. + * + * + *

+ * The following features are supported: + *

    + *
  • {@link org.openhab.model.sitemap.Colorpicker#getFrequency Frequency}
  • + *
+ *

+ * + * @see org.openhab.model.sitemap.SitemapPackage#getColorpicker() + * @model + * @generated + */ +public interface Colorpicker extends NonLinkableWidget +{ + /** + * Returns the value of the 'Frequency' attribute. + * + *

+ * If the meaning of the 'Frequency' attribute isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Frequency' attribute. + * @see #setFrequency(int) + * @see org.openhab.model.sitemap.SitemapPackage#getColorpicker_Frequency() + * @model + * @generated + */ + int getFrequency(); + + /** + * Sets the value of the '{@link org.openhab.model.sitemap.Colorpicker#getFrequency Frequency}' attribute. + * + * + * @param value the new value of the 'Frequency' attribute. + * @see #getFrequency() + * @generated + */ + void setFrequency(int value); + +} // Colorpicker diff --git a/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Frame.java b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Frame.java new file mode 100644 index 0000000000000..0d7ab945a6242 --- /dev/null +++ b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Frame.java @@ -0,0 +1,18 @@ +/** + */ +package org.openhab.model.sitemap; + + +/** + * + * A representation of the model object 'Frame'. + * + * + * + * @see org.openhab.model.sitemap.SitemapPackage#getFrame() + * @model + * @generated + */ +public interface Frame extends LinkableWidget +{ +} // Frame diff --git a/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Group.java b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Group.java new file mode 100644 index 0000000000000..5de36047d1db8 --- /dev/null +++ b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Group.java @@ -0,0 +1,18 @@ +/** + */ +package org.openhab.model.sitemap; + + +/** + * + * A representation of the model object 'Group'. + * + * + * + * @see org.openhab.model.sitemap.SitemapPackage#getGroup() + * @model + * @generated + */ +public interface Group extends LinkableWidget +{ +} // Group diff --git a/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Image.java b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Image.java new file mode 100644 index 0000000000000..50c3f3e5ce634 --- /dev/null +++ b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Image.java @@ -0,0 +1,95 @@ +/** + */ +package org.openhab.model.sitemap; + +import org.eclipse.emf.common.util.EList; + +/** + * + * A representation of the model object 'Image'. + * + * + *

+ * The following features are supported: + *

    + *
  • {@link org.openhab.model.sitemap.Image#getUrl Url}
  • + *
  • {@link org.openhab.model.sitemap.Image#getRefresh Refresh}
  • + *
  • {@link org.openhab.model.sitemap.Image#getIconColor Icon Color}
  • + *
+ *

+ * + * @see org.openhab.model.sitemap.SitemapPackage#getImage() + * @model + * @generated + */ +public interface Image extends LinkableWidget +{ + /** + * Returns the value of the 'Url' attribute. + * + *

+ * If the meaning of the 'Url' attribute isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Url' attribute. + * @see #setUrl(String) + * @see org.openhab.model.sitemap.SitemapPackage#getImage_Url() + * @model + * @generated + */ + String getUrl(); + + /** + * Sets the value of the '{@link org.openhab.model.sitemap.Image#getUrl Url}' attribute. + * + * + * @param value the new value of the 'Url' attribute. + * @see #getUrl() + * @generated + */ + void setUrl(String value); + + /** + * Returns the value of the 'Refresh' attribute. + * + *

+ * If the meaning of the 'Refresh' attribute isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Refresh' attribute. + * @see #setRefresh(int) + * @see org.openhab.model.sitemap.SitemapPackage#getImage_Refresh() + * @model + * @generated + */ + int getRefresh(); + + /** + * Sets the value of the '{@link org.openhab.model.sitemap.Image#getRefresh Refresh}' attribute. + * + * + * @param value the new value of the 'Refresh' attribute. + * @see #getRefresh() + * @generated + */ + void setRefresh(int value); + + /** + * Returns the value of the 'Icon Color' containment reference list. + * The list contents are of type {@link org.openhab.model.sitemap.ColorArray}. + * + *

+ * If the meaning of the 'Icon Color' containment reference list isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Icon Color' containment reference list. + * @see org.openhab.model.sitemap.SitemapPackage#getImage_IconColor() + * @model containment="true" + * @generated + */ + EList getIconColor(); + +} // Image diff --git a/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/LinkableWidget.java b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/LinkableWidget.java new file mode 100644 index 0000000000000..43236894c2646 --- /dev/null +++ b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/LinkableWidget.java @@ -0,0 +1,41 @@ +/** + */ +package org.openhab.model.sitemap; + +import org.eclipse.emf.common.util.EList; + +/** + * + * A representation of the model object 'Linkable Widget'. + * + * + *

+ * The following features are supported: + *

    + *
  • {@link org.openhab.model.sitemap.LinkableWidget#getChildren Children}
  • + *
+ *

+ * + * @see org.openhab.model.sitemap.SitemapPackage#getLinkableWidget() + * @model + * @generated + */ +public interface LinkableWidget extends Widget +{ + /** + * Returns the value of the 'Children' containment reference list. + * The list contents are of type {@link org.openhab.model.sitemap.Widget}. + * + *

+ * If the meaning of the 'Children' containment reference list isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Children' containment reference list. + * @see org.openhab.model.sitemap.SitemapPackage#getLinkableWidget_Children() + * @model containment="true" + * @generated + */ + EList getChildren(); + +} // LinkableWidget diff --git a/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/List.java b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/List.java new file mode 100644 index 0000000000000..6b9ab068650b6 --- /dev/null +++ b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/List.java @@ -0,0 +1,50 @@ +/** + */ +package org.openhab.model.sitemap; + + +/** + * + * A representation of the model object 'List'. + * + * + *

+ * The following features are supported: + *

    + *
  • {@link org.openhab.model.sitemap.List#getSeparator Separator}
  • + *
+ *

+ * + * @see org.openhab.model.sitemap.SitemapPackage#getList() + * @model + * @generated + */ +public interface List extends NonLinkableWidget +{ + /** + * Returns the value of the 'Separator' attribute. + * + *

+ * If the meaning of the 'Separator' attribute isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Separator' attribute. + * @see #setSeparator(String) + * @see org.openhab.model.sitemap.SitemapPackage#getList_Separator() + * @model + * @generated + */ + String getSeparator(); + + /** + * Sets the value of the '{@link org.openhab.model.sitemap.List#getSeparator Separator}' attribute. + * + * + * @param value the new value of the 'Separator' attribute. + * @see #getSeparator() + * @generated + */ + void setSeparator(String value); + +} // List diff --git a/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Mapping.java b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Mapping.java new file mode 100644 index 0000000000000..3b66359020802 --- /dev/null +++ b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Mapping.java @@ -0,0 +1,78 @@ +/** + */ +package org.openhab.model.sitemap; + +import org.eclipse.emf.ecore.EObject; + +/** + * + * A representation of the model object 'Mapping'. + * + * + *

+ * The following features are supported: + *

    + *
  • {@link org.openhab.model.sitemap.Mapping#getCmd Cmd}
  • + *
  • {@link org.openhab.model.sitemap.Mapping#getLabel Label}
  • + *
+ *

+ * + * @see org.openhab.model.sitemap.SitemapPackage#getMapping() + * @model + * @generated + */ +public interface Mapping extends EObject +{ + /** + * Returns the value of the 'Cmd' attribute. + * + *

+ * If the meaning of the 'Cmd' attribute isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Cmd' attribute. + * @see #setCmd(String) + * @see org.openhab.model.sitemap.SitemapPackage#getMapping_Cmd() + * @model + * @generated + */ + String getCmd(); + + /** + * Sets the value of the '{@link org.openhab.model.sitemap.Mapping#getCmd Cmd}' attribute. + * + * + * @param value the new value of the 'Cmd' attribute. + * @see #getCmd() + * @generated + */ + void setCmd(String value); + + /** + * Returns the value of the 'Label' attribute. + * + *

+ * If the meaning of the 'Label' attribute isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Label' attribute. + * @see #setLabel(String) + * @see org.openhab.model.sitemap.SitemapPackage#getMapping_Label() + * @model + * @generated + */ + String getLabel(); + + /** + * Sets the value of the '{@link org.openhab.model.sitemap.Mapping#getLabel Label}' attribute. + * + * + * @param value the new value of the 'Label' attribute. + * @see #getLabel() + * @generated + */ + void setLabel(String value); + +} // Mapping diff --git a/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/NonLinkableWidget.java b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/NonLinkableWidget.java new file mode 100644 index 0000000000000..a44084587a4e3 --- /dev/null +++ b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/NonLinkableWidget.java @@ -0,0 +1,18 @@ +/** + */ +package org.openhab.model.sitemap; + + +/** + * + * A representation of the model object 'Non Linkable Widget'. + * + * + * + * @see org.openhab.model.sitemap.SitemapPackage#getNonLinkableWidget() + * @model + * @generated + */ +public interface NonLinkableWidget extends Widget +{ +} // NonLinkableWidget diff --git a/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Selection.java b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Selection.java new file mode 100644 index 0000000000000..36784aafcc822 --- /dev/null +++ b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Selection.java @@ -0,0 +1,41 @@ +/** + */ +package org.openhab.model.sitemap; + +import org.eclipse.emf.common.util.EList; + +/** + * + * A representation of the model object 'Selection'. + * + * + *

+ * The following features are supported: + *

    + *
  • {@link org.openhab.model.sitemap.Selection#getMappings Mappings}
  • + *
+ *

+ * + * @see org.openhab.model.sitemap.SitemapPackage#getSelection() + * @model + * @generated + */ +public interface Selection extends NonLinkableWidget +{ + /** + * Returns the value of the 'Mappings' containment reference list. + * The list contents are of type {@link org.openhab.model.sitemap.Mapping}. + * + *

+ * If the meaning of the 'Mappings' containment reference list isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Mappings' containment reference list. + * @see org.openhab.model.sitemap.SitemapPackage#getSelection_Mappings() + * @model containment="true" + * @generated + */ + EList getMappings(); + +} // Selection diff --git a/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Setpoint.java b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Setpoint.java new file mode 100644 index 0000000000000..bca7016396af5 --- /dev/null +++ b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Setpoint.java @@ -0,0 +1,105 @@ +/** + */ +package org.openhab.model.sitemap; + +import java.math.BigDecimal; + +/** + * + * A representation of the model object 'Setpoint'. + * + * + *

+ * The following features are supported: + *

    + *
  • {@link org.openhab.model.sitemap.Setpoint#getMinValue Min Value}
  • + *
  • {@link org.openhab.model.sitemap.Setpoint#getMaxValue Max Value}
  • + *
  • {@link org.openhab.model.sitemap.Setpoint#getStep Step}
  • + *
+ *

+ * + * @see org.openhab.model.sitemap.SitemapPackage#getSetpoint() + * @model + * @generated + */ +public interface Setpoint extends NonLinkableWidget +{ + /** + * Returns the value of the 'Min Value' attribute. + * + *

+ * If the meaning of the 'Min Value' attribute isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Min Value' attribute. + * @see #setMinValue(BigDecimal) + * @see org.openhab.model.sitemap.SitemapPackage#getSetpoint_MinValue() + * @model + * @generated + */ + BigDecimal getMinValue(); + + /** + * Sets the value of the '{@link org.openhab.model.sitemap.Setpoint#getMinValue Min Value}' attribute. + * + * + * @param value the new value of the 'Min Value' attribute. + * @see #getMinValue() + * @generated + */ + void setMinValue(BigDecimal value); + + /** + * Returns the value of the 'Max Value' attribute. + * + *

+ * If the meaning of the 'Max Value' attribute isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Max Value' attribute. + * @see #setMaxValue(BigDecimal) + * @see org.openhab.model.sitemap.SitemapPackage#getSetpoint_MaxValue() + * @model + * @generated + */ + BigDecimal getMaxValue(); + + /** + * Sets the value of the '{@link org.openhab.model.sitemap.Setpoint#getMaxValue Max Value}' attribute. + * + * + * @param value the new value of the 'Max Value' attribute. + * @see #getMaxValue() + * @generated + */ + void setMaxValue(BigDecimal value); + + /** + * Returns the value of the 'Step' attribute. + * + *

+ * If the meaning of the 'Step' attribute isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Step' attribute. + * @see #setStep(BigDecimal) + * @see org.openhab.model.sitemap.SitemapPackage#getSetpoint_Step() + * @model + * @generated + */ + BigDecimal getStep(); + + /** + * Sets the value of the '{@link org.openhab.model.sitemap.Setpoint#getStep Step}' attribute. + * + * + * @param value the new value of the 'Step' attribute. + * @see #getStep() + * @generated + */ + void setStep(BigDecimal value); + +} // Setpoint diff --git a/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Sitemap.java b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Sitemap.java new file mode 100644 index 0000000000000..c01b333876df2 --- /dev/null +++ b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Sitemap.java @@ -0,0 +1,122 @@ +/** + */ +package org.openhab.model.sitemap; + +import org.eclipse.emf.common.util.EList; + +/** + * + * A representation of the model object 'Sitemap'. + * + * + *

+ * The following features are supported: + *

    + *
  • {@link org.openhab.model.sitemap.Sitemap#getName Name}
  • + *
  • {@link org.openhab.model.sitemap.Sitemap#getLabel Label}
  • + *
  • {@link org.openhab.model.sitemap.Sitemap#getIcon Icon}
  • + *
  • {@link org.openhab.model.sitemap.Sitemap#getChildren Children}
  • + *
+ *

+ * + * @see org.openhab.model.sitemap.SitemapPackage#getSitemap() + * @model + * @generated + */ +public interface Sitemap extends SitemapModel +{ + /** + * Returns the value of the 'Name' attribute. + * + *

+ * If the meaning of the 'Name' attribute isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Name' attribute. + * @see #setName(String) + * @see org.openhab.model.sitemap.SitemapPackage#getSitemap_Name() + * @model + * @generated + */ + String getName(); + + /** + * Sets the value of the '{@link org.openhab.model.sitemap.Sitemap#getName Name}' attribute. + * + * + * @param value the new value of the 'Name' attribute. + * @see #getName() + * @generated + */ + void setName(String value); + + /** + * Returns the value of the 'Label' attribute. + * + *

+ * If the meaning of the 'Label' attribute isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Label' attribute. + * @see #setLabel(String) + * @see org.openhab.model.sitemap.SitemapPackage#getSitemap_Label() + * @model + * @generated + */ + String getLabel(); + + /** + * Sets the value of the '{@link org.openhab.model.sitemap.Sitemap#getLabel Label}' attribute. + * + * + * @param value the new value of the 'Label' attribute. + * @see #getLabel() + * @generated + */ + void setLabel(String value); + + /** + * Returns the value of the 'Icon' attribute. + * + *

+ * If the meaning of the 'Icon' attribute isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Icon' attribute. + * @see #setIcon(String) + * @see org.openhab.model.sitemap.SitemapPackage#getSitemap_Icon() + * @model + * @generated + */ + String getIcon(); + + /** + * Sets the value of the '{@link org.openhab.model.sitemap.Sitemap#getIcon Icon}' attribute. + * + * + * @param value the new value of the 'Icon' attribute. + * @see #getIcon() + * @generated + */ + void setIcon(String value); + + /** + * Returns the value of the 'Children' containment reference list. + * The list contents are of type {@link org.openhab.model.sitemap.Widget}. + * + *

+ * If the meaning of the 'Children' containment reference list isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Children' containment reference list. + * @see org.openhab.model.sitemap.SitemapPackage#getSitemap_Children() + * @model containment="true" + * @generated + */ + EList getChildren(); + +} // Sitemap diff --git a/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/SitemapModel.java b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/SitemapModel.java new file mode 100644 index 0000000000000..19ff030deecf9 --- /dev/null +++ b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/SitemapModel.java @@ -0,0 +1,19 @@ +/** + */ +package org.openhab.model.sitemap; + +import org.eclipse.emf.ecore.EObject; + +/** + * + * A representation of the model object 'Model'. + * + * + * + * @see org.openhab.model.sitemap.SitemapPackage#getSitemapModel() + * @model + * @generated + */ +public interface SitemapModel extends EObject +{ +} // SitemapModel diff --git a/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Slider.java b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Slider.java new file mode 100644 index 0000000000000..135b055b7f3c4 --- /dev/null +++ b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Slider.java @@ -0,0 +1,77 @@ +/** + */ +package org.openhab.model.sitemap; + + +/** + * + * A representation of the model object 'Slider'. + * + * + *

+ * The following features are supported: + *

    + *
  • {@link org.openhab.model.sitemap.Slider#getFrequency Frequency}
  • + *
  • {@link org.openhab.model.sitemap.Slider#isSwitchEnabled Switch Enabled}
  • + *
+ *

+ * + * @see org.openhab.model.sitemap.SitemapPackage#getSlider() + * @model + * @generated + */ +public interface Slider extends NonLinkableWidget +{ + /** + * Returns the value of the 'Frequency' attribute. + * + *

+ * If the meaning of the 'Frequency' attribute isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Frequency' attribute. + * @see #setFrequency(int) + * @see org.openhab.model.sitemap.SitemapPackage#getSlider_Frequency() + * @model + * @generated + */ + int getFrequency(); + + /** + * Sets the value of the '{@link org.openhab.model.sitemap.Slider#getFrequency Frequency}' attribute. + * + * + * @param value the new value of the 'Frequency' attribute. + * @see #getFrequency() + * @generated + */ + void setFrequency(int value); + + /** + * Returns the value of the 'Switch Enabled' attribute. + * + *

+ * If the meaning of the 'Switch Enabled' attribute isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Switch Enabled' attribute. + * @see #setSwitchEnabled(boolean) + * @see org.openhab.model.sitemap.SitemapPackage#getSlider_SwitchEnabled() + * @model + * @generated + */ + boolean isSwitchEnabled(); + + /** + * Sets the value of the '{@link org.openhab.model.sitemap.Slider#isSwitchEnabled Switch Enabled}' attribute. + * + * + * @param value the new value of the 'Switch Enabled' attribute. + * @see #isSwitchEnabled() + * @generated + */ + void setSwitchEnabled(boolean value); + +} // Slider diff --git a/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Switch.java b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Switch.java new file mode 100644 index 0000000000000..9e25290d7d256 --- /dev/null +++ b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Switch.java @@ -0,0 +1,41 @@ +/** + */ +package org.openhab.model.sitemap; + +import org.eclipse.emf.common.util.EList; + +/** + * + * A representation of the model object 'Switch'. + * + * + *

+ * The following features are supported: + *

    + *
  • {@link org.openhab.model.sitemap.Switch#getMappings Mappings}
  • + *
+ *

+ * + * @see org.openhab.model.sitemap.SitemapPackage#getSwitch() + * @model + * @generated + */ +public interface Switch extends NonLinkableWidget +{ + /** + * Returns the value of the 'Mappings' containment reference list. + * The list contents are of type {@link org.openhab.model.sitemap.Mapping}. + * + *

+ * If the meaning of the 'Mappings' containment reference list isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Mappings' containment reference list. + * @see org.openhab.model.sitemap.SitemapPackage#getSwitch_Mappings() + * @model containment="true" + * @generated + */ + EList getMappings(); + +} // Switch diff --git a/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Text.java b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Text.java new file mode 100644 index 0000000000000..07c57d5676db1 --- /dev/null +++ b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Text.java @@ -0,0 +1,18 @@ +/** + */ +package org.openhab.model.sitemap; + + +/** + * + * A representation of the model object 'Text'. + * + * + * + * @see org.openhab.model.sitemap.SitemapPackage#getText() + * @model + * @generated + */ +public interface Text extends LinkableWidget +{ +} // Text diff --git a/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Video.java b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Video.java new file mode 100644 index 0000000000000..379a1bee0df93 --- /dev/null +++ b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Video.java @@ -0,0 +1,50 @@ +/** + */ +package org.openhab.model.sitemap; + + +/** + * + * A representation of the model object 'Video'. + * + * + *

+ * The following features are supported: + *

    + *
  • {@link org.openhab.model.sitemap.Video#getUrl Url}
  • + *
+ *

+ * + * @see org.openhab.model.sitemap.SitemapPackage#getVideo() + * @model + * @generated + */ +public interface Video extends NonLinkableWidget +{ + /** + * Returns the value of the 'Url' attribute. + * + *

+ * If the meaning of the 'Url' attribute isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Url' attribute. + * @see #setUrl(String) + * @see org.openhab.model.sitemap.SitemapPackage#getVideo_Url() + * @model + * @generated + */ + String getUrl(); + + /** + * Sets the value of the '{@link org.openhab.model.sitemap.Video#getUrl Url}' attribute. + * + * + * @param value the new value of the 'Url' attribute. + * @see #getUrl() + * @generated + */ + void setUrl(String value); + +} // Video diff --git a/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/VisibilityRule.java b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/VisibilityRule.java new file mode 100644 index 0000000000000..3eac63a984020 --- /dev/null +++ b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/VisibilityRule.java @@ -0,0 +1,132 @@ +/** + */ +package org.openhab.model.sitemap; + +import org.eclipse.emf.ecore.EObject; + +/** + * + * A representation of the model object 'Visibility Rule'. + * + * + *

+ * The following features are supported: + *

    + *
  • {@link org.openhab.model.sitemap.VisibilityRule#getItem Item}
  • + *
  • {@link org.openhab.model.sitemap.VisibilityRule#getCondition Condition}
  • + *
  • {@link org.openhab.model.sitemap.VisibilityRule#getSign Sign}
  • + *
  • {@link org.openhab.model.sitemap.VisibilityRule#getState State}
  • + *
+ *

+ * + * @see org.openhab.model.sitemap.SitemapPackage#getVisibilityRule() + * @model + * @generated + */ +public interface VisibilityRule extends EObject +{ + /** + * Returns the value of the 'Item' attribute. + * + *

+ * If the meaning of the 'Item' attribute isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Item' attribute. + * @see #setItem(String) + * @see org.openhab.model.sitemap.SitemapPackage#getVisibilityRule_Item() + * @model + * @generated + */ + String getItem(); + + /** + * Sets the value of the '{@link org.openhab.model.sitemap.VisibilityRule#getItem Item}' attribute. + * + * + * @param value the new value of the 'Item' attribute. + * @see #getItem() + * @generated + */ + void setItem(String value); + + /** + * Returns the value of the 'Condition' attribute. + * + *

+ * If the meaning of the 'Condition' attribute isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Condition' attribute. + * @see #setCondition(String) + * @see org.openhab.model.sitemap.SitemapPackage#getVisibilityRule_Condition() + * @model + * @generated + */ + String getCondition(); + + /** + * Sets the value of the '{@link org.openhab.model.sitemap.VisibilityRule#getCondition Condition}' attribute. + * + * + * @param value the new value of the 'Condition' attribute. + * @see #getCondition() + * @generated + */ + void setCondition(String value); + + /** + * Returns the value of the 'Sign' attribute. + * + *

+ * If the meaning of the 'Sign' attribute isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Sign' attribute. + * @see #setSign(String) + * @see org.openhab.model.sitemap.SitemapPackage#getVisibilityRule_Sign() + * @model + * @generated + */ + String getSign(); + + /** + * Sets the value of the '{@link org.openhab.model.sitemap.VisibilityRule#getSign Sign}' attribute. + * + * + * @param value the new value of the 'Sign' attribute. + * @see #getSign() + * @generated + */ + void setSign(String value); + + /** + * Returns the value of the 'State' attribute. + * + *

+ * If the meaning of the 'State' attribute isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'State' attribute. + * @see #setState(String) + * @see org.openhab.model.sitemap.SitemapPackage#getVisibilityRule_State() + * @model + * @generated + */ + String getState(); + + /** + * Sets the value of the '{@link org.openhab.model.sitemap.VisibilityRule#getState State}' attribute. + * + * + * @param value the new value of the 'State' attribute. + * @see #getState() + * @generated + */ + void setState(String value); + +} // VisibilityRule diff --git a/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Webview.java b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Webview.java new file mode 100644 index 0000000000000..4ec866416fa22 --- /dev/null +++ b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Webview.java @@ -0,0 +1,77 @@ +/** + */ +package org.openhab.model.sitemap; + + +/** + * + * A representation of the model object 'Webview'. + * + * + *

+ * The following features are supported: + *

    + *
  • {@link org.openhab.model.sitemap.Webview#getHeight Height}
  • + *
  • {@link org.openhab.model.sitemap.Webview#getUrl Url}
  • + *
+ *

+ * + * @see org.openhab.model.sitemap.SitemapPackage#getWebview() + * @model + * @generated + */ +public interface Webview extends NonLinkableWidget +{ + /** + * Returns the value of the 'Height' attribute. + * + *

+ * If the meaning of the 'Height' attribute isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Height' attribute. + * @see #setHeight(int) + * @see org.openhab.model.sitemap.SitemapPackage#getWebview_Height() + * @model + * @generated + */ + int getHeight(); + + /** + * Sets the value of the '{@link org.openhab.model.sitemap.Webview#getHeight Height}' attribute. + * + * + * @param value the new value of the 'Height' attribute. + * @see #getHeight() + * @generated + */ + void setHeight(int value); + + /** + * Returns the value of the 'Url' attribute. + * + *

+ * If the meaning of the 'Url' attribute isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Url' attribute. + * @see #setUrl(String) + * @see org.openhab.model.sitemap.SitemapPackage#getWebview_Url() + * @model + * @generated + */ + String getUrl(); + + /** + * Sets the value of the '{@link org.openhab.model.sitemap.Webview#getUrl Url}' attribute. + * + * + * @param value the new value of the 'Url' attribute. + * @see #getUrl() + * @generated + */ + void setUrl(String value); + +} // Webview diff --git a/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Widget.java b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Widget.java new file mode 100644 index 0000000000000..9cbd6342370b2 --- /dev/null +++ b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/model/sitemap/Widget.java @@ -0,0 +1,158 @@ +/** + */ +package org.openhab.model.sitemap; + +import org.eclipse.emf.common.util.EList; + +import org.eclipse.emf.ecore.EObject; + +/** + * + * A representation of the model object 'Widget'. + * + * + *

+ * The following features are supported: + *

    + *
  • {@link org.openhab.model.sitemap.Widget#getItem Item}
  • + *
  • {@link org.openhab.model.sitemap.Widget#getLabel Label}
  • + *
  • {@link org.openhab.model.sitemap.Widget#getIcon Icon}
  • + *
  • {@link org.openhab.model.sitemap.Widget#getLabelColor Label Color}
  • + *
  • {@link org.openhab.model.sitemap.Widget#getValueColor Value Color}
  • + *
  • {@link org.openhab.model.sitemap.Widget#getVisibility Visibility}
  • + *
+ *

+ * + * @see org.openhab.model.sitemap.SitemapPackage#getWidget() + * @model + * @generated + */ +public interface Widget extends EObject +{ + /** + * Returns the value of the 'Item' attribute. + * + *

+ * If the meaning of the 'Item' attribute isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Item' attribute. + * @see #setItem(String) + * @see org.openhab.model.sitemap.SitemapPackage#getWidget_Item() + * @model + * @generated + */ + String getItem(); + + /** + * Sets the value of the '{@link org.openhab.model.sitemap.Widget#getItem Item}' attribute. + * + * + * @param value the new value of the 'Item' attribute. + * @see #getItem() + * @generated + */ + void setItem(String value); + + /** + * Returns the value of the 'Label' attribute. + * + *

+ * If the meaning of the 'Label' attribute isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Label' attribute. + * @see #setLabel(String) + * @see org.openhab.model.sitemap.SitemapPackage#getWidget_Label() + * @model + * @generated + */ + String getLabel(); + + /** + * Sets the value of the '{@link org.openhab.model.sitemap.Widget#getLabel Label}' attribute. + * + * + * @param value the new value of the 'Label' attribute. + * @see #getLabel() + * @generated + */ + void setLabel(String value); + + /** + * Returns the value of the 'Icon' attribute. + * + *

+ * If the meaning of the 'Icon' attribute isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Icon' attribute. + * @see #setIcon(String) + * @see org.openhab.model.sitemap.SitemapPackage#getWidget_Icon() + * @model + * @generated + */ + String getIcon(); + + /** + * Sets the value of the '{@link org.openhab.model.sitemap.Widget#getIcon Icon}' attribute. + * + * + * @param value the new value of the 'Icon' attribute. + * @see #getIcon() + * @generated + */ + void setIcon(String value); + + /** + * Returns the value of the 'Label Color' containment reference list. + * The list contents are of type {@link org.openhab.model.sitemap.ColorArray}. + * + *

+ * If the meaning of the 'Label Color' containment reference list isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Label Color' containment reference list. + * @see org.openhab.model.sitemap.SitemapPackage#getWidget_LabelColor() + * @model containment="true" + * @generated + */ + EList getLabelColor(); + + /** + * Returns the value of the 'Value Color' containment reference list. + * The list contents are of type {@link org.openhab.model.sitemap.ColorArray}. + * + *

+ * If the meaning of the 'Value Color' containment reference list isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Value Color' containment reference list. + * @see org.openhab.model.sitemap.SitemapPackage#getWidget_ValueColor() + * @model containment="true" + * @generated + */ + EList getValueColor(); + + /** + * Returns the value of the 'Visibility' containment reference list. + * The list contents are of type {@link org.openhab.model.sitemap.VisibilityRule}. + * + *

+ * If the meaning of the 'Visibility' containment reference list isn't clear, + * there really should be more of a description here... + *

+ * + * @return the value of the 'Visibility' containment reference list. + * @see org.openhab.model.sitemap.SitemapPackage#getWidget_Visibility() + * @model containment="true" + * @generated + */ + EList getVisibility(); + +} // Widget diff --git a/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/ui/chart/ChartProvider.java b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/ui/chart/ChartProvider.java new file mode 100644 index 0000000000000..17dfeb5f8ae2f --- /dev/null +++ b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/ui/chart/ChartProvider.java @@ -0,0 +1,82 @@ +package org.openhab.ui.chart; + +import java.awt.image.BufferedImage; +import java.util.Date; + +import org.openhab.core.items.ItemNotFoundException; + +/** + * Defines the interface for chart providers. A chart provider interfaces with + * the persistence store to get the data and receives parameters from the UI + * chart servlet and returns a chart image object (PNG). + * + * @author Chris Jackson + * @since 1.4.0 + * + * + */ +public interface ChartProvider { + /** + * Gets the name of this chart provider. + * + * @return String containing the provider name + */ + String getName(); + + /** + * Creates a chart object. This sets the initial parameters for the chart + * before the items are added + * + * @param service + * A string containing the name of the persistence service. May + * be null in which case the chart provider can decide itself + * which store to use. + * @param widget + * The widget ID. This allows the chart provider to look up the + * widget and get the items directly from the sitemap definition. + * May be null. + * @param theme + * A string containing a theme name for the chart. The provider + * should store its own themes. May be null to use a default + * theme. + * @param height + * The height of the chart. + * @param width + * The width of the chart. + * @param startTime + * The start time of the chart + * @param endTime + * The end time of the chart + * @param height + * The height of the chart + * @param width + * The width of the chart + * @param items + * The items to display on the chart + * @param groups + * The groups to display on the chart + * + * @return BufferedImage object if the chart is rendered correctly, + * otherwise null. + * + * @throws ItemNotFoundException if an item or group is not found + * @throws IllegalArgumentException if an invalid argument is passed + */ + BufferedImage createChart(String service, String theme, Date startTime, Date endTime, int height, + int width, String items, String groups) throws ItemNotFoundException; + + /** + * Gets the type of data that will be written by the chart. + * + * @return ImageType + */ + ImageType getChartType(); + + /** + * Provides a list of image types + * + */ + public enum ImageType { + png, jpg, gif; + } +} diff --git a/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/ui/chart/internal/ChartProviderDelegate.java b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/ui/chart/internal/ChartProviderDelegate.java new file mode 100644 index 0000000000000..e6c0338db2c17 --- /dev/null +++ b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/ui/chart/internal/ChartProviderDelegate.java @@ -0,0 +1,54 @@ +/** + * Copyright (c) 2014-2015 openHAB UG (haftungsbeschraenkt) and others. + * + * 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.ui.chart.internal; + +import java.awt.image.BufferedImage; +import java.util.Date; + +import org.apache.commons.lang.StringUtils; +import org.eclipse.smarthome.core.items.ItemNotFoundException; +import org.openhab.ui.chart.ChartProvider; + + +/** + * This class serves as a mapping from the "old" org.openhab namespace to the new org.eclipse.smarthome + * namespace for the action service. It wraps an instance with the old interface + * into a class with the new interface. + * + * @author Kai Kreuzer - Initial contribution and API + */ +public class ChartProviderDelegate implements org.eclipse.smarthome.ui.chart.ChartProvider { + + private ChartProvider provider; + + public ChartProviderDelegate(ChartProvider chartProvider) { + this.provider = chartProvider; + } + + @Override + public String getName() { + return provider.getName(); + } + + @Override + public BufferedImage createChart(String service, String theme, Date startTime, Date endTime, int height, int width, + String items, String groups) throws ItemNotFoundException { + try { + return provider.createChart(service, theme, startTime, endTime, height, width, items, groups); + } catch (org.openhab.core.items.ItemNotFoundException e) { + throw new ItemNotFoundException(StringUtils.substringBetween(e.getMessage(), "'")); + } + } + + @Override + public ImageType getChartType() { + return ImageType.valueOf(provider.getChartType().name()); + } + +} diff --git a/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/ui/chart/internal/ChartProviderFactory.java b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/ui/chart/internal/ChartProviderFactory.java new file mode 100644 index 0000000000000..393e9664c0c1d --- /dev/null +++ b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/ui/chart/internal/ChartProviderFactory.java @@ -0,0 +1,82 @@ +/** + * Copyright (c) 2014-2015 openHAB UG (haftungsbeschraenkt) and others. + * + * 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.ui.chart.internal; + +import java.util.Dictionary; +import java.util.HashMap; +import java.util.HashSet; +import java.util.Hashtable; +import java.util.Map; +import java.util.Set; + +import org.openhab.ui.chart.ChartProvider; +import org.osgi.framework.BundleContext; +import org.osgi.framework.ServiceRegistration; + +/** + * This class listens for services that implement the old chart provider service interface and registers + * an according service for each under the new interface. + * + * @author Kai Kreuzer - Initial contribution and API + */ +public class ChartProviderFactory { + + private Map> delegates = new HashMap<>(); + private BundleContext context; + + private Set chartProviders = new HashSet<>(); + + public void activate(BundleContext context) { + this.context = context; + for(ChartProvider provider : chartProviders) { + registerDelegateProvider(provider); + } + } + + public void deactivate() { + for(ServiceRegistration serviceReg : delegates.values()) { + serviceReg.unregister(); + } + delegates.clear(); + this.context = null; + } + + public void addChartProvider(ChartProvider provider) { + if(context!=null) { + registerDelegateProvider(provider); + } else { + chartProviders.add(provider); + } + } + + public void removeChartProvider(ChartProvider provider) { + if(context!=null) { + unregisterDelegateProvider(provider); + } + } + + private void registerDelegateProvider(ChartProvider chartProvider) { + if(!delegates.containsKey(chartProvider.getName())) { + ChartProviderDelegate service = new ChartProviderDelegate(chartProvider); + Dictionary props = new Hashtable(); + ServiceRegistration serviceReg = + context.registerService(org.eclipse.smarthome.ui.chart.ChartProvider.class, service, props); + delegates.put(chartProvider.getName(), serviceReg); + } + } + + private void unregisterDelegateProvider(ChartProvider chartProvider) { + if(delegates.containsKey(chartProvider.getName())) { + ServiceRegistration serviceReg = + delegates.get(chartProvider.getName()); + delegates.remove(chartProvider.getName()); + serviceReg.unregister(); + } + } +} diff --git a/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/ui/items/ItemUIProvider.java b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/ui/items/ItemUIProvider.java new file mode 100644 index 0000000000000..6ea8ec247b8a7 --- /dev/null +++ b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/ui/items/ItemUIProvider.java @@ -0,0 +1,68 @@ +/** + * Copyright (c) 2010-2014, openHAB.org and others. + * + * 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.ui.items; + +import org.openhab.core.items.Item; +import org.openhab.model.sitemap.Widget; + + +/** + * This interface describes the methods that need to be implemented by a provider that + * wants to define the appearance of an item in the UI. + * + * @author Kai Kreuzer + * + */ +public interface ItemUIProvider { + + /** + * Returns the name of a bitmap to use as an icon. This name does not need to include + * state information or a file extension; if these are missing, they will be automatically added. + * + * TODO: Note that the consumer of this provider needs to be aware of these icons, so we + * have some implicit dependency between them. Maybe worth refactoring? + * + * @param itemName the name of the item to return the icon for + * @return the name of the icon to use or null if undefined. + */ + public String getIcon(String itemName); + + /** + * Returns the label text to be used for an item in the UI. + * + * @param item the name of the item to return the label text for + * @return the label text to be used in the UI or null if undefined. + */ + public String getLabel(String itemName); + + /** + * Provides a default widget for a given item (class). This is used whenever + * the UI needs to be created dynamically and there is no other source + * of information about the widgets. + * + * @param itemType the class of the item + * @param itemName the item name to get the default widget for + * + * @return a widget implementation that can be used for the given item + */ + public Widget getDefaultWidget(Class itemType, String itemName); + + /** + *

Provides a widget for a given item. This can be used to overwrite the widget + * listed in the sitemap. A use case for this is that the sitemap defines merely + * the parent-child-relation of widgets, but the concrete widget to be used for + * rendering might be selected dynamically at runtime.

+ *

If the sitemap widget should not be overridden, this method must return + * null.

+ * + * @param itemName the item name to get the widget for + * @return a widget to use for the given item or null if sitemap should not be overridden. + */ + public Widget getWidget(String itemName); +} diff --git a/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/ui/items/ItemUIRegistry.java b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/ui/items/ItemUIRegistry.java new file mode 100644 index 0000000000000..f78376b53c90c --- /dev/null +++ b/bundles/core/org.openhab.core.compat1x/src/main/java/org/openhab/ui/items/ItemUIRegistry.java @@ -0,0 +1,158 @@ +/** + * Copyright (c) 2010-2014, openHAB.org and others. + * + * 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.ui.items; + +import org.eclipse.emf.common.util.EList; +import org.openhab.core.items.ItemRegistry; +import org.openhab.core.types.State; +import org.openhab.model.sitemap.LinkableWidget; +import org.openhab.model.sitemap.Sitemap; +import org.openhab.model.sitemap.Widget; + +/** + * This interface is used by a service which combines the core item registry + * with an aggregation of item ui providers; it can be therefore widely used for + * all UI related information requests regarding items. + * + * @author Kai Kreuzer + * @author Chris Jackson + * @since 0.8.0 + * + */ +public interface ItemUIRegistry extends ItemRegistry, ItemUIProvider { + + /** + * Retrieves the label for a widget. + * + * This first checks, if there is a label defined in the sitemap. If not, it + * checks all item UI providers for a label. If no label can be found, it is + * set to an empty string. + * + * If the label contains a "[%format]" section, i.e. + * “[%s]" for a string or "[%.3f]" for a decimal, this is replaced by the + * current value of the item and padded by a "" element. + * + * @param w + * the widget to retrieve the label for + * @return the label to use for the widget + */ + public String getLabel(Widget w); + + /** + * Retrieves the icon name for a widget. + * + * This first checks, if there is an icon defined in the sitemap. If not, if + * checks all item UI providers for an icon. If no icon can be found, the + * default icon name is the widget type name, e.g. "switch". + * + * If the icon name does not contain a "-" and has a state other than + * "undefined", its current state is appended to the icon name, e.g. + * "switch-on". If no such icon exists, the base icon ("switch") will be + * returned nonetheless. + * + * @param w + * the widget to retrieve the icon name for + * @return the icon name to use for the widget + */ + public String getIcon(Widget w); + + /** + * Retrieves the current state of the item of a widget or + * UnDefType.UNDEF. + * + * @param w + * the widget to retrieve the item state for + * @return the item state of the widget + */ + public State getState(Widget w); + + /** + * Retrieves the widget for a given id on a given sitemap. + * + * @param sitemap + * the sitemap to look for the widget + * @param id + * the id of the widget to look for + * @return the widget for the given id + */ + public Widget getWidget(Sitemap sitemap, String id); + + /** + * Provides an id for a widget. + * + * This constructs a string out of the position of the sitemap, so if this + * widget is the third child of a page linked from the fifth widget on the + * home screen, its id would be "0503". If the widget is dynamically created + * and not available in the sitemap, the name of its associated item is used + * instead. + * + * @param w + * the widget to get the id for + * @return an id for this widget + */ + public String getWidgetId(Widget w); + + /** + * this should be used instead of LinkableWidget.getChildren() as there + * might be no children defined on the widget, but they should be + * dynamically determined by looking at the members of the underlying item. + * + * @param w + * the widget to retrieve the children for + * @return the (dynamically or statically defined) children of the widget + */ + public EList getChildren(LinkableWidget w); + + /** + * Checks whether an icon with a given name exists + * + * @param icon + * the icon name to check + * @return true, if the icon exists + */ + public boolean iconExists(String icon); + + /** + * Gets the label color for the widget. Checks conditional statements to + * find the color based on the item value + * + * @param w + * Widget + * @return String with the color + */ + public String getLabelColor(Widget w); + + /** + * Gets the value color for the widget. Checks conditional statements to + * find the color based on the item value + * + * @param w + * Widget + * @return String with the color + */ + public String getValueColor(Widget w); + + /** + * Gets the widget visibility based on the item state + * + * @param w + * Widget + * @return true if the item is visible + */ + public boolean getVisiblity(Widget w); + + /** + * Gets the item state + * + * @param itemName + * item name + * @return State of the item + */ + public State getItemState(String itemName); +} diff --git a/bundles/core/org.openhab.core.init/.classpath b/bundles/core/org.openhab.core.init/.classpath index 913a170d25eb1..1e446acfc621c 100644 --- a/bundles/core/org.openhab.core.init/.classpath +++ b/bundles/core/org.openhab.core.init/.classpath @@ -1,8 +1,8 @@ + + - - diff --git a/bundles/core/org.openhab.core.init/.settings/org.eclipse.jdt.core.prefs b/bundles/core/org.openhab.core.init/.settings/org.eclipse.jdt.core.prefs index 4ede96d8a736c..443e08599a2e6 100644 --- a/bundles/core/org.openhab.core.init/.settings/org.eclipse.jdt.core.prefs +++ b/bundles/core/org.openhab.core.init/.settings/org.eclipse.jdt.core.prefs @@ -1,2 +1,8 @@ eclipse.preferences.version=1 +org.eclipse.jdt.core.compiler.codegen.inlineJsrBytecode=enabled +org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.7 +org.eclipse.jdt.core.compiler.compliance=1.7 +org.eclipse.jdt.core.compiler.problem.assertIdentifier=error +org.eclipse.jdt.core.compiler.problem.enumIdentifier=error org.eclipse.jdt.core.compiler.problem.forbiddenReference=warning +org.eclipse.jdt.core.compiler.source=1.7 diff --git a/bundles/core/org.openhab.core/.classpath b/bundles/core/org.openhab.core/.classpath index 913a170d25eb1..1e446acfc621c 100644 --- a/bundles/core/org.openhab.core/.classpath +++ b/bundles/core/org.openhab.core/.classpath @@ -1,8 +1,8 @@ + + - - diff --git a/bundles/core/org.openhab.core/.settings/org.eclipse.jdt.core.prefs b/bundles/core/org.openhab.core/.settings/org.eclipse.jdt.core.prefs index 4ede96d8a736c..443e08599a2e6 100644 --- a/bundles/core/org.openhab.core/.settings/org.eclipse.jdt.core.prefs +++ b/bundles/core/org.openhab.core/.settings/org.eclipse.jdt.core.prefs @@ -1,2 +1,8 @@ eclipse.preferences.version=1 +org.eclipse.jdt.core.compiler.codegen.inlineJsrBytecode=enabled +org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.7 +org.eclipse.jdt.core.compiler.compliance=1.7 +org.eclipse.jdt.core.compiler.problem.assertIdentifier=error +org.eclipse.jdt.core.compiler.problem.enumIdentifier=error org.eclipse.jdt.core.compiler.problem.forbiddenReference=warning +org.eclipse.jdt.core.compiler.source=1.7 diff --git a/bundles/core/org.openhab.core/META-INF/MANIFEST.MF b/bundles/core/org.openhab.core/META-INF/MANIFEST.MF index 4c713086c27cc..68b54c33551df 100644 --- a/bundles/core/org.openhab.core/META-INF/MANIFEST.MF +++ b/bundles/core/org.openhab.core/META-INF/MANIFEST.MF @@ -29,6 +29,7 @@ Import-Package: com.google.common.cache;version="10.0.1", org.eclipse.smarthome.core.items, org.eclipse.smarthome.core.thing, org.eclipse.smarthome.core.thing.link, + org.eclipse.smarthome.core.thing.setup, org.eclipse.smarthome.core.thing.type, org.eclipse.smarthome.core.types, org.eclipse.smarthome.model.rule.runtime;resolution:=optional, diff --git a/bundles/core/org.openhab.core/OSGI-INF/autoapprove.xml b/bundles/core/org.openhab.core/OSGI-INF/autoapprove.xml index 9cd2117d884ae..8c8cbf74e5316 100644 --- a/bundles/core/org.openhab.core/OSGI-INF/autoapprove.xml +++ b/bundles/core/org.openhab.core/OSGI-INF/autoapprove.xml @@ -11,7 +11,7 @@ --> - + diff --git a/bundles/core/org.openhab.core/OSGI-INF/thingitemprovider.xml b/bundles/core/org.openhab.core/OSGI-INF/thingitemprovider.xml deleted file mode 100644 index f44867c8854f0..0000000000000 --- a/bundles/core/org.openhab.core/OSGI-INF/thingitemprovider.xml +++ /dev/null @@ -1,19 +0,0 @@ - - - - - - - - - - diff --git a/bundles/core/org.openhab.core/src/main/java/org/openhab/core/internal/inbox/AutoApproveService.java b/bundles/core/org.openhab.core/src/main/java/org/openhab/core/internal/inbox/AutoApproveService.java index 695a7bda835fd..d58869ecbcda5 100644 --- a/bundles/core/org.openhab.core/src/main/java/org/openhab/core/internal/inbox/AutoApproveService.java +++ b/bundles/core/org.openhab.core/src/main/java/org/openhab/core/internal/inbox/AutoApproveService.java @@ -16,7 +16,7 @@ import org.eclipse.smarthome.config.discovery.DiscoveryResultFlag; import org.eclipse.smarthome.config.discovery.inbox.Inbox; import org.eclipse.smarthome.config.discovery.inbox.InboxListener; -import org.eclipse.smarthome.core.thing.ManagedThingProvider; +import org.eclipse.smarthome.core.thing.setup.ThingSetupManager; import org.osgi.service.cm.ConfigurationException; import org.slf4j.Logger; import org.slf4j.LoggerFactory; @@ -33,35 +33,41 @@ public class AutoApproveService implements InboxListener { final static private Logger logger = LoggerFactory.getLogger(AutoApproveService.class); - private ManagedThingProvider managedThingProvider; + private ThingSetupManager thingSetupManager; private Inbox inbox; protected void activate(Map configProps) throws ConfigurationException { String enabled = (String) configProps.get("enabled"); - if("true".equalsIgnoreCase(enabled)) { - inbox.addInboxListener(this); - for(DiscoveryResult result : inbox.getAll()) { - if(result.getFlag().equals(DiscoveryResultFlag.NEW)) { - thingAdded(inbox, result); - } - } - } else { - this.inbox.removeInboxListener(this); - } + enable(enabled); + } + + protected void modified(Map configProps) throws ConfigurationException { + String enabled = (String) configProps.get("enabled"); + enable(enabled); } - @Override + private void enable(String enabled) { + if("true".equalsIgnoreCase(enabled)) { + inbox.addInboxListener(this); + for(DiscoveryResult result : inbox.getAll()) { + if(result.getFlag().equals(DiscoveryResultFlag.NEW)) { + thingAdded(inbox, result); + } + } + } else { + this.inbox.removeInboxListener(this); + } + } + + @Override public void thingAdded(Inbox source, DiscoveryResult result) { logger.debug("Approving inbox entry '{}'", result.toString()); Map props = new HashMap<>(result.getProperties()); - // TODO: this is a hack as long as we do not have a possibility to store localized labels for things - props.put("label", result.getLabel()); - Configuration conf = new Configuration(props); - managedThingProvider.createThing(result.getThingTypeUID(), result.getThingUID(), result.getBridgeUID(), conf); + thingSetupManager.addThing(result.getThingUID(), conf, result.getBridgeUID(), result.getLabel()); } @Override @@ -82,12 +88,12 @@ protected void unsetInbox(Inbox inbox) { } - protected void setManagedThingProvider(ManagedThingProvider managedThingProvider) { - this.managedThingProvider = managedThingProvider; + protected void setThingSetupManager(ThingSetupManager thingSetupManager) { + this.thingSetupManager = thingSetupManager; } - protected void unsetManagedThingProvider(ManagedThingProvider managedThingProvider) { - this.managedThingProvider = null; + protected void unsetThingSetupManager(ThingSetupManager thingSetupManager) { + this.thingSetupManager = null; } } diff --git a/bundles/core/org.openhab.core/src/main/java/org/openhab/core/internal/item/DefaultSitemapProvider.java b/bundles/core/org.openhab.core/src/main/java/org/openhab/core/internal/item/DefaultSitemapProvider.java index e4bd3fc29f7a4..530d72d6c1ac8 100644 --- a/bundles/core/org.openhab.core/src/main/java/org/openhab/core/internal/item/DefaultSitemapProvider.java +++ b/bundles/core/org.openhab.core/src/main/java/org/openhab/core/internal/item/DefaultSitemapProvider.java @@ -11,6 +11,7 @@ import org.eclipse.smarthome.core.items.GroupItem; import org.eclipse.smarthome.core.items.Item; import org.eclipse.smarthome.core.items.ItemRegistry; +import org.eclipse.smarthome.core.thing.setup.ThingSetupManager; import org.eclipse.smarthome.model.sitemap.Sitemap; import org.eclipse.smarthome.model.sitemap.SitemapFactory; import org.eclipse.smarthome.model.sitemap.SitemapProvider; @@ -41,20 +42,38 @@ protected void unsetItemRegistry(ItemRegistry itemRegistry) { public Sitemap getSitemap(String sitemapName) { if(sitemapName.equals("default")) { SitemapImpl sitemap = (SitemapImpl) SitemapFactory.eINSTANCE.createSitemap(); - FrameImpl frame = (FrameImpl) SitemapFactory.eINSTANCE.createFrame(); + FrameImpl mainFrame = (FrameImpl) SitemapFactory.eINSTANCE.createFrame(); + + FrameImpl thingFrame = (FrameImpl) SitemapFactory.eINSTANCE.createFrame(); + thingFrame.setLabel("Things"); sitemap.setLabel("Home"); sitemap.setName("default"); - sitemap.getChildren().add(frame); for(Item item : itemRegistry.getAll()) { - if(item instanceof GroupItem && !item.getTags().contains("home-group")) { + if(item instanceof GroupItem && (item.getTags().contains(ThingSetupManager.TAG_HOME_GROUP) || item.getTags().contains(ThingSetupManager.TAG_THING))) { GroupImpl group = (GroupImpl) SitemapFactory.eINSTANCE.createGroup(); group.setItem(item.getName()); group.setLabel(item.getLabel()); - frame.getChildren().add(group); + String category = item.getCategory(); + if(category != null) { + group.setIcon(item.getCategory()); + } + if(item.getTags().contains(ThingSetupManager.TAG_HOME_GROUP)) { + mainFrame.getChildren().add(group); + } else { + thingFrame.getChildren().add(group); + } } } + + if(!mainFrame.getChildren().isEmpty()) { + sitemap.getChildren().add(mainFrame); + } + if(!thingFrame.getChildren().isEmpty()) { + sitemap.getChildren().add(thingFrame); + } + return sitemap; } return null; diff --git a/bundles/core/org.openhab.core/src/main/java/org/openhab/core/internal/item/ThingItemProvider.java b/bundles/core/org.openhab.core/src/main/java/org/openhab/core/internal/item/ThingItemProvider.java deleted file mode 100644 index 33041a6fe0c51..0000000000000 --- a/bundles/core/org.openhab.core/src/main/java/org/openhab/core/internal/item/ThingItemProvider.java +++ /dev/null @@ -1,159 +0,0 @@ -/** - * Copyright (c) 2014-2015 openHAB UG (haftungsbeschraenkt) and others. - * - * 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.core.internal.item; - -import java.util.Collection; -import java.util.Collections; -import java.util.HashSet; -import java.util.Map; -import java.util.Set; - -import org.eclipse.smarthome.core.common.registry.ProviderChangeListener; -import org.eclipse.smarthome.core.common.registry.RegistryChangeListener; -import org.eclipse.smarthome.core.events.EventPublisher; -import org.eclipse.smarthome.core.items.ActiveItem; -import org.eclipse.smarthome.core.items.GroupItem; -import org.eclipse.smarthome.core.items.Item; -import org.eclipse.smarthome.core.items.ItemProvider; -import org.eclipse.smarthome.core.items.ItemRegistry; -import org.eclipse.smarthome.core.thing.ManagedThingProvider; -import org.eclipse.smarthome.core.types.UnDefType; -import org.osgi.service.cm.ConfigurationException; - -/** - * This class dynamically provides items incl. labels from all things of the {@link ManagedThingProvider}. - * All items are hierarchically sorted with a root group item called "Things". - * - * @author Kai Kreuzer - * - */ -public class ThingItemProvider implements ItemProvider, RegistryChangeListener { - - private Set> listeners = new HashSet<>(); - - private ItemRegistry itemRegistry; - private EventPublisher eventPublisher; - private GroupItem rootItem; - - private boolean enabled = false; - - @Override - public Collection getAll() { - if(!enabled) return Collections.emptySet(); - - Set items = new HashSet<>(); - GroupItem all = getRootItem(); - for(Item item : itemRegistry.getItemsByTag("thing")) { - ActiveItem aItem = (ActiveItem) item; - aItem.addGroupName(all.getName()); - all.addMember(item); - } - items.add(all); - return items; - } - - @Override - public void addProviderChangeListener(ProviderChangeListener listener) { - listeners.add(listener); - for(Item item : getAll()) { - listener.added(this, item); - } - } - - @Override - public void removeProviderChangeListener( - ProviderChangeListener listener) { - listeners.remove(listener); - - } - - protected void setItemRegistry(ItemRegistry itemRegistry) { - this.itemRegistry = itemRegistry; - itemRegistry.addRegistryChangeListener(this); - } - - protected void unsetItemRegistry(ItemRegistry itemRegistry) { - itemRegistry.removeRegistryChangeListener(this); - this.itemRegistry = null; - } - - protected void setEventPublisher(EventPublisher eventPublisher) { - this.eventPublisher = eventPublisher; - } - - protected void unsetEventPublisher(EventPublisher eventPublisher) { - this.eventPublisher = null; - } - - private synchronized GroupItem getRootItem() { - if(rootItem==null) { - rootItem = new GroupItem("All"); - rootItem.addTag("home-group"); - rootItem.setLabel("All"); - getAll(); - } - return rootItem; - } - - protected void activate(Map properties) throws ConfigurationException { - if(properties!=null) { - String enabled = (String) properties.get("enabled"); - if("true".equalsIgnoreCase(enabled)) { - this.enabled = true; - for(ProviderChangeListener listener : listeners) { - for(Item item : getAll()) { - listener.added(this, item); - } - } - } else { - this.enabled = false; - for(ProviderChangeListener listener : listeners) { - for(Item item : getAll()) { - listener.removed(this, item); - } - } - } - } - } - - @Override - public void added(Item element) { - if(!enabled) return; - if(!element.getTags().contains("thing")) return; - rootItem = null; - rootItem = getRootItem(); - for(ProviderChangeListener listener : listeners) { - listener.removed(this, getRootItem()); - listener.added(this, getRootItem()); - } - } - - @Override - public void removed(Item element) { - if(!enabled) return; - if(!element.getTags().contains("thing")) return; - for(ProviderChangeListener listener : listeners) { - listener.removed(this, getRootItem()); - rootItem = null; - listener.added(this, getRootItem()); - } - } - - @Override - public void updated(Item oldElement, Item element) { - if(!enabled) return; - removed(oldElement); - added(element); - } - - public boolean isEnabled() { - return enabled; - } - -} diff --git a/bundles/io/org.openhab.io.transport.serial/.classpath b/bundles/io/org.openhab.io.transport.serial/.classpath index e5b1c31ae6985..37b651fd08612 100644 --- a/bundles/io/org.openhab.io.transport.serial/.classpath +++ b/bundles/io/org.openhab.io.transport.serial/.classpath @@ -1,7 +1,7 @@ + - diff --git a/bundles/io/org.openhab.io.transport.serial/META-INF/MANIFEST.MF b/bundles/io/org.openhab.io.transport.serial/META-INF/MANIFEST.MF index 29ca72fbdc567..0ab79a14d5997 100644 --- a/bundles/io/org.openhab.io.transport.serial/META-INF/MANIFEST.MF +++ b/bundles/io/org.openhab.io.transport.serial/META-INF/MANIFEST.MF @@ -4,7 +4,7 @@ Bundle-Name: openHAB Serial Transport Bundle Bundle-SymbolicName: org.openhab.io.transport.serial Bundle-Version: 2.0.0.qualifier Bundle-Vendor: openHAB.org -Bundle-RequiredExecutionEnvironment: J2SE-1.5 +Bundle-RequiredExecutionEnvironment: JavaSE-1.7 Bundle-ClassPath: lib/nrjavaserial-3.8.8.jar Export-Package: gnu.io Import-Package: gnu.io diff --git a/bundles/ui/org.openhab.ui.dashboard/web/img/habmin.png b/bundles/ui/org.openhab.ui.dashboard/web/img/habmin.png new file mode 100644 index 0000000000000..5f8ba9aae98c0 Binary files /dev/null and b/bundles/ui/org.openhab.ui.dashboard/web/img/habmin.png differ diff --git a/bundles/ui/org.openhab.ui.dashboard/web/index.html b/bundles/ui/org.openhab.ui.dashboard/web/index.html index e5458c72db496..5a42c1e6e5975 100644 --- a/bundles/ui/org.openhab.ui.dashboard/web/index.html +++ b/bundles/ui/org.openhab.ui.dashboard/web/index.html @@ -46,6 +46,16 @@

Welcome to openHAB 2.0

+