diff options
Diffstat (limited to 'classes/config.php')
-rw-r--r-- | classes/config.php | 9 |
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 { |