Mercurial > irccd
annotate plugins/logger/logger.js @ 454:8b615d37d303 release-2.1
Fix #642: plugins must be case sensitive
author | David Demelier <markand@malikania.fr> |
---|---|
date | Tue, 25 Jul 2017 17:08:19 +0200 |
parents | 9bc2da03dbe1 |
children | 3d0dbc0bee7d |
rev | line source |
---|---|
0 | 1 /* |
2 * logger.js -- plugin to log everything | |
3 * | |
394 | 4 * Copyright (c) 2013-2017 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 = { |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
21 author: "David Demelier <markand@malikania.fr>", |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
22 license: "ISC", |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
23 summary: "A plugin to log everything", |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
24 version: "@IRCCD_VERSION@" |
0 | 25 }; |
26 | |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
144
diff
changeset
|
27 // Modules. |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
28 var Directory = Irccd.Directory; |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
29 var File = Irccd.File; |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
30 var Logger = Irccd.Logger; |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
31 var Plugin = Irccd.Plugin; |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
32 var Util = Irccd.Util; |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
144
diff
changeset
|
33 |
0 | 34 /** |
35 * All available formats. | |
36 */ | |
144
5ed0c78a6785
Plugin logger: use new format section, #410
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
37 Plugin.format = { |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
38 "cmode": "%H:%M:%S :: #{nickname} changed the mode to: #{mode} #{arg}", |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
39 "cnotice": "%H:%M:%S :: [notice] (#{channel}) #{nickname}: #{message}", |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
40 "join": "%H:%M:%S >> #{nickname} joined #{channel}", |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
41 "kick": "%H:%M:%S :: #{target} has been kicked by #{nickname} [reason: #{reason}]", |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
42 "me": "%H:%M:%S * #{nickname} #{message}", |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
43 "message": "%H:%M:%S #{nickname}: #{message}", |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
44 "mode": "%H:%M:%S :: #{nickname} set mode #{mode} to #{arg}", |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
45 "notice": "%H:%M:%S [notice] (#{nickname}) #{message}", |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
46 "part": "%H:%M:%S << #{nickname} left #{channel} [#{reason}]", |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
47 "query": "%H:%M:%S #{nickname}: #{message}", |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
48 "topic": "%H:%M:%S :: #{nickname} changed the topic of #{channel} to: #{topic}" |
0 | 49 }; |
50 | |
51 /** | |
52 * Load all formats. | |
53 */ | |
54 function loadFormats() | |
55 { | |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
56 // --- DEPRECATED ------------------------------------------- |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
57 // |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
58 // This code will be removed. |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
59 // |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
60 // Since: 2.1.0 |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
61 // Until: 3.0.0 |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
62 // Reason: new [format] section replaces it. |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
63 // |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
64 // ---------------------------------------------------------- |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
65 for (var key in Plugin.format) { |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
66 var optname = "format-" + key; |
0 | 67 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
68 if (typeof (Plugin.config[optname]) !== "string") |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
69 continue; |
0 | 70 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
71 if (Plugin.config[optname].length === 0) |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
72 Logger.warning("skipping empty '" + optname + "' format"); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
73 else |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
74 Plugin.format[key] = Plugin.config[optname]; |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
75 } |
0 | 76 } |
77 | |
78 function keywords(server, channel, origin, extra) | |
79 { | |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
80 var kw = { |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
81 "server": server.toString(), |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
82 "channel": channel, |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
83 "origin": origin, |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
84 "nickname": Util.splituser(origin) |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
85 }; |
0 | 86 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
87 for (var key in extra) |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
88 kw[key] = extra[key]; |
0 | 89 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
90 return kw; |
0 | 91 } |
92 | |
93 function write(fmt, args) | |
94 { | |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
95 var path = Util.format(Plugin.config["path"], args); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
96 var directory = File.dirname(path); |
0 | 97 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
98 // Try to create the directory. |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
99 if (!File.exists(directory)) { |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
100 Logger.debug("creating directory: " + directory); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
101 Directory.mkdir(directory); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
102 } |
0 | 103 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
104 Logger.debug("opening: " + path); |
0 | 105 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
106 var str = Util.format(Plugin.format[fmt], args); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
107 var file = new File(path, "a"); |
0 | 108 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
109 file.write(str + "\n"); |
0 | 110 } |
111 | |
112 function onLoad() | |
113 { | |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
114 if (Plugin.config["path"] === undefined) |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
115 throw new Error("Missing 'path' option"); |
144
5ed0c78a6785
Plugin logger: use new format section, #410
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
116 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
117 loadFormats(); |
144
5ed0c78a6785
Plugin logger: use new format section, #410
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
118 } |
5ed0c78a6785
Plugin logger: use new format section, #410
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
119 |
5ed0c78a6785
Plugin logger: use new format section, #410
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
120 function onReload() |
5ed0c78a6785
Plugin logger: use new format section, #410
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
121 { |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
122 loadFormats(); |
0 | 123 } |
124 | |
125 function onChannelMode(server, origin, channel, mode, arg) | |
126 { | |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
127 origin = origin.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
128 channel = channel.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
129 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
130 write("cmode", keywords(server, channel, origin, { |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
131 "arg": arg, |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
132 "mode": mode, |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
133 "source": channel |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
134 })); |
0 | 135 } |
136 | |
137 function onChannelNotice(server, origin, channel, notice) | |
138 { | |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
139 origin = origin.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
140 channel = channel.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
141 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
142 write("cnotice", keywords(server, channel, origin, { |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
143 "message": notice, |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
144 "source": channel |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
145 })); |
0 | 146 } |
147 | |
148 function onInvite(server, origin, channel) | |
149 { | |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
150 origin = origin.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
151 channel = channel.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
152 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
153 write("invite", keywords(server, channel, origin, { |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
154 "source": channel |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
155 })); |
0 | 156 } |
157 | |
158 function onJoin(server, origin, channel) | |
159 { | |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
160 origin = origin.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
161 channel = channel.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
162 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
163 write("join", keywords(server, channel, origin, { |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
164 "source": channel |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
165 })); |
0 | 166 } |
167 | |
168 function onKick(server, origin, channel, target, reason) | |
169 { | |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
170 origin = origin.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
171 channel = channel.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
172 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
173 write("kick", keywords(server, channel, origin, { |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
174 "target": target, |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
175 "source": channel, |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
176 "reason": reason |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
177 })); |
0 | 178 } |
179 | |
180 function onMe(server, origin, channel, message) | |
181 { | |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
182 origin = origin.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
183 channel = channel.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
184 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
185 write("me", keywords(server, channel, origin, { |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
186 "message": message, |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
187 "source": channel |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
188 })); |
0 | 189 } |
190 | |
191 function onMessage(server, origin, channel, message) | |
192 { | |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
193 origin = origin.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
194 channel = channel.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
195 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
196 write("message", keywords(server, channel, origin, { |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
197 "message": message, |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
198 "source": channel |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
199 })); |
0 | 200 } |
201 | |
202 function onMode(server, origin, mode) | |
203 { | |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
204 origin = origin.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
205 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
206 write("mode", keywords(server, undefined, origin, { |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
207 "mode": mode, |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
208 "source": Util.splituser(origin) |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
209 })); |
0 | 210 } |
211 | |
212 function onNick(server, origin, nickname) | |
213 { | |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
214 // TODO: write for all servers/channels a log entry |
0 | 215 } |
216 | |
217 function onNotice(server, origin, notice) | |
218 { | |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
219 origin = origin.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
220 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
221 write("notice", keywords(server, undefined, origin, { |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
222 "message": notice, |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
223 "source": Util.splituser(origin) |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
224 })); |
0 | 225 } |
226 | |
227 function onPart(server, origin, channel, reason) | |
228 { | |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
229 origin = origin.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
230 channel = channel.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
231 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
232 write("part", keywords(server, channel, origin, { |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
233 "reason": reason, |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
234 "source": channel |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
235 })); |
0 | 236 } |
237 | |
238 function onQuery(server, origin, message) | |
239 { | |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
240 origin = origin.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
241 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
242 write("query", keywords(server, undefined, origin, { |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
243 "source": Util.splituser(origin), |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
244 "message": message |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
245 })); |
0 | 246 } |
247 | |
248 function onTopic(server, origin, channel, topic) | |
249 { | |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
250 origin = origin.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
251 channel = channel.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
252 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
253 write("topic", keywords(server, channel, origin, { |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
254 "source": channel, |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
255 "topic": topic |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
256 })); |
0 | 257 } |