class Oauth2Token in Simple OAuth (OAuth2) & OpenID Connect 5.x
Same name in this branch
- 5.x src/Controller/Oauth2Token.php \Drupal\simple_oauth\Controller\Oauth2Token
- 5.x src/Entity/Oauth2Token.php \Drupal\simple_oauth\Entity\Oauth2Token
Same name and namespace in other branches
- 8.4 src/Controller/Oauth2Token.php \Drupal\simple_oauth\Controller\Oauth2Token
- 8.2 src/Controller/Oauth2Token.php \Drupal\simple_oauth\Controller\Oauth2Token
- 8.3 src/Controller/Oauth2Token.php \Drupal\simple_oauth\Controller\Oauth2Token
Hierarchy
- class \Drupal\Core\Controller\ControllerBase implements ContainerInjectionInterface uses LoggerChannelTrait, MessengerTrait, RedirectDestinationTrait, StringTranslationTrait
- class \Drupal\simple_oauth\Controller\Oauth2Token
Expanded class hierarchy of Oauth2Token
File
- src/
Controller/ Oauth2Token.php, line 13
Namespace
Drupal\simple_oauth\ControllerView source
class Oauth2Token extends ControllerBase {
/**
* @var \Drupal\simple_oauth\Plugin\Oauth2GrantManagerInterface
*/
protected $grantManager;
/**
* Oauth2Token constructor.
*
* @param \Drupal\simple_oauth\Plugin\Oauth2GrantManagerInterface $grant_manager
* The grant manager.
*/
public function __construct(Oauth2GrantManagerInterface $grant_manager) {
$this->grantManager = $grant_manager;
}
/**
* {@inheritdoc}
*/
public static function create(ContainerInterface $container) {
return new static($container
->get('plugin.manager.oauth2_grant.processor'));
}
/**
* Processes POST requests to /oauth/token.
*/
public function token(ServerRequestInterface $request) {
// Extract the grant type from the request body.
$body = $request
->getParsedBody();
$grant_type_id = !empty($body['grant_type']) ? $body['grant_type'] : 'implicit';
$client_drupal_entity = NULL;
if (!empty($body['client_id'])) {
$consumer_storage = $this
->entityTypeManager()
->getStorage('consumer');
$client_drupal_entities = $consumer_storage
->loadByProperties([
'uuid' => $body['client_id'],
]);
if (empty($client_drupal_entities)) {
return OAuthServerException::invalidClient($request)
->generateHttpResponse(new Response());
}
$client_drupal_entity = reset($client_drupal_entities);
}
// Get the auth server object from that uses the League library.
try {
// Respond to the incoming request and fill in the response.
$auth_server = $this->grantManager
->getAuthorizationServer($grant_type_id, $client_drupal_entity);
$response = $this
->handleToken($request, $auth_server);
} catch (OAuthServerException $exception) {
watchdog_exception('simple_oauth', $exception);
$response = $exception
->generateHttpResponse(new Response());
}
return $response;
}
/**
* Handles the token processing.
*
* @param \Psr\Http\Message\ServerRequestInterface $psr7_request
* The psr request.
* @param \League\OAuth2\Server\AuthorizationServer $auth_server
* The authorization server.
*
* @return \Psr\Http\Message\ResponseInterface
* The response.
*
* @throws \League\OAuth2\Server\Exception\OAuthServerException
*/
protected function handleToken(ServerRequestInterface $psr7_request, AuthorizationServer $auth_server) {
// Instantiate a new PSR-7 response object so the library can fill it.
return $auth_server
->respondToAccessTokenRequest($psr7_request, new Response());
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
ControllerBase:: |
protected | property | The configuration factory. | |
ControllerBase:: |
protected | property | The current user service. | 1 |
ControllerBase:: |
protected | property | The entity form builder. | |
ControllerBase:: |
protected | property | The entity type manager. | |
ControllerBase:: |
protected | property | The form builder. | 2 |
ControllerBase:: |
protected | property | The key-value storage. | 1 |
ControllerBase:: |
protected | property | The language manager. | 1 |
ControllerBase:: |
protected | property | The module handler. | 2 |
ControllerBase:: |
protected | property | The state service. | |
ControllerBase:: |
protected | function | Returns the requested cache bin. | |
ControllerBase:: |
protected | function | Retrieves a configuration object. | |
ControllerBase:: |
private | function | Returns the service container. | |
ControllerBase:: |
protected | function | Returns the current user. | 1 |
ControllerBase:: |
protected | function | Retrieves the entity form builder. | |
ControllerBase:: |
protected | function | Retrieves the entity type manager. | |
ControllerBase:: |
protected | function | Returns the form builder service. | 2 |
ControllerBase:: |
protected | function | Returns a key/value storage collection. | 1 |
ControllerBase:: |
protected | function | Returns the language manager service. | 1 |
ControllerBase:: |
protected | function | Returns the module handler. | 2 |
ControllerBase:: |
protected | function | Returns a redirect response object for the specified route. | |
ControllerBase:: |
protected | function | Returns the state storage service. | |
LoggerChannelTrait:: |
protected | property | The logger channel factory service. | |
LoggerChannelTrait:: |
protected | function | Gets the logger for a specific channel. | |
LoggerChannelTrait:: |
public | function | Injects the logger channel factory. | |
MessengerTrait:: |
protected | property | The messenger. | 27 |
MessengerTrait:: |
public | function | Gets the messenger. | 27 |
MessengerTrait:: |
public | function | Sets the messenger. | |
Oauth2Token:: |
protected | property | ||
Oauth2Token:: |
public static | function |
Instantiates a new instance of this class. Overrides ControllerBase:: |
|
Oauth2Token:: |
protected | function | Handles the token processing. | |
Oauth2Token:: |
public | function | Processes POST requests to /oauth/token. | |
Oauth2Token:: |
public | function | Oauth2Token constructor. | |
RedirectDestinationTrait:: |
protected | property | The redirect destination service. | 1 |
RedirectDestinationTrait:: |
protected | function | Prepares a 'destination' URL query parameter for use with \Drupal\Core\Url. | |
RedirectDestinationTrait:: |
protected | function | Returns the redirect destination service. | |
RedirectDestinationTrait:: |
public | function | Sets the redirect destination service. | |
StringTranslationTrait:: |
protected | property | The string translation service. | 4 |
StringTranslationTrait:: |
protected | function | Formats a string containing a count of items. | |
StringTranslationTrait:: |
protected | function | Returns the number of plurals supported by a given language. | |
StringTranslationTrait:: |
protected | function | Gets the string translation service. | |
StringTranslationTrait:: |
public | function | Sets the string translation service to use. | 2 |
StringTranslationTrait:: |
protected | function | Translates a string to the current language or to a given language. |