function sess_read in Memcache API and Integration 5.2
Same name in this branch
- 5.2 session-memcache.inc \sess_read()
- 5.2 session-memcache-db.inc \sess_read()
- 5.2 session-memcache.db.inc \sess_read()
Same name and namespace in other branches
- 5 memcache-session.inc \sess_read()
- 6 memcache-session.inc \sess_read()
File
- ./
session-memcache.inc, line 16 - User session handling functions.
Code
function sess_read($key) {
global $user;
// Write and Close handlers are called after destructing objects since PHP 5.0.5
// Thus destructors can use sessions but session handler can't use objects.
// So we are moving session closure before destructing objects.
register_shutdown_function('session_write_close');
// Handle the case of first time visitors and clients that don't store cookies (eg. web crawlers).
if (!isset($_COOKIE[session_name()])) {
$user = drupal_anonymous_user();
return '';
}
// Otherwise, if the session is still active, we have a record of the client's session in memcache.
$user = dmemcache_get($key, 'session');
// We found the client's session record and they are an authenticated user
if ($user && $user->uid > 0) {
// This is done to unserialize the data member of $user
$user = drupal_unpack($user);
$user->access = $user->timestamp;
// Add roles element to $user
$user->roles = array();
$user->roles[DRUPAL_AUTHENTICATED_RID] = 'authenticated user';
$result = db_query("SELECT r.rid, r.name FROM {role} r INNER JOIN {users_roles} ur ON ur.rid = r.rid WHERE ur.uid = %d", $user->uid);
while ($role = db_fetch_object($result)) {
$user->roles[$role->rid] = $role->name;
}
}
else {
$session = isset($user->session) ? $user->session : '';
$user = drupal_anonymous_user($session);
}
return $user->session;
}