2018-03-08 09:29:42 -08:00
|
|
|
// 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.
|
|
|
|
|
|
|
|
using namespace ircd;
|
|
|
|
|
|
|
|
mapi::header
|
|
|
|
IRCD_MODULE
|
|
|
|
{
|
|
|
|
"Matrix Typing"
|
|
|
|
};
|
|
|
|
|
|
|
|
static void _handle_edu_m_typing(const m::event &, const m::edu::m_typing &edu);
|
|
|
|
static void handle_edu_m_typing(const m::event &);
|
|
|
|
|
2018-05-26 22:05:56 -07:00
|
|
|
const m::hookfn<>
|
2018-03-08 09:29:42 -08:00
|
|
|
_m_typing_eval
|
|
|
|
{
|
|
|
|
handle_edu_m_typing,
|
|
|
|
{
|
|
|
|
{ "_site", "vm.eval" },
|
|
|
|
{ "type", "m.typing" },
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
void
|
|
|
|
handle_edu_m_typing(const m::event &event)
|
|
|
|
{
|
|
|
|
const json::object &content
|
|
|
|
{
|
|
|
|
at<"content"_>(event)
|
|
|
|
};
|
|
|
|
|
|
|
|
_handle_edu_m_typing(event, content);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
_handle_edu_m_typing(const m::event &event,
|
|
|
|
const m::edu::m_typing &edu)
|
|
|
|
{
|
2018-04-21 23:51:37 -07:00
|
|
|
const auto &room_id
|
2018-03-08 09:29:42 -08:00
|
|
|
{
|
2018-04-21 23:51:37 -07:00
|
|
|
json::get<"room_id"_>(edu)
|
2018-03-08 09:29:42 -08:00
|
|
|
};
|
|
|
|
|
2018-04-21 23:51:37 -07:00
|
|
|
if(!room_id)
|
|
|
|
return;
|
|
|
|
|
2018-03-08 09:29:42 -08:00
|
|
|
const m::user::id &user_id
|
|
|
|
{
|
|
|
|
at<"user_id"_>(edu)
|
|
|
|
};
|
|
|
|
|
|
|
|
if(user_id.host() != at<"origin"_>(event))
|
|
|
|
{
|
2018-03-15 12:26:29 -07:00
|
|
|
log::dwarning
|
2018-03-08 09:29:42 -08:00
|
|
|
{
|
|
|
|
"Ignoring %s from %s for user %s",
|
|
|
|
at<"type"_>(event),
|
|
|
|
at<"origin"_>(event),
|
|
|
|
string_view{user_id}
|
|
|
|
};
|
|
|
|
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2018-04-12 15:15:03 -07:00
|
|
|
log::info
|
2018-03-08 09:29:42 -08:00
|
|
|
{
|
2018-04-12 15:15:03 -07:00
|
|
|
"%s %s %s typing in %s",
|
2018-03-08 09:29:42 -08:00
|
|
|
at<"origin"_>(event),
|
|
|
|
string_view{user_id},
|
|
|
|
json::get<"typing"_>(edu)? "started"_sv : "stopped"_sv,
|
|
|
|
string_view{room_id}
|
|
|
|
};
|
2018-04-21 23:51:37 -07:00
|
|
|
|
|
|
|
m::event typing{event};
|
|
|
|
json::get<"room_id"_>(typing) = room_id;
|
2018-06-12 00:45:18 -07:00
|
|
|
json::get<"type"_>(typing) = "m.typing"_sv;
|
2018-04-21 23:51:37 -07:00
|
|
|
|
|
|
|
char buf[512];
|
|
|
|
const json::value user_ids[]
|
|
|
|
{
|
|
|
|
{ user_id }
|
|
|
|
};
|
|
|
|
|
|
|
|
json::get<"content"_>(typing) = json::stringify(mutable_buffer{buf}, json::members
|
|
|
|
{
|
|
|
|
{ "user_ids", { user_ids, size_t(bool(json::get<"typing"_>(edu))) } }
|
|
|
|
});
|
|
|
|
|
|
|
|
m::vm::opts vmopts;
|
2018-05-27 19:56:28 -07:00
|
|
|
vmopts.notify_servers = false;
|
2018-04-21 23:51:37 -07:00
|
|
|
vmopts.non_conform.set(m::event::conforms::INVALID_OR_MISSING_EVENT_ID);
|
|
|
|
vmopts.non_conform.set(m::event::conforms::INVALID_OR_MISSING_ROOM_ID);
|
|
|
|
vmopts.non_conform.set(m::event::conforms::INVALID_OR_MISSING_SENDER_ID);
|
|
|
|
vmopts.non_conform.set(m::event::conforms::MISSING_ORIGIN_SIGNATURE);
|
|
|
|
vmopts.non_conform.set(m::event::conforms::MISSING_SIGNATURES);
|
|
|
|
vmopts.non_conform.set(m::event::conforms::MISSING_PREV_EVENTS);
|
|
|
|
vmopts.non_conform.set(m::event::conforms::MISSING_PREV_STATE);
|
|
|
|
vmopts.non_conform.set(m::event::conforms::DEPTH_ZERO);
|
|
|
|
m::vm::eval eval
|
|
|
|
{
|
|
|
|
typing, vmopts
|
|
|
|
};
|
2018-03-08 09:29:42 -08:00
|
|
|
}
|