]> source.dussan.org Git - nextcloud-server.git/commitdiff
Set files_sharing:hide_disabled_user_shares to 'yes' to hide shares from disabled...
authorCôme Chilliet <come.chilliet@nextcloud.com>
Thu, 3 Aug 2023 14:13:38 +0000 (16:13 +0200)
committerbackportbot-nextcloud[bot] <backportbot-nextcloud[bot]@users.noreply.github.com>
Mon, 28 Aug 2023 13:50:26 +0000 (13:50 +0000)
Signed-off-by: Côme Chilliet <come.chilliet@nextcloud.com>
lib/private/Share20/Manager.php

index 732bd5bb97d397e191acd27ee74b62b303429bdb..b03d304aa1e61877a31cf82f8ab2642c009bca5f 100644 (file)
@@ -1352,7 +1352,7 @@ class Manager implements IManager {
                        $added = 0;
                        foreach ($shares as $share) {
                                try {
-                                       $this->checkExpireDate($share);
+                                       $this->checkShare($share);
                                } catch (ShareNotFound $e) {
                                        //Ignore since this basically means the share is deleted
                                        continue;
@@ -1411,7 +1411,7 @@ class Manager implements IManager {
                // remove all shares which are already expired
                foreach ($shares as $key => $share) {
                        try {
-                               $this->checkExpireDate($share);
+                               $this->checkShare($share);
                        } catch (ShareNotFound $e) {
                                unset($shares[$key]);
                        }
@@ -1457,7 +1457,7 @@ class Manager implements IManager {
 
                $share = $provider->getShareById($id, $recipient);
 
-               $this->checkExpireDate($share);
+               $this->checkShare($share);
 
                return $share;
        }
@@ -1541,7 +1541,7 @@ class Manager implements IManager {
                        throw new ShareNotFound($this->l->t('The requested share does not exist anymore'));
                }
 
-               $this->checkExpireDate($share);
+               $this->checkShare($share);
 
                /*
                 * Reduce the permissions for link or email shares if public upload is not enabled
@@ -1554,11 +1554,25 @@ class Manager implements IManager {
                return $share;
        }
 
-       protected function checkExpireDate($share) {
+       /**
+        * Check expire date and disabled owner
+        *
+        * @throws ShareNotFound
+        */
+       protected function checkShare(IShare $share): void {
                if ($share->isExpired()) {
                        $this->deleteShare($share);
                        throw new ShareNotFound($this->l->t('The requested share does not exist anymore'));
                }
+               if ($this->config->getAppValue('files_sharing', 'hide_disabled_user_shares', 'no') === 'yes') {
+                       $uids = array_unique([$share->getShareOwner(),$share->getSharedBy()]);
+                       foreach ($uids as $uid) {
+                               $user = $this->userManager->get($uid);
+                               if (($user !== null) && !$user->isEnabled()) {
+                                       throw new ShareNotFound($this->l->t('The requested share comes from a disabled user'));
+                               }
+                       }
+               }
        }
 
        /**