diff options
author | Joas Schilling <coding@schilljs.com> | 2022-04-27 20:13:40 +0300 |
---|---|---|
committer | Joas Schilling <coding@schilljs.com> | 2022-04-27 22:22:43 +0300 |
commit | 5874253f25e5d780680d2dbdc7c71540d6a95aee (patch) | |
tree | 68e586d58272819a398a55065e8af9a823943103 /lib/Collaboration | |
parent | 7f0dbc0c6497225090cab15fb416e7352edd9323 (diff) |
Disallow sharing without chat permissions
Signed-off-by: Joas Schilling <coding@schilljs.com>
Diffstat (limited to 'lib/Collaboration')
-rw-r--r-- | lib/Collaboration/Collaborators/RoomPlugin.php | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/lib/Collaboration/Collaborators/RoomPlugin.php b/lib/Collaboration/Collaborators/RoomPlugin.php index ea9e92d8e..cc03429fe 100644 --- a/lib/Collaboration/Collaborators/RoomPlugin.php +++ b/lib/Collaboration/Collaborators/RoomPlugin.php @@ -25,6 +25,8 @@ declare(strict_types=1); namespace OCA\Talk\Collaboration\Collaborators; use OCA\Talk\Manager; +use OCA\Talk\Model\Attendee; +use OCA\Talk\Participant; use OCA\Talk\Room; use OCP\Collaboration\Collaborators\ISearchPlugin; use OCP\Collaboration\Collaborators\ISearchResult; @@ -62,6 +64,12 @@ class RoomPlugin implements ISearchPlugin { continue; } + $participant = $room->getParticipant($userId, false); + if (!$participant instanceof Participant || !($participant->getPermissions() & Attendee::PERMISSIONS_CHAT)) { + // No chat permissions is like read-only + continue; + } + if (stripos($room->getDisplayName($userId), $search) !== false) { $item = $this->roomToSearchResultItem($room, $userId); |