class UserCreate in CiviCRM Entity 8.3
Provides a 'User create' action.
Plugin annotation
@RulesAction(
id = "civicrm_entity_user_create",
label = @Translation("Create linked drupal user account"),
category = @Translation("CiviCRM"),
context = {
"contact_id" = @ContextDefinition("integer",
label = @Translation("CiviCRM contact ID"),
description = @Translation("The CiviCRM contact ID."),
required = TRUE
),
"is_active" = @ContextDefinition("boolean",
label = @Translation("Activate account"),
description = @Translation("Set to TRUE to activate account. Leave empty to not activate the account. Defaults to TRUE."),
assignment_restriction = "input",
default_value = TRUE,
required = FALSE
),
"notify" = @ContextDefinition("boolean",
label = @Translation("Send account notification email"),
description = @Translation("Set to TRUE to send a notification email. Leave empty to not send an account notification email."),
assignment_restriction = "input",
default_value = TRUE,
required = FALSE
),
"signin" = @ContextDefinition("boolean",
label = @Translation("Instant signin"),
description = @Translation("Set to TRUE to automatically log in the user. Leave empty to not automatically log in the user."),
assignment_restriction = "input",
default_value = TRUE,
required = FALSE
),
"format" = @ContextDefinition("string",
label = @Translation("Format"),
description = @Translation("Format of the username."),
)
},
provides = {
"civicrm_user" = @ContextDefinition("entity:user",
label = @Translation("Created Drupal user")
)
}
)
Hierarchy
- class \Drupal\Component\Plugin\PluginBase implements DerivativeInspectionInterface, PluginInspectionInterface
- class \Drupal\Component\Plugin\ContextAwarePluginBase implements ContextAwarePluginInterface
- class \Drupal\Core\Plugin\ContextAwarePluginBase implements CacheableDependencyInterface, ContextAwarePluginInterface uses DependencySerializationTrait, StringTranslationTrait, TypedDataTrait
- class \Drupal\rules\Core\RulesActionBase implements RulesActionInterface uses ContextProviderTrait, ConfigurationAccessControlTrait, ExecutablePluginTrait
- class \Drupal\civicrm_entity\Plugin\RulesAction\UserCreate implements ContainerFactoryPluginInterface
- class \Drupal\rules\Core\RulesActionBase implements RulesActionInterface uses ContextProviderTrait, ConfigurationAccessControlTrait, ExecutablePluginTrait
- class \Drupal\Core\Plugin\ContextAwarePluginBase implements CacheableDependencyInterface, ContextAwarePluginInterface uses DependencySerializationTrait, StringTranslationTrait, TypedDataTrait
- class \Drupal\Component\Plugin\ContextAwarePluginBase implements ContextAwarePluginInterface
Expanded class hierarchy of UserCreate
File
- src/
Plugin/ RulesAction/ UserCreate.php, line 59
Namespace
Drupal\civicrm_entity\Plugin\RulesActionView source
class UserCreate extends RulesActionBase implements ContainerFactoryPluginInterface {
/**
* The CiviCRM contact storage service.
*
* @var \Drupal\civicrm_entity\CiviEntityStorage
*/
protected $contactStorage;
/**
* The user storage service.
*
* @var \Drupal\user\UserStorageInterface
*/
protected $userStorage;
/**
* The messenger service.
*
* @var \Drupal\Core\Messenger\MessengerInterface
*/
protected $messenger;
/**
* The CiviCRM API service.
*
* @var \Drupal\civicrm_entity\CiviCrmApiInterface
*/
protected $civicrmApi;
/**
* {@inheritdoc}
*/
public function __construct(array $configuration, $plugin_id, $plugin_definition, CiviEntityStorage $contact_storage, UserStorageInterface $user_storage, MessengerInterface $messenger, CiviCrmApiInterface $civicrm_api) {
parent::__construct($configuration, $plugin_id, $plugin_definition);
$this->contactStorage = $contact_storage;
$this->userStorage = $user_storage;
$this->messenger = $messenger;
$this->civicrmApi = $civicrm_api;
}
/**
* {@inheritdoc}
*/
public static function create(ContainerInterface $container, array $configuration, $plugin_id, $plugin_definition) {
return new static($configuration, $plugin_id, $plugin_definition, $container
->get('entity_type.manager')
->getStorage('civicrm_contact'), $container
->get('entity_type.manager')
->getStorage('user'), $container
->get('messenger'), $container
->get('civicrm_entity.api'));
}
/**
* {@inheritdoc}
*/
public function doExecute($contact_id, $is_active, $notify, $signin, $format) {
$contact = $this->civicrmApi
->getSingle('Contact', [
'return' => [
'email',
'contact_type',
],
'id' => $contact_id,
]);
if (empty($contact) || empty($contact['email'])) {
return;
}
$params = [
'name' => $format,
'mail' => $contact['email'],
'init' => $contact['email'],
'status' => (bool) $is_active,
];
$this->civicrmApi
->civicrmInitialize();
$config = \CRM_Core_Config::singleton();
if ($this
->checkUserNameExists($params, $config->userSystem)) {
$counter = 0;
do {
$params['name'] = $params['name'] . '_' . $counter++;
} while ($this
->checkUserNameExists($params, $config->userSystem));
}
/** @var \Drupal\user\UserInterface $user */
$user = $this->userStorage
->create($params);
$violations = $user
->validate()
->getByFields(array_keys($params));
if ($violations
->count() > 0) {
$messages = 'Unable to create user for %email due to the following error(s):<ul>';
/** @var \Symfony\Component\Validator\ConstraintViolation $violation */
foreach ($violations as $violation) {
$messages .= '<li>' . $violation
->getMessage() . '</li>';
}
$messages .= '</ul>';
\Drupal::logger('civicrm_entity')
->error($messages, [
'%email' => $params['mail'],
]);
}
if ($violations
->count() === 0 && $user
->save()) {
$this->civicrmApi
->civicrmInitialize();
if ($contact['contact_type'] === 'Individual') {
\CRM_Core_BAO_UFMatch::synchronizeUFMatch($user, $user
->id(), $contact['email'], 'Drupal8', NULL, 'Individual', TRUE);
}
else {
\CRM_Core_BAO_UFMatch::synchronizeUFMatch($user, $user
->id(), $contact['email'], 'Drupal8', NULL, NULL, TRUE);
}
$this->messenger
->addStatus($this
->t('User with username @name has been created.', [
'@name' => $user
->getUsername(),
]));
$this
->setProvidedValue('civicrm_user', $user);
if ((bool) $signin) {
user_login_finalize($user);
}
if ((bool) $notify) {
_user_mail_notify('register_no_approval_required', $user);
}
}
}
/**
* Check if username exists.
*
* @param array $params
* The parameters.
* @param \CRM_Utils_System_Base $userSystem
* The user system.
*
* @return boolean
* TRUE if username exists; otherwise FALSE.
*/
protected function checkUserNameExists(array $params, \CRM_Utils_System_Base $userSystem) {
$errors = [];
$userSystem
->checkUserNameEmailExists($params, $errors);
return isset($errors['cms_name']);
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
ConfigurationAccessControlTrait:: |
public | function | Checks configuration permission. | |
ContextAwarePluginBase:: |
protected | property | The data objects representing the context of this plugin. | |
ContextAwarePluginBase:: |
private | property | Data objects representing the contexts passed in the plugin configuration. | |
ContextAwarePluginBase:: |
protected | function | Wraps the context handler. | |
ContextAwarePluginBase:: |
protected | function |
Overrides ContextAwarePluginBase:: |
|
ContextAwarePluginBase:: |
public | function |
The cache contexts associated with this object. Overrides CacheableDependencyInterface:: |
9 |
ContextAwarePluginBase:: |
public | function |
The maximum age for which this object may be cached. Overrides CacheableDependencyInterface:: |
7 |
ContextAwarePluginBase:: |
public | function |
The cache tags associated with this object. Overrides CacheableDependencyInterface:: |
4 |
ContextAwarePluginBase:: |
public | function |
This code is identical to the Component in order to pick up a different
Context class. Overrides ContextAwarePluginBase:: |
|
ContextAwarePluginBase:: |
public | function |
Overrides ContextAwarePluginBase:: |
|
ContextAwarePluginBase:: |
public | function |
Overrides ContextAwarePluginBase:: |
|
ContextAwarePluginBase:: |
public | function |
Gets a mapping of the expected assignment names to their context names. Overrides ContextAwarePluginInterface:: |
|
ContextAwarePluginBase:: |
public | function |
Gets the defined contexts. Overrides ContextAwarePluginInterface:: |
|
ContextAwarePluginBase:: |
public | function |
Gets the values for all defined contexts. Overrides ContextAwarePluginInterface:: |
|
ContextAwarePluginBase:: |
public | function |
Set a context on this plugin. Overrides ContextAwarePluginBase:: |
|
ContextAwarePluginBase:: |
public | function |
Sets a mapping of the expected assignment names to their context names. Overrides ContextAwarePluginInterface:: |
|
ContextAwarePluginBase:: |
public | function |
Sets the value for a defined context. Overrides ContextAwarePluginBase:: |
|
ContextAwarePluginBase:: |
public | function |
Validates the set values for the defined contexts. Overrides ContextAwarePluginInterface:: |
|
ContextAwarePluginBase:: |
public | function | Implements magic __get() method. | |
ContextProviderTrait:: |
protected | property | The data objects that are provided by this plugin. | |
ContextProviderTrait:: |
public | function | ||
ContextProviderTrait:: |
public | function | ||
ContextProviderTrait:: |
public | function | ||
ContextProviderTrait:: |
public | function | ||
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 | |
ExecutablePluginTrait:: |
protected | function | Get the translated label from the plugin definition. | |
ExecutablePluginTrait:: |
public | function | Get the translated summary from the label annotation. | 4 |
PluginBase:: |
protected | property | The plugin implementation definition. | 1 |
PluginBase:: |
protected | property | The plugin_id. | |
PluginBase:: |
constant | A string which is used to separate base plugin IDs from the derivative ID. | ||
PluginBase:: |
public | function |
Gets the base_plugin_id of the plugin instance. Overrides DerivativeInspectionInterface:: |
|
PluginBase:: |
public | function |
Gets the derivative_id of the plugin instance. Overrides DerivativeInspectionInterface:: |
|
PluginBase:: |
public | function |
Gets the definition of the plugin implementation. Overrides PluginInspectionInterface:: |
3 |
PluginBase:: |
public | function |
Gets the plugin_id of the plugin instance. Overrides PluginInspectionInterface:: |
|
PluginBase:: |
public | function | Determines if the plugin is configurable. | |
RulesActionBase:: |
protected | property |
The plugin configuration. Overrides PluginBase:: |
|
RulesActionBase:: |
public | function |
Checks object access. Overrides RulesActionInterface:: |
|
RulesActionBase:: |
public | function |
Asserts additional metadata for the selected data. Overrides ContextAwarePluginInterface:: |
|
RulesActionBase:: |
public | function |
Returns a list of context names that should be auto-saved after execution. Overrides RulesActionInterface:: |
14 |
RulesActionBase:: |
public | function | @todo this documentation is not actually inherited from any interface. Do we need this empty implementation? | |
RulesActionBase:: |
public | function | @todo this documentation is not actually inherited from any interface. Do we need this empty implementation? | |
RulesActionBase:: |
public | function |
Executes the plugin. Overrides ExecutableInterface:: |
2 |
RulesActionBase:: |
public | function | @todo this documentation is not actually inherited from any interface. Do we need this empty implementation? | |
RulesActionBase:: |
public | function | @todo this documentation is not actually inherited from any interface. | |
RulesActionBase:: |
public | function |
Gets the value for a defined context. Overrides ContextAwarePluginBase:: |
|
RulesActionBase:: |
public | function |
Refines used and provided context definitions based upon context values. Overrides ContextAwarePluginInterface:: |
5 |
RulesActionBase:: |
public | function | @todo this documentation is not actually inherited from any interface. | |
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. | |
TypedDataTrait:: |
protected | property | The typed data manager used for creating the data types. | |
TypedDataTrait:: |
public | function | Gets the typed data manager. | 2 |
TypedDataTrait:: |
public | function | Sets the typed data manager. | 2 |
UserCreate:: |
protected | property | The CiviCRM API service. | |
UserCreate:: |
protected | property | The CiviCRM contact storage service. | |
UserCreate:: |
protected | property | The messenger service. | |
UserCreate:: |
protected | property | The user storage service. | |
UserCreate:: |
protected | function | Check if username exists. | |
UserCreate:: |
public static | function |
Creates an instance of the plugin. Overrides ContainerFactoryPluginInterface:: |
|
UserCreate:: |
public | function | ||
UserCreate:: |
public | function |
Overrides \Drupal\Component\Plugin\PluginBase::__construct(). Overrides ContextAwarePluginBase:: |