1
0

Improve the session decoding, limit it to a sample size, improve the output.

This commit is contained in:
Bharat Mediratta 2012-02-05 16:58:29 -08:00
parent 32b620f33a
commit 75e37f0dfa
2 changed files with 51 additions and 11 deletions

View File

@ -1,4 +1,4 @@
<?php defined("SYSPATH") or die("No direct script access."); 41<?php defined("SYSPATH") or die("No direct script access.");
/** /**
* Gallery - a web based photo album viewer and editor * Gallery - a web based photo album viewer and editor
* Copyright (C) 2000-2011 Bharat Mediratta * Copyright (C) 2000-2011 Bharat Mediratta
@ -19,27 +19,29 @@
*/ */
class Admin_Session_Explorer_Controller extends Admin_Controller { class Admin_Session_Explorer_Controller extends Admin_Controller {
public function index() { public function index() {
list($uas, $ips) = $this->get_uas_and_ips(); list($uas, $ips, $sample_size) = $this->get_uas_and_ips();
$view = new Admin_View("admin.html"); $view = new Admin_View("admin.html");
$view->page_title = t("Akismet spam filtering"); $view->page_title = t("Akismet spam filtering");
$view->content = new View("admin_session_explorer.html"); $view->content = new View("admin_session_explorer.html");
$view->content->uas = $uas; $view->content->uas = $uas;
$view->content->ips = $ips; $view->content->ips = $ips;
$view->content->sample_size = $sample_size;
print $view; print $view;
} }
private function get_uas_and_ips() { private function get_uas_and_ips() {
$uas = array(); $uas = array();
$ips = array(); $ips = array();
$sample_size = 0;
$d = new Session_Database_Driver(); $d = new Session_Database_Driver();
foreach (db::build() foreach (db::build()
->select("session_id") ->select("session_id")
->from("sessions") ->from("sessions")
->execute() as $r) { ->execute() as $r) {
$data = explode("|", $d->read($r->session_id)); $data = $this->unserialize_session($d->read($r->session_id));
$ua = unserialize($data[4]); $ua = $data["user_agent"];
$ip = unserialize($data[5]); $ip = $data["ip_address"];
if (!isset($uas[$ua])) { if (!isset($uas[$ua])) {
$uas[$ua] = 0; $uas[$ua] = 0;
} }
@ -48,14 +50,49 @@ class Admin_Session_Explorer_Controller extends Admin_Controller {
} }
$uas[$ua]++; $uas[$ua]++;
$ips[$ip]++; $ips[$ip]++;
// Limit the sample size once we've found N user agents
if (++$sample_size == 5000) {
break;
}
} }
arsort($uas); arsort($uas);
arsort($ips); arsort($ips);
// Top 20 only // Top N only
array_splice($uas, 20); array_splice($uas, 15);
array_splice($ips, 20); array_splice($ips, 15);
return array($uas, $ips); return array($uas, $ips, $sample_size);
}
// Adapted from
// http://us3.php.net/manual/en/function.session-decode.php#101687
// by jason at joeymail dot net
function unserialize_session( $data ) {
if (strlen($data) == 0) {
return array();
}
// match all the session keys and offsets
preg_match_all('/(^|;|\})([a-zA-Z0-9_]+)\|/i', $data, $matches_array, PREG_OFFSET_CAPTURE);
$return_array = array();
$last_offset = null;
$current_key = '';
foreach ($matches_array[2] as $value) {
$offset = $value[1];
if(!is_null($last_offset)) {
$value_text = substr($data, $last_offset, $offset - $last_offset);
$return_array[$current_key] = unserialize($value_text);
}
$current_key = $value[0];
$last_offset = $offset + strlen($current_key) + 1;
}
$value_text = substr($data, $last_offset);
$return_array[$current_key] = unserialize($value_text);
return $return_array;
} }
} }

View File

@ -1,6 +1,9 @@
<?php defined("SYSPATH") or die("No direct script access.") ?> <?php defined("SYSPATH") or die("No direct script access.") ?>
<div id="g-admin-session-explorer" class="g-block"> <div id="g-admin-session-explorer" class="g-block">
<h1> <?= t("Top user agents and ips") ?> </h1> <h1> <?= t("Top user agents and ips") ?> </h1>
<p>
<?= t("Numbers are based on a sample size of %sample_size sessions", array("sample_size" => $sample_size)) ?>
</p>
<div class="g-block-content"> <div class="g-block-content">
<h2> <?= t("User agents") ?> </h2> <h2> <?= t("User agents") ?> </h2>
@ -11,8 +14,8 @@
<th> <?= t("User agent") ?> </th> <th> <?= t("User agent") ?> </th>
</tr> </tr>
<? foreach ($uas as $ua => $count): ?>
<? $rank = 0; ?> <? $rank = 0; ?>
<? foreach ($uas as $ua => $count): ?>
<tr class="<?= text::alternate("g-odd", "g-even") ?>"> <tr class="<?= text::alternate("g-odd", "g-even") ?>">
<td> <?= ++$rank ?> </td> <td> <?= ++$rank ?> </td>
<td> <?= $count ?> </td> <td> <?= $count ?> </td>
@ -31,8 +34,8 @@
<th> <?= t("Internet address") ?> </th> <th> <?= t("Internet address") ?> </th>
</tr> </tr>
<? foreach ($ips as $ip => $count): ?>
<? $rank = 0; ?> <? $rank = 0; ?>
<? foreach ($ips as $ip => $count): ?>
<tr class="<?= text::alternate("g-odd", "g-even") ?>"> <tr class="<?= text::alternate("g-odd", "g-even") ?>">
<td> <?= ++$rank ?> </td> <td> <?= ++$rank ?> </td>
<td> <?= $count ?> </td> <td> <?= $count ?> </td>