class ChildController in Bakery Single Sign-On System 8.2
Hierarchy
- class \Drupal\Core\Controller\ControllerBase implements ContainerInjectionInterface uses LoggerChannelTrait, MessengerTrait, LinkGeneratorTrait, RedirectDestinationTrait, UrlGeneratorTrait, StringTranslationTrait
- class \Drupal\bakery\Controller\ChildController
Expanded class hierarchy of ChildController
File
- src/
Controller/ ChildController.php, line 14
Namespace
Drupal\bakery\ControllerView source
class ChildController extends ControllerBase {
/**
* @var \Drupal\bakery\BakeryService
*/
protected $bakeryService;
/**
* @var \Drupal\bakery\Kitchen
*/
protected $kitchen;
/**
* Initialize bakery service.
*
* @param \Drupal\bakery\BakeryService $bakeryService
* For bakery service.
* @param \Drupal\bakery\Kitchen $kitchen
* Kitchen service to work on all those cookies.
*/
public function __construct(BakeryService $bakeryService, Kitchen $kitchen) {
$this->bakeryService = $bakeryService;
$this->kitchen = $kitchen;
}
/**
* When this controller is created, it will get the bakery.bakery_service.
*
* @param \Symfony\Component\DependencyInjection\ContainerInterface $container
* For getting Bakery service.
*
* @return static
*/
public static function create(ContainerInterface $container) {
return new static($container
->get('bakery.bakery_service'), $container
->get('bakery.kitchen'));
}
/**
* Validate update request.
*/
public function tasteStroopwafelCookie(Request $request) {
$type = 'stroopwafel';
$post = $request->request;
if (!$post
->has($type)) {
return AccessResult::forbidden();
}
$cookie = $this->kitchen
->tasteData($post
->get($type), $type);
if ($cookie === FALSE) {
return AccessResult::forbidden();
}
$request->attributes
->set('bakery', $cookie);
return AccessResult::allowed();
}
/**
* Menu callback, invoked on the child.
*/
public function eatStroopwafelCookie(Request $request) {
// The session got set during validation.
$stroopwafel = Stroopwafel::fromData($request->attributes
->get('bakery'));
$request->attributes
->remove('bakery');
$response = new Response();
// Check if the user exists.
/** @var \Drupal\user\UserInterface[] $account */
$account = $this
->entityTypeManager()
->getStorage('user')
->loadByProperties([
'init' => $this->kitchen
->generateInitField($stroopwafel
->getUid()),
]);
if (empty($account)) {
// User not present.
$response
->setContent(t('Account not found on @child.', [
'@child' => $this
->config('system.site')
->get('name'),
]));
}
else {
$account = reset($account);
$response->headers
->set('X-Drupal-bakery-UID', $account
->id());
// If profile field is enabled we manually save profile fields along.
$field_data = $stroopwafel
->getData();
$this->bakeryService
->updateUserFields($account, $field_data);
if ($account
->save() != SAVED_UPDATED) {
$this
->getLogger('bakery')
->error('User update from name %name_old to %name_new, mail %mail_old to %mail_new failed.', [
'%name_old' => $account
->getAccountName(),
'%name_new' => $field_data['name'],
'%mail_old' => $account
->getEmail(),
'%mail_new' => $field_data['mail'],
]);
$response
->setContent(t('There was a problem updating your account on @child. Please contact the administrator.', [
'@child' => $this
->config('system.site')
->get('name'),
]));
$response
->setStatusCode(Response::HTTP_CONFLICT);
}
else {
$this
->getLogger('bakery')
->notice('user updated name %name_old to %name_new, mail %mail_old to %mail_new.', [
'%name_old' => $account
->getAccountName(),
'%name_new' => $field_data['name'],
'%mail_old' => $account
->getEmail(),
'%mail_new' => $field_data['mail'],
]);
$response
->setContent(t('Successfully updated account on @child.', [
'@child' => $this
->config('system.site')
->get('name'),
]));
}
}
return $response;
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
ChildController:: |
protected | property | ||
ChildController:: |
protected | property | ||
ChildController:: |
public static | function |
When this controller is created, it will get the bakery.bakery_service. Overrides ControllerBase:: |
|
ChildController:: |
public | function | Menu callback, invoked on the child. | |
ChildController:: |
public | function | Validate update request. | |
ChildController:: |
public | function | Initialize bakery service. | |
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 manager. | |
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 manager service. | |
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. Overrides UrlGeneratorTrait:: |
|
ControllerBase:: |
protected | function | Returns the state storage service. | |
LinkGeneratorTrait:: |
protected | property | The link generator. | 1 |
LinkGeneratorTrait:: |
protected | function | Returns the link generator. | |
LinkGeneratorTrait:: |
protected | function | Renders a link to a route given a route name and its parameters. | |
LinkGeneratorTrait:: |
public | function | Sets the link generator 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. | 29 |
MessengerTrait:: |
public | function | Gets the messenger. | 29 |
MessengerTrait:: |
public | function | Sets the messenger. | |
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. | 1 |
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. | |
UrlGeneratorTrait:: |
protected | property | The url generator. | |
UrlGeneratorTrait:: |
protected | function | Returns the URL generator service. | |
UrlGeneratorTrait:: |
public | function | Sets the URL generator service. | |
UrlGeneratorTrait:: |
protected | function | Generates a URL or path for a specific route based on the given parameters. |