Make WordPress Core

Ticket #185: 0000185-wp-login.php

File 0000185-wp-login.php, 10.6 KB (added by Jonathan Stanley, 19 years ago)
Line 
1<?php
2require(dirname(__FILE__) . '/wp-config.php');
3
4        function login() {
5                global $wpdb, $log, $pwd, $error, $user_ID;
6                global $pass_is_md5;
7                $user_login = &$log;
8                $pwd = md5($pwd);
9                $password = &$pwd;
10                if (!$user_login) {
11                        $error = __('<strong>Error</strong>: the login field is empty.');
12                        return false;
13                }
14
15                if (!$password) {
16                        $error = __('<strong>Error</strong>: the password field is empty.');
17                        return false;
18                }
19
20                $query = "SELECT ID, user_login, user_pass FROM $wpdb->users WHERE user_login = '$user_login' AND user_pass = '$password'";
21       
22                $login = $wpdb->get_row($query);
23
24                if (!$login) {
25                        $error = __('<strong>Error</strong>: wrong login or password.');
26                        $pwd = '';
27                        return false;
28                } else {
29                $user_ID = $login->ID;
30                        if (($pass_is_md5 == 0 && $login->user_login == $user_login && $login->user_pass == $password) || ($pass_is_md5 == 1 && $login->user_login == $user_login && $login->user_pass == md5($password))) {
31                                return true;
32                        } else {
33                                $error = __('<strong>Error</strong>: wrong login or password.');
34                                $pwd = '';
35                        return false;
36                        }
37                }
38        }
39
40        function checklogin() {
41                global $user_login, $user_pass_md5, $user_ID;
42
43                $userdata = get_userdatabylogin($user_login);
44
45                if ($user_pass_md5 != md5($userdata->user_pass)) {
46                        return false;
47                } else {
48                        return true;
49                }
50        } 
51       
52if (!function_exists('add_magic_quotes')) {
53        function add_magic_quotes($array) {
54                foreach ($array as $k => $v) {
55                        if (is_array($v)) {
56                                $array[$k] = add_magic_quotes($v);
57                        } else {
58                                $array[$k] = addslashes($v);
59                        }
60                }
61                return $array;
62        } 
63}
64
65if (!get_magic_quotes_gpc()) {
66        $_GET    = add_magic_quotes($_GET);
67        $_POST   = add_magic_quotes($_POST);
68        $_COOKIE = add_magic_quotes($_COOKIE);
69}
70
71$wpvarstoreset = array('action','mode','error','text','popupurl','popuptitle');
72
73for ($i = 0; $i < count($wpvarstoreset); $i = $i + 1) {
74        $wpvar = $wpvarstoreset[$i];
75        if (!isset($$wpvar)) {
76                if (empty($_POST["$wpvar"])) {
77                        if (empty($_GET["$wpvar"])) {
78                                $$wpvar = '';
79                        } else {
80                                $$wpvar = $_GET["$wpvar"];
81                        }
82                } else {
83                        $$wpvar = $_POST["$wpvar"];
84                }
85        }
86}
87
88// If someone has moved WordPress let's try to detect it
89if ( dirname('http://' . $_SERVER['HTTP_HOST'] . $_SERVER['REQUEST_URI']) != get_settings('siteurl') )
90        update_option('siteurl', dirname('http://' . $_SERVER['HTTP_HOST'] . $_SERVER['REQUEST_URI']) );
91
92switch($action) {
93
94case 'logout':
95
96    setcookie('wordpressuser_'.$cookiehash, " ", time() - 31536000, COOKIEPATH);
97    setcookie('wordpresspass_'.$cookiehash, " ", time() - 31536000, COOKIEPATH);
98        header('Expires: Wed, 11 Jan 1984 05:00:00 GMT');
99        header('Last-Modified: ' . gmdate('D, d M Y H:i:s') . ' GMT');
100        header('Cache-Control: no-cache, must-revalidate');
101        header('Pragma: no-cache');
102        if ($is_IIS) {
103                header('Refresh: 0;url=wp-login.php');
104        } else {
105                header('Location: wp-login.php');
106        }
107        exit();
108
109break;
110
111case 'login':
112
113        if(!empty($_POST)) {
114                $log = $_POST['log'];
115                $pwd = stripslashes($_POST['pwd']);
116                $redirect_to = $_POST['redirect_to'];
117        }
118       
119        $user = get_userdatabylogin($log);
120       
121        if (0 == $user->user_level) {
122                $redirect_to = get_settings('siteurl') . '/wp-admin/profile.php';
123        }
124
125
126
127        if (!login()) {
128                header('Expires: Wed, 11 Jan 1984 05:00:00 GMT');
129                header('Last-Modified: ' . gmdate('D, d M Y H:i:s') . ' GMT');
130                header('Cache-Control: no-cache, must-revalidate');
131                header('Pragma: no-cache');
132        if ($is_IIS) {
133                header('Refresh: 0;url=wp-login.php');
134        } else {
135                header('Location: wp-login.php');
136        }
137                exit();
138        } else {
139                $user_login = $log;
140                $user_pass = $pwd;
141                setcookie('wordpressuser_'.$cookiehash, $user_login, time() + 31536000, COOKIEPATH);
142                setcookie('wordpresspass_'.$cookiehash, md5($user_pass), time() + 31536000, COOKIEPATH);
143
144                header('Expires: Wed, 11 Jan 1984 05:00:00 GMT');
145                header('Last-Modified: ' . gmdate('D, d M Y H:i:s') . ' GMT');
146                header('Cache-Control: no-cache, must-revalidate');
147                header('Pragma: no-cache');
148
149                switch($mode) {
150                        case 'bookmarklet':
151                                $location = "wp-admin/bookmarklet.php?text=$text&popupurl=$popupurl&popuptitle=$popuptitle";
152                                break;
153                        case 'sidebar':
154                                $location = "wp-admin/sidebar.php?text=$text&popupurl=$popupurl&popuptitle=$popuptitle";
155                                break;
156                        case 'profile':
157                                $location = "wp-admin/profile.php?text=$text&popupurl=$popupurl&popuptitle=$popuptitle";
158                                break;
159                        default:
160                                $location = "$redirect_to";
161                                break;
162                }
163
164                if ($is_IIS) {
165                        header("Refresh: 0;url=$location");
166                } else {
167                        header("Location: $location");
168                }
169        }
170
171break;
172
173
174case 'lostpassword':
175
176        ?>
177<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
178<html xmlns="http://www.w3.org/1999/xhtml">
179<head>
180        <title><?php _e('WordPress &raquo; Lost password ?') ?></title>
181        <meta http-equiv="Content-Type" content="text/html; charset=<?php echo get_settings('blog_charset'); ?>" />
182        <link rel="stylesheet" href="<?php echo get_settings('siteurl'); ?>/wp-admin/wp-admin.css" type="text/css" />
183        <script type="text/javascript">
184        function focusit() {
185                // focus on first input field
186                document.getElementById('user_login').focus();
187        }
188        window.onload = focusit;
189        </script>
190</head>
191<body>
192
193
194<div id="login">
195<p><?php _e('Please enter your information here. We will send you a new password.') ?> </p>
196<?php
197if ($error) echo "<div align=\"right\" style=\"padding:4px;\"><font color=\"#FF0000\">$error</font><br />&nbsp;</div>";
198?>
199
200<form name="" action="wp-login.php" method="post" id="lostpass">
201<input type="hidden" name="action" value="retrievepassword" />
202<label><?php _e('Login:') ?> <input type="text" name="user_login" id="user_login" value="" size="12" /></label><br />
203<label><?php _e('E-mail:') ?> <input type="text" name="email" id="email" value="" size="12" /></label><br />
204<input type="submit" name="Submit2" value="OK" class="search" />
205
206</form>
207</div>
208
209
210
211</body>
212</html>
213        <?php
214
215break;
216
217case 'retrievepassword':
218
219        $user_data = get_userdatabylogin($_POST["user_login"]);
220        // redefining user_login ensures we return the right case in the email
221        $user_login = $user_data->user_login;
222        $user_email = $user_data->user_email;
223
224        if (!$user_email || $user_email != $_POST['email']) die(sprintf(__('Sorry, that user does not seem to exist in our database. Perhaps you have the wrong username or e-mail address? <a href="%s">Try again</a>.'), 'wp-login.php?action=lostpassword'));
225        // Generate something random for a password... md5'ing current time with a rand salt
226    $user_pass = substr((MD5("time" . rand(1,16000))), 0, 6);
227        // now insert the new pass md5'd into the db
228        $wpdb->query("UPDATE $wpdb->users SET user_pass = MD5('$user_pass') WHERE user_login = '$user_login'");
229        $message  = "Login: $user_login\r\n";
230        $message .= "Password: $user_pass\r\n";
231        $message .= 'Login at: ' . get_settings('siteurl') . '/wp-login.php';
232
233        $m = mail($user_email, '[' . get_settings('blogname') . "] Your weblog's login/password", $message);
234
235        if ($m == false) {
236                 echo '<p>' . __('The e-mail could not be sent.') . "<br />\n";
237         echo  __('Possible reason: your host may have disabled the mail() function...') . "</p>";
238                die();
239        } else {
240                echo '<p>' .  sprintf(__("The e-mail was sent successfully to %s's e-mail address."), $user_login) . '<br />';
241        echo  "<a href='wp-login.php' title='" . __('Check your e-mail first, of course') . "'>" . __('Click here to login!') . '</a></p>';
242                // send a copy of password change notification to the admin
243                mail(get_settings('admin_email'), sprintf(__('[%s] Password Lost/Change'), get_settings('blogname')), sprintf(__('Password Lost and Changed for user: %s'), $user_login));
244                die();
245        }
246
247break;
248
249
250default:
251
252        if((!empty($_COOKIE['wordpressuser_'.$cookiehash])) && (!empty($_COOKIE['wordpresspass_'.$cookiehash]))) {
253                $user_login = $_COOKIE['wordpressuser_'.$cookiehash];
254                $user_pass_md5 = $_COOKIE['wordpresspass_'.$cookiehash];
255        }
256
257        if ( !(checklogin()) ) {
258                if (!empty($_COOKIE['wordpressuser_'.$cookiehash])) {
259                        $error="Error: wrong login/password"; //, or your session has expired.";
260                }
261        } else {
262                header("Expires: Wed, 5 Jun 1979 23:41:00 GMT"); /* private joke: this is Michel's birthdate - though officially it's on the 6th, since he's GMT+1 :) */
263                header("Last-Modified: " . gmdate("D, d M Y H:i:s") . " GMT"); /* different all the time */
264                header("Cache-Control: no-cache, must-revalidate"); /* to cope with HTTP/1.1 */
265                header("Pragma: no-cache");
266                header("Location: wp-admin/");
267                exit();
268        }
269        ?>
270<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
271<html xmlns="http://www.w3.org/1999/xhtml">
272<head>
273        <title><?php printf(__('WordPress > %s > Login form'), htmlspecialchars(get_settings('blogname'))) ?></title>
274        <meta http-equiv="Content-Type" content="text/html; charset=<?php echo get_settings('blog_charset'); ?>" />
275        <link rel="stylesheet" href="<?php echo get_settings('siteurl'); ?>/wp-admin/wp-admin.css" type="text/css" />
276        <script type="text/javascript">
277        function focusit() {
278                // focus on first input field
279                document.getElementById('log').focus();
280        }
281        window.onload = focusit;
282        </script>
283</head>
284<body>
285
286<div id="login">
287<p>
288        <a href="<?php echo get_settings('home'); ?>" title="<?php _e('Are you lost?') ?>"><?php _e('Back to blog?') ?></a><br />
289<?php if (get_settings('users_can_register')) { ?>
290        <a href="<?php echo get_settings('siteurl'); ?>/wp-register.php" title="<?php _e('Register to be an author') ?>"><?php _e('Register?') ?></a><br />
291<?php } ?>
292        <a href="<?php echo get_settings('siteurl'); ?>/wp-login.php?action=lostpassword" title="<?php _e('Password Lost and Found') ?>"><?php _e('Lost your password?') ?></a>
293</p>
294
295<?php
296if ($error) echo "<div align=\"right\" style=\"padding:4px;\"><font color=\"#FF0000\">$error</font><br />&nbsp;</div>";
297?>
298
299<form name="login" id="loginform" action="wp-login.php" method="post">
300<?php if ($mode=="bookmarklet") { ?>
301        <input type="hidden" name="mode" value="<?php echo $mode ?>" />
302        <input type="hidden" name="text" value="<?php echo $text ?>" />
303        <input type="hidden" name="popupurl" value="<?php echo $popupurl ?>" />
304        <input type="hidden" name="popuptitle" value="<?php echo $popuptitle ?>" />
305<?php } ?>
306<?php if (isset($_GET["redirect_to"])) { ?>
307        <input type="hidden" name="redirect_to" value="<?php echo $_GET["redirect_to"] ?>" />
308<?php } else { ?>
309        <input type="hidden" name="redirect_to" value="wp-admin/" />
310<?php } ?>
311        <input type="hidden" name="action" value="login" />
312        <label><?php _e('Login:') ?> <input type="text" name="log" id="log" value="" size="20" tabindex="1" /></label><br />
313        <label><?php _e('Password:') ?> <input type="password" name="pwd" value="" size="20" tabindex="2" /></label><br />
314        <input type="submit" name="Submit2" value="OK" class="search" tabindex="3" />
315</form>
316
317</div>
318
319</body>
320</html>
321<?php
322
323break;
324} // end action switch
325?>