air780e-forwarder/script/util_http.lua

48 lines
1.3 KiB
Lua

local util_http = {}
-- 用于生成 http 请求的 id
local http_count = 0
-- 记录正在运行的 http 请求数量
local http_running_count = 0
--- 对 http.request 的封装
-- @param timeout 超时时间(单位: 毫秒)
-- @param method 请求方法
-- @param url 请求地址
-- @param headers 请求头
-- @param body 请求体
function util_http.fetch(timeout, method, url, headers, body)
timeout = timeout or 1000 * 25
local opts = {timeout = timeout}
http_count = http_count + 1
http_running_count = http_running_count + 1
local id = "http_" .. http_count
local res_code, res_headers, res_body = -99, {}, ""
util_netled.blink(50, 50)
sys.taskInit(
function()
log.debug("util_http.fetch", "开始请求", "id:", id)
res_code, res_headers, res_body = http.request(method, url, headers, body, opts).wait()
log.debug("util_http.fetch", "请求结束", "id:", id, "code:", res_code)
sys.publish(id)
end
)
local result = sys.waitUntil(id, timeout + 1000 * 25)
if not result or res_code == -8 then
log.warn("util_http.fetch", "请求超时", "id:", id)
end
http_running_count = http_running_count - 1
if http_running_count == 0 then
util_netled.blink()
end
return res_code, res_headers, res_body
end
return util_http