class CasPreRegisterEvent in CAS 8
Same name and namespace in other branches
- 2.x src/Event/CasPreRegisterEvent.php \Drupal\cas\Event\CasPreRegisterEvent
Class CasPreRegisterEvent.
The CAS module dispatches this event during the authentication process just before a user is automatically registered to Drupal if:
- Automatic user registration is enabled in the CAS module settings.
- No existing Drupal account can be found that's associated with the CAS username of the user attempting authentication.
Subscribers to this event can:
- Prevent a Drupal account from being created for this user (thereby also preventing the user from logging in).
- Change the username that will be assigned to the Drupal account. By default it is the same as the CAS username.
- Set properties on the user account that will be created, like user roles or a custom first name field (for example by populating it with data from the CAS attributes available in $casPropertyBag).
Any CAS attributes will be available via the $casPropertyBag data object.
Hierarchy
- class \Drupal\cas\Event\CasPreRegisterEvent extends \Symfony\Component\EventDispatcher\Event
Expanded class hierarchy of CasPreRegisterEvent
4 files declare their use of CasPreRegisterEvent
- CasAutoAssignRolesSubscriber.php in src/
Subscriber/ CasAutoAssignRolesSubscriber.php - CasTestSubscriber.php in tests/
modules/ cas_test/ src/ CasTestSubscriber.php - CasUserManager.php in src/
Service/ CasUserManager.php - CasUserManagerTest.php in tests/
src/ Unit/ Service/ CasUserManagerTest.php
File
- src/
Event/ CasPreRegisterEvent.php, line 28
Namespace
Drupal\cas\EventView source
class CasPreRegisterEvent extends Event {
/**
* The user information returned from the CAS server.
*
* @var \Drupal\cas\CasPropertyBag
*/
protected $casPropertyBag;
/**
* Determines if this user will be allowed to auto-register or not.
*
* @var bool
*/
protected $allowAutomaticRegistration = TRUE;
/**
* The username that will be assigned to the Drupal user account.
*
* By default this will be populated with the CAS username.
*
* @var string
*/
protected $drupalUsername;
/**
* An array of property values to assign to the user account on registration.
*
* @var array
*/
protected $propertyValues = [];
/**
* Contructor.
*
* @param \Drupal\cas\CasPropertyBag $cas_property_bag
* The CasPropertyBag for context.
*/
public function __construct(CasPropertyBag $cas_property_bag) {
$this->casPropertyBag = $cas_property_bag;
$this->drupalUsername = $cas_property_bag
->getUsername();
}
/**
* Return the CasPropertyBag of the event.
*
* @return \Drupal\cas\CasPropertyBag
* The $casPropertyBag property.
*/
public function getCasPropertyBag() {
return $this->casPropertyBag;
}
/**
* Retrieve the username that will be assigned to the Drupal account.
*
* @return string
* The username.
*/
public function getDrupalUsername() {
return $this->drupalUsername;
}
/**
* Assign a different username to the Drupal account that is to be registered.
*
* @param string $username
* The username.
*/
public function setDrupalUsername($username) {
$this->drupalUsername = $username;
}
/**
* Sets the allow auto registration proprety.
*
* @param bool $allow_automatic_registration
* TRUE to allow auto registration, FALSE to deny it.
*/
public function setAllowAutomaticRegistration($allow_automatic_registration) {
if ($allow_automatic_registration) {
$this->allowAutomaticRegistration = TRUE;
}
else {
$this->allowAutomaticRegistration = FALSE;
}
}
/**
* Return if this user is allowed to be auto-registered or not.
*
* @return bool
* TRUE if the user is allowed to be registered, FALSE otherwise.
*/
public function getAllowAutomaticRegistration() {
return $this->allowAutomaticRegistration;
}
/**
* Getter for propertyValues.
*
* @return array
* The user property values.
*/
public function getPropertyValues() {
return $this->propertyValues;
}
/**
* Set a single property value for the user entity on registration.
*
* @param string $property
* The user entity property to set.
* @param mixed $value
* The value of the property.
*/
public function setPropertyValue($property, $value) {
$this->propertyValues[$property] = $value;
}
/**
* Set an array of property values for the user entity on registration.
*
* @param array $property_values
* The property values to set with each key corresponding to the property.
*/
public function setPropertyValues(array $property_values) {
$this->propertyValues = array_merge($this->propertyValues, $property_values);
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
CasPreRegisterEvent:: |
protected | property | Determines if this user will be allowed to auto-register or not. | |
CasPreRegisterEvent:: |
protected | property | The user information returned from the CAS server. | |
CasPreRegisterEvent:: |
protected | property | The username that will be assigned to the Drupal user account. | |
CasPreRegisterEvent:: |
protected | property | An array of property values to assign to the user account on registration. | |
CasPreRegisterEvent:: |
public | function | Return if this user is allowed to be auto-registered or not. | |
CasPreRegisterEvent:: |
public | function | Return the CasPropertyBag of the event. | |
CasPreRegisterEvent:: |
public | function | Retrieve the username that will be assigned to the Drupal account. | |
CasPreRegisterEvent:: |
public | function | Getter for propertyValues. | |
CasPreRegisterEvent:: |
public | function | Sets the allow auto registration proprety. | |
CasPreRegisterEvent:: |
public | function | Assign a different username to the Drupal account that is to be registered. | |
CasPreRegisterEvent:: |
public | function | Set a single property value for the user entity on registration. | |
CasPreRegisterEvent:: |
public | function | Set an array of property values for the user entity on registration. | |
CasPreRegisterEvent:: |
public | function | Contructor. |