matrixion/src/CacheCryptoStructs.h

207 lines
5.8 KiB
C
Raw Normal View History

// SPDX-FileCopyrightText: Nheko Contributors
2021-03-05 02:35:15 +03:00
//
// SPDX-License-Identifier: GPL-3.0-or-later
#pragma once
#include <QObject>
2023-06-19 02:38:40 +03:00
#include <QQmlEngine>
#include <map>
#include <mutex>
#include <set>
2020-10-27 19:45:28 +03:00
#include <mtx/responses/crypto.hpp>
#include <mtxclient/crypto/objects.hpp>
namespace mtx::events::msg {
struct Encrypted;
}
namespace crypto {
Q_NAMESPACE
2023-06-19 02:38:40 +03:00
QML_NAMED_ELEMENT(Crypto)
//! How much a participant is trusted.
enum Trust
{
Unverified, //! Device unverified or master key changed.
MessageUnverified, //! Only for messages. The sender might be trusted, but we don't know, who
//! was the sender for the message.
TOFU, //! Device is signed by the sender, but the user is not verified, but they never
//! changed the master key.
Verified, //! User was verified and has crosssigned this device or device is verified.
};
Q_ENUM_NS(Trust)
}
struct DeviceKeysToMsgIndex
{
2021-09-18 01:22:33 +03:00
// map from device key to message_index
// Using the device id is safe because we check for reuse on device list updates
// Using the device id makes our logic much easier to read.
2022-10-26 02:10:35 +03:00
std::map<std::string, uint32_t> deviceids;
};
struct SharedWithUsers
{
2021-09-18 01:22:33 +03:00
// userid to keys
std::map<std::string, DeviceKeysToMsgIndex> keys;
};
// Extra information associated with an outbound megolm session.
struct GroupSessionData
{
2021-09-18 01:22:33 +03:00
uint64_t timestamp = 0;
2022-10-26 02:10:35 +03:00
uint32_t message_index = 0;
// We generally don't trust keys unless they were sent to us by the original sender and include
// that senders signature.
bool trusted = false;
2021-08-17 04:23:51 +03:00
// the original 25519 key
std::string sender_key;
2021-09-18 01:22:33 +03:00
std::string sender_claimed_ed25519_key;
std::vector<std::string> forwarding_curve25519_key_chain;
2021-09-18 01:22:33 +03:00
//! map from index to event_id to check for replay attacks
std::map<uint32_t, std::string> indices;
2021-08-08 00:54:35 +03:00
2021-09-18 01:22:33 +03:00
// who has access to this session.
// Rotate, when a user leaves the room and share, when a user gets added.
SharedWithUsers currently;
};
void
to_json(nlohmann::json &obj, const GroupSessionData &msg);
void
from_json(const nlohmann::json &obj, GroupSessionData &msg);
struct OutboundGroupSessionDataRef
{
2021-09-18 01:22:33 +03:00
mtx::crypto::OutboundGroupSessionPtr session;
GroupSessionData data;
};
struct DevicePublicKeys
{
2021-09-18 01:22:33 +03:00
std::string ed25519;
std::string curve25519;
};
void
to_json(nlohmann::json &obj, const DevicePublicKeys &msg);
void
from_json(const nlohmann::json &obj, DevicePublicKeys &msg);
//! Represents a unique megolm session identifier.
struct MegolmSessionIndex
{
2021-09-18 01:22:33 +03:00
MegolmSessionIndex() = default;
MegolmSessionIndex(std::string room_id_, const mtx::events::msg::Encrypted &e);
2021-09-18 01:22:33 +03:00
//! The room in which this session exists.
std::string room_id;
//! The session_id of the megolm session.
std::string session_id;
};
void
to_json(nlohmann::json &obj, const MegolmSessionIndex &msg);
void
from_json(const nlohmann::json &obj, MegolmSessionIndex &msg);
2020-10-20 14:46:05 +03:00
struct StoredOlmSession
{
2021-09-18 01:22:33 +03:00
std::uint64_t last_message_ts = 0;
std::string pickled_session;
2020-10-20 14:46:05 +03:00
};
void
to_json(nlohmann::json &obj, const StoredOlmSession &msg);
void
from_json(const nlohmann::json &obj, StoredOlmSession &msg);
//! Verification status of a single user
struct VerificationStatus
{
2021-09-18 01:22:33 +03:00
//! True, if the users master key is verified
crypto::Trust user_verified = crypto::Trust::Unverified;
//! List of all devices marked as verified
std::set<std::string> verified_devices;
//! Map from sender key/curve25519 to trust status
std::map<std::string, crypto::Trust> verified_device_keys;
//! Count of unverified devices
int unverified_device_count = 0;
// if the keys are not in cache
bool no_keys = false;
};
//! In memory cache of verification status
struct VerificationStorage
{
2021-09-18 01:22:33 +03:00
//! mapping of user to verification status
std::map<std::string, VerificationStatus> status;
std::mutex verification_storage_mtx;
};
//! In memory cache of verification status
struct SecretsStorage
{
//! secret name -> secret
std::map<std::string, std::string> secrets;
std::mutex mtx;
};
// this will store the keys of the user with whom a encrypted room is shared with
struct UserKeyCache
2020-06-28 18:31:34 +03:00
{
2021-09-18 01:22:33 +03:00
//! Device id to device keys
std::map<std::string, mtx::crypto::DeviceKeys> device_keys;
//! cross signing keys
mtx::crypto::CrossSigningKeys master_keys, user_signing_keys, self_signing_keys;
//! Sync token when nheko last fetched the keys
std::string updated_at;
//! Sync token when the keys last changed. updated != last_changed means they are outdated.
std::string last_changed;
//! if the master key has ever changed
bool master_key_changed = false;
//! Device keys that were already used at least once
std::set<std::string> seen_device_keys;
//! Device ids that were already used at least once
std::set<std::string> seen_device_ids;
2020-06-28 18:31:34 +03:00
};
void
to_json(nlohmann::json &j, const UserKeyCache &info);
2020-06-28 18:31:34 +03:00
void
from_json(const nlohmann::json &j, UserKeyCache &info);
2020-06-28 18:31:34 +03:00
// the reason these are stored in a seperate cache rather than storing it in the user cache is
// UserKeyCache stores only keys of users with which encrypted room is shared
struct VerificationCache
2020-06-28 18:31:34 +03:00
{
2021-09-18 01:22:33 +03:00
//! list of verified device_ids with device-verification
std::set<std::string> device_verified;
//! list of devices the user blocks
std::set<std::string> device_blocked;
2020-06-28 18:31:34 +03:00
};
void
to_json(nlohmann::json &j, const VerificationCache &info);
2020-06-28 18:31:34 +03:00
void
from_json(const nlohmann::json &j, VerificationCache &info);
2021-08-17 04:23:51 +03:00
struct OnlineBackupVersion
{
2021-09-18 01:22:33 +03:00
//! the version of the online backup currently enabled
std::string version;
//! the algorithm used by the backup
std::string algorithm;
2021-08-17 04:23:51 +03:00
};
void
to_json(nlohmann::json &j, const OnlineBackupVersion &info);
void
from_json(const nlohmann::json &j, OnlineBackupVersion &info);