Skip to content
Snippets Groups Projects
CacheCryptoStructs.h 3.12 KiB
Newer Older
  • Learn to ignore specific revisions
  • #pragma once
    
    #include <map>
    #include <mutex>
    
    //#include <nlohmann/json.hpp>
    
    #include <mtx/responses.hpp>
    #include <mtxclient/crypto/client.hpp>
    
    // Extra information associated with an outbound megolm session.
    struct OutboundGroupSessionData
    {
            std::string session_id;
            std::string session_key;
            uint64_t message_index = 0;
    };
    
    void
    to_json(nlohmann::json &obj, const OutboundGroupSessionData &msg);
    void
    from_json(const nlohmann::json &obj, OutboundGroupSessionData &msg);
    
    struct OutboundGroupSessionDataRef
    {
            OlmOutboundGroupSession *session;
            OutboundGroupSessionData data;
    };
    
    struct DevicePublicKeys
    {
            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
    {
            //! The room in which this session exists.
            std::string room_id;
            //! The session_id of the megolm session.
            std::string session_id;
            //! The curve25519 public key of the sender.
            std::string sender_key;
    };
    
    void
    to_json(nlohmann::json &obj, const MegolmSessionIndex &msg);
    void
    from_json(const nlohmann::json &obj, MegolmSessionIndex &msg);
    
    struct OlmSessionStorage
    {
            // Megolm sessions
            std::map<std::string, mtx::crypto::InboundGroupSessionPtr> group_inbound_sessions;
            std::map<std::string, mtx::crypto::OutboundGroupSessionPtr> group_outbound_sessions;
            std::map<std::string, OutboundGroupSessionData> group_outbound_session_data;
    
            // Guards for accessing megolm sessions.
            std::mutex group_outbound_mtx;
            std::mutex group_inbound_mtx;
    };
    
    // this will store the keys of the user with whom a encrypted room is shared with
    
    struct UserKeyCache
    
            //! Device id to device keys
            std::map<std::string, mtx::crypto::DeviceKeys> device_keys;
            //! corss 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;
    
    to_json(nlohmann::json &j, const UserKeyCache &info);
    
    from_json(const nlohmann::json &j, UserKeyCache &info);
    
    // 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
    
    {
            //! list of verified device_ids with device-verification
            std::vector<std::string> device_verified;
    
            //! list of verified device_ids with cross-signing, calculated from master key
    
            std::vector<std::string> cross_verified;
            //! list of devices the user blocks
    
            std::vector<std::string> device_blocked;
    
            //! The verified master key.
            std::string verified_master_key;
    
    to_json(nlohmann::json &j, const VerificationCache &info);
    
    from_json(const nlohmann::json &j, VerificationCache &info);