aboutsummaryrefslogtreecommitdiff
path: root/engine/lib
diff options
context:
space:
mode:
authorcash <cash@36083f99-b078-4883-b0ff-0f9b5a30f544>2009-11-04 12:25:44 +0000
committercash <cash@36083f99-b078-4883-b0ff-0f9b5a30f544>2009-11-04 12:25:44 +0000
commit06169d33aae4d27129c77baaee9ecb064683e576 (patch)
tree2ebe154bf3d7e7fcb32c1c46a7eb3cba31b0bf42 /engine/lib
parent8dffaa185c1744b8ddad732c57c2b36e8251c4b2 (diff)
downloadelgg-06169d33aae4d27129c77baaee9ecb064683e576.tar.gz
elgg-06169d33aae4d27129c77baaee9ecb064683e576.tar.bz2
users now allowed to have multiple sessions but not multiple remember me cookies (yet)
git-svn-id: http://code.elgg.org/elgg/trunk@3618 36083f99-b078-4883-b0ff-0f9b5a30f544
Diffstat (limited to 'engine/lib')
-rw-r--r--engine/lib/sessions.php53
1 files changed, 20 insertions, 33 deletions
diff --git a/engine/lib/sessions.php b/engine/lib/sessions.php
index 914f3701a..7a6250afb 100644
--- a/engine/lib/sessions.php
+++ b/engine/lib/sessions.php
@@ -378,13 +378,11 @@ function login(ElggUser $user, $persistent = false) {
$_SESSION['username'] = $user->username;
$_SESSION['name'] = $user->name;
- $code = (md5($user->name . $user->username . time() . rand()));
-
- $user->code = md5($code);
-
- $_SESSION['code'] = $code;
-
+ // if remember me checked, set cookie with token and store token on user
if (($persistent)) {
+ $code = (md5($user->name . $user->username . time() . rand()));
+ $_SESSION['code'] = $code;
+ $user->code = md5($code);
setcookie("elggperm", $code, (time()+(86400 * 30)),"/");
}
@@ -507,46 +505,35 @@ function session_init($event, $object_type, $object) {
$_SESSION['__elgg_session'] = md5(microtime().rand());
}
+ // test whether we have a user session
if (empty($_SESSION['guid'])) {
+
+ // clear session variables before checking cookie
+ unset($_SESSION['user']);
+ unset($_SESSION['id']);
+ unset($_SESSION['guid']);
+ unset($_SESSION['code']);
+
+ // is there a remember me cookie
if (isset($_COOKIE['elggperm'])) {
+ // we have a cookie, so try to log the user in
$code = $_COOKIE['elggperm'];
$code = md5($code);
- unset($_SESSION['guid']);//$_SESSION['guid'] = 0;
- unset($_SESSION['id']);//$_SESSION['id'] = 0;
if ($user = get_user_by_code($code)) {
+ // we have a user, log him in
$_SESSION['user'] = $user;
$_SESSION['id'] = $user->getGUID();
$_SESSION['guid'] = $_SESSION['id'];
$_SESSION['code'] = $_COOKIE['elggperm'];
}
- } else {
- unset($_SESSION['id']); //$_SESSION['id'] = 0;
- unset($_SESSION['guid']);//$_SESSION['guid'] = 0;
- unset($_SESSION['code']);//$_SESSION['code'] = "";
- }
+ }
} else {
- if (!empty($_SESSION['code'])) {
- $code = md5($_SESSION['code']);
- if ($user = get_user_by_code($code)) {
- $_SESSION['user'] = $user;
- $_SESSION['id'] = $user->getGUID();
- $_SESSION['guid'] = $_SESSION['id'];
- } else {
- unset($_SESSION['user']);
- unset($_SESSION['id']); //$_SESSION['id'] = 0;
- unset($_SESSION['guid']);//$_SESSION['guid'] = 0;
- unset($_SESSION['code']);//$_SESSION['code'] = "";
- }
- } else {
- //$_SESSION['user'] = new ElggDummy();
- unset($_SESSION['id']); //$_SESSION['id'] = 0;
- unset($_SESSION['guid']);//$_SESSION['guid'] = 0;
- unset($_SESSION['code']);//$_SESSION['code'] = "";
- }
+ // we have a session and we have already checked the fingerprint
+ // no need to load user data because it should already be in the session
}
- if ($_SESSION['id'] > 0) {
- set_last_action($_SESSION['id']);
+ if (isset($_SESSION['guid'])) {
+ set_last_action($_SESSION['guid']);
}
register_action("login",true);