// Matrix Construct // // Copyright (C) Matrix Construct Developers, Authors & Contributors // Copyright (C) 2016-2018 Jason Volk // // 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 { "federation 2.2.1.1: Publishing Keys" }; struct server :resource { using resource::resource; } server_resource { "/_matrix/key/v2/server/", resource::opts { "federation 2.2.1.1: Publishing Keys", resource::DIRECTORY, } }; resource::response handle_get(client &client, const resource::request &request) { char key_id_buf[256]; const auto key_id { url::decode(request.parv[0], key_id_buf) }; std::string my_key; m::keys::get(my_host(), key_id, [&my_key](const auto &key) { my_key = json::strung(key); }); return resource::response { client, json::object{my_key} }; } resource::method method_get { server_resource, "GET", handle_get }; // __attribute__((constructor)) static void foop() { using namespace ircd; char seed_buf[ed25519::SEED_SZ + 10]; 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"}; const auto test{[&](const std::string &object) { const auto sig { sk.sign(const_buffer{object}) }; char sigb64_buf[128]; const auto sigb64 { b64encode_unpadded(sigb64_buf, sig) }; std::cout << "sig: " << sigb64 << std::endl; ed25519::sig unsig; const auto unsigb64 { b64decode(unsig, sigb64) }; return pk.verify(const_buffer{object}, unsig); }}; std::cout << test(std::string{json::object { "{}" }}) << std::endl; std::cout << test(json::strung(json::members { { "one", 1L }, { "two", "Two" } })) << std::endl; }