Wordpress 3.1-scripts
[autoinstalls/wordpress.git] / wp-login.php
index c97edd938f12b96282dba59efddff1a210cc9b2d..ab9cff5580a6e05c2615c98c24631dda76c8ec59 100644 (file)
@@ -79,13 +79,14 @@ function login_header($title = 'Log In', $message = '', $wp_error = '') {
 <?php
        }
 
-       do_action('login_head'); ?>
+       do_action( 'login_enqueue_scripts' );
+       do_action( 'login_head' ); ?>
 </head>
 <body class="login">
 <?php   if ( !is_multisite() ) { ?>
-<div id="login"><h1><a href="<?php echo apply_filters('login_headerurl', 'http://wordpress.org/'); ?>" title="<?php echo apply_filters('login_headertitle', __('Powered by WordPress')); ?>"><?php bloginfo('name'); ?></a></h1>
+<div id="login"><h1><a href="<?php echo apply_filters('login_headerurl', 'http://wordpress.org/'); ?>" title="<?php echo apply_filters('login_headertitle', esc_attr__('Powered by WordPress')); ?>"><?php bloginfo('name'); ?></a></h1>
 <?php   } else { ?>
-<div id="login"><h1><a href="<?php echo apply_filters('login_headerurl', network_home_url() ); ?>" title="<?php echo apply_filters('login_headertitle', $current_site->site_name ); ?>"><span class="hide"><?php bloginfo('name'); ?></span></a></h1>
+<div id="login"><h1><a href="<?php echo apply_filters('login_headerurl', network_home_url() ); ?>" title="<?php echo apply_filters('login_headertitle', esc_attr($current_site->site_name) ); ?>"><span class="hide"><?php bloginfo('name'); ?></span></a></h1>
 <?php   }
 
        $message = apply_filters('login_message', $message);
@@ -115,6 +116,31 @@ function login_header($title = 'Log In', $message = '', $wp_error = '') {
                        echo '<p class="message">' . apply_filters('login_messages', $messages) . "</p>\n";
        }
 } // End of login_header()
