123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135 |
- <?php
- /**
- * @file
- * Contains rules integration for the user module needed during evaluation.
- *
- * @addtogroup rules
- *
- * @{
- */
- /**
- * Condition user: condition to check whether user has particular roles.
- */
- function rules_condition_user_has_role($account, $roles, $operation = 'AND') {
- switch ($operation) {
- case 'OR':
- foreach ($roles as $rid) {
- if (isset($account->roles[$rid])) {
- return TRUE;
- }
- }
- return FALSE;
- case 'AND':
- foreach ($roles as $rid) {
- if (!isset($account->roles[$rid])) {
- return FALSE;
- }
- }
- return TRUE;
- }
- }
- /**
- * Condition: User is blocked.
- */
- function rules_condition_user_is_blocked($account) {
- return $account->status == 0;
- }
- /**
- * Action: Adds roles to a particular user.
- */
- function rules_action_user_add_role($account, $roles) {
- if ($account->uid || !empty($account->is_new)) {
- // Get role list (minus the anonymous).
- $role_list = user_roles(TRUE);
- foreach ($roles as $rid) {
- $account->roles[$rid] = $role_list[$rid];
- }
- if (!empty($account->is_new) && $account->uid) {
- // user_save() inserts roles after invoking hook_user_insert() anyway, so
- // we skip saving to avoid errors due saving them twice.
- return FALSE;
- }
- }
- else {
- return FALSE;
- }
- }
- /**
- * Action: Remove roles from a given user.
- */
- function rules_action_user_remove_role($account, $roles) {
- if ($account->uid || !empty($account->is_new)) {
- foreach ($roles as $rid) {
- // If the user has this role, remove it.
- if (isset($account->roles[$rid])) {
- unset($account->roles[$rid]);
- }
- }
- if (!empty($account->is_new) && $account->uid) {
- // user_save() inserts roles after invoking hook_user_insert() anyway, so
- // we skip saving to avoid errors due saving them twice.
- return FALSE;
- }
- }
- else {
- return FALSE;
- }
- }
- /**
- * Action: Block a user.
- */
- function rules_action_user_block($account) {
- $account->status = 0;
- drupal_session_destroy_uid($account->uid);
- }
- /**
- * Action: Unblock a user.
- */
- function rules_action_user_unblock($account) {
- $account->status = 1;
- }
- /**
- * Action: Send a user account e-mail.
- */
- function rules_action_user_send_account_email($account, $email_type) {
- // If we received an authenticated user account...
- if (!empty($account->uid)) {
- module_load_include('inc', 'rules', 'modules/user.rules');
- $types = rules_user_account_email_options_list();
- // Attempt to send the account e-mail.
- // This code is adapted from _user_mail_notify().
- $params = array('account' => $account);
- $language = user_preferred_language($account);
- $mail = drupal_mail('user', $email_type, $account->mail, $language, $params);
- if ($email_type == 'register_pending_approval') {
- // If a user registered requiring admin approval, notify the admin, too.
- // We use the site default language for this.
- drupal_mail('user', 'register_pending_approval_admin', variable_get('site_mail', ini_get('sendmail_from')), language_default(), $params);
- }
- $result = empty($mail) ? NULL : $mail['result'];
- // Log the success or failure.
- if ($result) {
- watchdog('rules', '%type e-mail sent to %recipient.', array('%type' => $types[$email_type], '%recipient' => $account->mail));
- }
- else {
- watchdog('rules', 'Failed to send %type e-mail to %recipient.', array('%type' => $types[$email_type], '%recipient' => $account->mail));
- }
- }
- }
- /**
- * @}
- */
|