Вход Регистрация
Файл: vendor/lusitanian/oauth/src/OAuth/Common/Storage/SymfonySession.php
Строк: 149
<?php
namespace OAuthCommonStorage;

use 
OAuthCommonTokenTokenInterface;
use 
OAuthCommonStorageExceptionTokenNotFoundException;
use 
SymfonyComponentHttpFoundationSessionSessionInterface;

class 
SymfonySession implements TokenStorageInterface
{
    private 
$session;
    private 
$sessionVariableName;

    public function 
__construct(SessionInterface $session$startSession true$sessionVariableName 'lusitanian_oauth_token')
    {
        
$this->session $session;
        
$this->sessionVariableName $sessionVariableName;

        if (!
$this->session->has($sessionVariableName))
        {
            
$this->session->set($sessionVariableName, array());
        }
    }

    
/**
     * @return OAuthCommonTokenTokenInterface
     * @throws TokenNotFoundException
     */
    
public function retrieveAccessToken($service)
    {
        if (
$this->hasAccessToken($service)) {
            
// get from session
            
$tokens $this->session->get($this->sessionVariableName);

            
// one item
            
return $tokens[$service];
        }

        throw new 
TokenNotFoundException('Token not found in session, are you sure you stored it?');
    }

    public function 
storeAccessToken($serviceTokenInterface $token)
    {
        
// get previously saved tokens
        
$tokens $this->session->get($this->sessionVariableName);

        if (
is_array($tokens))
        {
            
// add to array
            
$tokens[$service] = $token;
        }
        else
        {
            
// new array
            
$tokens = array(
                
$service => $token,
            );
        }

        
// save
        
$this->session->set($this->sessionVariableName$tokens);

        
// allow chaining
        
return $this;
    }

    
/**
    * @return bool
    */
    
public function hasAccessToken($service)
    {
        
// get from session
        
$tokens $this->session->get($this->sessionVariableName);

        return 
is_array($tokens) &&
               isset(
$tokens[$service]) &&
               
$tokens[$service] instanceof TokenInterface;
    }

    
/**
     * Delete the user's token. Aka, log out.
     */
    
public function clearToken($service)
    {
        
// get previously saved tokens
        
$tokens $this->session->get($this->sessionVariableName);

        if (
array_key_exists($service$tokens)) {
            unset(
$tokens[$service]);
        }

        
// Replace the stored tokens array
        
$this->session->set($this->sessionVariableName$tokens);

        
// allow chaining
        
return $this;
    }

    
/**
     * Delete *ALL* user tokens. Use with care. Most of the time you will likely
     * want to use clearToken() instead.
     */
    
public function clearAllTokens()
    {
        
$this->session->remove($this->sessionVariableName);

        
// allow chaining
        
return $this;
    }

    
/**
     * @return Session
     */
    
public function getSession()
    {
        return 
$this->session;
    }
}
Онлайн: 1
Реклама