mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-25 05:49:28 +00:00
fix(Communities): don't crash on rejoin attempt
Prior to this commit there was a scenario where the application would crash due a memory bug when attempting to (re)join a community. The scenario is as follows: 1. User creates or has been invited to community with `ON_REQUEST` permissions 2. User leaves community 3. User decides to rejoin, so she selects the community she's been part of and hits the "Join" button At this point Status Desktop would send a new `RequestToJoin` request, as the community has a corresponding permissions setting. This would then result in an `already a member` error in status-go, because status-go checks whether the requestee is already part of the members list of the community. The error isn't handled inside Status Desktop which causes a crash because we're trying to access data in memory that doesn't exist. Why is this happening? While this might be unexpected, when leaving a community (as done on step 2 of the mentioned scenario), users don't actually lose membership but simply "unsubscribe" from all channels in the community in question and their `joined` flag is set to `false`. From that point on, re-joininng a community is done by sending a `JoinCommunity` request (instead of `RequestToJoin`), which will then set the `joined` flag to `true` and doesn't actually check the membership in the database. This commit ensures we're calling the right API by checking whether not only whether the community is needs `ON _REQUEST` permissions, but also whether the user isn't already a member of it. Fixes #2017
This commit is contained in:
parent
e4cdb29a0b
commit
51c8d86ccc
@ -16,6 +16,7 @@ ModalPopup {
|
|||||||
property bool ensOnly: community.ensOnly
|
property bool ensOnly: community.ensOnly
|
||||||
property bool canJoin: community.canJoin
|
property bool canJoin: community.canJoin
|
||||||
property bool canRequestAccess: community.canRequestAccess
|
property bool canRequestAccess: community.canRequestAccess
|
||||||
|
property bool isMember: community.isMember
|
||||||
|
|
||||||
id: popup
|
id: popup
|
||||||
|
|
||||||
@ -220,7 +221,7 @@ ModalPopup {
|
|||||||
anchors.right: parent.right
|
anchors.right: parent.right
|
||||||
onClicked: {
|
onClicked: {
|
||||||
let error
|
let error
|
||||||
if (access === Constants.communityChatOnRequestAccess) {
|
if (access === Constants.communityChatOnRequestAccess && !popup.isMember) {
|
||||||
error = chatsModel.communities.requestToJoinCommunity(popup.communityId,
|
error = chatsModel.communities.requestToJoinCommunity(popup.communityId,
|
||||||
profileModel.profile.ensVerified ? profileModel.profile.username : "")
|
profileModel.profile.ensVerified ? profileModel.profile.username : "")
|
||||||
if (!error) {
|
if (!error) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user