mirror of
https://github.com/matrix-construct/construct
synced 2024-06-08 21:18:57 +02:00
modules: Implement s2s unstable 22.3 m.signing_key_update handler.
This commit is contained in:
parent
d6e01f5a43
commit
a49fa17c7e
|
@ -63,6 +63,7 @@ ircd::m::matrix::module_names
|
|||
"m_control",
|
||||
"m_device",
|
||||
"m_device_list_update",
|
||||
"m_signing_key_update",
|
||||
"m_direct",
|
||||
"m_direct_to_device",
|
||||
"m_ignored_user_list",
|
||||
|
|
|
@ -81,6 +81,7 @@ m_command_la_SOURCES = m_command.cc
|
|||
m_control_la_SOURCES = m_control.cc
|
||||
m_device_la_SOURCES = m_device.cc
|
||||
m_device_list_update_la_SOURCES = m_device_list_update.cc
|
||||
m_signing_key_update_la_SOURCES = m_signing_key_update.cc
|
||||
m_direct_la_SOURCES = m_direct.cc
|
||||
m_direct_to_device_la_SOURCES = m_direct_to_device.cc
|
||||
m_ignored_user_list_la_SOURCES = m_ignored_user_list.cc
|
||||
|
@ -113,6 +114,7 @@ m_module_LTLIBRARIES = \
|
|||
m_control.la \
|
||||
m_device.la \
|
||||
m_device_list_update.la \
|
||||
m_signing_key_update.la \
|
||||
m_direct.la \
|
||||
m_direct_to_device.la \
|
||||
m_ignored_user_list.la \
|
||||
|
|
109
modules/m_signing_key_update.cc
Normal file
109
modules/m_signing_key_update.cc
Normal file
|
@ -0,0 +1,109 @@
|
|||
// The Construct
|
||||
//
|
||||
// Copyright (C) The Construct Developers, Authors & Contributors
|
||||
// Copyright (C) 2016-2021 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;
|
||||
|
||||
static void
|
||||
handle_edu_m_signing_key_update(const m::event &,
|
||||
m::vm::eval &);
|
||||
|
||||
mapi::header
|
||||
IRCD_MODULE
|
||||
{
|
||||
"Matrix Signing Key Update"
|
||||
};
|
||||
|
||||
m::hookfn<m::vm::eval &>
|
||||
_m_signing_key_update_eval
|
||||
{
|
||||
handle_edu_m_signing_key_update,
|
||||
{
|
||||
{ "_site", "vm.effect" },
|
||||
{ "type", "m.signing_key_update" },
|
||||
}
|
||||
};
|
||||
|
||||
void
|
||||
handle_edu_m_signing_key_update(const m::event &event,
|
||||
m::vm::eval &eval)
|
||||
try
|
||||
{
|
||||
if(m::my_host(at<"origin"_>(event)))
|
||||
return;
|
||||
|
||||
const json::object &content
|
||||
{
|
||||
at<"content"_>(event)
|
||||
};
|
||||
|
||||
const m::signing_key_update update
|
||||
{
|
||||
content
|
||||
};
|
||||
|
||||
const m::user::id &user_id
|
||||
{
|
||||
json::get<"user_id"_>(update)
|
||||
};
|
||||
|
||||
if(user_id.host() != at<"origin"_>(event))
|
||||
return;
|
||||
|
||||
const json::object &msk
|
||||
{
|
||||
json::get<"master_key"_>(update)
|
||||
};
|
||||
|
||||
const m::user::room room
|
||||
{
|
||||
user_id
|
||||
};
|
||||
|
||||
const auto master_id
|
||||
{
|
||||
msk?
|
||||
send(room, user_id, "ircd.device.signing.master", "", msk):
|
||||
m::event::id::buf{}
|
||||
};
|
||||
|
||||
const json::object &ssk
|
||||
{
|
||||
json::get<"self_signing_key"_>(update)
|
||||
};
|
||||
|
||||
const auto self_id
|
||||
{
|
||||
ssk?
|
||||
send(room, user_id, "ircd.device.signing.self", "", ssk):
|
||||
m::event::id::buf{}
|
||||
};
|
||||
|
||||
log::info
|
||||
{
|
||||
m::log, "Signing key update from :%s by %s master:%s self:%s",
|
||||
json::get<"origin"_>(event),
|
||||
json::get<"user_id"_>(update),
|
||||
string_view{master_id},
|
||||
string_view{self_id},
|
||||
};
|
||||
}
|
||||
catch(const ctx::interrupted &e)
|
||||
{
|
||||
throw;
|
||||
}
|
||||
catch(const std::exception &e)
|
||||
{
|
||||
log::derror
|
||||
{
|
||||
m::log, "m.signing_key_update from %s :%s",
|
||||
json::get<"origin"_>(event),
|
||||
e.what(),
|
||||
};
|
||||
}
|
Loading…
Reference in a new issue