[httpclient] turn globe led on after each successful REST call (200 and 204 status)
This commit is contained in:
parent
f0fa58daac
commit
0808d5db69
2 changed files with 21 additions and 0 deletions
|
@ -1,6 +1,10 @@
|
||||||
# Put your custom commands here that should be executed once
|
# Put your custom commands here that should be executed once
|
||||||
# the system init finished. By default this file does nothing.
|
# the system init finished. By default this file does nothing.
|
||||||
|
|
||||||
|
# set the globe led pin (=GPIO 5) direction to output
|
||||||
|
gpioctl dirout 5
|
||||||
|
# turn the globe led pin off (inverted logic)
|
||||||
|
gpioctl set 5
|
||||||
# set the wifi led pin (=GPIO 7) direction to output
|
# set the wifi led pin (=GPIO 7) direction to output
|
||||||
gpioctl dirout 7
|
gpioctl dirout 7
|
||||||
|
|
||||||
|
|
|
@ -20,6 +20,7 @@ local util = require "luci.util"
|
||||||
local table = require "table"
|
local table = require "table"
|
||||||
local coroutine = require "coroutine"
|
local coroutine = require "coroutine"
|
||||||
local string = require "string"
|
local string = require "string"
|
||||||
|
local os = require "os"
|
||||||
local http = require "luci.http.protocol"
|
local http = require "luci.http.protocol"
|
||||||
local date = require "luci.http.protocol.date"
|
local date = require "luci.http.protocol.date"
|
||||||
|
|
||||||
|
@ -106,19 +107,35 @@ end
|
||||||
|
|
||||||
function create_persistent()
|
function create_persistent()
|
||||||
return coroutine.wrap(function(uri, options)
|
return coroutine.wrap(function(uri, options)
|
||||||
|
local function globe_on()
|
||||||
|
os.execute("gpioctl clear 5 > /dev/null")
|
||||||
|
end
|
||||||
|
|
||||||
|
local function globe_off()
|
||||||
|
os.execute("gpioctl set 5 > /dev/null")
|
||||||
|
end
|
||||||
|
|
||||||
local status, response, buffer, sock
|
local status, response, buffer, sock
|
||||||
|
|
||||||
while true do
|
while true do
|
||||||
local output = {}
|
local output = {}
|
||||||
|
|
||||||
|
globe_off()
|
||||||
status, response, buffer, sock = request_raw(uri, options, sock)
|
status, response, buffer, sock = request_raw(uri, options, sock)
|
||||||
|
|
||||||
if not status then
|
if not status then
|
||||||
uri, options = coroutine.yield(nil, response, buffer)
|
uri, options = coroutine.yield(nil, response, buffer)
|
||||||
|
|
||||||
elseif status ~= 200 and status ~= 206 then
|
elseif status ~= 200 and status ~= 206 then
|
||||||
|
if status == 204 then
|
||||||
|
globe_on()
|
||||||
|
end
|
||||||
|
|
||||||
uri, options = coroutine.yield(nil, status, response)
|
uri, options = coroutine.yield(nil, status, response)
|
||||||
|
|
||||||
else
|
else
|
||||||
|
globe_on()
|
||||||
|
|
||||||
local content_length = tonumber(response.headers["Content-Length"])
|
local content_length = tonumber(response.headers["Content-Length"])
|
||||||
local bytes_read = 0
|
local bytes_read = 0
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue