Newer
Older
<?php
/**
* @file
* Admin page callback file for the user module.
*/
Jennifer Hodgdon
committed
/**
* Page callback: Generates the appropriate user administration form.
*
* This function generates the user registration, multiple user cancellation,
* or filtered user list admin form, depending on the argument and the POST
* form values.
*
* @param string $callback_arg
* (optional) Indicates which form to build. Defaults to '', which will
* trigger the user filter form. If the POST value 'op' is present, this
* function uses that value as the callback argument.
*
* @return string
* A renderable form array for the respective request.
*/
function user_admin($callback_arg = '') {
$op = isset($_POST['op']) ? $_POST['op'] : $callback_arg;
switch ($op) {
case t('Create new account'):
case 'create':
$account = entity_create('user', array());
$build['user_register'] = entity_get_form($account, 'register');
break;
default:
Angie Byron
committed
if (!empty($_POST['accounts']) && isset($_POST['operation']) && ($_POST['operation'] == 'cancel')) {
Dries Buytaert
committed
$build['user_multiple_cancel_confirm'] = drupal_get_form('user_multiple_cancel_confirm');
}
else {
Dries Buytaert
committed
$build['user_filter_form'] = drupal_get_form('user_filter_form');
$build['user_admin_account'] = drupal_get_form('user_admin_account');
}
}
Dries Buytaert
committed
return $build;
}
/**
* Form builder; Return form for user administration filters.
Dries Buytaert
committed
*
* @ingroup forms
Gábor Hojtsy
committed
* @see user_filter_form_submit()
*/
function user_filter_form() {
Dries Buytaert
committed
$session = isset($_SESSION['user_overview_filter']) ? $_SESSION['user_overview_filter'] : array();
$filters = user_filters();
$i = 0;
Gábor Hojtsy
committed
$form['filters'] = array(
'#type' => 'details',
Gábor Hojtsy
committed
'#title' => t('Show only users where'),
Dries Buytaert
committed
'#theme' => 'exposed_filters__user',
Gábor Hojtsy
committed
);
foreach ($session as $filter) {
list($type, $value) = $filter;
if ($type == 'permission') {
// Merge arrays of module permissions into one.
// Slice past the first element '[any]' whose value is not an array.
$options = call_user_func_array('array_merge', array_slice($filters[$type]['options'], 1));
$value = $options[$value];
}
else {
$value = $filters[$type]['options'][$value];
}
Dries Buytaert
committed
$t_args = array('%property' => $filters[$type]['title'], '%value' => $value);
if ($i++) {
Dries Buytaert
committed
$form['filters']['current'][] = array('#markup' => t('and where %property is %value', $t_args));
Gábor Hojtsy
committed
}
else {
Dries Buytaert
committed
$form['filters']['current'][] = array('#markup' => t('%property is %value', $t_args));
Gábor Hojtsy
committed
}
}
Dries Buytaert
committed
$form['filters']['status'] = array(
'#type' => 'container',
'#attributes' => array('class' => array('clearfix')),
'#prefix' => ($i ? '<div class="additional-filters">' . t('and where') . '</div>' : ''),
);
$form['filters']['status']['filters'] = array(
'#type' => 'container',
'#attributes' => array('class' => array('filters')),
);
foreach ($filters as $key => $filter) {
Dries Buytaert
committed
$form['filters']['status']['filters'][$key] = array(
Gábor Hojtsy
committed
'#type' => 'select',
'#options' => $filter['options'],
'#title' => $filter['title'],
'#default_value' => '[any]',
Gábor Hojtsy
committed
);
}
Dries Buytaert
committed
$form['filters']['status']['actions'] = array(
Dries Buytaert
committed
'#type' => 'actions',
'#attributes' => array('class' => array('container-inline')),
);
Dries Buytaert
committed
$form['filters']['status']['actions']['submit'] = array(
Gábor Hojtsy
committed
'#type' => 'submit',
'#value' => (count($session) ? t('Refine') : t('Filter')),
);
if (count($session)) {
Dries Buytaert
committed
$form['filters']['status']['actions']['undo'] = array(
Gábor Hojtsy
committed
'#type' => 'submit',
'#value' => t('Undo'),
);
Dries Buytaert
committed
$form['filters']['status']['actions']['reset'] = array(
Gábor Hojtsy
committed
'#type' => 'submit',
'#value' => t('Reset'),
);
}
Angie Byron
committed
drupal_add_library('system', 'drupal.form');
Angie Byron
committed
return $form;
}
/**
* Process result from user administration filter form.
*/
function user_filter_form_submit($form, &$form_state) {
$op = $form_state['values']['op'];
$filters = user_filters();
switch ($op) {
case t('Filter'):
case t('Refine'):
// Apply every filter that has a choice selected other than 'any'.
foreach ($filters as $filter => $options) {
if (isset($form_state['values'][$filter]) && $form_state['values'][$filter] != '[any]') {
catch
committed
$_SESSION['user_overview_filter'][] = array($filter, $form_state['values'][$filter]);
}
}
break;
case t('Undo'):
array_pop($_SESSION['user_overview_filter']);
break;
case t('Reset'):
Dries Buytaert
committed
$_SESSION['user_overview_filter'] = array();
break;
case t('Update'):
return;
}
Dries Buytaert
committed
$form_state['redirect'] = 'admin/people';
return;
}
/**
* Form builder; User administration page.
*
* @ingroup forms
Gábor Hojtsy
committed
* @see user_admin_account_validate()
* @see user_admin_account_submit()
*/
function user_admin_account() {
$header = array(
Dries Buytaert
committed
'username' => array('data' => t('Username'), 'field' => 'u.name'),
'status' => array('data' => t('Status'), 'field' => 'u.status', 'class' => array(RESPONSIVE_PRIORITY_LOW)),
'roles' => array('data' => t('Roles'), 'class' => array(RESPONSIVE_PRIORITY_LOW)),
'member_for' => array('data' => t('Member for'), 'field' => 'u.created', 'sort' => 'desc', 'class' => array(RESPONSIVE_PRIORITY_LOW)),
'access' => array('data' => t('Last access'), 'field' => 'u.access', 'class' => array(RESPONSIVE_PRIORITY_LOW)),
Angie Byron
committed
'operations' => t('Operations'),
);
Dries Buytaert
committed
$query = db_select('users', 'u');
$query->condition('u.uid', 0, '<>');
user_build_filter_query($query);
$count_query = clone $query;
$count_query->addExpression('COUNT(u.uid)');
catch
committed
$query = $query
->extend('Drupal\Core\Database\Query\PagerSelectExtender')
->extend('Drupal\Core\Database\Query\TableSortExtender');
$query
->fields('u', array('uid', 'name', 'status', 'created', 'access'))
->limit(50)
Dries Buytaert
committed
->orderByHeader($header)
->setCountQuery($count_query);
$result = $query->execute();
$form['options'] = array(
'#type' => 'details',
'#title' => t('Update options'),
Dries Buytaert
committed
'#attributes' => array('class' => array('container-inline')),
);
$options = array();
foreach (module_invoke_all('user_operations') as $operation => $array) {
$options[$operation] = $array['label'];
}
$form['options']['operation'] = array(
'#type' => 'select',
Dries Buytaert
committed
'#title' => t('Operation'),
'#title_display' => 'invisible',
'#options' => $options,
'#default_value' => 'unblock',
);
Dries Buytaert
committed
$options = array();
$form['options']['submit'] = array(
'#type' => 'submit',
'#value' => t('Update'),
);
$destination = drupal_get_destination();
$status = array(t('blocked'), t('active'));
$roles = array_map('check_plain', user_roles(TRUE));
$accounts = array();
Dries Buytaert
committed
foreach ($result as $account) {
Dries Buytaert
committed
$account = user_load($account->uid);
Angie Byron
committed
$users_roles = array();
Dries Buytaert
committed
$roles_result = db_query('SELECT rid FROM {users_roles} WHERE uid = :uid', array(':uid' => $account->uid));
foreach ($roles_result as $user_role) {
Angie Byron
committed
$users_roles[] = $roles[$user_role->rid];
}
Angie Byron
committed
asort($users_roles);
Dries Buytaert
committed
$options[$account->uid] = array(
Dries Buytaert
committed
'username' => theme('username', array('account' => $account)),
Dries Buytaert
committed
'status' => $status[$account->status],
Dries Buytaert
committed
'roles' => theme('item_list', array('items' => $users_roles)),
Dries Buytaert
committed
'member_for' => format_interval(REQUEST_TIME - $account->created),
'access' => $account->access ? t('@time ago', array('@time' => format_interval(REQUEST_TIME - $account->access))) : t('never'),
Angie Byron
committed
);
$links = array();
$links['edit'] = array(
'title' => t('edit'),
Dries Buytaert
committed
'href' => 'user/' . $account->uid . '/edit',
Angie Byron
committed
'query' => $destination,
);
Dries Buytaert
committed
if (module_invoke('translation_entity', 'translate_access', $account)) {
$links['translate'] = array(
'title' => t('translate'),
'href' => 'user/' . $account->uid . '/translations',
'query' => $destination,
);
}
Angie Byron
committed
$options[$account->uid]['operations']['data'] = array(
'#type' => 'operations',
'#links' => $links,
Dries Buytaert
committed
);
}
$form['accounts'] = array(
Dries Buytaert
committed
'#type' => 'tableselect',
'#header' => $header,
'#options' => $options,
'#empty' => t('No people available.'),
);
$form['pager'] = array('#markup' => theme('pager'));
return $form;
}
/**
* Submit the user administration update form.
*/
function user_admin_account_submit($form, &$form_state) {
$operations = module_invoke_all('user_operations', $form, $form_state);
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
$operation = $operations[$form_state['values']['operation']];
// Filter out unchecked accounts.
$accounts = array_filter($form_state['values']['accounts']);
if ($function = $operation['callback']) {
// Add in callback arguments if present.
if (isset($operation['callback arguments'])) {
$args = array_merge(array($accounts), $operation['callback arguments']);
}
else {
$args = array($accounts);
}
call_user_func_array($function, $args);
drupal_set_message(t('The update has been performed.'));
}
}
function user_admin_account_validate($form, &$form_state) {
$form_state['values']['accounts'] = array_filter($form_state['values']['accounts']);
if (count($form_state['values']['accounts']) == 0) {
form_set_error('', t('No users selected.'));
}
}
/**
* Form builder; Configure user settings for this site.
*
* @ingroup forms
Angie Byron
committed
* @see user_admin_settings_submit()
*/
Angie Byron
committed
function user_admin_settings($form, &$form_state) {
$config = config('user.settings');
Angie Byron
committed
$mail_config = config('user.mail');
Angie Byron
committed
// Settings for anonymous users.
$form['anonymous_settings'] = array(
'#type' => 'details',
Angie Byron
committed
'#title' => t('Anonymous users'),
);
$form['anonymous_settings']['anonymous'] = array(
'#type' => 'textfield',
'#title' => t('Name'),
Angie Byron
committed
'#default_value' => $config->get('anonymous'),
Angie Byron
committed
'#description' => t('The name used to indicate anonymous users.'),
'#required' => TRUE,
);
Dries Buytaert
committed
// Administrative role option.
$form['admin_role'] = array(
'#type' => 'details',
'#title' => t('Administrator role'),
Dries Buytaert
committed
);
// Do not allow users to set the anonymous or authenticated user roles as the
Dries Buytaert
committed
// administrator role.
$roles = user_roles();
Angie Byron
committed
unset($roles[DRUPAL_ANONYMOUS_RID]);
unset($roles[DRUPAL_AUTHENTICATED_RID]);
Dries Buytaert
committed
$roles[0] = t('disabled');
$form['admin_role']['user_admin_role'] = array(
'#type' => 'select',
'#title' => t('Administrator role'),
Angie Byron
committed
'#default_value' => $config->get('admin_role'),
Dries Buytaert
committed
'#options' => $roles,
'#description' => t('This role will be automatically assigned new permissions whenever a module is enabled. Changing this setting will not affect existing permissions.'),
);
Angie Byron
committed
// @todo Remove this check once language settings are generalized.
if (module_exists('translation_entity')) {
$form['language'] = array(
'#type' => 'details',
Angie Byron
committed
'#title' => t('Language settings'),
'#tree' => TRUE,
);
$form_state['translation_entity']['key'] = 'language';
$form['language'] += translation_entity_enable_widget('user', 'user', $form, $form_state);
}
Angie Byron
committed
// User registration settings.
$form['registration_cancellation'] = array(
'#type' => 'details',
Angie Byron
committed
'#title' => t('Registration and cancellation'),
);
$form['registration_cancellation']['user_register'] = array(
'#type' => 'radios',
'#title' => t('Who can register accounts?'),
Angie Byron
committed
'#default_value' => $config->get('register'),
Angie Byron
committed
'#options' => array(
Dries Buytaert
committed
USER_REGISTER_ADMINISTRATORS_ONLY => t('Administrators only'),
USER_REGISTER_VISITORS => t('Visitors'),
USER_REGISTER_VISITORS_ADMINISTRATIVE_APPROVAL => t('Visitors, but administrator approval is required'),
Angie Byron
committed
)
);
$form['registration_cancellation']['user_email_verification'] = array(
'#type' => 'checkbox',
'#title' => t('Require e-mail verification when a visitor creates an account.'),
Angie Byron
committed
'#default_value' => $config->get('verify_mail'),
Dries Buytaert
committed
'#description' => t('New users will be required to validate their e-mail address prior to logging into the site, and will be assigned a system-generated password. With this setting disabled, users will be logged in immediately upon registering, and may select their own passwords during registration.')
Angie Byron
committed
);
Angie Byron
committed
form_load_include($form_state, 'inc', 'user', 'user.pages');
Angie Byron
committed
$form['registration_cancellation']['user_cancel_method'] = array(
Angie Byron
committed
'#type' => 'radios',
Angie Byron
committed
'#title' => t('When cancelling a user account'),
catch
committed
'#default_value' => $config->get('cancel_method'),
Angie Byron
committed
'#description' => t('Users with the %select-cancel-method or %administer-users <a href="@permissions-url">permissions</a> can override this default method.', array('%select-cancel-method' => t('Select method for cancelling account'), '%administer-users' => t('Administer users'), '@permissions-url' => url('admin/people/permissions'))),
Angie Byron
committed
);
Angie Byron
committed
$form['registration_cancellation']['user_cancel_method'] += user_cancel_methods();
Angie Byron
committed
foreach (element_children($form['registration_cancellation']['user_cancel_method']) as $key) {
// All account cancellation methods that specify #access cannot be
// configured as default method.
// @see hook_user_cancel_methods_alter()
if (isset($form['registration_cancellation']['user_cancel_method'][$key]['#access'])) {
$form['registration_cancellation']['user_cancel_method'][$key]['#access'] = FALSE;
Angie Byron
committed
}
}
Angie Byron
committed
// Account settings.
$form['personalization'] = array(
'#type' => 'details',
Angie Byron
committed
'#title' => t('Personalization'),
);
$form['personalization']['user_signatures'] = array(
'#type' => 'checkbox',
'#title' => t('Enable signatures.'),
Angie Byron
committed
'#default_value' => $config->get('signatures'),
Angie Byron
committed
);
$form['email'] = array(
'#type' => 'vertical_tabs',
Angie Byron
committed
'#title' => t('E-mails'),
);
// These email tokens are shared for all settings, so just define
// the list once to help ensure they stay in sync.
Angie Byron
committed
$email_token_help = t('Available variables are: [site:name], [site:url], [user:name], [user:mail], [site:login-url], [site:url-brief], [user:edit-url], [user:one-time-login-url], [user:cancel-url].');
Angie Byron
committed
$form['email_admin_created'] = array(
'#type' => 'details',
Angie Byron
committed
'#title' => t('Welcome (new user created by administrator)'),
'#collapsible' => TRUE,
Angie Byron
committed
'#collapsed' => ($config->get('register') != USER_REGISTER_ADMINISTRATORS_ONLY),
Angie Byron
committed
'#description' => t('Edit the welcome e-mail messages sent to new member accounts created by an administrator.') . ' ' . $email_token_help,
Angie Byron
committed
'#group' => 'email',
);
Angie Byron
committed
$form['email_admin_created']['user_mail_register_admin_created_subject'] = array(
'#type' => 'textfield',
'#title' => t('Subject'),
Angie Byron
committed
'#default_value' => $mail_config->get('register_admin_created.subject'),
'#maxlength' => 180,
);
Angie Byron
committed
$form['email_admin_created']['user_mail_register_admin_created_body'] = array(
'#type' => 'textarea',
'#title' => t('Body'),
Angie Byron
committed
'#default_value' => $mail_config->get('register_admin_created.body'),
'#rows' => 15,
);
Dries Buytaert
committed
$form['email_pending_approval'] = array(
'#type' => 'details',
Dries Buytaert
committed
'#title' => t('Welcome (awaiting approval)'),
'#collapsible' => TRUE,
Angie Byron
committed
'#collapsed' => ($config->get('register') != USER_REGISTER_VISITORS_ADMINISTRATIVE_APPROVAL),
Angie Byron
committed
'#description' => t('Edit the welcome e-mail messages sent to new members upon registering, when administrative approval is required.') . ' ' . $email_token_help,
Angie Byron
committed
'#group' => 'email',
);
Dries Buytaert
committed
$form['email_pending_approval']['user_mail_register_pending_approval_subject'] = array(
'#type' => 'textfield',
'#title' => t('Subject'),
Angie Byron
committed
'#default_value' => $mail_config->get('register_pending_approval.subject'),
'#maxlength' => 180,
);
Dries Buytaert
committed
$form['email_pending_approval']['user_mail_register_pending_approval_body'] = array(
'#type' => 'textarea',
'#title' => t('Body'),
Angie Byron
committed
'#default_value' => $mail_config->get('register_pending_approval.body'),
Dries Buytaert
committed
'#rows' => 8,
);
Dries Buytaert
committed
$form['email_no_approval_required'] = array(
'#type' => 'details',
Dries Buytaert
committed
'#title' => t('Welcome (no approval required)'),
'#collapsible' => TRUE,
Angie Byron
committed
'#collapsed' => ($config->get('register') != USER_REGISTER_VISITORS),
Angie Byron
committed
'#description' => t('Edit the welcome e-mail messages sent to new members upon registering, when no administrator approval is required.') . ' ' . $email_token_help,
Angie Byron
committed
'#group' => 'email',
);
Dries Buytaert
committed
$form['email_no_approval_required']['user_mail_register_no_approval_required_subject'] = array(
'#type' => 'textfield',
'#title' => t('Subject'),
Angie Byron
committed
'#default_value' => $mail_config->get('register_no_approval_required.subject'),
'#maxlength' => 180,
);
Dries Buytaert
committed
$form['email_no_approval_required']['user_mail_register_no_approval_required_body'] = array(
'#type' => 'textarea',
'#title' => t('Body'),
Angie Byron
committed
'#default_value' => $mail_config->get('register_no_approval_required.body'),
Dries Buytaert
committed
'#rows' => 15,
);
Angie Byron
committed
$form['email_password_reset'] = array(
'#type' => 'details',
Angie Byron
committed
'#title' => t('Password recovery'),
'#collapsible' => TRUE,
'#collapsed' => TRUE,
Angie Byron
committed
'#description' => t('Edit the e-mail messages sent to users who request a new password.') . ' ' . $email_token_help,
Angie Byron
committed
'#group' => 'email',
'#weight' => 10,
);
Angie Byron
committed
$form['email_password_reset']['user_mail_password_reset_subject'] = array(
'#type' => 'textfield',
'#title' => t('Subject'),
Angie Byron
committed
'#default_value' => $mail_config->get('password_reset.subject'),
'#maxlength' => 180,
);
Angie Byron
committed
$form['email_password_reset']['user_mail_password_reset_body'] = array(
'#type' => 'textarea',
'#title' => t('Body'),
Angie Byron
committed
'#default_value' => $mail_config->get('password_reset.body'),
'#rows' => 12,
);
Angie Byron
committed
$form['email_activated'] = array(
'#type' => 'details',
Angie Byron
committed
'#title' => t('Account activation'),
'#collapsible' => TRUE,
'#collapsed' => TRUE,
Angie Byron
committed
'#description' => t('Enable and edit e-mail messages sent to users upon account activation (when an administrator activates an account of a user who has already registered, on a site where administrative approval is required).') . ' ' . $email_token_help,
Angie Byron
committed
'#group' => 'email',
);
Angie Byron
committed
$form['email_activated']['user_mail_status_activated_notify'] = array(
'#type' => 'checkbox',
'#title' => t('Notify user when account is activated.'),
Angie Byron
committed
'#default_value' => $config->get('notify.status_activated'),
);
Dries Buytaert
committed
$form['email_activated']['settings'] = array(
'#type' => 'container',
'#states' => array(
// Hide the additional settings when this email is disabled.
'invisible' => array(
'input[name="user_mail_status_activated_notify"]' => array('checked' => FALSE),
),
),
);
$form['email_activated']['settings']['user_mail_status_activated_subject'] = array(
'#type' => 'textfield',
'#title' => t('Subject'),
Angie Byron
committed
'#default_value' => $mail_config->get('status_activated.subject'),
'#maxlength' => 180,
);
Dries Buytaert
committed
$form['email_activated']['settings']['user_mail_status_activated_body'] = array(
'#type' => 'textarea',
'#title' => t('Body'),
Angie Byron
committed
'#default_value' => $mail_config->get('status_activated.body'),
'#rows' => 15,
);
Angie Byron
committed
$form['email_blocked'] = array(
'#type' => 'details',
Angie Byron
committed
'#title' => t('Account blocked'),
'#collapsible' => TRUE,
'#collapsed' => TRUE,
Angie Byron
committed
'#description' => t('Enable and edit e-mail messages sent to users when their accounts are blocked.') . ' ' . $email_token_help,
Angie Byron
committed
'#group' => 'email',
);
Angie Byron
committed
$form['email_blocked']['user_mail_status_blocked_notify'] = array(
'#type' => 'checkbox',
'#title' => t('Notify user when account is blocked.'),
Angie Byron
committed
'#default_value' => $config->get('notify.status_blocked'),
);
Dries Buytaert
committed
$form['email_blocked']['settings'] = array(
'#type' => 'container',
'#states' => array(
// Hide the additional settings when the blocked email is disabled.
'invisible' => array(
'input[name="user_mail_status_blocked_notify"]' => array('checked' => FALSE),
),
),
);
$form['email_blocked']['settings']['user_mail_status_blocked_subject'] = array(
'#type' => 'textfield',
'#title' => t('Subject'),
Angie Byron
committed
'#default_value' => $mail_config->get('status_blocked.subject'),
'#maxlength' => 180,
);
Dries Buytaert
committed
$form['email_blocked']['settings']['user_mail_status_blocked_body'] = array(
'#type' => 'textarea',
'#title' => t('Body'),
Angie Byron
committed
'#default_value' => $mail_config->get('status_blocked.body'),
'#rows' => 3,
);
Angie Byron
committed
$form['email_cancel_confirm'] = array(
'#type' => 'details',
Angie Byron
committed
'#title' => t('Account cancellation confirmation'),
Angie Byron
committed
'#collapsible' => TRUE,
'#collapsed' => TRUE,
Angie Byron
committed
'#description' => t('Edit the e-mail messages sent to users when they attempt to cancel their accounts.') . ' ' . $email_token_help,
Angie Byron
committed
'#group' => 'email',
Angie Byron
committed
);
Angie Byron
committed
$form['email_cancel_confirm']['user_mail_cancel_confirm_subject'] = array(
Angie Byron
committed
'#type' => 'textfield',
'#title' => t('Subject'),
Angie Byron
committed
'#default_value' => $mail_config->get('cancel_confirm.subject'),
Angie Byron
committed
'#maxlength' => 180,
);
Angie Byron
committed
$form['email_cancel_confirm']['user_mail_cancel_confirm_body'] = array(
Angie Byron
committed
'#type' => 'textarea',
'#title' => t('Body'),
Angie Byron
committed
'#default_value' => $mail_config->get('cancel_confirm.body'),
Angie Byron
committed
'#rows' => 3,
);
Angie Byron
committed
$form['email_canceled'] = array(
'#type' => 'details',
Angie Byron
committed
'#title' => t('Account canceled'),
'#collapsible' => TRUE,
'#collapsed' => TRUE,
Angie Byron
committed
'#description' => t('Enable and edit e-mail messages sent to users when their accounts are canceled.') . ' ' . $email_token_help,
Angie Byron
committed
'#group' => 'email',
);
Angie Byron
committed
$form['email_canceled']['user_mail_status_canceled_notify'] = array(
'#type' => 'checkbox',
Angie Byron
committed
'#title' => t('Notify user when account is canceled.'),
Angie Byron
committed
'#default_value' => $config->get('notify.status_canceled'),
);
Dries Buytaert
committed
$form['email_canceled']['settings'] = array(
'#type' => 'container',
'#states' => array(
// Hide the settings when the cancel notify checkbox is disabled.
Dries Buytaert
committed
'invisible' => array(
'input[name="user_mail_status_canceled_notify"]' => array('checked' => FALSE),
),
),
);
$form['email_canceled']['settings']['user_mail_status_canceled_subject'] = array(
'#type' => 'textfield',
'#title' => t('Subject'),
Angie Byron
committed
'#default_value' => $mail_config->get('status_canceled.subject'),
'#maxlength' => 180,
);
Dries Buytaert
committed
$form['email_canceled']['settings']['user_mail_status_canceled_body'] = array(
'#type' => 'textarea',
'#title' => t('Body'),
Angie Byron
committed
'#default_value' => $mail_config->get('status_canceled.body'),
'#rows' => 3,
);
Angie Byron
committed
return system_config_form($form, $form_state);
}
/**
* Form submission handler for user_admin_settings().
*/
function user_admin_settings_submit($form, &$form_state) {
config('user.settings')
->set('anonymous', $form_state['values']['anonymous'])
->set('admin_role', $form_state['values']['user_admin_role'])
->set('register', $form_state['values']['user_register'])
->set('verify_mail', $form_state['values']['user_email_verification'])
->set('signatures', $form_state['values']['user_signatures'])
catch
committed
->set('cancel_method', $form_state['values']['user_cancel_method'])
Angie Byron
committed
->set('notify.status_activated', $form_state['values']['user_mail_status_activated_notify'])
->set('notify.status_blocked', $form_state['values']['user_mail_status_blocked_notify'])
->set('notify.status_canceled', $form_state['values']['user_mail_status_canceled_notify'])
->save();
Angie Byron
committed
config('user.mail')
->set('cancel_confirm.body', $form_state['values']['user_mail_cancel_confirm_body'])
->set('cancel_confirm.subject', $form_state['values']['user_mail_cancel_confirm_subject'])
->set('password_reset.body', $form_state['values']['user_mail_password_reset_body'])
->set('password_reset.subject', $form_state['values']['user_mail_password_reset_subject'])
->set('register_admin_created.body', $form_state['values']['user_mail_register_admin_created_body'])
->set('register_admin_created.subject', $form_state['values']['user_mail_register_admin_created_subject'])
->set('register_no_approval_required.body', $form_state['values']['user_mail_register_no_approval_required_body'])
->set('register_no_approval_required.subject', $form_state['values']['user_mail_register_no_approval_required_subject'])
->set('register_pending_approval.body', $form_state['values']['user_mail_register_pending_approval_body'])
->set('register_pending_approval.subject', $form_state['values']['user_mail_register_pending_approval_subject'])
->set('status_activated.body', $form_state['values']['user_mail_status_activated_body'])
->set('status_activated.subject', $form_state['values']['user_mail_status_activated_subject'])
->set('status_blocked.body', $form_state['values']['user_mail_status_blocked_body'])
->set('status_blocked.subject', $form_state['values']['user_mail_status_blocked_subject'])
->set('status_canceled.body', $form_state['values']['user_mail_status_canceled_body'])
->set('status_canceled.subject', $form_state['values']['user_mail_status_canceled_subject'])
->save();
}
/**
* Menu callback: administer permissions.
Dries Buytaert
committed
*
* @ingroup forms
Dries Buytaert
committed
* @see user_admin_permissions_submit()
* @see theme_user_admin_permissions()
*/
function user_admin_permissions($form, $form_state, $rid = NULL) {
// Retrieve role names for columns.
$role_names = user_roles();
catch
committed
if (isset($rid)) {
$role_names = array($rid => $role_names[$rid]);
}
// Fetch permissions for all roles or the one selected role.
$role_permissions = user_role_permissions($role_names);
// Store $role_names for use when saving the data.
$form['role_names'] = array(
'#type' => 'value',
'#value' => $role_names,
);
// Render role/permission overview:
$options = array();
Angie Byron
committed
$module_info = system_get_info('module');
Dries Buytaert
committed
$hide_descriptions = system_admin_compact_mode();
// Get a list of all the modules implementing a hook_permission() and sort by
// display name.
$modules = array();
foreach (module_implements('permission') as $module) {
$modules[$module] = $module_info[$module]['name'];
}
asort($modules);
foreach ($modules as $module => $display_name) {
if ($permissions = module_invoke($module, 'permission')) {
$form['permission'][] = array(
Angie Byron
committed
'#markup' => $module_info[$module]['name'],
'#id' => $module,
Dries Buytaert
committed
);
Angie Byron
committed
foreach ($permissions as $perm => $perm_item) {
Dries Buytaert
committed
// Fill in default values for the permission.
$perm_item += array(
'description' => '',
'restrict access' => FALSE,
'warning' => !empty($perm_item['restrict access']) ? t('Warning: Give to trusted roles only; this permission has security implications.') : '',
);
$options[$perm] = '';
$form['permission'][$perm] = array(
'#type' => 'item',
Angie Byron
committed
'#markup' => $perm_item['title'],
Dries Buytaert
committed
'#description' => theme('user_permission_description', array('permission_item' => $perm_item, 'hide' => $hide_descriptions)),
);
foreach ($role_names as $rid => $name) {
// Builds arrays for checked boxes for each role
if (isset($role_permissions[$rid][$perm])) {
$status[$rid][] = $perm;
}
}
}
}
}
// Have to build checkboxes here after checkbox arrays are built
foreach ($role_names as $rid => $name) {
$form['checkboxes'][$rid] = array(
'#type' => 'checkboxes',
'#options' => $options,
'#default_value' => isset($status[$rid]) ? $status[$rid] : array(),
'#attributes' => array('class' => array('rid-' . $rid)),
);
$form['role_names'][$rid] = array('#markup' => check_plain($name), '#tree' => TRUE);
}
Dries Buytaert
committed
Dries Buytaert
committed
$form['actions'] = array('#type' => 'actions');
$form['actions']['submit'] = array('#type' => 'submit', '#value' => t('Save permissions'));
$form['#attached']['library'][] = array('user', 'drupal.user.permissions');
Dries Buytaert
committed
return $form;
}
/**
* Save permissions selected on the administer permissions page.
*
Dries Buytaert
committed
* @see user_admin_permissions()
*/
Dries Buytaert
committed
function user_admin_permissions_submit($form, &$form_state) {
foreach ($form_state['values']['role_names'] as $rid => $name) {
Dries Buytaert
committed
user_role_change_permissions($rid, $form_state['values'][$rid]);
}
drupal_set_message(t('The changes have been saved.'));
// Clear the cached pages and blocks.
cache_invalidate_tags(array('content' => TRUE));
}
/**
* Returns HTML for the administer permissions page.
*
* @param $variables
* An associative array containing:
* - form: A render element representing the form.
*
* @ingroup themeable
*/
Dries Buytaert
committed
function theme_user_admin_permissions($variables) {
$form = $variables['form'];
Gábor Hojtsy
committed
$roles = user_roles();
foreach (element_children($form['permission']) as $key) {
$row = array();
// Module name
if (is_numeric($key)) {
$row[] = array('data' => drupal_render($form['permission'][$key]), 'class' => array('module'), 'id' => 'module-' . $form['permission'][$key]['#id'], 'colspan' => count($form['role_names']['#value']) + 1);
}
else {
// Permission row.
$row[] = array(
'data' => drupal_render($form['permission'][$key]),
'class' => array('permission'),
);
foreach (element_children($form['checkboxes']) as $rid) {
Dries Buytaert
committed
$form['checkboxes'][$rid][$key]['#title'] = $roles[$rid] . ': ' . $form['permission'][$key]['#markup'];
Dries Buytaert
committed
$form['checkboxes'][$rid][$key]['#title_display'] = 'invisible';
$row[] = array('data' => drupal_render($form['checkboxes'][$rid][$key]), 'class' => array('checkbox'));
}
}
}
$header[] = (t('Permission'));
foreach (element_children($form['role_names']) as $rid) {
$header[] = array('data' => drupal_render($form['role_names'][$rid]), 'class' => array('checkbox'));
}
$output = theme('system_compact_link');
Dries Buytaert
committed
$output .= theme('table', array('header' => $header, 'rows' => $rows, 'attributes' => array('id' => 'permissions')));
$output .= drupal_render_children($form);
return $output;
}
Dries Buytaert
committed
/**
* Returns HTML for an individual permission description.
Dries Buytaert
committed
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
*
* @param $variables
* An associative array containing:
* - permission_item: An associative array representing the permission whose
* description is being themed. Useful keys include:
* - description: The text of the permission description.
* - warning: A security-related warning message about the permission (if
* there is one).
* - hide: A boolean indicating whether or not the permission description was
* requested to be hidden rather than shown.
*
* @ingroup themeable
*/
function theme_user_permission_description($variables) {
if (!$variables['hide']) {
$description = array();
$permission_item = $variables['permission_item'];
if (!empty($permission_item['description'])) {
$description[] = $permission_item['description'];
}
if (!empty($permission_item['warning'])) {
$description[] = '<em class="permission-warning">' . $permission_item['warning'] . '</em>';
}
if (!empty($description)) {
return implode(' ', $description);
}
}
}
/**
* Form to re-order roles or add a new one.
Dries Buytaert
committed
*
* @ingroup forms
* @see theme_user_admin_roles()
*/
function user_admin_roles($form, $form_state) {
catch
committed
$roles = db_select('role', 'r')
->addTag('translatable')
->fields('r')
->orderBy('weight')
->orderBy('name')
->execute();
$form['roles'] = array(
'#tree' => TRUE,
);
catch
committed
$max_weight = 0;
foreach ($roles as $role) {
$max_weight = max($max_weight, $role->weight);
$form['roles'][$role->rid]['#role'] = $role;
$form['roles'][$role->rid]['#weight'] = $role->weight;
$form['roles'][$role->rid]['name'] = array(
'#markup' => check_plain($role->name),
);
catch
committed
$form['roles'][$role->rid]['weight'] = array(
'#type' => 'textfield',
catch
committed
'#title' => t('Weight for @title', array('@title' => $role->name)),
Dries Buytaert
committed
'#title_display' => 'invisible',
'#size' => 4,
catch
committed
'#default_value' => $role->weight,
'#attributes' => array('class' => array('role-weight')),
);
Angie Byron
committed
$links['edit'] = array(
'title' => t('edit role'),
'href' => 'admin/people/roles/edit/' . $role->rid,
'weight' => 0,
);
$links['permissions'] = array(
'title' => t('edit permissions'),
'href' => 'admin/people/permissions/' . $role->rid,
'weight' => 5,
catch
committed
);
Angie Byron
committed
$form['roles'][$role->rid]['operations'] = array(
'#type' => 'operations',
'#links' => $links,
catch
committed
);
}
catch
committed
// Embed the role add form.
$add_role = (object) array(
'rid' => NULL,
'name' => NULL,
'weight' => $max_weight + 1,
);
catch
committed
$add_form = user_admin_role(array(), $form_state, $add_role);
$add_form['actions']['submit']['#submit'] = array('user_admin_role_submit');
$add_form['role']['actions'] = $add_form['actions'];
unset($add_form['actions']);
$form += $add_form;
$form['actions']['#type'] = 'actions';
Dries Buytaert
committed
$form['actions']['submit'] = array(
'#type' => 'submit',
'#value' => t('Save order'),
catch
committed
// Do not validate the add form when saving the order.
'#limit_validation_errors' => array(array('roles')),
'#submit' => array('user_admin_roles_order_submit'),
);
return $form;
}
/**
* Form submit function. Update the role weights.
*/
function user_admin_roles_order_submit($form, &$form_state) {
foreach ($form_state['values']['roles'] as $rid => $role_values) {
$role = $form['roles'][$rid]['#role'];
$role->weight = $role_values['weight'];
user_role_save($role);
}
drupal_set_message(t('The role settings have been updated.'));
}
/**
* Returns HTML for the role order and new role form.
*
* @param $variables
* An associative array containing:
* - form: A render element representing the form.
*
* @ingroup themeable
*/
function theme_user_admin_roles($variables) {
$form = $variables['form'];
Angie Byron
committed
$header = array(t('Name'), t('Weight'), t('Operations'));
foreach (element_children($form['roles']) as $rid) {
$row = array();
catch
committed
foreach (element_children($form['roles'][$rid]) as $column) {
$row[] = drupal_render($form['roles'][$rid][$column]);
}
$rows[] = array('data' => $row, 'class' => array('draggable'));
}
catch
committed
// Distribute the role add form into table columns.
$form['role']['name']['#title_display'] = 'invisible';
unset($form['role']['name']['#description']);
unset($form['role']['rid']['#description']);
$actions = $form['role']['actions'];
unset($form['role']['actions']);
unset($form['role']['weight']);
$row = array();
$row[] = drupal_render($form['role']);
// Empty placeholder for the weight column.
$row[] = '';
$row[] = array('data' => drupal_render($actions), 'colspan' => 2);
$rows[] = array('data' => $row);
drupal_add_tabledrag('user-roles', 'order', 'sibling', 'role-weight');
$output = theme('table', array('header' => $header, 'rows' => $rows, 'attributes' => array('id' => 'user-roles')));
$output .= drupal_render_children($form);
return $output;
}
/**
* Form to configure a single role.
*
* @ingroup forms
* @see user_admin_role_submit()
*/
function user_admin_role($form, $form_state, $role) {
catch
committed
$form['role'] = array(
'#tree' => TRUE,
'#parents' => array('role'),
);
catch
committed
$form['role']['name'] = array(
'#type' => 'textfield',
'#title' => t('Role name'),
'#default_value' => $role->name,
'#size' => 30,
'#required' => TRUE,
'#maxlength' => 64,
catch
committed
'#description' => t('The name for this role. Example: "Moderator", "Editorial board", "Site architect".'),
);
catch
committed
$form['role']['rid'] = array(
'#type' => 'machine_name',
'#default_value' => $role->rid,
'#required' => TRUE,
'#disabled' => !empty($role->rid),
'#size' => 30,
'#maxlength' => 64,
'#machine_name' => array(
'exists' => 'user_role_load',
'source' => array('role', 'name'),
),
);
catch
committed
$form['role']['weight'] = array(
'#type' => 'value',
'#value' => $role->weight,
);
Dries Buytaert
committed
$form['actions'] = array('#type' => 'actions');
$form['actions']['submit'] = array(
'#type' => 'submit',
catch
committed
'#value' => !empty($role->rid) ? t('Save role') : t('Add role'),
);
$form['actions']['delete'] = array(
'#type' => 'submit',
'#value' => t('Delete role'),
catch
committed
'#access' => !empty($role->rid) && !in_array($role->rid, array(DRUPAL_ANONYMOUS_RID, DRUPAL_AUTHENTICATED_RID)),
Dries Buytaert
committed
'#submit' => array('user_admin_role_delete_submit'),
);
return $form;