mirror of
https://github.com/hyperion-project/hyperion.ng.git
synced 2023-10-10 13:36:59 +02:00
FIX: [hue] proper save state (#1014)
This commit is contained in:
parent
9e4c7af5e9
commit
f7ccf9d0da
@ -31,6 +31,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
|||||||
- Change links from http to https (#1067)
|
- Change links from http to https (#1067)
|
||||||
|
|
||||||
### Fixed
|
### Fixed
|
||||||
|
- Properly save Hue light state between sessions (#1014)
|
||||||
- AVAHI included in Webserver (#996)
|
- AVAHI included in Webserver (#996)
|
||||||
- Also allow an 8-LED configuration when using Karatelight (#1037)
|
- Also allow an 8-LED configuration when using Karatelight (#1037)
|
||||||
- Fix #1007 - LED's retain last state after clearing a source (#1008)
|
- Fix #1007 - LED's retain last state after clearing a source (#1008)
|
||||||
@ -42,6 +43,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
|||||||
- Fix typos (#1051)
|
- Fix typos (#1051)
|
||||||
- Fix Python reset thread state
|
- Fix Python reset thread state
|
||||||
|
|
||||||
|
|
||||||
### Removed
|
### Removed
|
||||||
- Replace Multi-Lightpack by multi-instance Lightpack configuration (#1049)
|
- Replace Multi-Lightpack by multi-instance Lightpack configuration (#1049)
|
||||||
|
|
||||||
|
@ -419,13 +419,7 @@ void LedDevicePhilipsHueBridge::log(const char* msg, const char* type, ...) cons
|
|||||||
|
|
||||||
QJsonDocument LedDevicePhilipsHueBridge::getAllBridgeInfos()
|
QJsonDocument LedDevicePhilipsHueBridge::getAllBridgeInfos()
|
||||||
{
|
{
|
||||||
// Read Groups/ Lights and Light-Ids
|
return get(API_ROOT);
|
||||||
_restApi->setPath(API_ROOT);
|
|
||||||
|
|
||||||
httpResponse response = _restApi->get();
|
|
||||||
checkApiError(response.getBody());
|
|
||||||
|
|
||||||
return response.getBody();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool LedDevicePhilipsHueBridge::initMaps()
|
bool LedDevicePhilipsHueBridge::initMaps()
|
||||||
@ -628,6 +622,15 @@ bool LedDevicePhilipsHueBridge::checkApiError(const QJsonDocument &response)
|
|||||||
return apiError;
|
return apiError;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
QJsonDocument LedDevicePhilipsHueBridge::get(const QString& route)
|
||||||
|
{
|
||||||
|
_restApi->setPath(route);
|
||||||
|
|
||||||
|
httpResponse response = _restApi->get();
|
||||||
|
checkApiError(response.getBody());
|
||||||
|
return response.getBody();
|
||||||
|
}
|
||||||
|
|
||||||
QJsonDocument LedDevicePhilipsHueBridge::post(const QString& route, const QString& content)
|
QJsonDocument LedDevicePhilipsHueBridge::post(const QString& route, const QString& content)
|
||||||
{
|
{
|
||||||
_restApi->setPath(route);
|
_restApi->setPath(route);
|
||||||
@ -637,6 +640,12 @@ QJsonDocument LedDevicePhilipsHueBridge::post(const QString& route, const QStrin
|
|||||||
return response.getBody();
|
return response.getBody();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
QJsonDocument LedDevicePhilipsHueBridge::getLightState(unsigned int lightId)
|
||||||
|
{
|
||||||
|
DebugIf( verbose, _log, "GetLightState [%u]", lightId );
|
||||||
|
return get( QString("%1/%2").arg( API_LIGHTS ).arg( lightId ) );
|
||||||
|
}
|
||||||
|
|
||||||
void LedDevicePhilipsHueBridge::setLightState(unsigned int lightId, const QString &state)
|
void LedDevicePhilipsHueBridge::setLightState(unsigned int lightId, const QString &state)
|
||||||
{
|
{
|
||||||
DebugIf( verbose, _log, "SetLightState [%u]: %s", lightId, QSTRING_CSTR(state) );
|
DebugIf( verbose, _log, "SetLightState [%u]: %s", lightId, QSTRING_CSTR(state) );
|
||||||
@ -645,10 +654,8 @@ void LedDevicePhilipsHueBridge::setLightState(unsigned int lightId, const QStrin
|
|||||||
|
|
||||||
QJsonDocument LedDevicePhilipsHueBridge::getGroupState(unsigned int groupId)
|
QJsonDocument LedDevicePhilipsHueBridge::getGroupState(unsigned int groupId)
|
||||||
{
|
{
|
||||||
_restApi->setPath( QString("%1/%2").arg( API_GROUPS ).arg( groupId ) );
|
DebugIf( verbose, _log, "GetGroupState [%u]", groupId );
|
||||||
httpResponse response = _restApi->get();
|
return get( QString("%1/%2").arg( API_GROUPS ).arg( groupId ) );
|
||||||
checkApiError(response.getBody());
|
|
||||||
return response.getBody();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
QJsonDocument LedDevicePhilipsHueBridge::setGroupState(unsigned int groupId, bool state)
|
QJsonDocument LedDevicePhilipsHueBridge::setGroupState(unsigned int groupId, bool state)
|
||||||
@ -712,8 +719,6 @@ PhilipsHueLight::PhilipsHueLight(Logger* log, unsigned int id, QJsonObject value
|
|||||||
_colorBlack = {0.0, 0.0, 0.0};
|
_colorBlack = {0.0, 0.0, 0.0};
|
||||||
}
|
}
|
||||||
|
|
||||||
saveOriginalState(values);
|
|
||||||
|
|
||||||
_lightname = values["name"].toString().trimmed().replace("\"", "");
|
_lightname = values["name"].toString().trimmed().replace("\"", "");
|
||||||
Info(_log, "Light ID %d (\"%s\", LED index \"%d\") created", id, QSTRING_CSTR(_lightname), ledidx );
|
Info(_log, "Light ID %d (\"%s\", LED index \"%d\") created", id, QSTRING_CSTR(_lightname), ledidx );
|
||||||
}
|
}
|
||||||
@ -806,7 +811,6 @@ LedDevicePhilipsHue::LedDevicePhilipsHue(const QJsonObject& deviceConfig)
|
|||||||
, _switchOffOnBlack(false)
|
, _switchOffOnBlack(false)
|
||||||
, _brightnessFactor(1.0)
|
, _brightnessFactor(1.0)
|
||||||
, _transitionTime(1)
|
, _transitionTime(1)
|
||||||
, _lightStatesRestored(false)
|
|
||||||
, _isInitLeds(false)
|
, _isInitLeds(false)
|
||||||
, _lightsCount(0)
|
, _lightsCount(0)
|
||||||
, _groupId(0)
|
, _groupId(0)
|
||||||
@ -1278,30 +1282,8 @@ void LedDevicePhilipsHue::stop()
|
|||||||
|
|
||||||
int LedDevicePhilipsHue::open()
|
int LedDevicePhilipsHue::open()
|
||||||
{
|
{
|
||||||
int retval = -1;
|
int retval = 0;
|
||||||
_isDeviceReady = false;
|
|
||||||
|
|
||||||
if( _useHueEntertainmentAPI )
|
|
||||||
{
|
|
||||||
if ( openStream() )
|
|
||||||
{
|
|
||||||
// Everything is OK, device is ready
|
|
||||||
_isDeviceReady = true;
|
_isDeviceReady = true;
|
||||||
retval = 0;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// TODO: Stop device (or fallback to classic mode) - suggest to stop device to meet user expectation
|
|
||||||
//_useHueEntertainmentAPI = false; -to be removed, if 1
|
|
||||||
// Everything is OK, device is ready
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// Classic mode, everything is OK, device is ready
|
|
||||||
_isDeviceReady = true;
|
|
||||||
retval = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
@ -1315,6 +1297,40 @@ int LedDevicePhilipsHue::close()
|
|||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool LedDevicePhilipsHue::switchOn()
|
||||||
|
{
|
||||||
|
Debug(_log, "");
|
||||||
|
|
||||||
|
bool rc = false;
|
||||||
|
|
||||||
|
if ( _isOn )
|
||||||
|
{
|
||||||
|
rc = true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if ( _isEnabled && _isDeviceInitialised )
|
||||||
|
{
|
||||||
|
storeState();
|
||||||
|
|
||||||
|
if ( _useHueEntertainmentAPI)
|
||||||
|
{
|
||||||
|
if ( openStream() )
|
||||||
|
{
|
||||||
|
_isOn = true;
|
||||||
|
rc = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if ( powerOn() )
|
||||||
|
{
|
||||||
|
_isOn = true;
|
||||||
|
rc = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
bool LedDevicePhilipsHue::switchOff()
|
bool LedDevicePhilipsHue::switchOff()
|
||||||
{
|
{
|
||||||
Debug(_log, "");
|
Debug(_log, "");
|
||||||
@ -1322,7 +1338,10 @@ bool LedDevicePhilipsHue::switchOff()
|
|||||||
this->stopBlackTimeoutTimer();
|
this->stopBlackTimeoutTimer();
|
||||||
|
|
||||||
stop_retry_left = 3;
|
stop_retry_left = 3;
|
||||||
|
if (_useHueEntertainmentAPI)
|
||||||
|
{
|
||||||
stopStream();
|
stopStream();
|
||||||
|
}
|
||||||
|
|
||||||
return LedDevicePhilipsHueBridge::switchOff();
|
return LedDevicePhilipsHueBridge::switchOff();
|
||||||
}
|
}
|
||||||
@ -1563,11 +1582,14 @@ bool LedDevicePhilipsHue::storeState()
|
|||||||
|
|
||||||
if ( _isRestoreOrigState )
|
if ( _isRestoreOrigState )
|
||||||
{
|
{
|
||||||
// Save device's original state
|
if( !_lightIds.empty() )
|
||||||
//_orignalStateValues = get device's state;
|
{
|
||||||
|
for ( PhilipsHueLight& light : _lights )
|
||||||
// TODO: Move saveOriginalState out of the HueLight constructor,
|
{
|
||||||
// as the light state may have change since last close and needs to be stored again before reopen
|
QJsonObject values = getLightState(light.getId()).object();
|
||||||
|
light.saveOriginalState(values);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return rc;
|
return rc;
|
||||||
@ -1577,11 +1599,9 @@ bool LedDevicePhilipsHue::restoreState()
|
|||||||
{
|
{
|
||||||
bool rc = true;
|
bool rc = true;
|
||||||
|
|
||||||
if ( _isRestoreOrigState && !_lightStatesRestored )
|
if ( _isRestoreOrigState )
|
||||||
{
|
{
|
||||||
// Restore device's original state
|
// Restore device's original state
|
||||||
_lightStatesRestored = true;
|
|
||||||
|
|
||||||
if( !_lightIds.empty() )
|
if( !_lightIds.empty() )
|
||||||
{
|
{
|
||||||
for ( PhilipsHueLight& light : _lights )
|
for ( PhilipsHueLight& light : _lights )
|
||||||
|
@ -152,12 +152,11 @@ public:
|
|||||||
/// @return the color space of the light determined by the model id reported by the bridge.
|
/// @return the color space of the light determined by the model id reported by the bridge.
|
||||||
CiColorTriangle getColorSpace() const;
|
CiColorTriangle getColorSpace() const;
|
||||||
|
|
||||||
|
void saveOriginalState(const QJsonObject& values);
|
||||||
QString getOriginalState() const;
|
QString getOriginalState() const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
void saveOriginalState(const QJsonObject& values);
|
|
||||||
|
|
||||||
Logger* _log;
|
Logger* _log;
|
||||||
/// light id
|
/// light id
|
||||||
unsigned int _id;
|
unsigned int _id;
|
||||||
@ -200,12 +199,23 @@ public:
|
|||||||
bool initRestAPI(const QString &hostname, int port, const QString &token );
|
bool initRestAPI(const QString &hostname, int port, const QString &token );
|
||||||
|
|
||||||
///
|
///
|
||||||
/// @param route the route of the POST request.
|
/// @brief Perform a REST-API GET
|
||||||
///
|
///
|
||||||
|
/// @param route the route of the GET request.
|
||||||
|
///
|
||||||
|
/// @return the content of the GET request.
|
||||||
|
///
|
||||||
|
QJsonDocument get(const QString& route);
|
||||||
|
|
||||||
|
///
|
||||||
|
/// @brief Perform a REST-API POST
|
||||||
|
///
|
||||||
|
/// @param route the route of the POST request.
|
||||||
/// @param content the content of the POST request.
|
/// @param content the content of the POST request.
|
||||||
///
|
///
|
||||||
QJsonDocument post(const QString& route, const QString& content);
|
QJsonDocument post(const QString& route, const QString& content);
|
||||||
|
|
||||||
|
QJsonDocument getLightState(unsigned int lightId);
|
||||||
void setLightState(unsigned int lightId = 0, const QString &state = "");
|
void setLightState(unsigned int lightId = 0, const QString &state = "");
|
||||||
|
|
||||||
QMap<quint16,QJsonObject> getLightMap() const;
|
QMap<quint16,QJsonObject> getLightMap() const;
|
||||||
@ -421,7 +431,7 @@ protected:
|
|||||||
///
|
///
|
||||||
/// @return True if success
|
/// @return True if success
|
||||||
///
|
///
|
||||||
//bool switchOn() override;
|
bool switchOn() override;
|
||||||
|
|
||||||
///
|
///
|
||||||
/// @brief Switch the LEDs off.
|
/// @brief Switch the LEDs off.
|
||||||
@ -525,7 +535,6 @@ private:
|
|||||||
/// The default of the Hue lights is 400 ms, but we may want it snappier.
|
/// The default of the Hue lights is 400 ms, but we may want it snappier.
|
||||||
int _transitionTime;
|
int _transitionTime;
|
||||||
|
|
||||||
bool _lightStatesRestored;
|
|
||||||
bool _isInitLeds;
|
bool _isInitLeds;
|
||||||
|
|
||||||
/// Array of the light ids.
|
/// Array of the light ids.
|
||||||
|
Loading…
Reference in New Issue
Block a user