Skip to content
This repository has been archived by the owner on Aug 28, 2019. It is now read-only.

Commit

Permalink
Add full EncryptionEvent to room logic. Issue quotient-im#95
Browse files Browse the repository at this point in the history
  • Loading branch information
a-andreyev committed Jun 27, 2019
1 parent 2706f88 commit 78b555e
Show file tree
Hide file tree
Showing 4 changed files with 114 additions and 9 deletions.
48 changes: 48 additions & 0 deletions lib/events/encryptionevent.cpp
Original file line number Diff line number Diff line change
@@ -1,5 +1,53 @@
//
// Created by rusakov on 26/09/2017.
// Contributed by andreev on 27/06/2019.
//

#include "encryptionevent.h"

#include "converters.h"
#include "logging.h"

#include <array>

static const std::array<QString, 1> encryptionStrings = { {
QStringLiteral("m.megolm.v1.aes-sha2")
} };

namespace QMatrixClient {
template <>
struct JsonConverter<EncryptionType>
{
static EncryptionType load(const QJsonValue& jv)
{
const auto& encryptionString = jv.toString();
for (auto it = encryptionStrings.begin();
it != encryptionStrings.end(); ++it)
if (encryptionString == *it)
return EncryptionType(it - encryptionStrings.begin());

qCWarning(EVENTS) << "Unknown EncryptionType: " << encryptionString;
return EncryptionType::Undefined;
}
};
}

using namespace QMatrixClient;

EncryptionEventContent::EncryptionEventContent(const QJsonObject& json)
: encryption(fromJson<EncryptionType>(json["algorithm"_ls]))
, algorithm(sanitized(json["algorithm"_ls].toString()))
, rotationPeriodMs(json["rotation_period_ms"_ls].toInt(604800000))
, rotationPeriodMsgs(json["rotation_period_msgs"_ls].toInt(100))
{ }

void EncryptionEventContent::fillJson(QJsonObject* o) const
{
Q_ASSERT(o);
Q_ASSERT_X(encryption != EncryptionType::Undefined, __FUNCTION__,
"The key 'algorithm' must be explicit in EncryptionEventContent");
if (encryption != EncryptionType::Undefined)
o->insert(QStringLiteral("algorithm"), algorithm);
o->insert(QStringLiteral("rotation_period_ms"), rotationPeriodMs);
o->insert(QStringLiteral("rotation_period_msgs"), rotationPeriodMsgs);
}
72 changes: 65 additions & 7 deletions lib/events/encryptionevent.h
Original file line number Diff line number Diff line change
Expand Up @@ -18,25 +18,83 @@

#pragma once

#include "roomevent.h"
#include "stateevent.h"
#include "eventcontent.h"

namespace QMatrixClient
{
class EncryptionEvent : public RoomEvent
class EncryptionEventContent: public EventContent::Base
{
public:
enum EncryptionType : size_t { MegolmV1AesSha2 = 0,
Undefined };

explicit EncryptionEventContent(EncryptionType et = Undefined)
: encryption(et)
{ }
explicit EncryptionEventContent(const QJsonObject& json);

EncryptionType encryption;
QString algorithm;
int rotationPeriodMs;
int rotationPeriodMsgs;

protected:
void fillJson(QJsonObject* o) const override;
};

using EncryptionType = EncryptionEventContent::EncryptionType;

class EncryptionEvent : public StateEvent<EncryptionEventContent>
{
Q_GADGET
public:
DEFINE_EVENT_TYPEID("m.room.encryption", EncryptionEvent)

explicit EncryptionEvent(const QJsonObject& obj)
: RoomEvent(typeId(), obj)
, _algorithm(contentJson()["algorithm"].toString())
using EncryptionType = EncryptionEventContent::EncryptionType;

explicit EncryptionEvent(const QJsonObject& obj = {}) // TODO: apropriate default value
: StateEvent(typeId(), obj)
{ }
EncryptionEvent(EncryptionEventContent&& c)
: StateEvent(typeId(), matrixTypeId(), c)
{ }

/// A special constructor to create unknown EncryptionEvents
/**
* This is needed in order to use EncryptionEvent as a "base event
* class" in cases like GetEncryptionByRoomJob when EncryptionEvents
* (rather than RoomEvents or StateEvents) are resolved from JSON.
* For such cases loadEvent<> requires an underlying class to be
* constructible with unknownTypeId() instead of its genuine id.
* Don't use it directly.
* \sa GetEncryptionByRoomJob, loadEvent, unknownTypeId
*/
EncryptionEvent(Type type, const QJsonObject& fullJson)
: StateEvent(type, fullJson)
{ }

QString algorithm() const { return _algorithm; }
EncryptionType encryption() const { return content().encryption; }

QString algorithm() const { return content().algorithm; }
int rotationPeriodMs() const { return content().rotationPeriodMs; }
int rotationPeriodMsgs() const { return content().rotationPeriodMsgs; }

private:
QString _algorithm;
REGISTER_ENUM(EncryptionType)
};

template <>
class EventFactory<EncryptionEvent>
{
public:
static event_ptr_tt<EncryptionEvent> make(const QJsonObject& json,
const QString&)
{
return makeEvent<EncryptionEvent>(json);
}
};

REGISTER_EVENT_TYPE(EncryptionEvent)
DEFINE_EVENTTYPE_ALIAS(Encryption, EncryptionEvent)
} // namespace QMatrixClient
Expand Down
2 changes: 0 additions & 2 deletions lib/events/simplestateevents.h
Original file line number Diff line number Diff line change
Expand Up @@ -86,7 +86,5 @@ namespace QMatrixClient
DEFINE_EVENTTYPE_ALIAS(RoomCanonicalAlias, RoomCanonicalAliasEvent)
DEFINE_SIMPLE_STATE_EVENT(RoomTopicEvent, "m.room.topic", QString, topic)
DEFINE_EVENTTYPE_ALIAS(RoomTopic, RoomTopicEvent)
DEFINE_SIMPLE_STATE_EVENT(EncryptionEvent, "m.room.encryption",
QString, algorithm)
DEFINE_EVENTTYPE_ALIAS(RoomEncryption, EncryptionEvent)
} // namespace QMatrixClient
1 change: 1 addition & 0 deletions lib/room.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@
#include "csapi/tags.h"
#include "csapi/room_upgrades.h"
#include "events/simplestateevents.h"
#include "events/encryptionevent.h"
#include "events/roomcreateevent.h"
#include "events/roomtombstoneevent.h"
#include "events/roomavatarevent.h"
Expand Down

0 comments on commit 78b555e

Please sign in to comment.