Newer
Older
<?php
/**
* @file
* Admin page callback file for the user module.
*/
function user_admin($callback_arg = '') {
$op = isset($_POST['op']) ? $_POST['op'] : $callback_arg;
switch ($op) {
case t('Create new account'):
case 'create':
$build['user_register'] = drupal_get_form('user_register_form');
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' => 'fieldset',
'#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]') {
// Merge an array of arrays into one if necessary.
$options = ($filter == 'permission') ? form_options_flatten($filters[$filter]['options']) : $filters[$filter]['options'];
// Only accept valid selections offered on the dropdown, block bad input.
if (isset($options[$form_state['values'][$filter]])) {
$_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'),
'roles' => array('data' => t('Roles')),
'member_for' => array('data' => t('Member for'), 'field' => 'u.created', 'sort' => 'desc'),
'access' => array('data' => t('Last access'), 'field' => 'u.access'),
'operations' => array('data' => 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)');
$query = $query->extend('PagerDefault')->extend('TableSort');
$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' => 'fieldset',
'#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) {
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'),
Dries Buytaert
committed
'operations' => array('data' => array('#type' => 'link', '#title' => t('edit'), '#href' => "user/$account->uid/edit", '#options' => array('query' => $destination))),
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);
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
$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
Gábor Hojtsy
committed
* @see system_settings_form()
*/
function user_admin_settings() {
Angie Byron
committed
// Settings for anonymous users.
$form['anonymous_settings'] = array(
'#type' => 'fieldset',
'#title' => t('Anonymous users'),
);
$form['anonymous_settings']['anonymous'] = array(
'#type' => 'textfield',
'#title' => t('Name'),
'#default_value' => variable_get('anonymous', t('Anonymous')),
'#description' => t('The name used to indicate anonymous users.'),
'#required' => TRUE,
);
Dries Buytaert
committed
// Administrative role option.
$form['admin_role'] = array(
'#type' => 'fieldset',
'#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'),
'#default_value' => variable_get('user_admin_role', 0),
'#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
// User registration settings.
$form['registration_cancellation'] = array(
Angie Byron
committed
'#type' => 'fieldset',
Angie Byron
committed
'#title' => t('Registration and cancellation'),
);
$form['registration_cancellation']['user_register'] = array(
'#type' => 'radios',
'#title' => t('Who can register accounts?'),
Dries Buytaert
committed
'#default_value' => variable_get('user_register', USER_REGISTER_VISITORS_ADMINISTRATIVE_APPROVAL),
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.'),
'#default_value' => variable_get('user_email_verification', TRUE),
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
module_load_include('inc', 'user', 'user.pages');
$form['registration_cancellation']['user_cancel_method'] = array(
Angie Byron
committed
'#type' => 'item',
'#title' => t('When cancelling a user account'),
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();
foreach (element_children($form['registration_cancellation']['user_cancel_method']) as $element) {
Angie Byron
committed
// Remove all account cancellation methods that have #access defined, as
// those cannot be configured as default method.
Angie Byron
committed
if (isset($form['registration_cancellation']['user_cancel_method'][$element]['#access'])) {
$form['registration_cancellation']['user_cancel_method'][$element]['#access'] = FALSE;
Angie Byron
committed
}
// Remove the description (only displayed on the confirmation form).
else {
Angie Byron
committed
unset($form['registration_cancellation']['user_cancel_method'][$element]['#description']);
Angie Byron
committed
}
}
Angie Byron
committed
// Account settings.
$form['personalization'] = array(
'#type' => 'fieldset',
Angie Byron
committed
'#title' => t('Personalization'),
);
$form['personalization']['user_signatures'] = array(
'#type' => 'checkbox',
'#title' => t('Enable signatures.'),
'#default_value' => variable_get('user_signatures', 0),
);
// If picture support is enabled, check whether the picture directory exists.
if (variable_get('user_pictures', 0)) {
$picture_path = file_default_scheme() . '://' . variable_get('user_picture_path', 'pictures');
if (!file_prepare_directory($picture_path, FILE_CREATE_DIRECTORY)) {
form_set_error('user_picture_path', t('The directory %directory does not exist or is not writable.', array('%directory' => $picture_path)));
Angie Byron
committed
watchdog('file system', 'The directory %directory does not exist or is not writable.', array('%directory' => $picture_path), WATCHDOG_ERROR);
}
Angie Byron
committed
}
$picture_support = variable_get('user_pictures', 0);
$form['personalization']['user_pictures'] = array(
'#type' => 'checkbox',
'#title' => t('Enable user pictures.'),
'#default_value' => $picture_support,
);
drupal_add_js(drupal_get_path('module', 'user') . '/user.js');
$form['personalization']['pictures'] = array(
Dries Buytaert
committed
'#type' => 'container',
'#states' => array(
// Hide the additional picture settings when user pictures are disabled.
'invisible' => array(
'input[name="user_pictures"]' => array('checked' => FALSE),
),
),
Angie Byron
committed
);
$form['personalization']['pictures']['user_picture_path'] = array(
'#type' => 'textfield',
'#title' => t('Picture directory'),
'#default_value' => variable_get('user_picture_path', 'pictures'),
'#size' => 30,
'#maxlength' => 255,
'#description' => t('Subdirectory in the file upload directory where pictures will be stored.'),
Angie Byron
committed
);
$form['personalization']['pictures']['user_picture_default'] = array(
'#type' => 'textfield',
'#title' => t('Default picture'),
'#default_value' => variable_get('user_picture_default', ''),
'#size' => 30,
'#maxlength' => 255,
'#description' => t('URL of picture to display for users with no custom picture selected. Leave blank for none.'),
);
if (module_exists('image')) {
$form['personalization']['pictures']['settings']['user_picture_style'] = array(
'#type' => 'select',
'#title' => t('Picture display style'),
'#options' => image_style_options(TRUE),
'#default_value' => variable_get('user_picture_style', ''),
Dries Buytaert
committed
'#description' => t('The style selected will be used on display, while the original image is retained. Styles may be configured in the <a href="!url">Image styles</a> administration area.', array('!url' => url('admin/config/media/image-styles'))),
);
}
Angie Byron
committed
$form['personalization']['pictures']['user_picture_dimensions'] = array(
'#type' => 'textfield',
'#title' => t('Picture upload dimensions'),
Angie Byron
committed
'#default_value' => variable_get('user_picture_dimensions', '85x85'),
'#size' => 10,
Angie Byron
committed
'#maxlength' => 10,
'#field_suffix' => ' ' . t('pixels'),
Dries Buytaert
committed
'#description' => t('Pictures larger than this will be scaled down to this size.'),
Angie Byron
committed
);
$form['personalization']['pictures']['user_picture_file_size'] = array(
'#type' => 'textfield',
'#title' => t('Picture upload file size'),
Angie Byron
committed
'#default_value' => variable_get('user_picture_file_size', '30'),
'#size' => 10,
Angie Byron
committed
'#maxlength' => 10,
'#field_suffix' => ' ' . t('KB'),
Dries Buytaert
committed
'#description' => t('Maximum allowed file size for uploaded pictures. Upload size is normally limited only by the PHP maximum post and file upload settings, and images are automatically scaled down to the dimensions specified above.'),
Angie Byron
committed
);
$form['personalization']['pictures']['user_picture_guidelines'] = array(
'#type' => 'textarea',
'#title' => t('Picture guidelines'),
'#default_value' => variable_get('user_picture_guidelines', ''),
'#description' => t("This text is displayed at the picture upload form in addition to the default guidelines. It's useful for helping or instructing your users."),
);
$form['email_title'] = array(
'#type' => 'item',
'#title' => t('E-mails'),
);
$form['email'] = array(
'#type' => 'vertical_tabs',
);
// 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' => 'fieldset',
Angie Byron
committed
'#title' => t('Welcome (new user created by administrator)'),
'#collapsible' => TRUE,
Dries Buytaert
committed
'#collapsed' => (variable_get('user_register', USER_REGISTER_VISITORS_ADMINISTRATIVE_APPROVAL) != 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'),
Dries Buytaert
committed
'#default_value' => _user_mail_text('register_admin_created_subject', NULL, array(), FALSE),
'#maxlength' => 180,
);
Angie Byron
committed
$form['email_admin_created']['user_mail_register_admin_created_body'] = array(
'#type' => 'textarea',
'#title' => t('Body'),
Dries Buytaert
committed
'#default_value' => _user_mail_text('register_admin_created_body', NULL, array(), FALSE),
'#rows' => 15,
);
Dries Buytaert
committed
$form['email_pending_approval'] = array(
'#type' => 'fieldset',
Dries Buytaert
committed
'#title' => t('Welcome (awaiting approval)'),
'#collapsible' => TRUE,
Dries Buytaert
committed
'#collapsed' => (variable_get('user_register', USER_REGISTER_VISITORS_ADMINISTRATIVE_APPROVAL) != 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'),
Dries Buytaert
committed
'#default_value' => _user_mail_text('register_pending_approval_subject', NULL, array(), FALSE),
'#maxlength' => 180,
);
Dries Buytaert
committed
$form['email_pending_approval']['user_mail_register_pending_approval_body'] = array(
'#type' => 'textarea',
'#title' => t('Body'),
Dries Buytaert
committed
'#default_value' => _user_mail_text('register_pending_approval_body', NULL, array(), FALSE),
Dries Buytaert
committed
'#rows' => 8,
);
Dries Buytaert
committed
$form['email_no_approval_required'] = array(
'#type' => 'fieldset',
Dries Buytaert
committed
'#title' => t('Welcome (no approval required)'),
'#collapsible' => TRUE,
Dries Buytaert
committed
'#collapsed' => (variable_get('user_register', USER_REGISTER_VISITORS_ADMINISTRATIVE_APPROVAL) != 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'),
Dries Buytaert
committed
'#default_value' => _user_mail_text('register_no_approval_required_subject', NULL, array(), FALSE),
'#maxlength' => 180,
);
Dries Buytaert
committed
$form['email_no_approval_required']['user_mail_register_no_approval_required_body'] = array(
'#type' => 'textarea',
'#title' => t('Body'),
Dries Buytaert
committed
'#default_value' => _user_mail_text('register_no_approval_required_body', NULL, array(), FALSE),
Dries Buytaert
committed
'#rows' => 15,
);
Angie Byron
committed
$form['email_password_reset'] = array(
'#type' => 'fieldset',
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'),
Dries Buytaert
committed
'#default_value' => _user_mail_text('password_reset_subject', NULL, array(), FALSE),
'#maxlength' => 180,
);
Angie Byron
committed
$form['email_password_reset']['user_mail_password_reset_body'] = array(
'#type' => 'textarea',
'#title' => t('Body'),
Dries Buytaert
committed
'#default_value' => _user_mail_text('password_reset_body', NULL, array(), FALSE),
'#rows' => 12,
);
Angie Byron
committed
$form['email_activated'] = array(
'#type' => 'fieldset',
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.'),
'#default_value' => variable_get('user_mail_status_activated_notify', TRUE),
);
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'),
Dries Buytaert
committed
'#default_value' => _user_mail_text('status_activated_subject', NULL, array(), FALSE),
'#maxlength' => 180,
);
Dries Buytaert
committed
$form['email_activated']['settings']['user_mail_status_activated_body'] = array(
'#type' => 'textarea',
'#title' => t('Body'),
Dries Buytaert
committed
'#default_value' => _user_mail_text('status_activated_body', NULL, array(), FALSE),
'#rows' => 15,
);
Angie Byron
committed
$form['email_blocked'] = array(
'#type' => 'fieldset',
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.'),
'#default_value' => variable_get('user_mail_status_blocked_notify', FALSE),
);
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'),
Dries Buytaert
committed
'#default_value' => _user_mail_text('status_blocked_subject', NULL, array(), FALSE),
'#maxlength' => 180,
);
Dries Buytaert
committed
$form['email_blocked']['settings']['user_mail_status_blocked_body'] = array(
'#type' => 'textarea',
'#title' => t('Body'),
Dries Buytaert
committed
'#default_value' => _user_mail_text('status_blocked_body', NULL, array(), FALSE),
'#rows' => 3,
);
Angie Byron
committed
$form['email_cancel_confirm'] = array(
Angie Byron
committed
'#type' => 'fieldset',
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'),
Dries Buytaert
committed
'#default_value' => _user_mail_text('cancel_confirm_subject', NULL, array(), FALSE),
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'),
Dries Buytaert
committed
'#default_value' => _user_mail_text('cancel_confirm_body', NULL, array(), FALSE),
Angie Byron
committed
'#rows' => 3,
);
Angie Byron
committed
$form['email_canceled'] = array(
'#type' => 'fieldset',
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.'),
'#default_value' => variable_get('user_mail_status_canceled_notify', FALSE),
);
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'),
Dries Buytaert
committed
'#default_value' => _user_mail_text('status_canceled_subject', NULL, array(), FALSE),
'#maxlength' => 180,
);
Dries Buytaert
committed
$form['email_canceled']['settings']['user_mail_status_canceled_body'] = array(
'#type' => 'textarea',
'#title' => t('Body'),
Dries Buytaert
committed
'#default_value' => _user_mail_text('status_canceled_body', NULL, array(), FALSE),
'#rows' => 3,
);
Dries Buytaert
committed
return system_settings_form($form);
}
/**
* 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();
if (is_numeric($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'));
Dries Buytaert
committed
$form['#attached']['js'][] = drupal_get_path('module', 'user') . '/user.permissions.js';
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_clear_all();
}
/**
* 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) {
$roles = user_roles();
$form['roles'] = array(
'#tree' => TRUE,
);
$order = 0;
foreach ($roles as $rid => $name) {
$form['roles'][$rid]['#role'] = (object) array(
'rid' => $rid,
'name' => $name,
'weight' => $order,
);
$form['roles'][$rid]['#weight'] = $order;
$form['roles'][$rid]['weight'] = array(
'#type' => 'textfield',
'#title' => t('Weight for @title', array('@title' => $name)),
Dries Buytaert
committed
'#title_display' => 'invisible',
'#size' => 4,
'#default_value' => $order,
'#attributes' => array('class' => array('role-weight')),
);
$order++;
}
$form['name'] = array(
'#type' => 'textfield',
Dries Buytaert
committed
'#title' => t('Name'),
'#title_display' => 'invisible',
'#size' => 32,
'#maxlength' => 64,
);
$form['add'] = array(
'#type' => 'submit',
'#value' => t('Add role'),
'#validate' => array('user_admin_role_validate'),
'#submit' => array('user_admin_role_submit'),
);
Dries Buytaert
committed
$form['actions'] = array('#type' => 'actions');
$form['actions']['submit'] = array(
'#type' => 'submit',
'#value' => t('Save order'),
'#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'];
$header = array(t('Name'), t('Weight'), array('data' => t('Operations'), 'colspan' => 2));
foreach (element_children($form['roles']) as $rid) {
$name = $form['roles'][$rid]['#role']->name;
$row = array();
if (in_array($rid, array(DRUPAL_ANONYMOUS_RID, DRUPAL_AUTHENTICATED_RID))) {
$row[] = t('@name <em>(locked)</em>', array('@name' => $name));
$row[] = drupal_render($form['roles'][$rid]['weight']);
$row[] = '';
$row[] = l(t('edit permissions'), 'admin/people/permissions/' . $rid);
}
else {
$row[] = check_plain($name);
$row[] = drupal_render($form['roles'][$rid]['weight']);
$row[] = l(t('edit role'), 'admin/people/permissions/roles/edit/' . $rid);
$row[] = l(t('edit permissions'), 'admin/people/permissions/' . $rid);
}
$rows[] = array('data' => $row, 'class' => array('draggable'));
}
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
$rows[] = array(array('data' => drupal_render($form['name']) . drupal_render($form['add']), 'colspan' => 4, 'class' => 'edit-name'));
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_validate()
* @see user_admin_role_submit()
*/
function user_admin_role($form, $form_state, $role) {
if ($role->rid == DRUPAL_ANONYMOUS_RID || $role->rid == DRUPAL_AUTHENTICATED_RID) {
drupal_goto('admin/people/permissions/roles');
}
// Display the edit role form.
$form['name'] = array(
'#type' => 'textfield',
'#title' => t('Role name'),
'#default_value' => $role->name,
'#size' => 30,
'#required' => TRUE,
'#maxlength' => 64,
'#description' => t('The name for this role. Example: "moderator", "editorial board", "site architect".'),
);
$form['rid'] = array(
'#type' => 'value',
'#value' => $role->rid,
);
$form['weight'] = array(
'#type' => 'value',
'#value' => $role->weight,
);
Dries Buytaert
committed
$form['actions'] = array('#type' => 'actions');
$form['actions']['submit'] = array(
'#type' => 'submit',
'#value' => t('Save role'),
);
$form['actions']['delete'] = array(
'#type' => 'submit',
'#value' => t('Delete role'),
Dries Buytaert
committed
'#submit' => array('user_admin_role_delete_submit'),
);
return $form;
}
Dries Buytaert
committed
/**
* Form validation handler for the user_admin_role() form.
*/
function user_admin_role_validate($form, &$form_state) {
Dries Buytaert
committed
if (!empty($form_state['values']['name'])) {
if ($form_state['values']['op'] == t('Save role')) {
Dries Buytaert
committed
$role = user_role_load_by_name($form_state['values']['name']);
Dries Buytaert
committed
if ($role && $role->rid != $form_state['values']['rid']) {
form_set_error('name', t('The role name %name already exists. Choose another role name.', array('%name' => $form_state['values']['name'])));
}
}
Angie Byron
committed
elseif ($form_state['values']['op'] == t('Add role')) {
Dries Buytaert
committed
if (user_role_load_by_name($form_state['values']['name'])) {
form_set_error('name', t('The role name %name already exists. Choose another role name.', array('%name' => $form_state['values']['name'])));
}
}
}
else {
form_set_error('name', t('You must specify a valid role name.'));
}
}
Dries Buytaert
committed
/**
* Form submit handler for the user_admin_role() form.
*/
function user_admin_role_submit($form, &$form_state) {
$role = (object) $form_state['values'];
if ($form_state['values']['op'] == t('Save role')) {
Dries Buytaert
committed
user_role_save($role);