| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230 | 
							- <?php
 
- /**
 
-  * @file
 
-  * Allows users to register with an e-mail address as their username.
 
-  */
 
- /**
 
-  * Implements hook_user_insert().
 
-  */
 
- function email_registration_user_insert(&$edit, &$account, $category = NULL) {
 
-   // Don't create a new username if one is already set.
 
-   if (!empty($account->name) && strpos($account->name, 'email_registration_') !== 0) {
 
-     return;
 
-   }
 
-   // Other modules may implement hook_email_registration_name($edit, $account)
 
-   // to generate a username (return a string to be used as the username, NULL
 
-   // to have email_registration generate it).
 
-   $names = module_invoke_all('email_registration_name', $edit, $account);
 
-   // Remove any empty entries.
 
-   $names = array_filter($names);
 
-   if (empty($names)) {
 
-     // Strip off everything after the @ sign.
 
-     $new_name = preg_replace('/@.*$/', '', $edit['mail']);
 
-     // Clean up the username.
 
-     $new_name = email_registration_cleanup_username($new_name, $account->uid);
 
-   }
 
-   else {
 
-     // One would expect a single implementation of the hook, but if there
 
-     // are multiples out there use the last one.
 
-     $new_name = array_pop($names);
 
-   }
 
-   // Ensure whatever name we have is unique.
 
-   $new_name = email_registration_unique_username($new_name, $account->uid);
 
-   // Replace with generated username.
 
-   db_update('users')
 
-     ->fields(array('name' => $new_name))
 
-     ->condition('uid', $account->uid)
 
-     ->execute();
 
-   $edit['name'] = $new_name;
 
-   $account->name = $new_name;
 
- }
 
- /**
 
-  * Given a starting point returns a legal, unique Drupal username.
 
-  *
 
-  * This function is designed to work on the results of the /user/register or
 
-  * /admin/people/create forms which have already called user_validate_name,
 
-  * valid_email_address or a similar function. If your custom code is creating
 
-  * users, you should ensure that the email/name is already validated using
 
-  * something like that. Alternatively you can prepend the account user name
 
-  * to contain 'email_registration_' to allow for the email registration hooks
 
-  * to generate a unique username based on mail.
 
-  *
 
-  * @param string $name
 
-  *   A name from which to base the final user name.  May contain illegal
 
-  *   characters; these will be stripped.
 
-  * @param int $uid
 
-  *   (optional) Uid to ignore when searching for unique user
 
-  *   (e.g. if we update the username after the {users} row is inserted)
 
-  *
 
-  * @return string
 
-  *   A unique user name based on $name.
 
-  *
 
-  * @see user_validate_name()
 
-  */
 
- function email_registration_unique_username($name, $uid = NULL) {
 
-   // Iterate until we find a unique name.
 
-   $i = 0;
 
-   do {
 
-     $new_name = empty($i) ? $name : $name . '_' . $i;
 
-     if ($uid) {
 
-       $found = db_query_range("SELECT uid from {users} WHERE uid <> :uid AND name = :name", 0, 1, array(':uid' => $uid, ':name' => $new_name))->fetchAssoc();
 
-     }
 
-     else {
 
-       $found = db_query_range("SELECT uid from {users} WHERE name = :name", 0, 1, array(':name' => $new_name))->fetchAssoc();
 
-     }
 
-     $i++;
 
-   } while (!empty($found));
 
-   return $new_name;
 
- }
 
- /**
 
-  * Function to clean up username.
 
-  *
 
-  * e.g.
 
-  *     Replace two or more spaces with a single underscore
 
-  *     Strip illegal characters.
 
-  *
 
-  * @param string $name
 
-  *   The username to be cleaned up.
 
-  *
 
-  * @return string
 
-  *   Cleaned up username.
 
-  */
 
- function email_registration_cleanup_username($name, $uid = NULL) {
 
-   // Strip illegal characters.
 
-   $name = preg_replace('/[^\x{80}-\x{F7} a-zA-Z0-9@_.\'-]/', '', $name);
 
-   // Strip leading and trailing spaces.
 
-   $name = trim($name);
 
-   // Convert any other series of spaces to a single underscore.
 
-   $name = preg_replace('/\s+/', '_', $name);
 
-   // If there's nothing left use a default.
 
-   $name = ('' === $name) ? t('user') : $name;
 
-   if (!empty($uid)) {
 
-     // Put uid on the end of the name.
 
-     $name = $name . '_' . $uid;
 
-   }
 
-   // Truncate to a reasonable size.
 
-   $name = (drupal_strlen($name) > (USERNAME_MAX_LENGTH - 10)) ? drupal_substr($name, 0, USERNAME_MAX_LENGTH - 11) : $name;
 
-   return $name;
 
- }
 
