1
0
mirror of https://github.com/esphome/esphome.git synced 2025-10-24 20:53:48 +01:00

specify data types

This commit is contained in:
Kevin Ahrendt
2025-07-14 14:56:51 -04:00
parent 6afda9d4dc
commit 5e8f1d82c3
5 changed files with 34 additions and 33 deletions

View File

@@ -83,7 +83,8 @@ void HttpRequestUpdate::update_task(void *params) {
container.reset(); // Release ownership of the container's shared_ptr
valid = json::parse_json(response, [this_update](JsonObject root) -> bool {
if (!root["name"].is<JsonVariant>() || !root["version"].is<JsonVariant>() || !root["builds"].is<JsonVariant>()) {
if (!root["name"].is<const char *>() || !root["version"].is<const char *>() ||
!root["builds"].is<const char *>()) {
ESP_LOGE(TAG, "Manifest does not contain required fields");
return false;
}
@@ -91,26 +92,26 @@ void HttpRequestUpdate::update_task(void *params) {
this_update->update_info_.latest_version = root["version"].as<std::string>();
for (auto build : root["builds"].as<JsonArray>()) {
if (!build["chipFamily"].is<JsonVariant>()) {
if (!build["chipFamily"].is<const char *>()) {
ESP_LOGE(TAG, "Manifest does not contain required fields");
return false;
}
if (build["chipFamily"] == ESPHOME_VARIANT) {
if (!build["ota"].is<JsonVariant>()) {
if (!build["ota"].is<JsonObject>()) {
ESP_LOGE(TAG, "Manifest does not contain required fields");
return false;
}
JsonObject ota = build["ota"].as<JsonObject>();
if (!ota["path"].is<JsonVariant>() || !ota["md5"].is<JsonVariant>()) {
if (!ota["path"].is<const char *>() || !ota["md5"].is<const char *>()) {
ESP_LOGE(TAG, "Manifest does not contain required fields");
return false;
}
this_update->update_info_.firmware_url = ota["path"].as<std::string>();
this_update->update_info_.md5 = ota["md5"].as<std::string>();
if (ota["summary"].is<JsonVariant>())
if (ota["summary"].is<const char *>())
this_update->update_info_.summary = ota["summary"].as<std::string>();
if (ota["release_url"].is<JsonVariant>())
if (ota["release_url"].is<const char *>())
this_update->update_info_.release_url = ota["release_url"].as<std::string>();
return true;

View File

@@ -73,7 +73,7 @@ void LightJSONSchema::dump_json(LightState &state, JsonObject root) {
}
void LightJSONSchema::parse_color_json(LightState &state, LightCall &call, JsonObject root) {
if (root["state"].is<JsonVariant>()) {
if (root["state"].is<const char *>()) {
auto val = parse_on_off(root["state"]);
switch (val) {
case PARSE_ON:
@@ -90,40 +90,40 @@ void LightJSONSchema::parse_color_json(LightState &state, LightCall &call, JsonO
}
}
if (root["brightness"].is<JsonVariant>()) {
if (root["brightness"].is<unsigned char>()) {
call.set_brightness(float(root["brightness"]) / 255.0f);
}
if (root["color"].is<JsonVariant>()) {
if (root["color"].is<JsonObject>()) {
JsonObject color = root["color"];
// HA also encodes brightness information in the r, g, b values, so extract that and set it as color brightness.
float max_rgb = 0.0f;
if (color["r"].is<JsonVariant>()) {
if (color["r"].is<unsigned char>()) {
float r = float(color["r"]) / 255.0f;
max_rgb = fmaxf(max_rgb, r);
call.set_red(r);
}
if (color["g"].is<JsonVariant>()) {
if (color["g"].is<unsigned char>()) {
float g = float(color["g"]) / 255.0f;
max_rgb = fmaxf(max_rgb, g);
call.set_green(g);
}
if (color["b"].is<JsonVariant>()) {
if (color["b"].is<unsigned char>()) {
float b = float(color["b"]) / 255.0f;
max_rgb = fmaxf(max_rgb, b);
call.set_blue(b);
}
if (color["r"].is<JsonVariant>() || color["g"].is<JsonVariant>() || color["b"].is<JsonVariant>()) {
if (color["r"].is<unsigned char>() || color["g"].is<unsigned char>() || color["b"].is<unsigned char>()) {
call.set_color_brightness(max_rgb);
}
if (color["c"].is<JsonVariant>()) {
if (color["c"].is<unsigned char>()) {
call.set_cold_white(float(color["c"]) / 255.0f);
}
if (color["w"].is<JsonVariant>()) {
if (color["w"].is<unsigned short>()) {
// the HA scheme is ambiguous here, the same key is used for white channel in RGBW and warm
// white channel in RGBWW.
if (color["c"].is<JsonVariant>()) {
if (color["c"].is<unsigned short>()) {
call.set_warm_white(float(color["w"]) / 255.0f);
} else {
call.set_white(float(color["w"]) / 255.0f);
@@ -131,11 +131,11 @@ void LightJSONSchema::parse_color_json(LightState &state, LightCall &call, JsonO
}
}
if (root["white_value"].is<JsonVariant>()) { // legacy API
if (root["white_value"].is<unsigned short>()) { // legacy API
call.set_white(float(root["white_value"]) / 255.0f);
}
if (root["color_temp"].is<JsonVariant>()) {
if (root["color_temp"].is<unsigned short>()) {
call.set_color_temperature(float(root["color_temp"]));
}
}
@@ -143,17 +143,17 @@ void LightJSONSchema::parse_color_json(LightState &state, LightCall &call, JsonO
void LightJSONSchema::parse_json(LightState &state, LightCall &call, JsonObject root) {
LightJSONSchema::parse_color_json(state, call, root);
if (root["flash"].is<JsonVariant>()) {
if (root["flash"].is<unsigned int>()) {
auto length = uint32_t(float(root["flash"]) * 1000);
call.set_flash_length(length);
}
if (root["transition"].is<JsonVariant>()) {
if (root["transition"].is<unsigned short>()) {
auto length = uint32_t(float(root["transition"]) * 1000);
call.set_transition_length(length);
}
if (root["effect"].is<JsonVariant>()) {
if (root["effect"].is<const char *>()) {
const char *effect = root["effect"];
call.set_effect(effect);
}

View File

@@ -20,13 +20,13 @@ MQTTDateComponent::MQTTDateComponent(DateEntity *date) : date_(date) {}
void MQTTDateComponent::setup() {
this->subscribe_json(this->get_command_topic_(), [this](const std::string &topic, JsonObject root) {
auto call = this->date_->make_call();
if (root["year"].is<JsonVariant>()) {
if (root["year"].is<unsigned short>()) {
call.set_year(root["year"]);
}
if (root["month"].is<JsonVariant>()) {
if (root["month"].is<unsigned char>()) {
call.set_month(root["month"]);
}
if (root["day"].is<JsonVariant>()) {
if (root["day"].is<unsigned short>()) {
call.set_day(root["day"]);
}
call.perform();

View File

@@ -20,22 +20,22 @@ MQTTDateTimeComponent::MQTTDateTimeComponent(DateTimeEntity *datetime) : datetim
void MQTTDateTimeComponent::setup() {
this->subscribe_json(this->get_command_topic_(), [this](const std::string &topic, JsonObject root) {
auto call = this->datetime_->make_call();
if (root["year"].is<JsonVariant>()) {
if (root["year"].is<unsigned short>()) {
call.set_year(root["year"]);
}
if (root["month"].is<JsonVariant>()) {
if (root["month"].is<unsigned char>()) {
call.set_month(root["month"]);
}
if (root["day"].is<JsonVariant>()) {
if (root["day"].is<unsigned char>()) {
call.set_day(root["day"]);
}
if (root["hour"].is<JsonVariant>()) {
if (root["hour"].is<unsigned short>()) {
call.set_hour(root["hour"]);
}
if (root["minute"].is<JsonVariant>()) {
if (root["minute"].is<unsigned short>()) {
call.set_minute(root["minute"]);
}
if (root["second"].is<JsonVariant>()) {
if (root["second"].is<unsigned short>()) {
call.set_second(root["second"]);
}
call.perform();

View File

@@ -20,13 +20,13 @@ MQTTTimeComponent::MQTTTimeComponent(TimeEntity *time) : time_(time) {}
void MQTTTimeComponent::setup() {
this->subscribe_json(this->get_command_topic_(), [this](const std::string &topic, JsonObject root) {
auto call = this->time_->make_call();
if (root["hour"].is<JsonVariant>()) {
if (root["hour"].is<unsigned short>()) {
call.set_hour(root["hour"]);
}
if (root["minute"].is<JsonVariant>()) {
if (root["minute"].is<unsigned short>()) {
call.set_minute(root["minute"]);
}
if (root["second"].is<JsonVariant>()) {
if (root["second"].is<unsigned short>()) {
call.set_second(root["second"]);
}
call.perform();