package WebGUI::Operation::ActiveSessions; #------------------------------------------------------------------- # WebGUI is Copyright 2001-2005 Plain Black Corporation. #------------------------------------------------------------------- # Please read the legal notices (docs/legal.txt) and the license # (docs/license.txt) that came with this distribution before using # this software. #------------------------------------------------------------------- # http://www.plainblack.com info@plainblack.com #------------------------------------------------------------------- use strict; use WebGUI::AdminConsole; use WebGUI::DateTime; use WebGUI::Grouping; use WebGUI::Icon; use WebGUI::International; use WebGUI::Paginator; use WebGUI::Privilege; use WebGUI::Session; use WebGUI::SQL; =head1 NAME Package WebGUI::Operations::ActiveSessions =head1 DESCRIPTION Operation handler for displaying and killing active sessions. =cut #------------------------------------------------------------------- =head2 www_killSession ( ) This method can be called directly, but is usually called from www_viewActiveSessions. It ends the active session in $session->form->process("sid"). Afterwards, it calls www_viewActiveSessions. =cut sub www_killSession { my $session = shift; return www_viewActiveSessions() if $session->form->process("sid") eq $session->var->get("sessionId"); return WebGUI::Privilege::adminOnly() unless (WebGUI::Grouping::isInGroup(3)); WebGUI::Session::end($session->form->process("sid")); return www_viewActiveSessions(); } #------------------------------------------------------------------- =head2 www_viewActiveSessions ( ) Display a list of all active user sessions, along with an icon to delete (kill) each one via www_killSession =cut sub www_viewActiveSessions { my $session = shift; return WebGUI::Privilege::adminOnly() unless (WebGUI::Grouping::isInGroup(3)); my ($output, $p, @row, $i, $sth, %data); tie %data, 'Tie::CPHash'; $sth = $session->db->read("select users.username,users.userId,userSession.sessionId,userSession.expires, userSession.lastPageView,userSession.lastIP from users,userSession where users.userId=userSession.userId and users.userId<>1 order by users.username,userSession.lastPageView desc"); while (%data = $sth->hash) { $row[$i] = ''.$data{username}.' ('.$data{userId}.')'; $row[$i] .= ''.$data{sessionId}.''; $row[$i] .= ''.epochToHuman($data{expires}).''; $row[$i] .= ''.epochToHuman($data{lastPageView}).''; $row[$i] .= ''.$data{lastIP}.''; $row[$i] .= ''.deleteIcon("op=killSession;sid=$data{sessionId}").''; $i++; } $sth->finish; $p = WebGUI::Paginator->new($session->url->page('op=viewActiveSessions')); $p->setDataByArrayRef(\@row); $output .= ''; $output .= ''; $output .= ''; $output .= ''; $output .= ''; $output .= ''; $output .= ''; $output .= $p->getPage($session->form->process("pn")); $output .= '
'.WebGUI::International::get(428).''.WebGUI::International::get(435).''.WebGUI::International::get(432).''.WebGUI::International::get(430).''.WebGUI::International::get(431).''.WebGUI::International::get(436).'
'; $output .= $p->getBarTraditional($session->form->process("pn")); return WebGUI::AdminConsole->new("activeSessions")->render($output); } 1;