annotate plugins/logger/logger.js @ 0:1158cffe5a5e

Initial import
author David Demelier <markand@malikania.fr>
date Mon, 08 Feb 2016 16:43:14 +0100
parents
children 5ed0c78a6785 50dcadcf5070
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
1 /*
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
2 * logger.js -- plugin to log everything
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
3 *
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
4 * Copyright (c) 2013-2016 David Demelier <markand@malikania.fr>
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
5 *
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
6 * Permission to use, copy, modify, and/or distribute this software for any
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
7 * purpose with or without fee is hereby granted, provided that the above
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
8 * copyright notice and this permission notice appear in all copies.
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
9 *
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
10 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
11 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
12 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
13 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
14 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
15 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
16 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
17 */
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
18
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
19 /* Modules */
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
20 var Directory = Irccd.Directory;
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
21 var File = Irccd.File;
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
22 var Logger = Irccd.Logger;
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
23 var Plugin = Irccd.Plugin;
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
24 var Util = Irccd.Util;
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
25
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
26 /* Plugin information */
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
27 info = {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
28 author: "David Demelier <markand@malikania.fr>",
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
29 license: "ISC",
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
30 summary: "A plugin to log everything",
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
31 version: "@IRCCD_VERSION@"
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
32 };
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
33
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
34 /**
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
35 * All available formats.
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
36 */
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
37 var formats = {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
38 "cmode": "%H:%M:%S :: #{nickname} changed the mode to: #{mode} #{arg}",
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
39 "cnotice": "%H:%M:%S :: [notice] (#{channel}) #{nickname}: #{message}",
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
40 "join": "%H:%M:%S >> #{nickname} joined #{channel}",
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
41 "kick": "%H:%M:%S :: #{target} has been kicked by #{nickname} [reason: #{reason}]",
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
42 "me": "%H:%M:%S * #{nickname} #{message}",
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
43 "message": "%H:%M:%S #{nickname}: #{message}",
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
44 "mode": "%H:%M:%S :: #{nickname} set mode #{mode} to #{arg}",
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
45 "notice": "%H:%M:%S [notice] (#{nickname}) #{message}",
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
46 "part": "%H:%M:%S << #{nickname} left #{channel} [#{reason}]",
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
47 "query": "%H:%M:%S #{nickname}: #{message}",
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
48 "topic": "%H:%M:%S :: #{nickname} changed the topic of #{channel} to: #{topic}"
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
49 };
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
50
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
51 /**
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
52 * Load all formats.
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
53 */
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
54 function loadFormats()
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
55 {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
56 for (var key in formats) {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
57 var optname = "format-" + key;
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
58
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
59 if (typeof (Plugin.config[optname]) !== "string")
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
60 continue;
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
61
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
62 if (Plugin.config[optname].length === 0)
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
63 Logger.warning("skipping empty '" + optname + "' format");
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
64 else
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
65 formats[key] = Plugin.config[optname];
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
66 }
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
67 }
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
68
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
69 function keywords(server, channel, origin, extra)
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
70 {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
71 var kw = {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
72 "server": server.toString(),
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
73 "channel": channel,
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
74 "origin": origin,
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
75 "nickname": Util.splituser(origin)
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
76 };
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
77
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
78 for (var key in extra)
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
79 kw[key] = extra[key];
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
80
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
81 return kw;
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
82 }
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
83
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
84 function write(fmt, args)
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
85 {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
86 var path = Util.format(Plugin.config["path"], args);
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
87 var directory = File.dirname(path);
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
88
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
89 /* Try to create the directory */
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
90 if (!File.exists(directory)) {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
91 Logger.debug("creating directory: " + directory);
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
92 Directory.mkdir(directory);
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
93 }
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
94
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
95 Logger.debug("opening: " + path);
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
96
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
97 var str = Util.format(formats[fmt], args);
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
98 var file = new File(path, "wa");
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
99
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
100 file.write(str + "\n");
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
101 }
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
102
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
103 function onLoad()
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
104 {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
105 if (Plugin.config["path"] === undefined)
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
106 throw new Error("Missing 'path' option");
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
107 }
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
108
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
109 function onChannelMode(server, origin, channel, mode, arg)
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
110 {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
111 write("cmode", keywords(server, channel, origin, {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
112 "arg": arg,
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
113 "mode": mode,
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
114 "source": channel
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
115 }));
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
116 }
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
117
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
118 function onChannelNotice(server, origin, channel, notice)
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
119 {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
120 write("cnotice", keywords(server, channel, origin, {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
121 "message": notice,
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
122 "source": channel
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
123 }));
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
124 }
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
125
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
126 function onInvite(server, origin, channel)
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
127 {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
128 write("invite", keywords(server, channel, origin, {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
129 "source": channel
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
130 }));
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
131 }
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
132
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
133 function onJoin(server, origin, channel)
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
134 {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
135 write("join", keywords(server, channel, origin, {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
136 "source": channel
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
137 }));
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
138 }
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
139
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
140 function onKick(server, origin, channel, target, reason)
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
141 {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
142 write("kick", keywords(server, channel, origin, {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
143 "target": target,
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
144 "source": channel,
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
145 "reason": reason
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
146 }));
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
147 }
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
148
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
149 function onMe(server, origin, channel, message)
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
150 {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
151 write("me", keywords(server, channel, origin, {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
152 "message": message,
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
153 "source": channel
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
154 }));
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
155 }
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
156
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
157 function onMessage(server, origin, channel, message)
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
158 {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
159 write("message", keywords(server, channel, origin, {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
160 "message": message,
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
161 "source": channel
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
162 }));
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
163 }
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
164
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
165 function onMode(server, origin, mode)
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
166 {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
167 write("mode", keywords(server, undefined, origin, {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
168 "mode": mode,
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
169 "source": Util.splituser(origin)
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
170 }));
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
171 }
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
172
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
173 function onNick(server, origin, nickname)
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
174 {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
175 // TODO: write for all servers/channels a log entry
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
176 }
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
177
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
178 function onNotice(server, origin, notice)
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
179 {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
180 write("notice", keywords(server, undefined, origin, {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
181 "message": notice,
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
182 "source": Util.splituser(origin)
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
183 }));
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
184 }
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
185
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
186 function onPart(server, origin, channel, reason)
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
187 {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
188 write("part", keywords(server, channel, origin, {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
189 "reason": reason,
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
190 "source": channel
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
191 }));
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
192 }
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
193
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
194 function onQuery(server, origin, message)
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
195 {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
196 write("query", keywords(server, undefined, origin, {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
197 "source": Util.splituser(origin),
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
198 "message": message
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
199 }));
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
200 }
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
201
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
202 function onTopic(server, origin, channel, topic)
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
203 {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
204 write("topic", keywords(server, channel, origin, {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
205 "source": channel,
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
206 "topic": topic
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
207 }));
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
208 }