diff options
author | Roeland Jago Douma <rullzer@users.noreply.github.com> | 2020-04-24 17:08:31 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-04-24 17:08:31 +0200 |
commit | 652639b63619a577087254803c16ae90b7e3bd7c (patch) | |
tree | 095ee008183658069be8e3db9cca16671691d9e6 | |
parent | 768b0120008b1b0de78918079888c920c446de59 (diff) | |
parent | f4b8623d330dcde02f07fa58d7134698744ee790 (diff) | |
download | nextcloud-server-652639b63619a577087254803c16ae90b7e3bd7c.tar.gz nextcloud-server-652639b63619a577087254803c16ae90b7e3bd7c.zip |
Merge pull request #20587 from nextcloud/enh/allow_default_expiration_date
Allow specifying a default expiration date
-rw-r--r-- | lib/private/Share20/Manager.php | 14 | ||||
-rw-r--r-- | tests/lib/Share20/ManagerTest.php | 1 |
2 files changed, 13 insertions, 2 deletions
diff --git a/lib/private/Share20/Manager.php b/lib/private/Share20/Manager.php index becf29e4cc7..eae26645b55 100644 --- a/lib/private/Share20/Manager.php +++ b/lib/private/Share20/Manager.php @@ -396,7 +396,12 @@ class Manager implements IManager { if ($fullId === null && $expirationDate === null && $this->shareApiInternalDefaultExpireDate()) { $expirationDate = new \DateTime(); $expirationDate->setTime(0,0,0); - $expirationDate->add(new \DateInterval('P'.$this->shareApiInternalDefaultExpireDays().'D')); + + $days = (int)$this->config->getAppValue('core', 'internal_defaultExpDays', $this->shareApiLinkDefaultExpireDays()); + if ($days > $this->shareApiLinkDefaultExpireDays()) { + $days = $this->shareApiLinkDefaultExpireDays(); + } + $expirationDate->add(new \DateInterval('P'.$days.'D')); } // If we enforce the expiration date check that is does not exceed @@ -467,7 +472,12 @@ class Manager implements IManager { if ($fullId === null && $expirationDate === null && $this->shareApiLinkDefaultExpireDate()) { $expirationDate = new \DateTime(); $expirationDate->setTime(0,0,0); - $expirationDate->add(new \DateInterval('P'.$this->shareApiLinkDefaultExpireDays().'D')); + + $days = (int)$this->config->getAppValue('core', 'link_defaultExpDays', $this->shareApiLinkDefaultExpireDays()); + if ($days > $this->shareApiLinkDefaultExpireDays()) { + $days = $this->shareApiLinkDefaultExpireDays(); + } + $expirationDate->add(new \DateInterval('P'.$days.'D')); } // If we enforce the expiration date check that is does not exceed diff --git a/tests/lib/Share20/ManagerTest.php b/tests/lib/Share20/ManagerTest.php index 4a7b0e9ae4b..b8364cfdc46 100644 --- a/tests/lib/Share20/ManagerTest.php +++ b/tests/lib/Share20/ManagerTest.php @@ -808,6 +808,7 @@ class ManagerTest extends \Test\TestCase { ['core', 'shareapi_enforce_expire_date', 'no', 'yes'], ['core', 'shareapi_expire_after_n_days', '7', '3'], ['core', 'shareapi_default_expire_date', 'no', 'yes'], + ['core', 'link_defaultExpDays', 3, '3'], ]); $expected = new \DateTime(); |