2018-02-04 03:22:01 +01: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 13:12:54 +02:00
|
|
|
|
|
|
|
#pragma once
|
|
|
|
#define HAVE_IRCD_M_KEYS_H
|
|
|
|
|
|
|
|
namespace ircd::m
|
|
|
|
{
|
2017-11-25 23:30:03 +01:00
|
|
|
struct keys;
|
2017-10-03 13:12:54 +02:00
|
|
|
}
|
|
|
|
|
2017-11-16 02:48:25 +01:00
|
|
|
namespace ircd::m::self
|
2017-10-03 13:12:54 +02:00
|
|
|
{
|
|
|
|
extern ed25519::sk secret_key;
|
2017-10-16 06:58:23 +02:00
|
|
|
extern ed25519::pk public_key;
|
2017-10-03 13:12:54 +02:00
|
|
|
extern std::string public_key_b64;
|
2017-10-16 06:58:23 +02:00
|
|
|
extern std::string public_key_id;
|
2017-11-16 02:48:25 +01:00
|
|
|
|
|
|
|
extern std::string tls_cert_der;
|
|
|
|
extern std::string tls_cert_der_sha256_b64;
|
2017-10-03 13:12:54 +02:00
|
|
|
}
|
|
|
|
|
2018-03-06 08:42:57 +01:00
|
|
|
#pragma GCC diagnostic push
|
|
|
|
#pragma GCC diagnostic ignored "-Wsubobject-linkage"
|
2017-11-25 23:30:03 +01:00
|
|
|
/// Contains the public keys and proof of identity for a remote server.
|
|
|
|
///
|
|
|
|
/// A user who wishes to verify a signature from a remote server must have
|
|
|
|
/// the name of the server (origin) and the key_id. Calling the appropriate
|
|
|
|
/// static function of this class will attempt to fetch the key from the db
|
|
|
|
/// or make network requests, with valid response being saved to the db. Keys
|
|
|
|
/// are thus managed internally so the user doesn't supply a buffer or ever
|
|
|
|
/// construct this object; instead this object backed by internal db data is
|
|
|
|
/// presented in the supplied synchronous closure.
|
|
|
|
///
|
2017-10-03 13:12:54 +02:00
|
|
|
/// 2.2.1.1 Publishing Keys
|
|
|
|
///
|
|
|
|
/// Key Type, Description
|
|
|
|
/// server_name String, DNS name of the homeserver.
|
|
|
|
/// verify_keys Object, Public keys of the homeserver for verifying digital signatures.
|
|
|
|
/// old_verify_keys Object, The public keys that the server used to use and when it stopped using them.
|
|
|
|
/// signatures Object, Digital signatures for this object signed using the verify_keys.
|
|
|
|
/// tls_fingerprints Array of Objects, Hashes of X.509 TLS certificates used by this this server encoded as Unpadded Base64.
|
|
|
|
/// valid_until_ts Integer, POSIX timestamp when the list of valid keys should be refreshed.
|
|
|
|
///
|
2017-11-25 23:30:03 +01:00
|
|
|
struct ircd::m::keys
|
2017-10-03 13:12:54 +02:00
|
|
|
:json::tuple
|
|
|
|
<
|
|
|
|
json::property<name::old_verify_keys, json::object>,
|
|
|
|
json::property<name::server_name, string_view>,
|
|
|
|
json::property<name::signatures, json::object>,
|
|
|
|
json::property<name::tls_fingerprints, json::array>,
|
|
|
|
json::property<name::valid_until_ts, time_t>,
|
|
|
|
json::property<name::verify_keys, json::object>
|
|
|
|
>
|
|
|
|
{
|
2017-12-12 21:33:14 +01:00
|
|
|
struct init;
|
|
|
|
|
2018-03-06 08:42:57 +01:00
|
|
|
public:
|
|
|
|
using closure = std::function<void (const keys &)>;
|
2018-05-08 01:04:11 +02:00
|
|
|
using closure_bool = std::function<bool (const keys &)>;
|
2017-11-25 23:30:03 +01:00
|
|
|
using key_closure = std::function<void (const string_view &)>; // remember to unquote()!!!
|
2018-03-21 02:46:20 +01:00
|
|
|
using ed25519_closure = std::function<void (const ed25519::pk &)>;
|
2018-05-08 01:04:11 +02:00
|
|
|
using queries = vector_view<const std::pair<string_view, string_view>>; // server, key_id
|
2017-10-03 13:12:54 +02:00
|
|
|
|
2018-03-06 08:42:57 +01:00
|
|
|
static void get(const string_view &server_name, const closure &);
|
|
|
|
static void get(const string_view &server_name, const string_view &key_id, const closure &);
|
2017-11-25 23:30:03 +01:00
|
|
|
static void get(const string_view &server_name, const string_view &key_id, const key_closure &);
|
2018-03-21 02:46:20 +01:00
|
|
|
static void get(const string_view &server_name, const string_view &key_id, const ed25519_closure &);
|
2018-05-08 01:04:11 +02:00
|
|
|
static bool query(const string_view &query_server, const queries &, const closure_bool &);
|
2017-10-16 06:58:23 +02:00
|
|
|
|
2017-10-03 13:12:54 +02:00
|
|
|
using super_type::tuple;
|
|
|
|
using super_type::operator=;
|
|
|
|
};
|
2018-03-06 08:42:57 +01:00
|
|
|
#pragma GCC diagnostic pop
|
2017-10-03 13:12:54 +02:00
|
|
|
|
2017-12-12 21:33:14 +01:00
|
|
|
struct ircd::m::keys::init
|
|
|
|
{
|
2018-03-02 09:35:02 +01:00
|
|
|
json::object config;
|
2017-12-12 21:33:14 +01:00
|
|
|
|
|
|
|
void certificate();
|
|
|
|
void signing();
|
|
|
|
|
|
|
|
public:
|
2018-03-02 09:35:02 +01:00
|
|
|
init(const json::object &config);
|
2017-12-12 21:33:14 +01:00
|
|
|
~init() noexcept;
|
|
|
|
};
|