// SPDX-FileCopyrightText: 2021 Carl Schwan // // SPDX-License-Identifier: LGPL-2.1-or-later #pragma once #include "e2ee/e2ee.h" #include "e2ee/qolmerrors.h" #include "olm/olm.h" #include #include namespace Quotient { //! An in-bound group session is responsible for decrypting incoming //! communication in a Megolm session. class QUOTIENT_API QOlmInboundGroupSession { public: ~QOlmInboundGroupSession(); //! Creates a new instance of `OlmInboundGroupSession`. static std::unique_ptr create(const QByteArray& key); //! Import an inbound group session, from a previous export. static std::unique_ptr import(const QByteArray& key); //! Serialises an `OlmInboundGroupSession` to encrypted Base64. QByteArray pickle(const PicklingMode &mode) const; //! Deserialises from encrypted Base64 that was previously obtained by pickling //! an `OlmInboundGroupSession`. static std::variant, QOlmError> unpickle(const QByteArray& picked, const PicklingMode& mode); //! Decrypts ciphertext received for this group session. std::variant, QOlmError> decrypt( const QByteArray& 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. QByteArray sessionId() const; bool isVerified() const; //! The olm session that this session was received from. //! Required to get the device this session is from. QString olmSessionId() const; void setOlmSessionId(const QString& setOlmSessionId); //! The sender of this session. QString senderId() const; void setSenderId(const QString& senderId); QOlmInboundGroupSession(OlmInboundGroupSession* session); private: OlmInboundGroupSession* m_groupSession; QString m_olmSessionId; QString m_senderId; }; using QOlmInboundGroupSessionPtr = std::unique_ptr; } // namespace Quotient