/**
\file ExtendedColorTemperatureStrategy.cpp
Copyright Notice\n
Copyright (C) 2017 Jan Rogall - developer\n
Copyright (C) 2017 Moritz Wirger - developer\n
This file is part of hueplusplus.
hueplusplus is free software: you can redistribute it and/or modify
it under the terms of the GNU Lesser General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
hueplusplus is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public License
along with hueplusplus. If not, see .
**/
#include "hueplusplus/ExtendedColorTemperatureStrategy.h"
#include
#include
#include
#include "hueplusplus/HueConfig.h"
#include "hueplusplus/HueExceptionMacro.h"
#include "hueplusplus/Utils.h"
namespace hueplusplus
{
bool ExtendedColorTemperatureStrategy::setColorTemperature(
unsigned int mired, uint8_t transition, HueLight& light) const
{
// Careful, only use state until any light function might refresh the value and invalidate the reference
const nlohmann::json& state = light.state.getValue()["state"];
nlohmann::json request = nlohmann::json::object();
if (transition != 4)
{
request["transitiontime"] = transition;
}
if (state["on"] != true)
{
request["on"] = true;
}
if (state["ct"] != mired || state["colormode"] != "ct")
{
if (mired > 500)
{
mired = 500;
}
if (mired < 153)
{
mired = 153;
}
request["ct"] = mired;
}
if (!request.count("on") && !request.count("ct"))
{
// Nothing needs to be changed
return true;
}
nlohmann::json reply = light.sendPutRequest(request, "/state", CURRENT_FILE_INFO);
// Check whether request was successful
return utils::validateReplyForLight(request, reply, light.id);
}
bool ExtendedColorTemperatureStrategy::alertTemperature(unsigned int mired, HueLight& light) const
{
// Careful, only use state until any light function might refresh the value and invalidate the reference
const nlohmann::json& state = light.state.getValue()["state"];
std::string cType = state["colormode"].get();
bool on = state["on"].get();
if (cType == "hs")
{
uint16_t oldHue = state["hue"].get();
uint8_t oldSat = state["sat"].get();
if (!light.setColorTemperature(mired, 1))
{
return false;
}
std::this_thread::sleep_for(Config::instance().getPreAlertDelay());
if (!light.alert())
{
return false;
}
std::this_thread::sleep_for(Config::instance().getPostAlertDelay());
if (!on)
{
light.setColorHueSaturation(oldHue, oldSat, 1);
return light.Off(1);
}
else
{
return light.setColorHueSaturation(oldHue, oldSat, 1);
}
}
else if (cType == "xy")
{
float oldX = state["xy"][0].get();
float oldY = state["xy"][1].get();
if (!light.setColorTemperature(mired, 1))
{
return false;
}
std::this_thread::sleep_for(Config::instance().getPreAlertDelay());
if (!light.alert())
{
return false;
}
std::this_thread::sleep_for(Config::instance().getPostAlertDelay());
if (!on)
{
light.setColorXY(oldX, oldY, 1);
return light.Off(1);
}
else
{
return light.setColorXY(oldX, oldY, 1);
}
}
else if (cType == "ct")
{
uint16_t oldCT = state["ct"].get();
if (!light.setColorTemperature(mired, 1))
{
return false;
}
std::this_thread::sleep_for(Config::instance().getPreAlertDelay());
if (!light.alert())
{
return false;
}
std::this_thread::sleep_for(Config::instance().getPostAlertDelay());
if (!on)
{
light.setColorTemperature(oldCT, 1);
return light.Off(1);
}
else
{
return light.setColorTemperature(oldCT, 1);
}
}
else
{
return false;
}
}
} // namespace hueplusplus