HEX
Server: Apache
System: Linux p3plzcpnl506847.prod.phx3.secureserver.net 4.18.0-553.54.1.lve.el8.x86_64 #1 SMP Wed Jun 4 13:01:13 UTC 2025 x86_64
User: slfopp7cb1df (5698090)
PHP: 8.1.34
Disabled: NONE
Upload Files
File: //home/slfopp7cb1df/www/home/wp-content/plugins/mailoptin/src/authifly/src/HttpClient/Util.php
<?php
/*!
* Authifly
* https://hybridauth.github.io | https://github.com/mailoptin/authifly
*  (c) 2017 Hybridauth authors | https://hybridauth.github.io/license.html
*/

namespace Authifly\HttpClient;

use Authifly\Data;

/**
 * HttpClient\Util home to a number of utility functions.
 */
class Util
{
    /**
    * Redirect handler.
    *
    * @var callable|null
    */
    protected static $redirectHandler;

    /**
    * Exit handler.
    *
    * @var callable|null
    */
    protected static $exitHandler;

   /**
    * Redirect to a given URL.
    *
    * In case your application need to perform certain required actions before Authifly redirect users
    * to IDPs websites, the default behaviour can be altered in one of two ways:
    *   If callable $redirectHandler is defined, it will be called instead.
    *   If callable $exitHandler is defined, it will be called instead of exit().
    *
    * @param string $url
    */
    public static function redirect($url)
    {
        if (static::$redirectHandler) {
            return call_user_func(static::$redirectHandler, $url);
        }

        header(sprintf('Location: %s', $url));

        if (static::$exitHandler) {
            return call_user_func(static::$exitHandler);
        }

        exit(1);
    }

    /**
    * Redirect handler to which the regular redirect() will yield the action of redirecting users.
    *
    * @param callable $callback
    */
    public static function setRedirectHandler($callback)
    {
        self::$redirectHandler = $callback;
    }

    /**
    * Exit handler will be called instead of regular exit() when calling Util::redirect() method.
    *
    * @param callable $callback
    */
    public static function setExitHandler($callback)
    {
        self::$exitHandler = $callback;
    }

    /**
    * Returns the Current URL.
    *
    * @param bool $requestUri TRUE to use $_SERVER['REQUEST_URI'], FALSE for $_SERVER['PHP_SELF']
    *
    * @return string
    */
    public static function getCurrentUrl($requestUri = false)
    {
        $collection = new Data\Collection($_SERVER);

        $protocol = 'http://';

        if (
            (
                $collection->get('HTTPS') && $collection->get('HTTPS') !== 'off'
            ) ||
                $collection->get('HTTP_X_FORWARDED_PROTO') === 'https'
        ) {
            $protocol = 'https://';
        }

        return $protocol.
               $collection->get('HTTP_HOST').
               $collection->get($requestUri ? 'REQUEST_URI' : 'PHP_SELF');
    }
}