// SPDX-FileCopyrightText: 2021 Carl Schwan // // SPDX-License-Identifier: LGPL-2.1-or-later #pragma once #ifdef Quotient_E2EE_ENABLED #include #include #include "olm/olm.h" #include "olm/errors.h" #include "olm/e2ee.h" namespace Quotient { //! An in-bound group session is responsible for decrypting incoming //! communication in a Megolm session. struct QOlmInboundGroupSession { public: ~QOlmInboundGroupSession(); //! Creates a new instance of `OlmInboundGroupSession`. static std::variant create(const QByteArray &key); //! Import an inbound group session, from a previous export. static std::variant import(const QByteArray &key); //! Serialises an `OlmInboundGroupSession` to encrypted Base64. std::variant pickle(const PicklingMode &mode) const; //! Deserialises from encrypted Base64 that was previously obtained by pickling //! an `OlmInboundGroupSession`. static std::variant unpickle(QByteArray &picked, const PicklingMode &mode); //! Decrypts ciphertext received for this group session. std::variant, OlmError> decrypt(QString &message); //! Export the base64-encoded ratchet key for this session, at the given index, //! in a format which can be used by import. std::variant exportSession(uint32_t messageIndex); //! Get the first message index we know how to decrypt. uint32_t firstKnownIndex() const; //! Get a base64-encoded identifier for this session. std::variant sessionId() const; bool isVerified() const; private: QOlmInboundGroupSession(OlmInboundGroupSession *session, QByteArray buffer); OlmInboundGroupSession *m_groupSession; QByteArray m_buffer; }; } // namespace Quotient #endif