summaryrefslogtreecommitdiffstats
path: root/remote.php
diff options
context:
space:
mode:
Diffstat (limited to 'remote.php')
-rw-r--r--remote.php77
1 files changed, 43 insertions, 34 deletions
diff --git a/remote.php b/remote.php
index 7738de04f60..ec0f2ecef72 100644
--- a/remote.php
+++ b/remote.php
@@ -1,40 +1,49 @@
<?php
$RUNTIME_NOAPPS = true;
-require_once 'lib/base.php';
-$path_info = OC_Request::getPathInfo();
-if ($path_info === false || $path_info === '') {
- OC_Response::setStatus(OC_Response::STATUS_NOT_FOUND);
- exit;
-}
-if (!$pos = strpos($path_info, '/', 1)) {
- $pos = strlen($path_info);
-}
-$service=substr($path_info, 1, $pos-1);
-$file = OC_AppConfig::getValue('core', 'remote_' . $service);
+try {
-if(is_null($file)) {
- OC_Response::setStatus(OC_Response::STATUS_NOT_FOUND);
- exit;
-}
+ require_once 'lib/base.php';
+ $path_info = OC_Request::getPathInfo();
+ if ($path_info === false || $path_info === '') {
+ OC_Response::setStatus(OC_Response::STATUS_NOT_FOUND);
+ exit;
+ }
+ if (!$pos = strpos($path_info, '/', 1)) {
+ $pos = strlen($path_info);
+ }
+ $service=substr($path_info, 1, $pos-1);
-$file=ltrim($file, '/');
+ $file = OC_AppConfig::getValue('core', 'remote_' . $service);
-$parts=explode('/', $file, 2);
-$app=$parts[0];
-switch ($app) {
- case 'core':
- $file = OC::$SERVERROOT .'/'. $file;
- break;
- default:
- OC_Util::checkAppEnabled($app);
- OC_App::loadApp($app);
- if (strtoupper(substr(PHP_OS, 0, 3)) === 'WIN') {
- $file = OC_App::getAppPath($app) .'/'. $parts[1];
- }else{
- $file = '/' . OC_App::getAppPath($app) .'/'. $parts[1];
- }
- break;
-}
-$baseuri = OC::$WEBROOT . '/remote.php/'.$service.'/';
-require_once $file;
+ if(is_null($file)) {
+ OC_Response::setStatus(OC_Response::STATUS_NOT_FOUND);
+ exit;
+ }
+
+ $file=ltrim($file, '/');
+
+ $parts=explode('/', $file, 2);
+ $app=$parts[0];
+ switch ($app) {
+ case 'core':
+ $file = OC::$SERVERROOT .'/'. $file;
+ break;
+ default:
+ OC_Util::checkAppEnabled($app);
+ OC_App::loadApp($app);
+ if (strtoupper(substr(PHP_OS, 0, 3)) === 'WIN') {
+ $file = OC_App::getAppPath($app) .'/'. $parts[1];
+ }else{
+ $file = '/' . OC_App::getAppPath($app) .'/'. $parts[1];
+ }
+ break;
+ }
+ $baseuri = OC::$WEBROOT . '/remote.php/'.$service.'/';
+ require_once $file;
+
+} catch (Exception $ex) {
+ OC_Response::setStatus(OC_Response::STATUS_INTERNAL_SERVER_ERROR);
+ \OCP\Util::writeLog('remote', $ex->getMessage(), \OCP\Util::FATAL);
+ OC_Template::printExceptionErrorPage($ex);
+} \ No newline at end of file