Mercurial > irccd
annotate plugins/logger/logger.js @ 763:4283dc118339
Irccd: style (transport_util)
author | David Demelier <markand@malikania.fr> |
---|---|
date | Mon, 13 Aug 2018 13:50:11 +0200 |
parents | 3e816cebed2c |
children | 8c44bbcbbab9 |
rev | line source |
---|---|
0 | 1 /* |
2 * logger.js -- plugin to log everything | |
3 * | |
628
27587ff92a64
Misc: update copyrights
David Demelier <markand@malikania.fr>
parents:
577
diff
changeset
|
4 * Copyright (c) 2013-2018 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 = { |
722
3e816cebed2c
Irccd: make plugin pure abstract, closes #796 @3h
David Demelier <markand@malikania.fr>
parents:
628
diff
changeset
|
21 name: "logger", |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
22 author: "David Demelier <markand@malikania.fr>", |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
23 license: "ISC", |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
24 summary: "A plugin to log everything", |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
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. |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
29 var Directory = Irccd.Directory; |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
30 var File = Irccd.File; |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
31 var Logger = Irccd.Logger; |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
32 var Plugin = Irccd.Plugin; |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
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 /** |
36 * All available formats. | |
37 */ | |
144
5ed0c78a6785
Plugin logger: use new format section, #410
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
38 Plugin.format = { |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
39 "join": "%H:%M:%S >> #{nickname} joined #{channel}", |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
40 "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
|
41 "me": "%H:%M:%S * #{nickname} #{message}", |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
42 "message": "%H:%M:%S #{nickname}: #{message}", |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
43 "mode": "%H:%M:%S :: #{nickname} set mode #{mode} to #{arg}", |
577
3d0dbc0bee7d
Irccd: update references to onChannel(Mode|Notice), onMode
David Demelier <markand@malikania.fr>
parents:
454
diff
changeset
|
44 "notice": "%H:%M:%S [notice] #{channel} (#{nickname}) #{message}", |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
45 "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
|
46 "query": "%H:%M:%S #{nickname}: #{message}", |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
47 "topic": "%H:%M:%S :: #{nickname} changed the topic of #{channel} to: #{topic}" |
0 | 48 }; |
49 | |
50 /** | |
51 * Load all formats. | |
52 */ | |
53 function loadFormats() | |
54 { | |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
55 // --- DEPRECATED ------------------------------------------- |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
56 // |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
57 // This code will be removed. |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
58 // |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
59 // Since: 2.1.0 |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
60 // Until: 3.0.0 |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
61 // Reason: new [format] section replaces it. |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
62 // |
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 for (var key in Plugin.format) { |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
65 var optname = "format-" + key; |
0 | 66 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
67 if (typeof (Plugin.config[optname]) !== "string") |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
68 continue; |
0 | 69 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
70 if (Plugin.config[optname].length === 0) |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
71 Logger.warning("skipping empty '" + optname + "' format"); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
72 else |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
73 Plugin.format[key] = Plugin.config[optname]; |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
74 } |
0 | 75 } |
76 | |
77 function keywords(server, channel, origin, extra) | |
78 { | |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
79 var kw = { |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
80 "server": server.toString(), |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
81 "channel": channel, |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
82 "origin": origin, |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
83 "nickname": Util.splituser(origin) |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
84 }; |
0 | 85 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
86 for (var key in extra) |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
87 kw[key] = extra[key]; |
0 | 88 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
89 return kw; |
0 | 90 } |
91 | |
92 function write(fmt, args) | |
93 { | |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
94 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
|
95 var directory = File.dirname(path); |
0 | 96 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
97 // Try to create the directory. |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
98 if (!File.exists(directory)) { |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
99 Logger.debug("creating directory: " + directory); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
100 Directory.mkdir(directory); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
101 } |
0 | 102 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
103 Logger.debug("opening: " + path); |
0 | 104 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
105 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
|
106 var file = new File(path, "a"); |
0 | 107 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
108 file.write(str + "\n"); |
0 | 109 } |
110 | |
111 function onLoad() | |
112 { | |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
113 if (Plugin.config["path"] === undefined) |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
114 throw new Error("Missing 'path' option"); |
144
5ed0c78a6785
Plugin logger: use new format section, #410
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
115 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
116 loadFormats(); |
144
5ed0c78a6785
Plugin logger: use new format section, #410
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
117 } |
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 function onReload() |
5ed0c78a6785
Plugin logger: use new format section, #410
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
120 { |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
121 loadFormats(); |
0 | 122 } |
123 | |
124 function onInvite(server, origin, channel) | |
125 { | |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
126 origin = origin.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
127 channel = channel.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
128 |
577
3d0dbc0bee7d
Irccd: update references to onChannel(Mode|Notice), onMode
David Demelier <markand@malikania.fr>
parents:
454
diff
changeset
|
129 write("invite", keywords(server, channel, origin)); |
0 | 130 } |
131 | |
132 function onJoin(server, origin, channel) | |
133 { | |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
134 origin = origin.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
135 channel = channel.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
136 |
577
3d0dbc0bee7d
Irccd: update references to onChannel(Mode|Notice), onMode
David Demelier <markand@malikania.fr>
parents:
454
diff
changeset
|
137 write("join", keywords(server, channel, origin)); |
0 | 138 } |
139 | |
140 function onKick(server, origin, channel, target, reason) | |
141 { | |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
142 origin = origin.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
143 channel = channel.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
144 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
145 write("kick", keywords(server, channel, origin, { |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
146 "target": target, |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
147 "reason": reason |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
148 })); |
0 | 149 } |
150 | |
151 function onMe(server, origin, channel, message) | |
152 { | |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
153 origin = origin.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
154 channel = channel.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
155 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
156 write("me", keywords(server, channel, origin, { |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
157 "message": message, |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
158 })); |
0 | 159 } |
160 | |
161 function onMessage(server, origin, channel, message) | |
162 { | |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
163 origin = origin.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
164 channel = channel.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
165 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
166 write("message", keywords(server, channel, origin, { |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
167 "message": message, |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
168 })); |
0 | 169 } |
170 | |
577
3d0dbc0bee7d
Irccd: update references to onChannel(Mode|Notice), onMode
David Demelier <markand@malikania.fr>
parents:
454
diff
changeset
|
171 function onMode(server, origin, channel, mode, limit, user, mask) |
0 | 172 { |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
173 origin = origin.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
174 |
577
3d0dbc0bee7d
Irccd: update references to onChannel(Mode|Notice), onMode
David Demelier <markand@malikania.fr>
parents:
454
diff
changeset
|
175 write("mode", keywords(server, channel, origin, { |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
176 "mode": mode, |
577
3d0dbc0bee7d
Irccd: update references to onChannel(Mode|Notice), onMode
David Demelier <markand@malikania.fr>
parents:
454
diff
changeset
|
177 "limit": limit, |
3d0dbc0bee7d
Irccd: update references to onChannel(Mode|Notice), onMode
David Demelier <markand@malikania.fr>
parents:
454
diff
changeset
|
178 "user": user, |
3d0dbc0bee7d
Irccd: update references to onChannel(Mode|Notice), onMode
David Demelier <markand@malikania.fr>
parents:
454
diff
changeset
|
179 "mask": mask |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
180 })); |
0 | 181 } |
182 | |
183 function onNick(server, origin, nickname) | |
184 { | |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
185 // TODO: write for all servers/channels a log entry |
0 | 186 } |
187 | |
577
3d0dbc0bee7d
Irccd: update references to onChannel(Mode|Notice), onMode
David Demelier <markand@malikania.fr>
parents:
454
diff
changeset
|
188 function onNotice(server, origin, channel, notice) |
0 | 189 { |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
190 origin = origin.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
191 |
577
3d0dbc0bee7d
Irccd: update references to onChannel(Mode|Notice), onMode
David Demelier <markand@malikania.fr>
parents:
454
diff
changeset
|
192 write("notice", keywords(server, channel, origin, { |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
193 "message": notice, |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
194 })); |
0 | 195 } |
196 | |
197 function onPart(server, origin, channel, reason) | |
198 { | |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
199 origin = origin.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
200 channel = channel.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
201 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
202 write("part", keywords(server, channel, origin, { |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
203 "reason": reason, |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
204 })); |
0 | 205 } |
206 | |
207 function onTopic(server, origin, channel, topic) | |
208 { | |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
209 origin = origin.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
210 channel = channel.toLowerCase(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
413
diff
changeset
|
211 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
212 write("topic", keywords(server, channel, origin, { |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
213 "topic": topic |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
182
diff
changeset
|
214 })); |
0 | 215 } |