Spamworldpro Mini Shell
Spamworldpro


Server : Apache
System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64
User : corals ( 1002)
PHP Version : 7.4.33
Disable Function : exec,passthru,shell_exec,system
Directory :  /home/corals/mautic.corals.io/vendor/kamermans/guzzle-oauth2-subscriber/src/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : /home/corals/mautic.corals.io/vendor/kamermans/guzzle-oauth2-subscriber/src/OAuth2Handler.php
<?php

namespace kamermans\OAuth2;

use GuzzleHttp\Exception\BadResponseException;

/**
 * OAuth2 plugin.
 *
 * @link http://tools.ietf.org/html/rfc6749 OAuth2 specification
 */
class OAuth2Handler
{
    /**
     * The grant type implementation used to acquire access tokens.
     *
     * @var GrantType\GrantTypeInterface
     */
    protected $grantType;

    /**
     * The grant type implementation used to refresh access tokens.
     *
     * @var GrantType\GrantTypeInterface
     */
    protected $refreshTokenGrantType;

    /**
     * The service in charge of including client credentials into requests.
     * to get an access token.
     *
     * @var Signer\ClientCredentials\SignerInterface
     */
    protected $clientCredentialsSigner;

    /**
     * The service in charge of including the access token into requests.
     *
     * @var Signer\AccessToken\SignerInterface
     */
    protected $accessTokenSigner;

    /**
     * The object including access token.
     *
     * @var Token\TokenInterface
     */
    protected $rawToken;

    /**
     * The service in charge of persisting access token.
     *
     * @var Persistence\TokenPersistenceInterface
     */
    protected $tokenPersistence;

    /**
     * Callable used to instantiate a blank TokenInterface instance.
     * Called with no arguments, must return a newly constructed class implementing TokenInterface
     *
     * @var callable
     */
    protected $newTokenSupplier;

    /**
     * Factory responsible for parsing server token response
     *
     * @var callable
     */
    protected $tokenFactory;

    /**
     * @param GrantType\GrantTypeInterface                  $grantType
     * @param GrantType\GrantTypeInterface|null             $refreshTokenGrantType
     * @param Signer\ClientCredentials\SignerInterface|null $clientCredentialsSigner
     * @param Signer\AccessToken\SignerInterface|null       $accessTokenSigner
     */
    public function __construct(
                    GrantType\GrantTypeInterface $grantType,
                    GrantType\GrantTypeInterface $refreshTokenGrantType = null,
                    Signer\ClientCredentials\SignerInterface $clientCredentialsSigner = null,
                    Signer\AccessToken\SignerInterface $accessTokenSigner = null
    ) {
        $this->grantType = $grantType;
        $this->refreshTokenGrantType = $refreshTokenGrantType;
        $this->clientCredentialsSigner = $clientCredentialsSigner;
        $this->accessTokenSigner = $accessTokenSigner;

        if ($this->clientCredentialsSigner === null) {
            $this->clientCredentialsSigner = new Signer\ClientCredentials\BasicAuth();
        }

        if ($this->accessTokenSigner === null) {
            $this->accessTokenSigner = new Signer\AccessToken\BearerAuth();
        }

        $this->tokenPersistence = new Persistence\NullTokenPersistence();
        $this->tokenFactory = new Token\RawTokenFactory();
        $this->newTokenSupplier = function(){ return new Token\RawToken(); };
    }

    /**
     * @param Signer\ClientCredentials\SignerInterface $signer
     *
     * @return self
     */
    public function setClientCredentialsSigner(Signer\ClientCredentials\SignerInterface $signer)
    {
        $this->clientCredentialsSigner = $signer;

        return $this;
    }

    /**
     * @param Signer\AccessToken\SignerInterface $signer
     *
     * @return self
     */
    public function setAccessTokenSigner(Signer\AccessToken\SignerInterface $signer)
    {
        $this->accessTokenSigner = $signer;

        return $this;
    }

    /**
     * @param Persistence\TokenPersistenceInterface $tokenPersistence
     *
     * @return self
     */
    public function setTokenPersistence(Persistence\TokenPersistenceInterface $tokenPersistence)
    {
        $this->tokenPersistence = $tokenPersistence;

        return $this;
    }

