summaryrefslogtreecommitdiff
path: root/weather-widget/weather.lua
diff options
context:
space:
mode:
authorstreetturtle <streetturtle@users.noreply.github.com>2019-07-03 11:48:03 -0400
committerGitHub <noreply@github.com>2019-07-03 11:48:03 -0400
commit372ae3c9e7cab4b64b8dcaf31d9d2d921a723585 (patch)
treeea7fe6ba9b88ad21d8bf67e84ff5c5a021239eed /weather-widget/weather.lua
parent0fb355887e0e6b6e0faa867f320d1dfd8c5be48d (diff)
parentfe631a4253802e597568e492a24c2b5dab897774 (diff)
Merge pull request #84 from webknjaz/bugfix/query-weather-async
Query weather with async timeouts
Diffstat (limited to 'weather-widget/weather.lua')
-rw-r--r--weather-widget/weather.lua37
1 files changed, 31 insertions, 6 deletions
diff --git a/weather-widget/weather.lua b/weather-widget/weather.lua
index d5f07f8..2d80947 100644
--- a/weather-widget/weather.lua
+++ b/weather-widget/weather.lua
@@ -6,7 +6,9 @@
-- @copyright 2018 Pavel Makhov
-------------------------------------------------
+local socket = require("socket")
local http = require("socket.http")
+local ltn12 = require("ltn12")
local json = require("json")
local naughty = require("naughty")
local wibox = require("wibox")
@@ -14,6 +16,13 @@ local gears = require("gears")
local secrets = require("awesome-wm-widgets.secrets")
+local weather_api_url = (
+ 'https://api.openweathermap.org/data/2.5/weather'
+ .. '?q=' .. secrets.weather_widget_city
+ .. '&appid=' .. secrets.weather_widget_api_key
+ .. '&units=' .. secrets.weather_widget_units
+)
+
local path_to_icons = "/usr/share/icons/Arc/status/symbolic/"
local icon_widget = wibox.widget {
@@ -93,18 +102,34 @@ local weather_timer = gears.timer({ timeout = 60 })
local resp
weather_timer:connect_signal("timeout", function ()
- local resp_json, status = http.request('https://api.openweathermap.org/data/2.5/weather?q='
- .. secrets.weather_widget_city
- .. '&appid=' .. secrets.weather_widget_api_key
- .. '&units=' .. secrets.weather_widget_units)
- if (status ~= 200 and resp_json ~= nil) then
+ local resp_json = {}
+ local res, status = http.request{
+ url=weather_api_url,
+ sink=ltn12.sink.table(resp_json),
+ -- ref:
+ -- http://w3.impa.br/~diego/software/luasocket/old/luasocket-2.0/http.html
+ create=function()
+ -- ref: https://stackoverflow.com/a/6021774/595220
+ local req_sock = socket.tcp()
+ -- 't' — overall timeout
+ req_sock:settimeout(0.2, 't')
+ -- 'b' — block timeout
+ req_sock:settimeout(0.001, 'b')
+ return req_sock
+ end
+ }
+ if (resp_json ~= nil) then
+ resp_json = table.concat(resp_json)
+ end
+
+ if (status ~= 200 and resp_json ~= nil and resp_json ~= '') then
local err_resp = json.decode(resp_json)
naughty.notify{
title = 'Weather Widget Error',
text = err_resp.message,
preset = naughty.config.presets.critical,
}
- elseif (resp_json ~= nil) then
+ elseif (resp_json ~= nil and resp_json ~= '') then
resp = json.decode(resp_json)
icon_widget.image = path_to_icons .. icon_map[resp.weather[1].icon]
temp_widget:set_text(string.gsub(resp.main.temp, "%.%d+", "")