aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
Diffstat (limited to 'lib')
-rw-r--r--lib/connection.cpp7
-rw-r--r--lib/connection.h2
-rw-r--r--lib/events/roomcreateevent.cpp38
-rw-r--r--lib/events/roomcreateevent.h51
4 files changed, 94 insertions, 4 deletions
diff --git a/lib/connection.cpp b/lib/connection.cpp
index 63b0a31d..2a2d4822 100644
--- a/lib/connection.cpp
+++ b/lib/connection.cpp
@@ -550,7 +550,8 @@ DownloadFileJob* Connection::downloadFile(const QUrl& url,
CreateRoomJob* Connection::createRoom(RoomVisibility visibility,
const QString& alias, const QString& name, const QString& topic,
- QStringList invites, const QString& presetName, bool isDirect,
+ QStringList invites, const QString& presetName,
+ const QString& roomVersion, bool isDirect,
const QVector<CreateRoomJob::StateEvent>& initialState,
const QVector<CreateRoomJob::Invite3pid>& invite3pids,
const QJsonObject& creationContent)
@@ -559,7 +560,7 @@ CreateRoomJob* Connection::createRoom(RoomVisibility visibility,
auto job = callApi<CreateRoomJob>(
visibility == PublishRoom ? QStringLiteral("public")
: QStringLiteral("private"),
- alias, name, topic, invites, invite3pids, QString(/*TODO: #233*/),
+ alias, name, topic, invites, invite3pids, roomVersion,
creationContent, initialState, presetName, isDirect);
connect(job, &BaseJob::success, this, [this,job] {
emit createdRoom(provideRoom(job->roomId(), JoinState::Join));
@@ -661,7 +662,7 @@ CreateRoomJob* Connection::createDirectChat(const QString& userId,
const QString& topic, const QString& name)
{
return createRoom(UnpublishRoom, "", name, topic, {userId},
- "trusted_private_chat", true);
+ "trusted_private_chat", {}, true);
}
ForgetRoomJob* Connection::forgetRoom(const QString& id)
diff --git a/lib/connection.h b/lib/connection.h
index 45b691e1..8c938df2 100644
--- a/lib/connection.h
+++ b/lib/connection.h
@@ -404,7 +404,7 @@ namespace QMatrixClient
CreateRoomJob* createRoom(RoomVisibility visibility,
const QString& alias, const QString& name, const QString& topic,
QStringList invites, const QString& presetName = {},
- bool isDirect = false,
+ const QString& roomVersion = {}, bool isDirect = false,
const QVector<CreateRoomJob::StateEvent>& initialState = {},
const QVector<CreateRoomJob::Invite3pid>& invite3pids = {},
const QJsonObject& creationContent = {});
diff --git a/lib/events/roomcreateevent.cpp b/lib/events/roomcreateevent.cpp
new file mode 100644
index 00000000..635efb92
--- /dev/null
+++ b/lib/events/roomcreateevent.cpp
@@ -0,0 +1,38 @@
+/******************************************************************************
+* Copyright (C) 2019 QMatrixClient project
+*
+* This library is free software; you can redistribute it and/or
+* modify it under the terms of the GNU Lesser General Public
+* License as published by the Free Software Foundation; either
+* version 2.1 of the License, or (at your option) any later version.
+*
+* This library is distributed in the hope that it will be useful,
+* but WITHOUT ANY WARRANTY; without even the implied warranty of
+* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+* Lesser General Public License for more details.
+*
+* You should have received a copy of the GNU Lesser General Public
+* License along with this library; if not, write to the Free Software
+* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+*/
+
+#include "roomcreateevent.h"
+
+using namespace QMatrixClient;
+
+RoomCreateDetails::RoomCreateDetails(const QJsonObject& json)
+ : federated(fromJson<bool>(json["m.federate"_ls]))
+ , version(fromJson<QString>(json["room_version"_ls]))
+{
+ const auto predecessorJson = json["predecessor"_ls].toObject();
+ if (!predecessorJson.isEmpty())
+ {
+ fromJson(predecessorJson["room_id"_ls], predRoomId);
+ fromJson(predecessorJson["event_id"_ls], predEventId);
+ }
+}
+
+std::pair<QString, QString> RoomCreateEvent::predecessor() const
+{
+ return { content().predRoomId, content().predEventId };
+}
diff --git a/lib/events/roomcreateevent.h b/lib/events/roomcreateevent.h
new file mode 100644
index 00000000..d93668f9
--- /dev/null
+++ b/lib/events/roomcreateevent.h
@@ -0,0 +1,51 @@
+/******************************************************************************
+* Copyright (C) 2019 QMatrixClient project
+*
+* This library is free software; you can redistribute it and/or
+* modify it under the terms of the GNU Lesser General Public
+* License as published by the Free Software Foundation; either
+* version 2.1 of the License, or (at your option) any later version.
+*
+* This library is distributed in the hope that it will be useful,
+* but WITHOUT ANY WARRANTY; without even the implied warranty of
+* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+* Lesser General Public License for more details.
+*
+* You should have received a copy of the GNU Lesser General Public
+* License along with this library; if not, write to the Free Software
+* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+*/
+
+#pragma once
+
+#include "stateevent.h"
+
+namespace QMatrixClient
+{
+ class RoomCreateDetails
+ {
+ public:
+ explicit RoomCreateDetails(const QJsonObject& json);
+
+ bool federated;
+ QString version;
+ QString predRoomId;
+ QString predEventId;
+ };
+
+ class RoomCreateEvent : public StateEvent<const RoomCreateDetails>
+ {
+ public:
+ DEFINE_EVENT_TYPEID("m.room.create", RoomCreateEvent)
+
+ explicit RoomCreateEvent(const QJsonObject& obj)
+ : StateEvent(typeId(), obj)
+ { }
+
+ bool isFederated() const { return content().federated; }
+ QString version() const { return content().version; }
+ std::pair<QString, QString> predecessor() const;
+ bool isUpgrade() const { return !content().predRoomId.isEmpty(); }
+ };
+ REGISTER_EVENT_TYPE(RoomCreateEvent)
+}