diff --git a/library.json b/library.json index c01fd544..4954403d 100644 --- a/library.json +++ b/library.json @@ -17,7 +17,7 @@ "platforms": ["espressif32"], "dependencies": [ { "name": "Adafruit GFX Library" }, - { "name": "Arduino_JSON" }, + { "name": "ArduinoJSON" }, { "name": "DS3232RTC" }, { "name": "NTPClient" }, { diff --git a/src/BLE.h b/src/BLE.h index e346711f..2278742f 100644 --- a/src/BLE.h +++ b/src/BLE.h @@ -12,8 +12,6 @@ #include "config.h" -class BLE; - class BLE { public: diff --git a/src/Watchy.cpp b/src/Watchy.cpp index 566e2f78..f45a2053 100644 --- a/src/Watchy.cpp +++ b/src/Watchy.cpp @@ -581,13 +581,17 @@ weatherData Watchy::getWeatherData(String cityID, String units, String lang, Str String weatherQueryURL = url + cityID + String("&units=") + units + String("&lang=") + lang + String("&appid=") + apiKey; http.begin(weatherQueryURL.c_str()); int httpResponseCode = http.GET(); - if(httpResponseCode == 200) { + if( httpResponseCode == 200) { String payload = http.getString(); - JSONVar responseObject = JSON.parse(payload); - currentWeather.temperature = int(responseObject["main"]["temp"]); - currentWeather.isMetric = settings.weatherUnit == String("metric"); - currentWeather.weatherConditionCode = int(responseObject["weather"][0]["id"]); - currentWeather.weatherDescription = responseObject["weather"][0]["main"]; + DynamicJsonDocument doc(1024); + if (auto error = deserializeJson(doc, payload)) { + Serial.println(error.c_str()); + } else { + currentWeather.temperature = doc["main"]["temp"].as(); + currentWeather.isMetric = settings.weatherUnit == String("metric"); + currentWeather.weatherConditionCode = doc["weather"][0]["id"].as(); + currentWeather.weatherDescription = doc["weather"][0]["main"].as(); + } }else{ //http error } diff --git a/src/Watchy.h b/src/Watchy.h index aeccc688..dd43ce09 100644 --- a/src/Watchy.h +++ b/src/Watchy.h @@ -6,7 +6,7 @@ #include #include #include -#include +#include #include #include #include