// Matrix Construct // // Copyright (C) Matrix Construct Developers, Authors & Contributors // Copyright (C) 2016-2018 Jason Volk <jason@zemos.net> // // 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 is present in all copies. The // full license for this software is available in the LICENSE file. namespace ircd::m { static void room_message_notify(const event &, vm::eval &); extern hookfn<vm::eval &> room_message_notify_hook; extern log::log room_message_log; } ircd::mapi::header IRCD_MODULE { "Matrix m.room.message" }; decltype(ircd::m::room_message_log) ircd::m::room_message_log { "m.message" }; decltype(ircd::m::room_message_notify_hook) ircd::m::room_message_notify_hook { room_message_notify, { { "_site", "vm.notify" }, { "type", "m.room.message" }, } }; void ircd::m::room_message_notify(const event &event, vm::eval &eval) { const auto &content { json::get<"content"_>(event) }; const json::string &body { content.get("body") }; const json::string &msgtype { content.get("msgtype") }; log::info { room_message_log, "%s said %s in %s %s :%s%s", json::get<"sender"_>(event), string_view{event.event_id}, json::get<"room_id"_>(event), msgtype, trunc(body, 128), size(body) > 128? "..."_sv : string_view{} }; }