function session_limit_page in Session Limit 5
Same name and namespace in other branches
- 6.2 session_limit.module \session_limit_page()
- 6 session_limit.module \session_limit_page()
- 7.2 session_limit.module \session_limit_page()
Display/Delete sessions..
1 string reference to 'session_limit_page'
- session_limit_menu in ./session_limit.module 
- Implementation of hook_menu(). Redirect user if over session limit.
File
- ./session_limit.module, line 126 
- Established Sessions do NOT need to verify every page load. new Session must deal w/ determining which connection is cut.
Code
function session_limit_page() {
  global $user;
  if (!$user->uid > 0) {
    drupal_goto();
  }
  if (variable_get('session_limit_auto_drop', 0)) {
    // Get the oldest session.
    $sid = db_result(db_query_range("SELECT sid FROM {sessions} WHERE uid = %d ORDER BY timestamp", $user->uid, 0, 1));
    if ($sid) {
      _session_limit_disconnect($sid);
    }
    drupal_goto();
  }
  $result = db_query('SELECT * FROM {sessions} WHERE uid = %d', $user->uid);
  while ($obj = db_fetch_object($result)) {
    if ($user->sid == $obj->sid) {
      $message = t('Your current session.');
    }
    else {
      unset($message);
    }
    $sids[$obj->sid] = t('<strong>Host:</strong> %host (idle: %time) <b>@message</b>', array(
      '%host' => $obj->hostname,
      '@message' => $message,
      '%time' => format_interval(time() - $obj->timestamp),
    ));
  }
  $form['sid'] = array(
    '#type' => 'radios',
    '#title' => t('Select a session to disconnect'),
    '#options' => $sids,
  );
  $form['submit'] = array(
    '#type' => 'submit',
    '#value' => t('Disconnect'),
  );
  return $form;
}