3 # Display current login sessions
5 require './acl-lib.pl';
6 $access{'sessions'} || &error($text{'sessions_ecannot'});
7 &ui_print_header(undef, $text{'sessions_title'}, "");
9 &get_miniserv_config(\%miniserv);
10 &open_session_db(\%miniserv);
13 foreach $u (&list_users()) {
14 $hasuser{$u->{'name'}}++;
17 $haslog = &foreign_available("webminlog");
19 print "<b>$text{'sessions_desc'}</b><p>\n";
20 print &ui_columns_start([ $text{'sessions_id'},
21 $text{'sessions_user'},
22 $text{'sessions_host'},
23 $haslog ? ( $text{'sessions_login'} ) : ( ),
25 foreach $k (sort { @a=split(/\s+/, $sessiondb{$a}); @b=split(/\s+/, $sessiondb{$b}); $b[1] <=> $a[1] } keys %sessiondb) {
26 next if ($k =~ /^1111111/);
27 local ($user, $ltime, $lip) = split(/\s+/, $sessiondb{$k});
28 next if ($miniserv{'logouttime'} &&
29 $time_now - $ltime > $miniserv{'logouttime'}*60);
31 if ($k eq $main::session_id ||
32 $k eq &hash_session_id($main::session_id)) {
33 # Cannot self-terminate
34 push(@cols, "<b>$k</b>");
37 push(@cols, "<a href='delete_session.cgi?id=$k'>$k</a>");
39 if ($hasuser{$user}) {
40 push(@cols, "<a href='edit_user.cgi?user=$user'>$user</a>");
42 elsif ($miniserv{'unixauth'}) {
43 push(@cols, "$user (<a href='edit_user.cgi?user=$miniserv{'unixauth'}'>$miniserv{'unixauth'}</a>)");
49 push(@cols, &make_date($ltime));
51 push(@cols, "<a href='../webminlog/search.cgi?uall=1&mall=1&tall=1&wall=1&fall=1&sid=$k'>$text{'sessions_lview'}</a>");
53 print &ui_columns_row(\@cols);
55 print &ui_columns_end();
57 &ui_print_footer("", $text{'index_return'});