Mercurial > irccd
view plugins/history/history.js @ 448:9be4f8a5cf1a
Irccdctl: implement rule-list
author | David Demelier <markand@malikania.fr> |
---|---|
date | Wed, 05 Jul 2017 18:20:26 +0200 |
parents | c6fbb6e0e06d |
children | 8b615d37d303 |
line wrap: on
line source
/* * history.js -- track nickname's history * * Copyright (c) 2013-2017 David Demelier <markand@malikania.fr> * * Permission to use, copy, modify, and/or distribute this software for any * purpose with or without fee is hereby granted, provided that the above * copyright notice and this permission notice appear in all copies. * * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */ // Plugin information. info = { author: "David Demelier <markand@malikania.fr>", license: "ISC", summary: "track nickname's history", version: "@IRCCD_VERSION@" }; // Modules. var Directory = Irccd.Directory; var File = Irccd.File; var Logger = Irccd.Logger; var Plugin = Irccd.Plugin; var Server = Irccd.Server; var Util = Irccd.Util; Plugin.format = { "error": "#{nickname}, I'm sorry, something went wrong.", "seen": "#{nickname}, I've seen #{target} for the last time the %d-%m-%Y %H:%M", "said": "#{nickname}, #{target} said on %d-%m-%Y %H:%M: #{message}", "unknown": "#{nickname}, I've never seen #{target}.", "usage": "#{nickname}, usage: #{plugin} seen | said <target>." }; function isSelf(server, origin) { return server.info().nickname === Util.splituser(origin); } function command(server) { return server.info().commandChar + "history"; } function path(server, channel) { var p; if (Plugin.config["file"] !== undefined) { p = Util.format(Plugin.config["file"], { "server": server.toString(), "channel": channel }); } else p = Plugin.cachePath + "db.json"; return p; } function read(server, channel, nickname) { var p = path(server, channel); var db = {}; if (File.exists(p)) { var file = new File(path(server, channel), "r"); var str = file.read(); db = JSON.parse(str); } // Complete if needed. if (!db[server]) db[server] = {}; if (!db[server][channel]) db[server][channel] = {}; if (!db[server][channel][nickname]) db[server][channel][nickname] = {}; return db; } function write(server, channel, nickname, message) { var db = read(server, channel, nickname); var entry = db[server][channel][nickname]; var p = path(server, channel); if (!File.exists(File.dirname(p))) { Logger.debug("creating directory " + File.dirname(p)); Directory.mkdir(File.dirname(p)); } var file = new File(path(server, channel), "wt"); entry.timestamp = Date.now(); entry.message = (message) ? message : entry.message; file.write(JSON.stringify(db)); } function find(server, channel, target) { var db = read(server, channel, target); var it = db[server][channel][target]; if (it.timestamp) return it; } function loadFormats() { // --- DEPRECATED ------------------------------------------- // // This code will be removed. // // Since: 2.1.0 // Until: 3.0.0 // Reason: new [format] section replaces it. // // ---------------------------------------------------------- for (var key in Plugin.format) { var optname = "format-" + key; if (typeof (Plugin.config[optname]) !== "string") continue; if (Plugin.config[optname].length === 0) Logger.warning("skipping empty '" + optname + "' format"); else Plugin.format[key] = Plugin.config[optname]; } } function onCommand(server, origin, channel, message) { var args = message.trim().split(" "); var kw = { channel: channel, command: command(server), nickname: Util.splituser(origin), origin: origin, plugin: Plugin.info().name, server: server.toString() }; if (args.length !== 2 || args[0].length === 0 || args[1].length === 0) { server.message(channel, Util.format(Plugin.format.usage, kw)); return; } if (args[0] !== "seen" && args[0] !== "said") { server.message(channel, Util.format(Plugin.format.usage, kw)); return; } if (isSelf(server, args[1])) return; try { var info = find(server, channel, args[1]); kw.target = args[1]; if (!info) { server.message(channel, Util.format(Plugin.format.unknown, kw)); return; } kw.date = info.timestamp; kw.message = info.message ? info.message : ""; server.message(channel, Util.format(Plugin.format[args[0] == "seen" ? "seen" : "said"], kw)); } catch (e) { server.message(channel, Util.format(Plugin.format["error"], kw)); } } function onJoin(server, origin, channel) { write(server, channel, Util.splituser(origin)); } function onMessage(server, origin, channel, message) { write(server, channel, Util.splituser(origin), message); } onMe = onMessage; function onTopic(server, origin, channel) { write(server, channel, Util.splituser(origin)); } function onLoad() { var table = Server.list(); for (var k in table) for (var c in table[k].info().channels) table[k].names(c); loadFormats(); } function onReload() { loadFormats(); } function onNames(server, channel, list) { for (var i = 0; i < list.length; ++i) write(server, channel, list[i]); }