- /**
 
-  * Implements hook_form_FORM_ID_alter().
 
-  */
 
- function email_registration_form_user_register_form_alter(&$form, &$form_state) {
 
-   $form['account']['name']['#type'] = 'hidden';
 
-   $form['account']['name']['#value'] = 'email_registration_' . user_password();
 
-   $form['account']['mail']['#title'] = t('E-mail');
 
- }
 
- /**
 
-  * Implements hook_form_FORM_ID_alter().
 
-  */
 
- function email_registration_form_user_pass_alter(&$form, &$form_state) {
 
-   $form['name']['#title'] = t('E-mail');
 
- }
 
- /**
 
-  * Implements hook_form_FORM_ID_alter().
 
-  */
 
- function email_registration_form_user_login_alter(&$form, &$form_state) {
 
-   $form['name']['#title'] = variable_get('email_registration_login_with_username', TRUE)
 
-     ? t('E-mail or username')
 
-     : t('E-mail');
 
-   $form['name']['#description'] = variable_get('email_registration_login_with_username', TRUE)
 
-       ? t('Enter your e-mail address or username.')
 
-       : t('Enter your e-mail address.');
 
-   $form['name']['#element_validate'][] = 'email_registration_user_login_validate';
 
-   $form['pass']['#description'] = t('Enter the password that accompanies your e-mail.');
 
- }
 
- /**
 
-  * Implements hook_form_FORM_ID_alter().
 
-  */
 
- function email_registration_form_user_login_block_alter(&$form, &$form_state) {
 
-   $form['name']['#title'] = variable_get('email_registration_login_with_username', TRUE)
 
-     ? t('E-mail or username')
 
-     : t('E-mail');
 
-   $form['name']['#element_validate'][] = 'email_registration_user_login_validate';
 
- }
 
- /**
 
-  * Implements hook_form_FORM_ID_alter().
 
-  */
 
- function email_registration_form_user_admin_settings_alter(&$form, &$form_state) {
 
-   $form['registration_cancellation']['email_registration_login_with_username'] = array(
 
-     '#type' => 'checkbox',
 
-     '#title' => t('Allow users login with e-mail or username.'),
 
-     '#description' => t('Allow users to login with their username in addition to their e-mail.'),
 
-     '#default_value' => variable_get('email_registration_login_with_username', TRUE),
 
-     );
 
-   $form['#submit'][] = 'email_registration_form_user_admin_settings_submit';
 
- }
 
- /**
 
-  * Submit function for user_admin_settings to save our variable.
 
-  *
 
-  * @see email_registration_form_user_admin_settings_alter().
 
-  */
 
- function email_registration_form_user_admin_settings_submit($form, &$form_state) {
 
-   variable_set('email_registration_login_with_username', $form_state['values']['email_registration_login_with_username']);
 
- }
 
- /**
 
-  * Form element validation handler for the user login form.
 
-  *
 
-  * Allows users to authenticate by email, which is our preferred method.
 
-  */
 
- function email_registration_user_login_validate($form, &$form_state) {
 
-   $name = NULL;
 
-   if (isset($form_state['values']['name']) && valid_email_address($form_state['values']['name'])) {
 
-     // Try to load the username matching the email, if any exists.
 
-     $name = db_select('users')
 
-     ->fields('users', array('name'))
 
-     ->condition('mail', db_like($form_state['values']['name']), 'LIKE')
 
-     ->execute()
 
-     ->fetchField();
 
-   }
 
-   // If the value is set, and a valid email, and a match was found, use it.
 
-   if (!empty($name)) {
 
-     // Keep the email value in form state for further use/validation.
 
-     $form_state['values']['email'] = $form_state['values']['name'];
 
-     // If the name matches an e-mail, assume that it's the desired name and
 
-     // set the username in the form values.
 
-     $form_state['values']['name'] = $name;
 
-   }
 
-   elseif (!variable_get('email_registration_login_with_username', TRUE)) {
 
-     // If no username was found for the e-mail, and registration with username
 
-     // is not allowed, unset the name from the form. This prevents
 
-     // user_login_authenticate_validate() from trying to load a user from the
 
-     // value as a username, which in turn causes user_login_final_validate()
 
-     // to set a form error telling the user that no account has been found.
 
-     // We have to set this to NULL rather than FALSE, because
 
-     // user_login_name_validate() uses isset() rather than empty().
 
-     $form_state['values']['name'] = NULL;
 
-   }
 
- }
 
- /**
 
-  * Implements hook_form_FORM_ID_alter().
 
-  */
 
- function email_registration_form_user_profile_form_alter(&$form, &$form_state) {
 
-   $form['account']['name']['#title'] = t('Display name');
 
- }
 
 
  |