    /**
     * @param callable $tokenFactory
     *
     * @return self
     */
    public function setTokenFactory(callable $tokenFactory)
    {
        $this->tokenFactory = $tokenFactory;

        return $this;
    }

    /**
     * @param callable $tokenSupplier the new token supplier
     *
     * @return self
     */
    public function setNewTokenSupplier(callable $tokenSupplier) {
        $this->newTokenSupplier = $tokenSupplier;

        return $this;
    }

    /**
     * Manually set the access token.
     *
     * @param string|array|Token\TokenInterface $token An array of token data, an access token string, or a TokenInterface object
     *
     * @return self
     */
    public function setAccessToken($token)
    {
        if ($token instanceof Token\TokenInterface) {
            $this->rawToken = $token;
        } else {
            $this->rawToken = is_array($token) ?
                $this->tokenFactory($token) :
                $this->tokenFactory(['access_token' => $token]);
        }

        if ($this->rawToken === null) {
            throw new Exception\OAuth2Exception("setAccessToken() takes a string, array or TokenInterface object");
        }

        return $this;
    }

    /**
     * Forcefully delete an access token, even if it's valid
     */
    public function deleteAccessToken()
    {
        $this->rawToken = null;
        $this->tokenPersistence->deleteToken();
    }

    /**
     * Get a valid access token.
     *
     * @return string|null A valid access token or null if unable to get one
     *
     * @throws Exception\AccessTokenRequestException while trying to run `requestNewAccessToken` method
     */
    public function getAccessToken()
    {
        // If token is not set try to get it from the persistent storage.
        if ($this->rawToken === null) {
            $this->rawToken = $this->tokenPersistence->restoreToken(call_user_func($this->newTokenSupplier));
        }

        // If token is not set or expired then try to acquire a new one...
        if ($this->rawToken === null || $this->rawToken->isExpired()) {

            // Hydrate `rawToken` with a new access token
            $this->requestNewAccessToken();

            // ...and save it.
            if ($this->rawToken) {
                $this->tokenPersistence->saveToken($this->rawToken);
            }
        }

        return $this->rawToken? $this->rawToken->getAccessToken(): null;
    }

    /**
     * Gets the current Token object
     *
     * @return Token\TokenInterface|null
     */
    public function getRawToken()
    {
        return $this->rawToken;
    }

    protected function signRequest($request)
    {
        $accessToken = $this->getAccessToken();

        if ($accessToken === null) {
            return $request;
        }

        return $this->accessTokenSigner->sign($request, $accessToken);
    }

    /**
     * Helper method for (callable)tokenFactory
     *
     * @return Token\TokenInterface
     */
    protected function tokenFactory()
    {
        return call_user_func_array($this->tokenFactory, func_get_args());
    }

    /**
     * Acquire a new access token from the server.
     *
     * @throws Exception\AccessTokenRequestException
     */
    protected function requestNewAccessToken()
    {
        if ($this->refreshTokenGrantType && $this->rawToken && $this->rawToken->getRefreshToken()) {
            try {
                // Get an access token using the stored refresh token.
                $rawData = $this->refreshTokenGrantType->getRawData(
                    $this->clientCredentialsSigner,
                    $this->rawToken->getRefreshToken()
                );

                $this->rawToken = $this->tokenFactory($rawData, $this->rawToken);

                return;
            } catch (BadResponseException $e) {
                // If the refresh token is invalid, then clear the entire token information.
                $this->rawToken = null;
            }
        }

        if ($this->grantType === null) {
            throw new Exception\ReauthorizationException('You must specify a grantType class to request an access token');
        }

        try {
            // Request an access token using the main grant type.
            $rawData = $this->grantType->getRawData($this->clientCredentialsSigner);

            $this->rawToken = $this->tokenFactory($rawData);
        } catch (BadResponseException $e) {
            throw new Exception\AccessTokenRequestException('Unable to request a new access token: ' . $e->getMessage(), $e);
        }
    }
}

Spamworldpro Mini