summaryrefslogtreecommitdiff
path: root/classes/config.php
diff options
context:
space:
mode:
Diffstat (limited to 'classes/config.php')
-rw-r--r--classes/config.php9
1 files changed, 9 insertions, 0 deletions
diff --git a/classes/config.php b/classes/config.php
index 17c555fa9..77795de7a 100644
--- a/classes/config.php
+++ b/classes/config.php
@@ -268,6 +268,8 @@ class Config {
/** @var Db_Migrations|null $migrations */
private $migrations;
+ private static $self_url_path_strip_dirs = 0;
+
public static function get_instance() : Config {
if (self::$instance == null)
self::$instance = new self();
@@ -476,6 +478,10 @@ class Config {
(!empty($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https');
}
+ static function strip_self_url_path_dirs($amount) {
+ self::$self_url_path_strip_dirs = $amount;
+ }
+
/** returns fully-qualified external URL to tt-rss (no trailing slash)
* SELF_URL_PATH configuration variable is used as a fallback for the CLI SAPI
* */
@@ -488,6 +494,9 @@ class Config {
$self_url_path = $proto . '://' . $_SERVER["HTTP_HOST"] . parse_url($_SERVER["REQUEST_URI"], PHP_URL_PATH);
$self_url_path = preg_replace("/\w+\.php(\?.*$)?$/", "", $self_url_path);
+ for ($i = 0; $i < self::$self_url_path_strip_dirs; $i++)
+ $self_url_path = dirname($self_url_path);
+
if (substr($self_url_path, -1) === "/") {
return substr($self_url_path, 0, -1);
} else {