+
+/**
+ * Outputs the footer for the login page.
+ *
+ * @param string $input_id Which input to auto-focus
+ */
+function login_footer($input_id = '') {
+       echo "</div>\n";
+
+       if ( !empty($input_id) ) {
+?>
+<script type="text/javascript">
+try{document.getElementById('<?php echo $input_id; ?>').focus();}catch(e){}
+if(typeof wpOnload=='function')wpOnload();
+</script>
+<?php
+       }
+?>
+<p id="backtoblog"><a href="<?php bloginfo('url'); ?>/" title="<?php esc_attr_e('Are you lost?') ?>"><?php printf(__('&larr; Back to %s'), get_bloginfo('title', 'display' )); ?></a></p>
+<?php do_action('login_footer'); ?>
+</body>
+</html>
+<?php
+}
+
 function wp_shake_js() {
        global $is_iphone;
        if ( $is_iphone )
@@ -186,11 +212,12 @@ function retrieve_password() {
                // Now insert the new md5 key into the db
                $wpdb->update($wpdb->users, array('user_activation_key' => $key), array('user_login' => $user_login));
        }
-       $message = __('Someone has asked to reset the password for the following site and username.') . "\r\n\r\n";
+       $message = __('Someone requested that the password be reset for the following account:') . "\r\n\r\n";
        $message .= network_site_url() . "\r\n\r\n";
        $message .= sprintf(__('Username: %s'), $user_login) . "\r\n\r\n";
-       $message .= __('To reset your password visit the following address, otherwise just ignore this email and nothing will happen.') . "\r\n\r\n";
-       $message .= network_site_url("wp-login.php?action=rp&key=$key&login=" . rawurlencode($user_login), 'login') . "\r\n";
+       $message .= __('If this was a mistake, just ignore this email and nothing will happen.') . "\r\n\r\n";
+       $message .= __('To reset your password, visit the following address:') . "\r\n\r\n";
+       $message .= '<' . network_site_url("wp-login.php?action=rp&key=$key&login=" . rawurlencode($user_login), 'login') . ">\r\n";
 
        if ( is_multisite() )
                $blogname = $GLOBALS['current_site']->site_name;
@@ -211,14 +238,16 @@ function retrieve_password() {
 }
 
 /**
- * Handles resetting the user's password.
+ * Retrieves a user row based on password reset key and login
  *
  * @uses $wpdb WordPress Database object
  *
  * @param string $key Hash to validate sending user's password
- * @return bool|WP_Error
+ * @param string $login The user login
+ *
+ * @return object|WP_Error
  */
-function reset_password($key, $login) {
+function check_password_reset_key($key, $login) {
        global $wpdb;
 
        $key = preg_replace('/[^a-z0-9]/i', '', $key);
@@ -230,38 +259,26 @@ function reset_password($key, $login) {
                return new WP_Error('invalid_key', __('Invalid key'));
 
        $user = $wpdb->get_row($wpdb->prepare("SELECT * FROM $wpdb->users WHERE user_activation_key = %s AND user_login = %s", $key, $login));
+
        if ( empty( $user ) )
                return new WP_Error('invalid_key', __('Invalid key'));
 
-       // Generate something random for a password...
-       $new_pass = wp_generate_password();
+       return $user;
+}
 
+/**
+ * Handles resetting the user's password.
+ *
+ * @uses $wpdb WordPress Database object
+ *
+ * @param string $key Hash to validate sending user's password
+ */
+function reset_password($user, $new_pass) {
        do_action('password_reset', $user, $new_pass);
 
        wp_set_password($new_pass, $user->ID);
-       update_user_option($user->ID, 'default_password_nag', true, true); //Set up the Password change nag.
-       $message  = sprintf(__('Username: %s'), $user->user_login) . "\r\n";
-       $message .= sprintf(__('Password: %s'), $new_pass) . "\r\n";
-       $message .= site_url('wp-login.php', 'login') . "\r\n";
-
-       if ( is_multisite() )
-               $blogname = $GLOBALS['current_site']->site_name;
-       else
-               // The blogname option is escaped with esc_html on the way into the database in sanitize_option
-               // we want to reverse this for the plain text arena of emails.
-               $blogname = wp_specialchars_decode(get_option('blogname'), ENT_QUOTES);
-
-       $title = sprintf( __('[%s] Your new password'), $blogname );
-
-       $title = apply_filters('password_reset_title', $title);
-       $message = apply_filters('password_reset_message', $message, $new_pass);
-
-       if ( $message && !wp_mail($user->user_email, $title, $message) )
-               wp_die( __('The e-mail could not be sent.') . "<br />\n" . __('Possible reason: your host may have disabled the mail() function...') );
 
        wp_password_change_notification($user);
-
-       return true;
 }
 
 /**
@@ -304,7 +321,7 @@ function register_new_user( $user_login, $user_email ) {
        if ( $errors->get_error_code() )
                return $errors;
 
-       $user_pass = wp_generate_password();
+       $user_pass = wp_generate_password( 12, false);
        $user_id = wp_create_user( $sanitized_user_login, $user_pass, $user_email );
        if ( ! $user_id ) {
                $errors->add( 'registerfail', sprintf( __( '<strong>ERROR</strong>: Couldn&#8217;t register you... please contact the <a href="mailto:%s">webmaster</a> !' ), get_option( 'admin_email' ) ) );
@@ -368,6 +385,7 @@ break;
 
 case 'lostpassword' :
 case 'retrievepassword' :
+
        if ( $http_post ) {
                $errors = retrieve_password();
                if ( !is_wp_error($errors) ) {
@@ -381,7 +399,7 @@ case 'retrievepassword' :
        $redirect_to = apply_filters( 'lostpassword_redirect', !empty( $_REQUEST['redirect_to'] ) ? $_REQUEST['redirect_to'] : '' );
 
        do_action('lost_password');
-       login_header(__('Lost Password'), '<p class="message">' . __('Please enter your username or e-mail address. You will receive a new password via e-mail.') . '</p>', $errors);
+       login_header(__('Lost Password'), '<p class="message">' . __('Please enter your username or email address. You will receive a link to create a new password via email.') . '</p>', $errors);
 
        $user_login = isset($_POST['user_login']) ? stripslashes($_POST['user_login']) : '';
 
@@ -398,58 +416,87 @@ case 'retrievepassword' :
 </form>
 
 <p id="nav">
-<?php if (get_option('users_can_register')) : ?>
-<a href="<?php echo site_url('wp-login.php', 'login') ?>"><?php _e('Log in') ?></a> |
-<a href="<?php echo site_url('wp-login.php?action=register', 'login') ?>"><?php _e('Register') ?></a>
-<?php else : ?>
 <a href="<?php echo site_url('wp-login.php', 'login') ?>"><?php _e('Log in') ?></a>
+<?php if (get_option('users_can_register')) : ?>
+ | <a href="<?php echo site_url('wp-login.php?action=register', 'login') ?>"><?php _e('Register') ?></a>
 <?php endif; ?>
 </p>
 
-</div>
-
-<p id="backtoblog"><a href="<?php bloginfo('url'); ?>/" title="<?php _e('Are you lost?') ?>"><?php printf(__('&larr; Back to %s'), get_bloginfo('title', 'display' )); ?></a></p>
-
-<script type="text/javascript">
-try{document.getElementById('user_login').focus();}catch(e){}
-if(typeof wpOnload=='function')wpOnload();
-</script>
-</body>
-</html>
 <?php
+login_footer('user_login');
 break;
 
 case 'resetpass' :
 case 'rp' :
-       $errors = reset_password($_GET['key'], $_GET['login']);
+       $user = check_password_reset_key($_GET['key'], $_GET['login']);
 
-       if ( ! is_wp_error($errors) ) {
-               wp_redirect('wp-login.php?checkemail=newpass');
-               exit();
+       if ( is_wp_error($user) ) {
+               wp_redirect( site_url('wp-login.php?action=lostpassword&error=invalidkey') );
+               exit;
        }
 
-       wp_redirect('wp-login.php?action=lostpassword&error=invalidkey');
-       exit();
+       $errors = '';
+
+       if ( isset($_POST['pass1']) && $_POST['pass1'] != $_POST['pass2'] ) {
+               $errors = new WP_Error('password_reset_mismatch', __('The passwords do not match.'));
+       } elseif ( isset($_POST['pass1']) && !empty($_POST['pass1']) ) {
+               reset_password($user, $_POST['pass1']);
+               login_header(__('Password Reset'), '<p class="message reset-pass">' . __('Your password has been reset.') . ' <a href="' . site_url('wp-login.php', 'login') . '">' . __('Log in') . '</a></p>');
+               login_footer();
+               exit;
+       }
 
+       wp_enqueue_script('utils');
+       wp_enqueue_script('user-profile');
+
+       login_header(__('Reset Password'), '<p class="message reset-pass">' . __('Enter your new password below.') . '</p>', $errors );
+
+?>
+<form name="resetpassform" id="resetpassform" action="<?php echo site_url('wp-login.php?action=resetpass&key=' . urlencode($_GET['key']) . '&login=' . urlencode($_GET['login']), 'login_post') ?>" method="post">
+       <input type="hidden" id="user_login" value="<?php echo esc_attr( $_GET['login'] ); ?>" autocomplete="off" />
+
+       <p>
+               <label><?php _e('New password') ?><br />
+               <input type="password" name="pass1" id="pass1" class="input" size="20" value="" autocomplete="off" /></label>
+       </p>
+       <p>
+               <label><?php _e('Confirm new password') ?><br />
+               <input type="password" name="pass2" id="pass2" class="input" size="20" value="" autocomplete="off" /></label>
+       </p>
+
+       <div id="pass-strength-result" class="hide-if-no-js"><?php _e('Strength indicator'); ?></div>
+       <p class="description indicator-hint"><?php _e('Hint: The password should be at least seven characters long. To make it stronger, use upper and lower case letters, numbers and symbols like ! " ? $ % ^ &amp; ).'); ?></p>
+
+       <br class="clear" />
+       <p class="submit"><input type="submit" name="wp-submit" id="wp-submit" class="button-primary" value="<?php esc_attr_e('Reset Password'); ?>" tabindex="100" /></p>
+</form>
+
+<p id="nav">
+<a href="<?php echo site_url('wp-login.php', 'login') ?>"><?php _e('Log in') ?></a>
+<?php if (get_option('users_can_register')) : ?>
+ | <a href="<?php echo site_url('wp-login.php?action=register', 'login') ?>"><?php _e('Register') ?></a>
+<?php endif; ?>
+</p>
+
+<?php
+login_footer('user_pass');
 break;
 
 case 'register' :
        if ( is_multisite() ) {
                // Multisite uses wp-signup.php
-               wp_redirect( apply_filters( 'wp_signup_location', get_bloginfo('wpurl') . '/wp-signup.php' ) );
+               wp_redirect( apply_filters( 'wp_signup_location', site_url('wp-signup.php') ) );
                exit;
        }
 
        if ( !get_option('users_can_register') ) {
-               wp_redirect('wp-login.php?registration=disabled');
+               wp_redirect( site_url('wp-login.php?registration=disabled') );
                exit();
        }
 
        $user_login = '';
        $user_email = '';
        if ( $http_post ) {
-               require_once( ABSPATH . WPINC . '/registration.php');
-
                $user_login = $_POST['user_login'];
                $user_email = $_POST['user_email'];
                $errors = register_new_user($user_login, $user_email);
@@ -485,17 +532,8 @@ case 'register' :
 <a href="<?php echo site_url('wp-login.php?action=lostpassword', 'login') ?>" title="<?php _e('Password Lost and Found') ?>"><?php _e('Lost your password?') ?></a>
 </p>
 
-</div>
-
-<p id="backtoblog"><a href="<?php bloginfo('url'); ?>/" title="<?php _e('Are you lost?') ?>"><?php printf(__('&larr; Back to %s'), get_bloginfo('title', 'display' )); ?></a></p>
-
-<script type="text/javascript">
-try{document.getElementById('user_login').focus();}catch(e){}
-if(typeof wpOnload=='function')wpOnload();
-</script>
-</body>
-</html>
 <?php
+login_footer('user_login');
 break;
 
 case 'login' :
@@ -545,9 +583,16 @@ default:
                        </div></body></html>
 <?php          exit;
                }
-               // If the user can't edit posts, send them to their profile.
-               if ( !$user->has_cap('edit_posts') && ( empty( $redirect_to ) || $redirect_to == 'wp-admin/' || $redirect_to == admin_url() ) )
-                       $redirect_to = admin_url('profile.php');
+
+               if ( ( empty( $redirect_to ) || $redirect_to == 'wp-admin/' || $redirect_to == admin_url() ) ) {
+                       // If the user doesn't belong to a blog, send them to user admin. If the user can't edit posts, send them to their profile.
+                       if ( is_multisite() && !get_active_blog_for_user($user->id) )
+                               $redirect_to = user_admin_url();
+                       elseif ( is_multisite() && !$user->has_cap('read') )
+                               $redirect_to = get_dashboard_url( $user->id );
+                       elseif ( !$user->has_cap('edit_posts') )
+                               $redirect_to = admin_url('profile.php');
+               }
                wp_safe_redirect($redirect_to);
                exit();
        }
@@ -619,7 +664,7 @@ default:
 <?php endif; ?>
 </p>
 </div>
-<p id="backtoblog"><a href="<?php bloginfo('url'); ?>/" title="<?php _e('Are you lost?') ?>"><?php printf(__('&larr; Back to %s'), get_bloginfo('title', 'display' )); ?></a></p>
+<p id="backtoblog"><a href="<?php bloginfo('url'); ?>/" title="<?php esc_attr_e('Are you lost?') ?>"><?php printf(__('&larr; Back to %s'), get_bloginfo('title', 'display' )); ?></a></p>
 <?php } else { ?>
 </div>
 <?php } ?>
@@ -629,11 +674,17 @@ function wp_attempt_focus(){
 setTimeout( function(){ try{
 <?php if ( $user_login || $interim_login ) { ?>
 d = document.getElementById('user_pass');
+d.value = '';
 <?php } else { ?>
 d = document.getElementById('user_login');
-<?php } ?>
+<?php if ( 'invalid_username' == $errors->get_error_code() ) { ?>
+if( d.value != '' )
 d.value = '';
+<?php
+}
+}?>
 d.focus();
+d.select();
 } catch(e){}
 }, 200);
 }
@@ -643,6 +694,7 @@ wp_attempt_focus();
 <?php } ?>
 if(typeof wpOnload=='function')wpOnload();
 </script>
+<?php do_action( 'login_footer' ); ?>
 </body>
 </html>
 <?php