diff options
author | Alexey Rusakov <Kitsune-Ral@users.sf.net> | 2021-06-07 07:55:23 +0200 |
---|---|---|
committer | Alexey Rusakov <Kitsune-Ral@users.sf.net> | 2021-06-07 08:00:03 +0200 |
commit | 0571ba1fb1948a6cc050230a85201291ababbf04 (patch) | |
tree | b6c8d029cc181be9b71b084d2b6059a8917bf4fc /lib | |
parent | 7761c2b791291adee0505c869305b5675e90ed3b (diff) | |
download | libquotient-0571ba1fb1948a6cc050230a85201291ababbf04.tar.gz libquotient-0571ba1fb1948a6cc050230a85201291ababbf04.zip |
Connection::joinRoom() shouldn't enforce room state
This is an adjustment to the earlier fix of #471: if a join is
immediately followed by a leave (e.g. from another client/bot - you
can't do it programmatically from libQuotient) the sync may bring the
room already in the Leave state; therefore `joinRoom` should not
impose the state but rather ask `provideRoom` to create a `Join` room -
just as it's designed when passed an empty `joinState`.
Diffstat (limited to 'lib')
-rw-r--r-- | lib/connection.cpp | 12 |
1 files changed, 6 insertions, 6 deletions
diff --git a/lib/connection.cpp b/lib/connection.cpp index a384783c..55067bb7 100644 --- a/lib/connection.cpp +++ b/lib/connection.cpp @@ -800,14 +800,14 @@ PostReceiptJob* Connection::postReceipt(Room* room, RoomEvent* event) JoinRoomJob* Connection::joinRoom(const QString& roomAlias, const QStringList& serverNames) { - auto job = callApi<JoinRoomJob>(roomAlias, serverNames); - // Upon completion, ensure a room object in Join state is created - // (or it might already be there due to a sync completing earlier). - // finished() is used here instead of success() to overtake clients - // that may add their own slots to finished(). + auto* const job = callApi<JoinRoomJob>(roomAlias, serverNames); + // Upon completion, ensure a room object is created in case it hasn't come + // with a sync yet. If the room object is not there, provideRoom() will + // create it in Join state. finished() is used here instead of success() + // to overtake clients that may add their own slots to finished(). connect(job, &BaseJob::finished, this, [this, job] { if (job->status().good()) - provideRoom(job->roomId(), JoinState::Join); + provideRoom(job->roomId()); }); return job; } |