Mercurial > irccd
annotate plugins/logger/logger.js @ 1004:3ea3361f0fc7
irccd: now track modes
author | David Demelier <markand@malikania.fr> |
---|---|
date | Tue, 16 Feb 2021 18:37:22 +0100 |
parents | 583d9f83e9f5 |
children | 637a98de3910 |
rev | line source |
---|---|
0 | 1 /* |
2 * logger.js -- plugin to log everything | |
3 * | |
913 | 4 * Copyright (c) 2013-2020 David Demelier <markand@malikania.fr> |
0 | 5 * |
6 * Permission to use, copy, modify, and/or distribute this software for any | |
7 * purpose with or without fee is hereby granted, provided that the above | |
8 * copyright notice and this permission notice appear in all copies. | |
9 * | |
10 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES | |
11 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF | |
12 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR | |
13 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES | |
14 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN | |
15 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF | |
16 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | |
17 */ | |
18 | |
144
5ed0c78a6785
Plugin logger: use new format section, #410
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
19 // Plugin information. |
0 | 20 info = { |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
21 name: "logger", |
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
22 author: "David Demelier <markand@malikania.fr>", |
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
23 license: "ISC", |
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
24 summary: "A plugin to log everything", |
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
25 version: "@IRCCD_VERSION@" |
0 | 26 }; |
27 | |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
144
diff
changeset
|
28 // Modules. |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
29 var Directory = Irccd.Directory; |
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
30 var File = Irccd.File; |
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
31 var Logger = Irccd.Logger; |
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
32 var Plugin = Irccd.Plugin; |
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
33 var Util = Irccd.Util; |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
144
diff
changeset
|
34 |
0 | 35 /** |
847
a23b7b574ed2
irccd: rename [format] section to [templates], closes #1671
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
36 * All available templates. |
0 | 37 */ |
847
a23b7b574ed2
irccd: rename [format] section to [templates], closes #1671
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
38 Plugin.templates = { |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
39 "join": "%H:%M:%S >> #{nickname} joined #{channel}", |
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
40 "kick": "%H:%M:%S :: #{target} has been kicked by #{nickname} [reason: #{reason}]", |
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
41 "me": "%H:%M:%S * #{nickname} #{message}", |
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
42 "message": "%H:%M:%S #{nickname}: #{message}", |
986
583d9f83e9f5
irccd: bring back Javascript plugins
David Demelier <markand@malikania.fr>
parents:
913
diff
changeset
|
43 "invite": "%H:%M:%S #{nickname} invited you on #{channel}", |
1004
3ea3361f0fc7
irccd: now track modes
David Demelier <markand@malikania.fr>
parents:
986
diff
changeset
|
44 "mode": "%H:%M:%S :: #{nickname} set mode #{channel} #{mode} #{args}", |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
45 "notice": "%H:%M:%S [notice] #{channel} (#{nickname}) #{message}", |
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
46 "part": "%H:%M:%S << #{nickname} left #{channel} [#{reason}]", |
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
47 "query": "%H:%M:%S #{nickname}: #{message}", |
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
48 "topic": "%H:%M:%S :: #{nickname} changed the topic of #{channel} to: #{topic}" |
0 | 49 }; |
50 | |
51 function keywords(server, channel, origin, extra) | |
52 { | |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
53 var kw = { |
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
54 "server": server.toString(), |
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
55 "channel": channel, |
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
56 "origin": origin, |
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
57 "nickname": Util.splituser(origin) |
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
58 }; |
0 | 59 |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
60 for (var key in extra) |
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
61 kw[key] = extra[key]; |
0 | 62 |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
63 return kw; |
0 | 64 } |
65 | |
66 function write(fmt, args) | |
67 { | |
862
6b65493d97cf
plugin logger: rename path configuration to file, closes #1670
David Demelier <markand@malikania.fr>
parents:
847
diff
changeset
|
68 var path = Util.format(Plugin.config["file"], args); |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
69 var directory = File.dirname(path); |
0 | 70 |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
71 // Try to create the directory. |
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
72 if (!File.exists(directory)) { |
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
73 Logger.debug("creating directory: " + directory); |
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
74 Directory.mkdir(directory); |
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
75 } |
0 | 76 |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
77 Logger.debug("opening: " + path); |
0 | 78 |
847
a23b7b574ed2
irccd: rename [format] section to [templates], closes #1671
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
79 var str = Util.format(Plugin.templates[fmt], args); |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
80 var file = new File(path, "a"); |
0 | 81 |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
82 file.write(str + "\n"); |
0 | 83 } |
84 | |
85 function onLoad() | |
86 { | |
862
6b65493d97cf
plugin logger: rename path configuration to file, closes #1670
David Demelier <markand@malikania.fr>
parents:
847
diff
changeset
|
87 if (Plugin.config["file"] === undefined) |
6b65493d97cf
plugin logger: rename path configuration to file, closes #1670
David Demelier <markand@malikania.fr>
parents:
847
diff
changeset
|
88 throw new Error("Missing 'file' option"); |
0 | 89 } |
90 | |
91 function onInvite(server, origin, channel) | |
92 { | |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
93 origin = origin.toLowerCase(); |
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
94 channel = channel.toLowerCase(); |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
95 |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
96 write("invite", keywords(server, channel, origin)); |
0 | 97 } |
98 | |
99 function onJoin(server, origin, channel) | |
100 { | |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
101 origin = origin.toLowerCase(); |
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
102 channel = channel.toLowerCase(); |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
103 |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
104 write("join", keywords(server, channel, origin)); |
0 | 105 } |
106 | |
107 function onKick(server, origin, channel, target, reason) | |
108 { | |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
109 origin = origin.toLowerCase(); |
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
110 channel = channel.toLowerCase(); |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
111 |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
112 write("kick", keywords(server, channel, origin, { |
986
583d9f83e9f5
irccd: bring back Javascript plugins
David Demelier <markand@malikania.fr>
parents:
913
diff
changeset
|
113 "target": target, |
583d9f83e9f5
irccd: bring back Javascript plugins
David Demelier <markand@malikania.fr>
parents:
913
diff
changeset
|
114 "reason": reason |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
115 })); |
0 | 116 } |
117 | |
118 function onMe(server, origin, channel, message) | |
119 { | |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
120 origin = origin.toLowerCase(); |
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
121 channel = channel.toLowerCase(); |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
122 |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
123 write("me", keywords(server, channel, origin, { |
986
583d9f83e9f5
irccd: bring back Javascript plugins
David Demelier <markand@malikania.fr>
parents:
913
diff
changeset
|
124 "message": message, |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
125 })); |
0 | 126 } |
127 | |
128 function onMessage(server, origin, channel, message) | |
129 { | |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
130 origin = origin.toLowerCase(); |
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
131 channel = channel.toLowerCase(); |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
132 |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
133 write("message", keywords(server, channel, origin, { |
986
583d9f83e9f5
irccd: bring back Javascript plugins
David Demelier <markand@malikania.fr>
parents:
913
diff
changeset
|
134 "message": message, |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
135 })); |
0 | 136 } |
137 | |
1004
3ea3361f0fc7
irccd: now track modes
David Demelier <markand@malikania.fr>
parents:
986
diff
changeset
|
138 function onMode(server, origin, channel, mode, args) |
0 | 139 { |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
140 origin = origin.toLowerCase(); |
1004
3ea3361f0fc7
irccd: now track modes
David Demelier <markand@malikania.fr>
parents:
986
diff
changeset
|
141 channel = channel.toLowerCase(); |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
142 |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
143 write("mode", keywords(server, channel, origin, { |
986
583d9f83e9f5
irccd: bring back Javascript plugins
David Demelier <markand@malikania.fr>
parents:
913
diff
changeset
|
144 "mode": mode, |
1004
3ea3361f0fc7
irccd: now track modes
David Demelier <markand@malikania.fr>
parents:
986
diff
changeset
|
145 "args": args.join(" "), |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
146 })); |
0 | 147 } |
148 | |
149 function onNick(server, origin, nickname) | |
150 { | |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
151 // TODO: write for all servers/channels a log entry |
0 | 152 } |
153 | |
577
3d0dbc0bee7d
Irccd: update references to onChannel(Mode|Notice), onMode
David Demelier <markand@malikania.fr>
parents:
454
diff
changeset
|
154 function onNotice(server, origin, channel, notice) |
0 | 155 { |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
156 origin = origin.toLowerCase(); |
1004
3ea3361f0fc7
irccd: now track modes
David Demelier <markand@malikania.fr>
parents:
986
diff
changeset
|
157 channel = channel.toLowerCase(); |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
158 |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
159 write("notice", keywords(server, channel, origin, { |
986
583d9f83e9f5
irccd: bring back Javascript plugins
David Demelier <markand@malikania.fr>
parents:
913
diff
changeset
|
160 "message": notice, |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
161 })); |
0 | 162 } |
163 | |
164 function onPart(server, origin, channel, reason) | |
165 { | |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
166 origin = origin.toLowerCase(); |
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
167 channel = channel.toLowerCase(); |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
168 |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
169 write("part", keywords(server, channel, origin, { |
986
583d9f83e9f5
irccd: bring back Javascript plugins
David Demelier <markand@malikania.fr>
parents:
913
diff
changeset
|
170 "reason": reason, |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
171 })); |
0 | 172 } |
173 | |
174 function onTopic(server, origin, channel, topic) | |
175 { | |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
176 origin = origin.toLowerCase(); |
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
177 channel = channel.toLowerCase(); |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
178 |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
179 write("topic", keywords(server, channel, origin, { |
986
583d9f83e9f5
irccd: bring back Javascript plugins
David Demelier <markand@malikania.fr>
parents:
913
diff
changeset
|
180 "topic": topic |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
181 })); |
0 | 182 } |