diff options
| author | Charles <sircharlesaze@gmail.com> | 2020-01-09 10:55:03 +0100 |
|---|---|---|
| committer | Charles <sircharlesaze@gmail.com> | 2020-01-09 13:09:38 +0100 |
| commit | 04d6d5ca99ebfd1cebb8ce06618fb3811fc1a8aa (patch) | |
| tree | 5c691241355c943a3c68ddb06b8cf8c60aa11319 /srcs/phpmyadmin/url.php | |
| parent | 7e0d85db834d6351ed85d01e5126ac31dc510b86 (diff) | |
| download | ft_server-04d6d5ca99ebfd1cebb8ce06618fb3811fc1a8aa.tar.gz ft_server-04d6d5ca99ebfd1cebb8ce06618fb3811fc1a8aa.tar.bz2 ft_server-04d6d5ca99ebfd1cebb8ce06618fb3811fc1a8aa.zip | |
phpmyadmin working
Diffstat (limited to 'srcs/phpmyadmin/url.php')
| -rw-r--r-- | srcs/phpmyadmin/url.php | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/srcs/phpmyadmin/url.php b/srcs/phpmyadmin/url.php new file mode 100644 index 0000000..4c9e0f0 --- /dev/null +++ b/srcs/phpmyadmin/url.php @@ -0,0 +1,52 @@ +<?php +/* vim: set expandtab sw=4 ts=4 sts=4: */ +/** + * URL redirector to avoid leaking Referer with some sensitive information. + * + * @package PhpMyAdmin + */ +declare(strict_types=1); + +use PhpMyAdmin\Core; +use PhpMyAdmin\Response; +use PhpMyAdmin\Sanitize; +use PhpMyAdmin\DatabaseInterface; + +if (! defined('ROOT_PATH')) { + define('ROOT_PATH', __DIR__ . DIRECTORY_SEPARATOR); +} + +/** + * Gets core libraries and defines some variables + */ +define('PMA_MINIMUM_COMMON', true); +require_once ROOT_PATH . 'libraries/common.inc.php'; + +// Load database service because services.yaml is not available here +$containerBuilder->set(DatabaseInterface::class, DatabaseInterface::load()); + +// Only output the http headers +$response = Response::getInstance(); +$response->getHeader()->sendHttpHeaders(); +$response->disable(); + +if (! Core::isValid($_GET['url']) + || ! preg_match('/^https:\/\/[^\n\r]*$/', $_GET['url']) + || ! Core::isAllowedDomain($_GET['url']) +) { + Core::sendHeaderLocation('./'); +} else { + // JavaScript redirection is necessary. Because if header() is used + // then web browser sometimes does not change the HTTP_REFERER + // field and so with old URL as Referer, token also goes to + // external site. + echo "<script type='text/javascript'> + window.onload=function(){ + window.location='" , Sanitize::escapeJsString($_GET['url']) , "'; + } + </script>"; + // Display redirecting msg on screen. + // Do not display the value of $_GET['url'] to avoid showing injected content + echo __('Taking you to the target site.'); +} +die(); |
