use of org.openhab.binding.hue.internal.data.HueSettings in project openhab1-addons by openhab.
the class HueBinding method execute.
/**
* Get current hue settings of the bulbs and update the items that are connected with the bulb.
* The refreshinterval determines the polling frequency.
*/
@Override
public void execute() {
if (activeBridge != null) {
// Get settings and update the bulbs
// Observation : If the power of a hue lamp is removed, the status is not updated in hue hub.
// The heartbeat functionality should fix this, but
logger.debug("Start Hue data refresh");
HueSettings settings = activeBridge.getSettings();
if (settings == null) {
logger.warn("Hue settings were null, maybe misconfigured bridge IP.");
return;
} else if (!settings.isAuthorized()) {
logger.warn("openHAB not authorized to access Hue bridge");
return;
}
Set<String> keys = settings.getKeys();
for (String key : keys) {
try {
HueBulb bulb = bulbCache.get(key);
if (bulb == null) {
bulb = new HueBulb(activeBridge, key, settings);
bulbCache.put(key, bulb);
}
bulb.getStatus(settings);
} catch (NumberFormatException e) {
logger.warn("lights index {} is not a number", key);
}
}
// Multiple items of different types can be linked to one bulb.
for (HueBindingProvider provider : this.providers) {
for (String hueItemName : provider.getInBindingItemNames()) {
HueBindingConfig deviceConfig = getConfigForItemName(hueItemName);
if (deviceConfig != null) {
HueBulb bulb = bulbCache.get(deviceConfig.getDeviceId());
if (bulb != null) {
//
if ((bulb.getIsOn() == true) && (bulb.getIsReachable() == true)) {
if ((deviceConfig.itemStateOnOffType == null) || (deviceConfig.itemStateOnOffType.equals(OnOffType.ON) == false)) {
eventPublisher.postUpdate(hueItemName, OnOffType.ON);
deviceConfig.itemStateOnOffType = OnOffType.ON;
}
} else {
if ((deviceConfig.itemStateOnOffType == null) || (deviceConfig.itemStateOnOffType.equals(OnOffType.OFF) == false)) {
eventPublisher.postUpdate(hueItemName, OnOffType.OFF);
deviceConfig.itemStateOnOffType = OnOffType.OFF;
}
}
if (deviceConfig.getType().equals(BindingType.brightness)) {
if ((bulb.getIsOn() == true) && (bulb.getIsReachable() == true)) {
// Only postUpdate when bulb is on, otherwise dimmer item is not retaining state and
// shows to max brightness value
PercentType newPercent = new PercentType((int) Math.round((bulb.getBrightness() * (double) 100) / HueBulb.MAX_BRIGHTNESS));
if ((deviceConfig.itemStatePercentType == null) || (deviceConfig.itemStatePercentType.equals(newPercent) == false)) {
eventPublisher.postUpdate(hueItemName, newPercent);
deviceConfig.itemStatePercentType = newPercent;
}
}
} else if (deviceConfig.getType().equals(BindingType.rgb)) {
if ((bulb.getIsOn() == true) && (bulb.getIsReachable() == true)) {
// Only postUpdate when bulb is on, otherwise color item is not retaining state and
// shows to max brightness value
DecimalType decimalHue = new DecimalType(bulb.getHue() / (double) 182);
PercentType percentBrightness = new PercentType((int) Math.round((bulb.getBrightness() * (double) 100) / HueBulb.MAX_BRIGHTNESS));
PercentType percentSaturation = new PercentType((int) Math.round((bulb.getSaturation() * (double) 100) / HueBulb.MAX_SATURATION));
HSBType newHsb = new HSBType(decimalHue, percentSaturation, percentBrightness);
if ((deviceConfig.itemStateHSBType == null) || (deviceConfig.itemStateHSBType.equals(newHsb) == false)) {
eventPublisher.postUpdate(hueItemName, newHsb);
deviceConfig.itemStateHSBType = newHsb;
}
}
}
}
}
}
}
logger.debug("Done Hue data refresh.");
}
}
use of org.openhab.binding.hue.internal.data.HueSettings in project openhab1-addons by openhab.
the class HueBridge method isAuthorized.
/**
* Checks if the configured secret/user is authorized on the hue bridge.
*/
public boolean isAuthorized() {
boolean isAuthorized = false;
if (!StringUtils.isBlank(secret)) {
HueSettings settings = getSettings();
isAuthorized = (settings != null && settings.isAuthorized());
}
return isAuthorized;
}
Aggregations