I am trying to setup the Open Weather Map Binding and have signed up for the free One call API (set the limit to 999) and submitted credit card information. Open Weather is showing my status as Activated.
In OpenHab I added the Open Weather Map Binding Bridge and configured it to point to the API I created within Open Weather Map and the status goes to ONLINE.
I then add the One Call API Weather Forecast Thing and configure it as to below and point to my Open Weather Map account.
Thank you @sihui. I did what you suggested last week. I did give them my CC and logged in and out. I have received an email from them confirming this. I am running openHAB 3.3.0 and have been stable for a long time. After some testing, I found calls to openweathermap:weather-and-forecast:f7e2c79590:locall works ok but calls to openweathermap:onecall:f7e2c79590:local does not. I will continue my investigation and let you know what I find. If anyone has any suggestions, please let me know. Cheers.
If you don’t have an option in your OWM Thing to switch to api version 3.0, your openHAB version is too old.
Only newer binding versions are able to switch from 2.5 to 3.0.
Even that might not make all the troubles go away. I am on 4.2.2 and using API 3.0, and for the the second time within two weeks I noticed it just stops updating. Disabling and enabling the OpenWeatherMap Account makes it wake up again.
Edit:
This happened again today. Log shows:
18:18:03.411 [WARN ] [ommon.WrappedScheduledExecutorService] - Scheduled runnable ended with an exception:
java.lang.NullPointerException: Cannot invoke "java.util.List.isEmpty()" because the return value of "org.openhab.binding.openweathermap.internal.dto.OpenWeatherMapOneCallAPIData.getMinutely()" is null
at org.openhab.binding.openweathermap.internal.handler.OpenWeatherMapOneCallHandler.updateMinutelyForecastTimeSeries(OpenWeatherMapOneCallHandler.java:442) ~[?:?]
at org.openhab.binding.openweathermap.internal.handler.OpenWeatherMapOneCallHandler.updateChannel(OpenWeatherMapOneCallHandler.java:254) ~[?:?]
at org.openhab.binding.openweathermap.internal.handler.AbstractOpenWeatherMapHandler.updateChannels(AbstractOpenWeatherMapHandler.java:165) ~[?:?]
at org.openhab.binding.openweathermap.internal.handler.AbstractOpenWeatherMapHandler.updateData(AbstractOpenWeatherMapHandler.java:136) ~[?:?]
at org.openhab.binding.openweathermap.internal.handler.OpenWeatherMapAPIHandler.updateThing(OpenWeatherMapAPIHandler.java:186) ~[?:?]
at org.openhab.binding.openweathermap.internal.handler.OpenWeatherMapAPIHandler.updateThings(OpenWeatherMapAPIHandler.java:176) ~[?:?]
at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:539) ~[?:?]
at java.util.concurrent.FutureTask.runAndReset(FutureTask.java:305) ~[?:?]
at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:305) ~[?:?]
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1136) [?:?]
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:635) [?:?]
at java.lang.Thread.run(Thread.java:840) [?:?]
I made a rule to restart the binding so it’s not a problem, but this should not be happening. Any ideas?