diff options
author | Thomas Müller <thomas.mueller@tmit.eu> | 2012-11-22 12:49:57 -0800 |
---|---|---|
committer | Thomas Müller <thomas.mueller@tmit.eu> | 2012-11-22 12:49:57 -0800 |
commit | 7e123cfb67e2bb0d7896f8f6a95eed464ebf5d9c (patch) | |
tree | a199f86eac10cedcdc3203e0452beb8cc9edb693 | |
parent | c773d071ee947a9065c492a356367ebbd78bc169 (diff) | |
parent | 6cb377470607f6e4e62fb6ca931ab63fb6938390 (diff) | |
download | nextcloud-server-7e123cfb67e2bb0d7896f8f6a95eed464ebf5d9c.tar.gz nextcloud-server-7e123cfb67e2bb0d7896f8f6a95eed464ebf5d9c.zip |
Merge pull request #554 from owncloud/reverse_proxy
better reverse proxy support
-rw-r--r-- | config/config.sample.php | 6 | ||||
-rwxr-xr-x[-rw-r--r--] | lib/request.php | 6 | ||||
-rw-r--r-- | ocs/providers.php | 2 |
3 files changed, 13 insertions, 1 deletions
diff --git a/config/config.sample.php b/config/config.sample.php index 3d0a70db1d8..0ef90a04699 100644 --- a/config/config.sample.php +++ b/config/config.sample.php @@ -30,6 +30,12 @@ $CONFIG = array( /* Force use of HTTPS connection (true = use HTTPS) */ "forcessl" => false, +/* The automatic hostname detection of ownCloud can fail in certain reverse proxy situations. This option allows to manually override the automatic detection. You can also add a port. For example "www.example.com:88" */ +"overwritehost" => "", + +/* The automatic protocol detection of ownCloud can fail in certain reverse proxy situations. This option allows to manually override the protocol detection. For example "https" */ +"overwriteprotocol" => "", + /* Enhanced auth forces users to enter their password again when performing potential sensitive actions like creating or deleting users */ "enhancedauth" => true, diff --git a/lib/request.php b/lib/request.php index 287d20d1a5d..c975c84a711 100644..100755 --- a/lib/request.php +++ b/lib/request.php @@ -18,6 +18,9 @@ class OC_Request { if(OC::$CLI) { return 'localhost'; } + if(OC_Config::getValue('overwritehost', '')<>''){ + return OC_Config::getValue('overwritehost'); + } if (isset($_SERVER['HTTP_X_FORWARDED_HOST'])) { if (strpos($_SERVER['HTTP_X_FORWARDED_HOST'], ",") !== false) { $host = trim(array_pop(explode(",", $_SERVER['HTTP_X_FORWARDED_HOST']))); @@ -40,6 +43,9 @@ class OC_Request { * Returns the server protocol. It respects reverse proxy servers and load balancers */ public static function serverProtocol() { + if(OC_Config::getValue('overwriteprotocol', '')<>''){ + return OC_Config::getValue('overwriteprotocol'); + } if (isset($_SERVER['HTTP_X_FORWARDED_PROTO'])) { $proto = strtolower($_SERVER['HTTP_X_FORWARDED_PROTO']); }else{ diff --git a/ocs/providers.php b/ocs/providers.php index 43c9dc2aa42..0c7cbaeff08 100644 --- a/ocs/providers.php +++ b/ocs/providers.php @@ -23,7 +23,7 @@ require_once '../lib/base.php'; -$url='http://'.substr(OCP\Util::getServerHost().$_SERVER['REQUEST_URI'], 0, -17).'ocs/v1.php/'; +$url=OCP\Util::getServerProtocol().'://'.substr(OCP\Util::getServerHost().$_SERVER['REQUEST_URI'], 0, -17).'ocs/v1.php/'; echo(' <providers> |