123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 |
- <?php
- // set forward url
- if (isset($_SESSION['last_forward_from']) && $_SESSION['last_forward_from']) {
- $forward_url = $_SESSION['last_forward_from'];
- unset($_SESSION['last_forward_from']);
- } elseif (get_input('returntoreferer')) {
- $forward_url = REFERER;
- } else {
- // forward to main index page
- $forward_url = '';
- }
- $username = get_input('username');
- $password = get_input('password', null, false);
- $persistent = get_input("persistent", false);
- $result = false;
- if (empty($username) || empty($password)) {
- register_error(elgg_echo('login:empty'));
- forward();
- }
- // check if logging in with email address
- if (strpos($username, '@') !== false && ($users = get_user_by_email($username))) {
- $username = $users[0]->username;
- }
- $result = elgg_authenticate($username, $password);
- // Open log
- openlog("elgg({$_SERVER['HTTP_HOST']})", LOG_PID, LOG_AUTH);
- $ip = $_SERVER['REMOTE_ADDR'];
- if (isset($_SERVER['HTTP_X_FORWARDED_FOR'])) {
- $proxies = explode(',', $_SERVER['HTTP_X_FORWARDED_FOR']); // We are behind a proxy
- $ip = trim($proxies[0]);
- }
- if ($result !== true) {
- // Log authentication error, in a format almost identical to the SSH rule (for compatibility)
- syslog(LOG_NOTICE,"Authentication failure for $username from $ip");
-
- register_error($result);
- forward(REFERER);
- }
- // We got here, so login was successful
- syslog(LOG_INFO,"Accepted password for $username from $ip");
- closelog();
- $user = get_user_by_username($username);
- if (!$user) {
- register_error(elgg_echo('login:baduser'));
- forward(REFERER);
- }
- try {
- login($user, $persistent);
- // re-register at least the core language file for users with language other than site default
- register_translations(dirname(dirname(__FILE__)) . "/languages/");
- } catch (LoginException $e) {
- register_error($e->getMessage());
- forward(REFERER);
- }
- // elgg_echo() caches the language and does not provide a way to change the language.
- // @todo we need to use the config object to store this so that the current language
- // can be changed. Refs #4171
- if ($user->language) {
- $message = elgg_echo('loginok', array(), $user->language);
- } else {
- $message = elgg_echo('loginok');
- }
- system_message($message);
- forward($forward_url);
|