Software /
code /
prosody-modules
Annotate
mod_log_json/mod_log_json.lua @ 3742:05bca7a771d6
mod_bookmarks2: Remove unused variables.
author | Emmanuel Gil Peyrot <linkmauve@linkmauve.fr> |
---|---|
date | Wed, 13 Nov 2019 16:45:48 +0100 |
parent | 3734:b8bd79c57040 |
child | 3746:bc865568ff02 |
rev | line source |
---|---|
3732 | 1 local pack = require "util.table".pack; |
2 local json = require "util.json"; | |
3 local array = require "util.array"; | |
4 local datetime = require "util.datetime".datetime; | |
5 | |
6 module:set_global(); | |
7 | |
8 local function sink_maker(config) | |
3734
b8bd79c57040
mod_log_json: Open file in read+append mode
Kim Alvefur <zash@zash.se>
parents:
3733
diff
changeset
|
9 local logfile = io.open(config.filename, "a+"); |
3732 | 10 logfile:setvbuf("no"); |
11 return function (source, level, message, ...) | |
12 local args = pack(...); | |
13 for i = 1, args.n do | |
14 if args[i] == nil then | |
15 args[i] = json.null; | |
16 elseif type(args[i]) ~= "string" or type(args[i]) ~= "number" then | |
17 args[i] = tostring(args[i]); | |
18 end | |
19 end | |
20 args.n = nil; | |
21 local payload = { | |
22 datetime = datetime(), | |
23 source = source, | |
24 level = level, | |
25 message = message, | |
26 args = array(args); | |
27 }; | |
28 logfile:write(json.encode(payload), "\n"); | |
29 end | |
30 end | |
31 | |
32 require"core.loggingmanager".register_sink_type("json", sink_maker); |