2018-02-03 18:22:01 -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.
|
2017-10-03 04:12:54 -07:00
|
|
|
|
|
|
|
using namespace ircd;
|
|
|
|
|
2018-03-05 09:56:10 -08:00
|
|
|
mapi::header
|
|
|
|
IRCD_MODULE
|
2017-10-03 04:12:54 -07:00
|
|
|
{
|
2018-03-05 09:56:10 -08:00
|
|
|
"Federation 2.2.1.1 :Publishing Keys"
|
2017-10-03 04:12:54 -07:00
|
|
|
};
|
|
|
|
|
2018-03-05 09:56:10 -08:00
|
|
|
resource
|
2017-10-03 04:12:54 -07:00
|
|
|
server_resource
|
|
|
|
{
|
2018-03-05 09:56:10 -08:00
|
|
|
"/_matrix/key/v2/server/",
|
2017-10-03 04:12:54 -07:00
|
|
|
{
|
2017-12-12 13:26:39 -07:00
|
|
|
"federation 2.2.1.1: Publishing Keys",
|
2017-10-03 04:12:54 -07:00
|
|
|
resource::DIRECTORY,
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
resource::response
|
|
|
|
handle_get(client &client,
|
|
|
|
const resource::request &request)
|
|
|
|
{
|
|
|
|
char key_id_buf[256];
|
|
|
|
const auto key_id
|
|
|
|
{
|
2017-12-12 13:14:47 -07:00
|
|
|
url::decode(request.parv[0], key_id_buf)
|
2017-10-03 04:12:54 -07:00
|
|
|
};
|
|
|
|
|
2018-03-05 09:56:10 -08:00
|
|
|
std::string my_keys;
|
|
|
|
m::keys::get(my_host(), key_id, [&my_keys](const m::keys &keys)
|
2017-10-03 04:12:54 -07:00
|
|
|
{
|
2018-03-05 09:56:10 -08:00
|
|
|
my_keys = json::strung(keys);
|
2017-10-03 04:12:54 -07:00
|
|
|
});
|
|
|
|
|
|
|
|
return resource::response
|
|
|
|
{
|
2018-03-05 09:56:10 -08:00
|
|
|
client, http::OK, json::object{my_keys}
|
2017-10-03 04:12:54 -07:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2018-03-05 09:56:10 -08:00
|
|
|
resource::method
|
|
|
|
method_get
|
2017-10-03 04:12:54 -07:00
|
|
|
{
|
|
|
|
server_resource, "GET", handle_get
|
|
|
|
};
|
|
|
|
|
2018-03-05 09:56:10 -08:00
|
|
|
__attribute__((constructor))
|
|
|
|
static void
|
|
|
|
_test_ed25519_()
|
|
|
|
noexcept
|
2017-10-03 04:12:54 -07:00
|
|
|
{
|
|
|
|
using namespace ircd;
|
|
|
|
|
2018-02-02 23:20:26 -08:00
|
|
|
char seed_buf[ed25519::SEED_SZ + 10];
|
2017-10-03 04:12:54 -07:00
|
|
|
const auto seed
|
|
|
|
{
|
|
|
|
b64decode(seed_buf, "YJDBA9Xnr2sVqXD9Vj7XVUnmFZcZrlw8Md7kMW+3XA1")
|
|
|
|
};
|
|
|
|
|
|
|
|
ed25519::pk pk;
|
|
|
|
ed25519::sk sk{&pk, seed};
|
|
|
|
|
|
|
|
const auto SERVER_NAME {"domain"};
|
|
|
|
const auto KEY_ID {"ed25519:1"};
|
|
|
|
|
2018-03-05 09:56:10 -08:00
|
|
|
const auto test{[&]
|
|
|
|
(const std::string &object) -> bool
|
2017-10-03 04:12:54 -07:00
|
|
|
{
|
|
|
|
const auto sig
|
|
|
|
{
|
2018-02-02 23:20:26 -08:00
|
|
|
sk.sign(const_buffer{object})
|
2017-10-03 04:12:54 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
char sigb64_buf[128];
|
|
|
|
const auto sigb64
|
|
|
|
{
|
|
|
|
b64encode_unpadded(sigb64_buf, sig)
|
|
|
|
};
|
|
|
|
|
|
|
|
ed25519::sig unsig; const auto unsigb64
|
|
|
|
{
|
|
|
|
b64decode(unsig, sigb64)
|
|
|
|
};
|
|
|
|
|
2018-02-02 23:20:26 -08:00
|
|
|
return pk.verify(const_buffer{object}, unsig);
|
2017-10-03 04:12:54 -07:00
|
|
|
}};
|
|
|
|
|
2018-03-05 09:56:10 -08:00
|
|
|
const bool tests[]
|
2017-10-03 04:12:54 -07:00
|
|
|
{
|
2018-03-05 09:56:10 -08:00
|
|
|
test(std::string{json::object
|
|
|
|
{
|
|
|
|
"{}"
|
|
|
|
}}),
|
2017-10-03 04:12:54 -07:00
|
|
|
|
2018-03-05 09:56:10 -08:00
|
|
|
test(json::strung(json::members
|
|
|
|
{
|
|
|
|
{ "one", 1L },
|
|
|
|
{ "two", "Two" }
|
|
|
|
})),
|
|
|
|
};
|
|
|
|
|
|
|
|
if(!std::all_of(begin(tests), end(tests), [](const bool &b) { return b; }))
|
|
|
|
throw ircd::assertive
|
|
|
|
{
|
|
|
|
"Seeded ed25519 test failed"
|
|
|
|
};
|
2017-10-03 04:12:54 -07:00
|
|
|
}
|