mirror of
https://gitlab.alpinelinux.org/alpine/aports.git
synced 2025-12-29 21:32:22 +01:00
60 lines
1.6 KiB
Lua
60 lines
1.6 KiB
Lua
local publish = require("mqtt.publish")
|
|
local json = require("cjson")
|
|
|
|
local hostname
|
|
local f = io.open("/proc/sys/kernel/hostname")
|
|
hostname = f:read()
|
|
f:close()
|
|
|
|
local urlprefix=("http://build.alpinelinux.org/buildlogs/%s"):format(hostname)
|
|
|
|
local m = {}
|
|
|
|
--local logtarget="distfiles.alpinelinux.org:/var/cache/distfiles/buildlogs/"..hostname
|
|
|
|
function shell_escape(args)
|
|
local ret = {}
|
|
for _,a in pairs(args) do
|
|
s = tostring(a)
|
|
if s:match("[^A-Za-z0-9_/:=-]") then
|
|
s = "'"..s:gsub("'", "'\\''").."'"
|
|
end
|
|
table.insert(ret,s)
|
|
end
|
|
return table.concat(ret, " ")
|
|
end
|
|
|
|
function run(args)
|
|
local h = io.popen(shell_escape(args))
|
|
local outstr = h:read("*a")
|
|
return h:close(), outstr
|
|
end
|
|
|
|
function m.postbuild(aport, success, repodest, arch, logfile)
|
|
-- upload log
|
|
local loghost,logdirprefix = (logtarget or ""):match("(.*):(.*)")
|
|
if logfile and loghost and logdirprefix then
|
|
local logdir = logdirprefix.."/"..aport:get_repo_name().."/"..aport.pkgname.."/"
|
|
run{"ssh", loghost, "mkdir", "-p", logdir}
|
|
run{"scp", logfile, loghost..":"..logdir}
|
|
end
|
|
|
|
if not success then
|
|
local topic = ("build/%s/errors"):format(hostname)
|
|
local payload = json.encode{
|
|
pkgname = aport.pkgname,
|
|
hostname = hostname,
|
|
reponame = aport:get_repo_name(),
|
|
logurl = ("%s/%s/%s-%s-r%s.log"):format(
|
|
urlprefix,
|
|
(string.match(aport.dir,"[^/]+/[^/]+$")),
|
|
aport.pkgname, aport.pkgver, aport.pkgrel),
|
|
status = success
|
|
}
|
|
publish.single(topic, payload, nil, nil, "msg.alpinelinux.org")
|
|
end
|
|
end
|
|
|
|
return m
|
|
|