class OgChangeMultipleRolesFormBase in Organic groups 8
Base class for forms that act on multiple roles.
Hierarchy
- class \Drupal\Core\Form\FormBase implements ContainerInjectionInterface, FormInterface uses DependencySerializationTrait, LoggerChannelTrait, MessengerTrait, LinkGeneratorTrait, RedirectDestinationTrait, UrlGeneratorTrait, StringTranslationTrait
- class \Drupal\og\Form\OgChangeMultipleRolesFormBase
Expanded class hierarchy of OgChangeMultipleRolesFormBase
File
- src/
Form/ OgChangeMultipleRolesFormBase.php, line 20
Namespace
Drupal\og\FormView source
class OgChangeMultipleRolesFormBase extends FormBase {
/**
* The action plugin ID for which this is the confirmation form.
*
* @var string
*/
protected $pluginId;
/**
* The memberships on which roles should be changed.
*
* @var \Drupal\og\OgMembershipInterface[]
*/
protected $memberships = [];
/**
* The tempstore factory.
*
* @var \Drupal\Core\TempStore\PrivateTempStoreFactory
*/
protected $tempStoreFactory;
/**
* The temporary storage for the current user.
*
* @var \Drupal\Core\TempStore\PrivateTempStore
*/
protected $tempStore;
/**
* The OG access service.
*
* @var \Drupal\og\OgAccessInterface
*/
protected $ogAccess;
/**
* Constructs a OgChangeMultipleRolesFormbase object.
*
* @param \Drupal\Core\TempStore\PrivateTempStoreFactory $temp_store_factory
* The tempstore factory.
* @param \Drupal\og\OgAccessInterface $og_access
* The OG access service.
*/
public function __construct(PrivateTempStoreFactory $temp_store_factory, OgAccessInterface $og_access) {
$this->tempStoreFactory = $temp_store_factory;
$this->ogAccess = $og_access;
}
/**
* {@inheritdoc}
*/
public static function create(ContainerInterface $container) {
return new static($container
->get('tempstore.private'), $container
->get('og.access'));
}
/**
* {@inheritdoc}
*/
public function getFormId() {
return $this->pluginId . '_form';
}
/**
* {@inheritdoc}
*/
public function buildForm(array $form, FormStateInterface $form_state) {
$form['submit'] = [
'#type' => 'submit',
'#value' => $this
->t('Submit'),
];
return $form;
}
/**
* {@inheritdoc}
*/
public function submitForm(array &$form, FormStateInterface $form_state) {
$role_ids = array_keys($form_state
->getValue('roles'));
/** @var \Drupal\og\OgRoleInterface[] $roles */
$roles = OgRole::loadMultiple($role_ids);
foreach ($this
->getMemberships() as $membership) {
$changed = FALSE;
foreach ($roles as $role) {
$group = $membership
->getGroup();
if ($group
->getEntityTypeId() === $role
->getGroupType() && $group
->bundle() === $role
->getGroupBundle()) {
if ($membership
->hasRole($role
->id())) {
$changed = TRUE;
$membership
->revokeRole($role);
}
}
}
// Only save the membership if it has actually changed.
if ($changed) {
$membership
->save();
}
}
}
/**
* Controls access to the form.
*
* @param \Drupal\Core\Session\AccountInterface $account
* The account for which to check access.
*
* @return \Drupal\Core\Access\AccessResult
* The access result.
*/
public function access(AccountInterface $account) {
// Only grant access to the form if there are memberships to process, and if
// the user has permission to manage members on all the memberships.
$memberships = $this
->getMemberships();
$access = AccessResult::allowedIf(!empty($memberships));
while ($access
->isAllowed() && ($membership = array_shift($memberships))) {
$access = $this->ogAccess
->userAccess($membership
->getGroup(), 'manage members', $account);
}
return $access;
}
/**
* Returns the temporary storage for the current user.
*
* @return \Drupal\Core\TempStore\PrivateTempStore
* The temporary storage for the current user.
*/
protected function getTempStore() {
if (empty($this->tempStore)) {
$this->tempStore = $this->tempStoreFactory
->get($this->pluginId);
}
return $this->tempStore;
}
/**
* Returns an array of memberships on which to change roles.
*
* @return \Drupal\og\OgMembershipInterface[]
* The array of memberships.
*/
protected function getMemberships() {
if (empty($this->memberships)) {
$membership_ids = $this
->getTempStore()
->get('membership_ids');
if (!empty($membership_ids)) {
$this->memberships = OgMembership::loadMultiple($membership_ids);
}
}
return $this->memberships;
}
/**
* Returns an array of group types for which memberships are present.
*
* @return array
* An array of group types, each value an array with two keys:
* - entity_type_id: The entity type ID of the group type.
* - bundle_id: The bundle ID of the group type.
*/
protected function getGroupTypes() {
$group_types = [];
foreach ($this
->getMemberships() as $membership) {
$group = $membership
->getGroup();
$key = implode('-', [
$group
->getEntityTypeId(),
$group
->bundle(),
]);
$group_types[$key] = [
'entity_type_id' => $group
->getEntityTypeId(),
'bundle_id' => $group
->bundle(),
];
}
return $group_types;
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
DependencySerializationTrait:: |
protected | property | An array of entity type IDs keyed by the property name of their storages. | |
DependencySerializationTrait:: |
protected | property | An array of service IDs keyed by property name used for serialization. | |
DependencySerializationTrait:: |
public | function | 1 | |
DependencySerializationTrait:: |
public | function | 2 | |
FormBase:: |
protected | property | The config factory. | 1 |
FormBase:: |
protected | property | The request stack. | 1 |
FormBase:: |
protected | property | The route match. | |
FormBase:: |
protected | function | Retrieves a configuration object. | |
FormBase:: |
protected | function | Gets the config factory for this form. | 1 |
FormBase:: |
private | function | Returns the service container. | |
FormBase:: |
protected | function | Gets the current user. | |
FormBase:: |
protected | function | Gets the request object. | |
FormBase:: |
protected | function | Gets the route match. | |
FormBase:: |
protected | function | Gets the logger for a specific channel. | |
FormBase:: |
protected | function |
Returns a redirect response object for the specified route. Overrides UrlGeneratorTrait:: |
|
FormBase:: |
public | function | Resets the configuration factory. | |
FormBase:: |
public | function | Sets the config factory for this form. | |
FormBase:: |
public | function | Sets the request stack object to use. | |
FormBase:: |
public | function |
Form validation handler. Overrides FormInterface:: |
62 |
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. | |
OgChangeMultipleRolesFormBase:: |
protected | property | The memberships on which roles should be changed. | |
OgChangeMultipleRolesFormBase:: |
protected | property | The OG access service. | |
OgChangeMultipleRolesFormBase:: |
protected | property | The action plugin ID for which this is the confirmation form. | 2 |
OgChangeMultipleRolesFormBase:: |
protected | property | The temporary storage for the current user. | |
OgChangeMultipleRolesFormBase:: |
protected | property | The tempstore factory. | |
OgChangeMultipleRolesFormBase:: |
public | function | Controls access to the form. | |
OgChangeMultipleRolesFormBase:: |
public | function |
Form constructor. Overrides FormInterface:: |
2 |
OgChangeMultipleRolesFormBase:: |
public static | function |
Instantiates a new instance of this class. Overrides FormBase:: |
|
OgChangeMultipleRolesFormBase:: |
public | function |
Returns a unique string identifying the form. Overrides FormInterface:: |
|
OgChangeMultipleRolesFormBase:: |
protected | function | Returns an array of group types for which memberships are present. | |
OgChangeMultipleRolesFormBase:: |
protected | function | Returns an array of memberships on which to change roles. | |
OgChangeMultipleRolesFormBase:: |
protected | function | Returns the temporary storage for the current user. | |
OgChangeMultipleRolesFormBase:: |
public | function |
Form submission handler. Overrides FormInterface:: |
2 |
OgChangeMultipleRolesFormBase:: |
public | function | Constructs a OgChangeMultipleRolesFormbase object. | |
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. |