diff options
author | provokateurin <kate@provokateurin.de> | 2025-02-24 11:28:28 +0100 |
---|---|---|
committer | provokateurin <kate@provokateurin.de> | 2025-03-04 08:01:03 +0100 |
commit | b51aad472cc8a522310697c62635c19040f0f26c (patch) | |
tree | 1e12d6202ae96205349c5a7609f7d2a22cad6d54 | |
parent | 3ca39e3d948c9cd52dd8d58eacabf47498838e96 (diff) | |
download | nextcloud-server-b51aad472cc8a522310697c62635c19040f0f26c.tar.gz nextcloud-server-b51aad472cc8a522310697c62635c19040f0f26c.zip |
fix(Share20\Manager): Propagate user and group deletion to remote share providers
Signed-off-by: provokateurin <kate@provokateurin.de>
-rw-r--r-- | lib/private/Share20/Manager.php | 20 |
1 files changed, 16 insertions, 4 deletions
diff --git a/lib/private/Share20/Manager.php b/lib/private/Share20/Manager.php index 92eeaa2b83b..f0cf3f45b15 100644 --- a/lib/private/Share20/Manager.php +++ b/lib/private/Share20/Manager.php @@ -1665,8 +1665,14 @@ class Manager implements IManager { * @inheritdoc */ public function groupDeleted($gid) { - $provider = $this->factory->getProviderForType(IShare::TYPE_GROUP); - $provider->groupDeleted($gid); + foreach ([IShare::TYPE_GROUP, IShare::TYPE_REMOTE_GROUP] as $type) { + try { + $provider = $this->factory->getProviderForType($type); + } catch (ProviderException $e) { + continue; + } + $provider->groupDeleted($gid); + } $excludedGroups = $this->config->getAppValue('core', 'shareapi_exclude_groups_list', ''); if ($excludedGroups === '') { @@ -1686,8 +1692,14 @@ class Manager implements IManager { * @inheritdoc */ public function userDeletedFromGroup($uid, $gid) { - $provider = $this->factory->getProviderForType(IShare::TYPE_GROUP); - $provider->userDeletedFromGroup($uid, $gid); + foreach ([IShare::TYPE_GROUP, IShare::TYPE_REMOTE_GROUP] as $type) { + try { + $provider = $this->factory->getProviderForType($type); + } catch (ProviderException $e) { + continue; + } + $provider->userDeletedFromGroup($uid, $gid); + } } /** |