404

[ Avaa Bypassed ]




Upload:

Command:

elspacio@18.116.63.107: ~ $
<?php

/*
 * This file is part of the Symfony package.
 *
 * (c) Fabien Potencier <fabien@symfony.com>
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */

namespace Symfony\Component\HttpKernel;

use Symfony\Component\HttpFoundation\Request;

/**
 * Signs URIs.
 *
 * @author Fabien Potencier <fabien@symfony.com>
 */
class UriSigner
{
    private string $secret;
    private string $parameter;

    /**
     * @param string $secret    A secret
     * @param string $parameter Query string parameter to use
     */
    public function __construct(#[\SensitiveParameter] string $secret, string $parameter = '_hash')
    {
        $this->secret = $secret;
        $this->parameter = $parameter;
    }

    /**
     * Signs a URI.
     *
     * The given URI is signed by adding the query string parameter
     * which value depends on the URI and the secret.
     */
    public function sign(string $uri): string
    {
        $url = parse_url($uri);
        $params = [];

        if (isset($url['query'])) {
            parse_str($url['query'], $params);
        }

        $uri = $this->buildUrl($url, $params);
        $params[$this->parameter] = $this->computeHash($uri);

        return $this->buildUrl($url, $params);
    }

    /**
     * Checks that a URI contains the correct hash.
     */
    public function check(string $uri): bool
    {
        $url = parse_url($uri);
        $params = [];

        if (isset($url['query'])) {
            parse_str($url['query'], $params);
        }

        if (empty($params[$this->parameter])) {
            return false;
        }

        $hash = $params[$this->parameter];
        unset($params[$this->parameter]);

        return hash_equals($this->computeHash($this->buildUrl($url, $params)), $hash);
    }

    public function checkRequest(Request $request): bool
    {
        $qs = ($qs = $request->server->get('QUERY_STRING')) ? '?'.$qs : '';

        // we cannot use $request->getUri() here as we want to work with the original URI (no query string reordering)
        return $this->check($request->getSchemeAndHttpHost().$request->getBaseUrl().$request->getPathInfo().$qs);
    }

    private function computeHash(string $uri): string
    {
        return base64_encode(hash_hmac('sha256', $uri, $this->secret, true));
    }

    private function buildUrl(array $url, array $params = []): string
    {
        ksort($params, \SORT_STRING);
        $url['query'] = http_build_query($params, '', '&');

        $scheme = isset($url['scheme']) ? $url['scheme'].'://' : '';
        $host = $url['host'] ?? '';
        $port = isset($url['port']) ? ':'.$url['port'] : '';
        $user = $url['user'] ?? '';
        $pass = isset($url['pass']) ? ':'.$url['pass'] : '';
        $pass = ($user || $pass) ? "$pass@" : '';
        $path = $url['path'] ?? '';
        $query = $url['query'] ? '?'.$url['query'] : '';
        $fragment = isset($url['fragment']) ? '#'.$url['fragment'] : '';

        return $scheme.$user.$pass.$host.$port.$path.$query.$fragment;
    }
}

Filemanager

Name Type Size Permission Actions
Attribute Folder 0755
Bundle Folder 0755
CacheClearer Folder 0755
CacheWarmer Folder 0755
Config Folder 0755
Controller Folder 0755
ControllerMetadata Folder 0755
DataCollector Folder 0755
Debug Folder 0755
DependencyInjection Folder 0755
Event Folder 0755
EventListener Folder 0755
Exception Folder 0755
Fragment Folder 0755
HttpCache Folder 0755
Log Folder 0755
Profiler Folder 0755
Resources Folder 0755
CHANGELOG.md File 18.19 KB 0644
HttpClientKernel.php File 3.84 KB 0644
HttpKernel.php File 10.43 KB 0644
HttpKernelBrowser.php File 5.71 KB 0644
HttpKernelInterface.php File 1.43 KB 0644
Kernel.php File 27.27 KB 0644
KernelEvents.php File 4.04 KB 0644
KernelInterface.php File 3.54 KB 0644
LICENSE File 1.04 KB 0644
README.md File 676 B 0644
RebootableInterface.php File 787 B 0644
TerminableInterface.php File 910 B 0644
UriSigner.php File 3.03 KB 0644
composer.json File 2.46 KB 0644