0
0
Fork 0
mirror of https://github.com/matrix-construct/construct synced 2024-12-25 15:04:10 +01:00

modules/client/keys/device_signing/upload: Implement c2s r0.6.1 13.11.2.3.2 POST.

This commit is contained in:
Jason Volk 2021-01-04 11:07:56 -08:00
parent 4b156cae2f
commit c852397a7d

View file

@ -70,37 +70,69 @@ ircd::m::post_keys_device_signing_upload(client &client,
request["auth"]
};
const json::object &master_key
const json::string &auth_type
{
request["master_key"]
auth["type"]
};
const json::object &self_signing_key
if(auth_type != "m.login.password")
return m::resource::response
{
client, http::UNAUTHORIZED, json::object{flows}
};
const json::string &password
{
request["self_signing_key"]
auth["password"]
};
const json::object &user_signing_key
{
request["user_signing_key"]
};
const m::device::id::buf device_id
{
m::user::tokens::device(request.access_token)
};
const m::user::room user_room
const m::user::room room
{
request.user_id
};
if(empty(auth))
return resource::response
if(!room.user.is_password(password))
throw m::ACCESS_DENIED
{
client, http::UNAUTHORIZED, json::object{flows}
"Incorrect password."
};
const json::object &msk
{
request["master_key"]
};
const auto master_id
{
msk?
send(room, request.user_id, "ircd.device.signing.master", "", msk):
event::id::buf{}
};
const json::object &ssk
{
request["self_signing_key"]
};
const auto self_signing_id
{
ssk?
send(room, request.user_id, "ircd.device.signing.self", "", ssk):
event::id::buf{}
};
const json::object &usk
{
request["user_signing_key"]
};
const auto user_signing_id
{
usk?
send(room, request.user_id, "ircd.device.signing.user", "", usk):
event::id::buf{}
};
return resource::response
{
client, http::OK