summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--lib/private/helper.php12
-rw-r--r--tests/lib/helper.php26
2 files changed, 28 insertions, 10 deletions
diff --git a/lib/private/helper.php b/lib/private/helper.php
index 7c1edd1b058..f696b5a8900 100644
--- a/lib/private/helper.php
+++ b/lib/private/helper.php
@@ -129,12 +129,12 @@ class OC_Helper {
* Returns a absolute url to the given service.
*/
public static function linkToPublic($service, $add_slash = false) {
- return OC::$server->getURLGenerator()->getAbsoluteURL(
- self::linkTo(
- '', 'public.php') . '?service=' . $service
- . (($add_slash && $service[strlen($service) - 1] != '/') ? '/' : ''
- )
- );
+ if ($service === 'files') {
+ $url = OC::$server->getURLGenerator()->getAbsoluteURL('/s');
+ } else {
+ $url = OC::$server->getURLGenerator()->getAbsoluteURL(self::linkTo('', 'public.php').'?service='.$service);
+ }
+ return $url . (($add_slash && $service[strlen($service) - 1] != '/') ? '/' : '');
}
/**
diff --git a/tests/lib/helper.php b/tests/lib/helper.php
index 20b8571b91d..cb342e295ba 100644
--- a/tests/lib/helper.php
+++ b/tests/lib/helper.php
@@ -443,15 +443,33 @@ class Test_Helper extends PHPUnit_Framework_TestCase {
public function testLinkToPublic() {
\OC::$WEBROOT = '';
$result = \OC_Helper::linkToPublic('files');
- $this->assertEquals('http://localhost/public.php?service=files', $result);
+ $this->assertEquals('http://localhost/s', $result);
$result = \OC_Helper::linkToPublic('files', false);
- $this->assertEquals('http://localhost/public.php?service=files', $result);
+ $this->assertEquals('http://localhost/s', $result);
+ $result = \OC_Helper::linkToPublic('files', true);
+ $this->assertEquals('http://localhost/s/', $result);
+
+ $result = \OC_Helper::linkToPublic('other');
+ $this->assertEquals('http://localhost/public.php?service=other', $result);
+ $result = \OC_Helper::linkToPublic('other', false);
+ $this->assertEquals('http://localhost/public.php?service=other', $result);
+ $result = \OC_Helper::linkToPublic('other', true);
+ $this->assertEquals('http://localhost/public.php?service=other/', $result);
\OC::$WEBROOT = '/owncloud';
$result = \OC_Helper::linkToPublic('files');
- $this->assertEquals('http://localhost/owncloud/public.php?service=files', $result);
+ $this->assertEquals('http://localhost/owncloud/s', $result);
$result = \OC_Helper::linkToPublic('files', false);
- $this->assertEquals('http://localhost/owncloud/public.php?service=files', $result);
+ $this->assertEquals('http://localhost/owncloud/s', $result);
+ $result = \OC_Helper::linkToPublic('files', true);
+ $this->assertEquals('http://localhost/owncloud/s/', $result);
+
+ $result = \OC_Helper::linkToPublic('other');
+ $this->assertEquals('http://localhost/owncloud/public.php?service=other', $result);
+ $result = \OC_Helper::linkToPublic('other', false);
+ $this->assertEquals('http://localhost/owncloud/public.php?service=other', $result);
+ $result = \OC_Helper::linkToPublic('other', true);
+ $this->assertEquals('http://localhost/owncloud/public.php?service=other/', $result);
}
/**