summaryrefslogtreecommitdiff
path: root/weather-widget
diff options
context:
space:
mode:
authorSviatoslav Sydorenko <wk@sydorenko.org.ua>2019-06-03 16:35:40 +0200
committerstreetturtle <streetturtle@gmail.com>2019-09-02 15:45:17 -0400
commitb41daeb9b2fd0206124740b165bcb8254a84c7b4 (patch)
tree9a11b1ccfc0a990b84032112efb244ab0886cb99 /weather-widget
parent54500cf15d1272ee63edd44de695c6e803f570ce (diff)
Query weather with async timeouts
Fixes #81
Diffstat (limited to 'weather-widget')
-rw-r--r--weather-widget/weather.lua80
1 files changed, 40 insertions, 40 deletions
diff --git a/weather-widget/weather.lua b/weather-widget/weather.lua
index deeff61..0899b8f 100644
--- a/weather-widget/weather.lua
+++ b/weather-widget/weather.lua
@@ -6,8 +6,8 @@
-- @copyright 2018 Pavel Makhov
-------------------------------------------------
-local http = require("socket.http")
local socket = require("socket")
+local http = require("socket.http")
local ltn12 = require("ltn12")
local json = require("json")
local naughty = require("naughty")
@@ -109,47 +109,47 @@ local function worker(args)
return directions[math.floor((degrees % 360) / 22.5) + 1]
end
- local weather_timer = gears.timer({ timeout = 60 })
- local resp
-
- weather_timer:connect_signal("timeout", function()
- 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)
+local weather_timer = gears.timer({ timeout = 60 })
+local resp
+
+weather_timer:connect_signal("timeout", function ()
+ 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) 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 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+", "")
- .. '°'
- .. (units == 'metric' and 'C' or 'F'))
- end
- end)
- weather_timer:start()
- weather_timer:emit_signal("timeout")
+ 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 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+", "")
+ .. '°'
+ .. (secrets.weather_widget_units == 'metric' and 'C' or 'F'))
+ end
+end)
+weather_timer:start()
+weather_timer:emit_signal("timeout")
--- Notification with weather information. Popups when mouse hovers over the icon
local notification