summaryrefslogtreecommitdiffstats
path: root/apps
diff options
context:
space:
mode:
authorRoeland Jago Douma <roeland@famdouma.nl>2015-08-29 13:31:18 +0200
committerRoeland Jago Douma <roeland@famdouma.nl>2015-08-30 10:31:43 +0200
commit2aff11c80bbc7fb0524c52d17824d68bda43aac5 (patch)
treec0c82538bdbdf9fc38f983831c091ba707ba2e58 /apps
parentfc64ea670d63b125d277ddcacc0b48253b62c28d (diff)
downloadnextcloud-server-2aff11c80bbc7fb0524c52d17824d68bda43aac5.tar.gz
nextcloud-server-2aff11c80bbc7fb0524c52d17824d68bda43aac5.zip
Actually validate the expire date on share
* Added more intergration tests
Diffstat (limited to 'apps')
-rw-r--r--apps/files_sharing/api/local.php12
-rw-r--r--apps/files_sharing/tests/api.php88
2 files changed, 95 insertions, 5 deletions
diff --git a/apps/files_sharing/api/local.php b/apps/files_sharing/api/local.php
index eeb31899830..87025998b3d 100644
--- a/apps/files_sharing/api/local.php
+++ b/apps/files_sharing/api/local.php
@@ -292,7 +292,7 @@ class Local {
try {
$expirationDate = isset($_POST['expireDate']) ? self::parseDate($_POST['expireDate']) : null;
} catch (\Exception $e) {
- return new \OC_OCS_Result(null, 404, 'Invalid Date');
+ return new \OC_OCS_Result(null, 404, 'Invalid Date. Format must be YYYY-MM-DD.');
}
break;
@@ -315,7 +315,11 @@ class Local {
$expirationDate
);
} catch (HintException $e) {
- return new \OC_OCS_Result(null, 400, $e->getHint());
+ if ($e->getCode() === 0) {
+ return new \OC_OCS_Result(null, 400, $e->getHint());
+ } else {
+ return new \OC_OCS_Result(null, $e->getCode(), $e->getHint());
+ }
} catch (\Exception $e) {
return new \OC_OCS_Result(null, 403, $e->getMessage());
}
@@ -559,13 +563,13 @@ class Local {
*/
private static function parseDate($expireDate) {
if (preg_match('/^\d{4}-\d{2}-\d{2}$/', $expireDate) === 0) {
- throw new \Exception();
+ throw new \Exception('Invalid date. Format must be YYYY-MM-DD');
}
$date = new \DateTime($expireDate);
if ($date === false) {
- throw new \Exception();
+ throw new \Exception('Invalid date. Format must be YYYY-MM-DD');
}
return $date;
diff --git a/apps/files_sharing/tests/api.php b/apps/files_sharing/tests/api.php
index a9b6ee9f64e..d0ee71cec5a 100644
--- a/apps/files_sharing/tests/api.php
+++ b/apps/files_sharing/tests/api.php
@@ -1518,7 +1518,7 @@ class Test_Files_Sharing_Api extends TestCase {
if ($valid === false) {
$this->assertFalse($result->succeeded());
$this->assertEquals(404, $result->getStatusCode());
- $this->assertEquals('Invalid Date', $result->getMeta()['message']);
+ $this->assertEquals('Invalid Date. Format must be YYYY-MM-DD.', $result->getMeta()['message']);
return;
}
@@ -1543,4 +1543,90 @@ class Test_Files_Sharing_Api extends TestCase {
$fileinfo = $this->view->getFileInfo($this->folder);
\OCP\Share::unshare('folder', $fileinfo['fileid'], \OCP\Share::SHARE_TYPE_LINK, null);
}
+
+ public function testCreatePublicLinkExpireDateValid() {
+ $config = \OC::$server->getConfig();
+
+ // enforce expire date, by default 7 days after the file was shared
+ $config->setAppValue('core', 'shareapi_default_expire_date', 'yes');
+ $config->setAppValue('core', 'shareapi_enforce_expire_date', 'yes');
+
+ $date = new \DateTime();
+ $date->add(new \DateInterval('P5D'));
+
+ $_POST['path'] = $this->folder;
+ $_POST['shareType'] = \OCP\Share::SHARE_TYPE_LINK;
+ $_POST['expireDate'] = $date->format('Y-m-d');
+
+ $result = \OCA\Files_Sharing\API\Local::createShare([]);
+
+ $this->assertTrue($result->succeeded());
+
+ $data = $result->getData();
+ $this->assertTrue(is_string($data['token']));
+
+ // check for correct link
+ $url = \OC::$server->getURLGenerator()->getAbsoluteURL('/index.php/s/' . $data['token']);
+ $this->assertEquals($url, $data['url']);
+
+
+ $share = $this->getShareFromId($data['id']);
+ $items = \OCP\Share::getItemShared('file', $share['item_source']);
+ $this->assertTrue(!empty($items));
+
+ $item = reset($items);
+ $this->assertTrue(is_array($item));
+ $this->assertEquals($date->format('Y-m-d'), substr($item['expiration'], 0, 10));
+
+ $fileinfo = $this->view->getFileInfo($this->folder);
+ \OCP\Share::unshare('folder', $fileinfo['fileid'], \OCP\Share::SHARE_TYPE_LINK, null);
+
+ $config->setAppValue('core', 'shareapi_default_expire_date', 'no');
+ $config->setAppValue('core', 'shareapi_enforce_expire_date', 'no');
+ }
+
+ public function testCreatePublicLinkExpireDateInvalidFuture() {
+ $config = \OC::$server->getConfig();
+
+ // enforce expire date, by default 7 days after the file was shared
+ $config->setAppValue('core', 'shareapi_default_expire_date', 'yes');
+ $config->setAppValue('core', 'shareapi_enforce_expire_date', 'yes');
+
+ $date = new \DateTime();
+ $date->add(new \DateInterval('P8D'));
+
+ $_POST['path'] = $this->folder;
+ $_POST['shareType'] = \OCP\Share::SHARE_TYPE_LINK;
+ $_POST['expireDate'] = $date->format('Y-m-d');
+
+ $result = \OCA\Files_Sharing\API\Local::createShare([]);
+
+ $this->assertFalse($result->succeeded());
+ $this->assertEquals(404, $result->getStatusCode());
+ $this->assertEquals('Cannot set expiration date. Shares cannot expire later than 7 after they have been shared', $result->getMeta()['message']);
+
+ $config->setAppValue('core', 'shareapi_default_expire_date', 'no');
+ $config->setAppValue('core', 'shareapi_enforce_expire_date', 'no');
+ }
+
+ public function testCreatePublicLinkExpireDateInvalidPast() {
+ $config = \OC::$server->getConfig();
+
+ $date = new \DateTime();
+ $date->sub(new \DateInterval('P8D'));
+
+ $_POST['path'] = $this->folder;
+ $_POST['shareType'] = \OCP\Share::SHARE_TYPE_LINK;
+ $_POST['expireDate'] = $date->format('Y-m-d');
+
+ $result = \OCA\Files_Sharing\API\Local::createShare([]);
+
+ $this->assertFalse($result->succeeded());
+ $this->assertEquals(404, $result->getStatusCode());
+ $this->assertEquals('Cannot set expiration date. Expiration date is in the past', $result->getMeta()['message']);
+
+ $config->setAppValue('core', 'shareapi_default_expire_date', 'no');
+ $config->setAppValue('core', 'shareapi_enforce_expire_date', 'no');
+ }
+
}