Same name and namespace in other branches
  1. 4.6.x modules/user.module \user_register()
  2. 4.7.x modules/user.module \user_register()
  3. 5.x modules/user/user.module \user_register()

Form builder; The user registration form.

See also

user_register_validate()

user_register_submit()

Related topics

4 string references to 'user_register'
user_admin_settings in modules/user/user.admin.inc
Form builder; Configure user settings for this site.
user_menu in modules/user/user.module
Implementation of hook_menu().
user_register_access in modules/user/user.module
user_register_submit in modules/user/user.module
Submit handler for the user registration form.

File

modules/user/user.module, line 2487
Enables the user registration and login system.

Code

function user_register() {
  global $user;
  $admin = user_access('administer users');

  // If we aren't admin but already logged on, go to the user page instead.
  if (!$admin && $user->uid) {
    drupal_goto('user/' . $user->uid);
  }
  $form = array();

  // Display the registration form.
  if (!$admin) {
    $form['user_registration_help'] = array(
      '#value' => filter_xss_admin(variable_get('user_registration_help', '')),
      // Ensure that user registration help appears above profile fields.
      '#weight' => -20,
    );
  }

  // Merge in the default user edit fields.
  $form = array_merge($form, user_edit_form($form_state, NULL, NULL, TRUE));
  if ($admin) {
    $form['account']['notify'] = array(
      '#type' => 'checkbox',
      '#title' => t('Notify user of new account'),
    );

    // Redirect back to page which initiated the create request;
    // usually admin/user/user/create.
    $form['destination'] = array(
      '#type' => 'hidden',
      '#value' => $_GET['q'],
    );
  }

  // Create a dummy variable for pass-by-reference parameters.
  $null = NULL;
  $extra = _user_forms($null, NULL, NULL, 'register');

  // Remove form_group around default fields if there are no other groups.
  if (!$extra) {
    foreach (array(
      'name',
      'mail',
      'pass',
      'status',
      'roles',
      'notify',
    ) as $key) {
      if (isset($form['account'][$key])) {
        $form[$key] = $form['account'][$key];
      }
    }
    unset($form['account']);
  }
  else {
    $form = array_merge($form, $extra);
  }
  if (variable_get('configurable_timezones', 1)) {

    // Override field ID, so we only change timezone on user registration,
    // and never touch it on user edit pages.
    $form['timezone'] = array(
      '#type' => 'hidden',
      '#default_value' => variable_get('date_default_timezone', NULL),
      '#id' => 'edit-user-register-timezone',
    );

    // Add the JavaScript callback to automatically set the timezone.
    drupal_add_js('
// Global Killswitch
if (Drupal.jsEnabled) {
  $(document).ready(function() {
    Drupal.setDefaultTimezone();
  });
}', 'inline');
  }
  $form['submit'] = array(
    '#type' => 'submit',
    '#value' => t('Create new account'),
    '#weight' => 30,
  );
  $form['#validate'][] = 'user_register_validate';
  return $form;
}