1
0
mirror of https://github.com/e107inc/e107.git synced 2025-10-24 19:26:21 +02:00

Allow include of inline CSS in header, update stats logging

This commit is contained in:
e107steved
2007-11-01 20:28:29 +00:00
parent aafab279e5
commit bcd6db8ae0
8 changed files with 1217 additions and 324 deletions

View File

@@ -11,23 +11,23 @@
| GNU General Public License (http://gnu.org).
|
| $Source: /cvs_backup/e107_0.8/e107_plugins/log/admin_config.php,v $
| $Revision: 1.1.1.1 $
| $Date: 2006-12-02 04:35:27 $
| $Author: mcfly_e107 $
| $Revision: 1.2 $
| $Date: 2007-11-01 20:28:20 $
| $Author: e107steved $
+----------------------------------------------------------------------------+
To do:
1. Admin log for changes
*/
require_once("../../class2.php");
if (!getperms("P")) {
if (!getperms("P"))
{
header("location:../index.php");
exit;
}
if (isset($_POST['updateStats']))
{
header("location: ".e_PLUGIN."log/admin_updateroutine.php");
exit;
}
require_once(e_ADMIN."auth.php");
require_once(e_HANDLER."userclass_class.php");
@@ -35,17 +35,122 @@ define("LOGPATH", e_PLUGIN."log/");
include_lan(LOGPATH."languages/admin/".e_LANGUAGE.".php");
if (e_QUERY)
{
$sl_qs = explode(".", e_QUERY);
}
$action = varset($sl_qs[0],'config');
$params = varset($sl_qs[1],'');
// List of the non-page-based info which is gathered - historically only 'all-time' stats, now we support monthly as well
$stats_list = array('statBrowser'=>ADSTAT_L6,'statOs'=>ADSTAT_L7,'statScreen'=>ADSTAT_L8,'statDomain'=>ADSTAT_L9,'statReferer'=>ADSTAT_L10,'statQuery'=>ADSTAT_L11);
$separator_list = array(1 => ADSTAT_L57, 2 => ADSTAT_L58);
$separator_char = array(1 => ',', 2 => '|');
$quote_list = array(1 => ADSTAT_L50, 2 => ADSTAT_L55, 3 => ADSTAT_L56);
$quote_char = array(1 => '', 2 => "'", 3 => '"');
//---------------------------------------------
// Export data file
//---------------------------------------------
$export_filter = ''; // can be 'LIKE', 'REGEX', or simple equality
$export_type = $tp->toDB(varset($_POST['export_type'],'page')); // Page data or one of the other bits of info
$export_date = intval(varset($_POST['export_date'],1));
$export2_date = intval(varset($_POST['export2_date'],3));
$export_year = intval(varset($_POST['export_year'],date('Y')));
$export_month = intval(varset($_POST['export_month'],date('m')));
$export_day = intval(varset($_POST['export_day'],date('j')));
$export_char = varset($_POST['export_char'], 1);
$export_quote = varset($_POST['export_quote'], 1);
$export_stripurl = varset($_POST['export_stripurl'], 0);
if (isset($_POST['create_export']) && (($action == 'export') || ($action == 'datasets')))
{
$first_date = 0;
$last_date = 0;
$date_error = FALSE;
if ($export_type == 'page')
{
switch ($export_date)
{
case '1' : // Single day
$first_date = gmmktime(0,0,0,$export_month,$export_day,$export_year);
$last_date = $first_date+86399;
$export_filter = " `log_id`='".date("Y-m-j",$first_date)."'";
break;
case '2' : // Daily for a month
$first_date = gmmktime(0,0,0,$export_month,1,$export_year);
$last_date = gmmktime(0,0,0,$export_month+1,1,$export_year) - 1;
$export_filter = " LEFT(`log_id`,8)='".gmstrftime("%Y-%m-",$first_date)."'";
break;
case '3' : // Monthly for a Year
$first_date = gmmktime(0,0,0,1,1,$export_year);
$last_date = gmmktime(0,0,0,1,1,$export_year+1) - 1;
$export_filter = " LENGTH(`log_id`)=7 AND LEFT(`log_id`,5)='".gmstrftime("%Y-",$first_date)."'";
break;
case '4' : // Accumulated
case '5' :
$export_filter = "`log_id`='pageTotal'";
$date_error = 'ignore';
break;
}
}
else
{ // Calculate strings for non-page sources
$prefix_len = 0;
$export_date = $export2_date;
if (isset($stats_list[$export_type]))
{
$prefix_len = strlen($export_type) + 1;
switch ($export2_date)
{
case '3' : // Monthly for a Year
if ($prefix_len > 0)
{
$first_date = gmmktime(0,0,0,1,1,$export_year);
$last_date = gmmktime(0,0,0,1,1,$export_year+1) - 1;
$export_filter = " LENGTH(`log_id`)='".($prefix_len + 7)."' AND LEFT(`log_id`,".($prefix_len + 5).")='".$export_type.":".gmstrftime("%Y-",$first_date)."'";
}
break;
case '4' : // Accumulated
$export_filter = " `log_id`='".$export_type."'";
$date_error = 'ignore';
break;
}
}
else
{
$message = ADSTAT_L54;
}
}
if (($date_error != 'ignore') && (($first_date == 0) || ($last_date == 0) || $date_error))
{
$message = ADSTAT_L47;
}
}
//---------------------------------------------
// Remove page entries
//---------------------------------------------
if(isset($_POST['openRemPageD']))
{
rempage();
$action = 'rempage';
}
if(isset($_POST['remSelP']))
{
rempagego();
$action = 'rempage';
rempagego(); // Do the deletions - then redisplay the list of pages
}
//---------------------------------------------
// Wipe accumulated stats
//---------------------------------------------
if(IsSet($_POST['wipeSubmit']))
{
foreach($_POST['wipe'] as $key => $wipe)
@@ -82,92 +187,110 @@ if(IsSet($_POST['wipeSubmit']))
if(!is_writable(LOGPATH."logs")) {
$message = "<b>You must set the permissions of the e107_plugins/log/logs folder to 777 (chmod 777)</b>";
if(!is_writable(LOGPATH."logs"))
{
$message = "<b>".ADSTAT_L38."</b>";
}
if (isset($_POST['updatesettings'])) {
$pref['statActivate'] = $_POST['statActivate'];
if (isset($_POST['updatesettings']))
{
$pref['statActivate'] = $_POST['statActivate'];
$pref['statCountAdmin'] = $_POST['statCountAdmin'];
$pref['statUserclass'] = $_POST['statUserclass'];
$pref['statBrowser'] = $_POST['statBrowser'];
$pref['statOs'] = $_POST['statOs'];
$pref['statScreen'] = $_POST['statScreen'];
$pref['statDomain'] = $_POST['statDomain'];
$pref['statRefer'] = $_POST['statRefer'];
$pref['statQuery'] = $_POST['statQuery'];
$pref['statRecent'] = $_POST['statRecent'];
$pref['statUserclass'] = $_POST['statUserclass'];
$pref['statBrowser'] = intval($_POST['statBrowser']);
$pref['statOs'] = intval($_POST['statOs']);
$pref['statScreen'] = intval($_POST['statScreen']);
$pref['statDomain'] = intval($_POST['statDomain']);
$pref['statRefer'] = intval($_POST['statRefer']);
$pref['statQuery'] = intval($_POST['statQuery']);
$pref['statRecent'] = intval($_POST['statRecent']);
$pref['statDisplayNumber'] = $_POST['statDisplayNumber'];
$pref['statPrevMonth'] = intval($_POST['statPrevMonth']);
save_prefs();
$message = ADSTAT_L17;
}
if (isset($message)) {
$ns->tablerender("", "<div style='text-align:center'><b>".$message."</b></div>");
if (isset($message))
{
$ns->tablerender("", "<div style='text-align:center'><b>".$message."</b></div>");
}
$text = "<div style='text-align:center'>
function gen_select($prompt,$name,$value)
{
$ret = "<div style='padding-bottom: 4px'>".$prompt."&nbsp;&nbsp;"."<select name='{$name}' class='tbox'>\n
<option value='0' ".($value == 0 ? " selected='selected'" : "").">".ADSTAT_L50."</option>\n
<option value='1' ".($value == 1 ? " selected='selected'" : "").">".ADSTAT_L49."</option>\n
<option value='2' ".($value == 2 ? " selected='selected'" : "").">".ADSTAT_L48."</option>\n
</select>\n</div>";
return $ret;
}
function data_type_select($name,$value)
{
global $stats_list;
$ret = "<select name='{$name}' class='tbox' onchange=\"settypebox(this.value);\">\n
<option value='page' ".($value == 'page' ? " selected='selected'" : "").">".ADSTAT_L52."</option>\n";
foreach ($stats_list as $k=>$v)
{
$ret .= "<option value='{$k}' ".($value == $k ? " selected='selected'" : "").">{$v}</option>\n";
}
$ret .= "</select>\n";
return $ret;
}
switch ($action)
{
case 'config' :
$text = "<div style='text-align:center'>
<form method='post' action='".e_SELF."'>
<table style='".ADMIN_WIDTH."' class='fborder'>
<colgroup>
<col style='width:50%' />
<col style='width:50%' />
</colgroup>
<tr>
<td style='width:50%' class='forumheader3'>".ADSTAT_L4."</td>
<td style='width:50%; text-align: right;' class='forumheader3'>
<td class='forumheader3'>".ADSTAT_L4."</td>
<td style='text-align: right;' class='forumheader3'>
<input type='radio' name='statActivate' value='1'".($pref['statActivate'] ? " checked='checked'" : "")." /> ".ADSTAT_ON."&nbsp;&nbsp;
<input type='radio' name='statActivate' value='0'".(!$pref['statActivate'] ? " checked='checked'" : "")." /> ".ADSTAT_OFF."
</td>
</tr>
<tr>
<td style='width:50%' class='forumheader3'>".ADSTAT_L18."</td>
<td style='width:50%; text-align: right;' class='forumheader3'>".r_userclass("statUserclass", $pref['statUserclass'],'off','public, member, admin, classes')."</td>
<td class='forumheader3'>".ADSTAT_L18."</td>
<td style='text-align: right;' class='forumheader3'>".r_userclass("statUserclass", $pref['statUserclass'],'off','public, member, admin, classes')."</td>
</tr>
<tr>
<td style='width:50%' class='forumheader3'>".ADSTAT_L20."</td>
<td style='width:50%; text-align: right;' class='forumheader3'>
<td class='forumheader3'>".ADSTAT_L20."</td>
<td style='text-align: right;' class='forumheader3'>
<input type='radio' name='statCountAdmin' value='1'".($pref['statCountAdmin'] ? " checked='checked'" : "")." /> ".ADSTAT_ON."&nbsp;&nbsp;
<input type='radio' name='statCountAdmin' value='0'".(!$pref['statCountAdmin'] ? " checked='checked'" : "")." /> ".ADSTAT_OFF."
</td>
</tr>
<tr>
<td style='width:50%' class='forumheader3'>".ADSTAT_L21."</td>
<td style='width:50%; text-align: right;' class='forumheader3'>
<td class='forumheader3'>".ADSTAT_L21."</td>
<td style='text-align: right;' class='forumheader3'>
<input class='tbox' type='text' name='statDisplayNumber' size='8' value='".$pref['statDisplayNumber']."' maxlength='3' />
</td>
</tr>
<tr>
<td style='width:50%' class='forumheader3'>".ADSTAT_L5."</td>
<td style='width:50%; text-align: right;' class='forumheader3'>
".ADSTAT_L6."&nbsp;&nbsp;
<input type='radio' name='statBrowser' value='1'".($pref['statBrowser'] ? " checked='checked'" : "")." /> ".ADSTAT_ON."&nbsp;&nbsp;
<input type='radio' name='statBrowser' value='0'".(!$pref['statBrowser'] ? " checked='checked'" : "")." /> ".ADSTAT_OFF."<br />
".ADSTAT_L7."&nbsp;&nbsp;
<input type='radio' name='statOs' value='1'".($pref['statOs'] ? " checked='checked'" : "")." /> ".ADSTAT_ON."&nbsp;&nbsp;
<input type='radio' name='statOs' value='0'".(!$pref['statOs'] ? " checked='checked'" : "")." /> ".ADSTAT_OFF."<br />
".ADSTAT_L8."&nbsp;&nbsp;
<input type='radio' name='statScreen' value='1'".($pref['statScreen'] ? " checked='checked'" : "")." /> ".ADSTAT_ON."&nbsp;&nbsp;
<input type='radio' name='statScreen' value='0'".(!$pref['statScreen'] ? " checked='checked'" : "")." /> ".ADSTAT_OFF."<br />
".ADSTAT_L9."&nbsp;&nbsp;
<input type='radio' name='statDomain' value='1'".($pref['statDomain'] ? " checked='checked'" : "")." /> ".ADSTAT_ON."&nbsp;&nbsp;
<input type='radio' name='statDomain' value='0'".(!$pref['statDomain'] ? " checked='checked'" : "")." /> ".ADSTAT_OFF."<br />
".ADSTAT_L10."&nbsp;&nbsp;
<input type='radio' name='statRefer' value='1'".($pref['statRefer'] ? " checked='checked'" : "")." /> ".ADSTAT_ON."&nbsp;&nbsp;
<input type='radio' name='statRefer' value='0'".(!$pref['statRefer'] ? " checked='checked'" : "")." /> ".ADSTAT_OFF."<br />
".ADSTAT_L11."&nbsp;&nbsp;
<input type='radio' name='statQuery' value='1'".($pref['statQuery'] ? " checked='checked'" : "")." /> ".ADSTAT_ON."&nbsp;&nbsp;
<input type='radio' name='statQuery' value='0'".(!$pref['statQuery'] ? " checked='checked'" : "")." /> ".ADSTAT_OFF."<br />
".ADSTAT_L19."&nbsp;&nbsp;
<td class='forumheader3'>".ADSTAT_L5."</td>
<td style='text-align: right' class='forumheader3'>
".gen_select(ADSTAT_L6, 'statBrowser',$pref['statBrowser'])
.gen_select(ADSTAT_L7, 'statOs',$pref['statOs'])
.gen_select(ADSTAT_L8, 'statScreen',$pref['statScreen'])
.gen_select(ADSTAT_L9, 'statDomain',$pref['statDomain'])
.gen_select(ADSTAT_L10, 'statRefer',$pref['statRefer'])
.gen_select(ADSTAT_L11, 'statQuery',$pref['statQuery'])
.ADSTAT_L19."&nbsp;&nbsp;
<input type='radio' name='statRecent' value='1'".($pref['statRecent'] ? " checked='checked'" : "")." /> ".ADSTAT_ON."&nbsp;&nbsp;
<input type='radio' name='statRecent' value='0'".(!$pref['statRecent'] ? " checked='checked'" : "")." /> ".ADSTAT_OFF."<br />
@@ -175,8 +298,14 @@ $text = "<div style='text-align:center'>
</tr>
<tr>
<td style='width:50%' class='forumheader3'>".ADSTAT_L12."<br /><span class='smalltext'>".ADSTAT_L13."</span></td>
<td style='width:50%; text-align: right;' class='forumheader3'>
<td class='forumheader3'>".ADSTAT_L78."<br /><span class='smalltext'>".ADSTAT_L79."</span></td>
<td style='text-align: right;' class='forumheader3'>
<input type='checkbox' name='statPrevMonth' value='1'".(varset($pref['statPrevMonth'],0) ? " checked='checked'" : "")." />
</td></tr>
<tr>
<td class='forumheader3'>".ADSTAT_L12."<br /><span class='smalltext'>".ADSTAT_L13."</span></td>
<td style='text-align: right;' class='forumheader3'>
".ADSTAT_L14."<input type='checkbox' name='wipe[statWipePage]' value='1' /><br />
".ADSTAT_L6."<input type='checkbox' name='wipe[statWipeBrowser]' value='1' /><br />
".ADSTAT_L7." <input type='checkbox' name='wipe[statWipeOs]' value='1' /><br />
@@ -189,17 +318,13 @@ $text = "<div style='text-align:center'>
</tr>
<tr>
<td style='width:50%' class='forumheader3'>".ADSTAT_L26."<br /><span class='smalltext'>".ADSTAT_L27."</span></td>
<td style='width:50%; text-align: right;' class='forumheader3'><input class='button' type='submit' name='openRemPageD' value='".ADSTAT_L28."' />
<td class='forumheader3'>".ADSTAT_L26."<br /><span class='smalltext'>".ADSTAT_L27."</span></td>
<td style='text-align: right;' class='forumheader3'><input class='button' type='submit' name='openRemPageD' value='".ADSTAT_L28."' />
</td>
</tr>
";
$text .= "
<tr>
<td colspan='2' style='text-align:center' class='forumheader'>
<input class='button' type='submit' name='updatesettings' value='".ADSTAT_L15."' />
@@ -209,12 +334,356 @@ $text = "<div style='text-align:center'>
</form>
</div>";
$ns->tablerender(ADSTAT_L16, $text);
$ns->tablerender(ADSTAT_L16, $text);
break; // case config
case 'rempage' : // Remove pages
rempage();
break;
case 'export' : // Export file
case 'datasets' :
//===========================================================
// EXPORT DATA
//===========================================================
$text = "<div style='text-align:center'>";
if ($action == 'export')
{
$text .= "<form method='post' action='".e_PLUGIN."log/stats_csv.php?export'>";
}
else
{
$text .= "<form method='post' action='".e_SELF."?datasets'>";
}
$text .= "<table style='".ADMIN_WIDTH."' class='fborder'>
<colgroup>
<col style='width:50%' />
<col style='width:50%' />
</colgroup>
";
if ($action == 'export')
{
$text .= "<tr><td class='forumheader3' colspan = '2'>".ADSTAT_L67."</td></tr>";
}
else
{
$text .= "<tr><td class='forumheader3' colspan = '2'>".ADSTAT_L68."</td></tr>";
}
// Type of output data - page data, browser stats....
$text .= "<tr><td class='forumheader3'>".ADSTAT_L51."</td><td class='forumheader3'>\n".data_type_select('export_type',$export_type);
// Period selection type for page data
$text .= "<tr><td class='forumheader3'>".ADSTAT_L41."</td><td class='forumheader3'>\n
<select class='tbox' name='export_date' id='export_date' onchange=\"setdatebox(this.value);\" ".($export_type=='page' ? "" : "style='display:none'" ).">\n
<option value='1'".($export_date==1 ? " selected='selected'" : "").">".ADSTAT_L42."</option>\n
<option value='2'".($export_date==2 ? " selected='selected'" : "").">".ADSTAT_L43."</option>\n
<option value='3'".($export_date==3 ? " selected='selected'" : "").">".ADSTAT_L44."</option>\n
<option value='4'".($export_date==4 ? " selected='selected'" : "").">".ADSTAT_L45."</option>\n
<option value='5'".($export_date==5 ? " selected='selected'" : "").">".ADSTAT_L62."</option>\n
</select>";
// Period selection type for non-page data
$text .= "
<select class='tbox' name='export2_date' id='export2_date' onchange=\"setdatebox(this.value);\" ".($export_type=='page' ? "style='display:none'" : "").">\n
<option value='3'".($export2_date==3 ? " selected='selected'" : "").">".ADSTAT_L44."</option>\n
<option value='4'".($export2_date==4 ? " selected='selected'" : "").">".ADSTAT_L45."</option>\n
</select>";
$text .= "</td></tr>";
$text .= "<tr><td class='forumheader3'>".ADSTAT_L46."</td><td class='forumheader3'>\n";
// Now put the various dropdowns - their visibility is controlled by the export_type dropdown
$text .= "<select class='tbox' name='export_day' id='export_day'>\n";
for ($i = 1; $i < 32; $i++)
{
$selected = $export_day == $i ? " selected='selected'" : "";
$text .= "<option value='{$i}'{$selected}>{$i}</option>\n";
};
$text .= "</select>\n&nbsp;&nbsp;&nbsp;";
$text .= "<select class='tbox' name='export_month' id='export_month'>\n";
for ($i = 1; $i < 13; $i++)
{
$selected = $export_month == $i ? " selected='selected'" : "";
$text .= "<option value='{$i}'{$selected}>".nl_langinfo(constant('MON_'.$i))."</option>\n";
};
$text .= "</select>\n&nbsp;&nbsp;&nbsp;";
$this_year = date("Y");
$text .= "<select class='tbox' name='export_year' id='export_year'>\n";
for ($i = $this_year; $i > $this_year - 6; $i--)
{
$selected = $export_year == $i ? " selected='selected'" : "";
$text .= "<option value='{$i}'{$selected}>{$i}</option>\n";
};
$text .= "</select>\n&nbsp;&nbsp;&nbsp;";
$text .= "<span id='export_cumulative' style='display: none'>".ADSTAT_L53."</span>\n";
$text .= "</td></tr>";
if ($action == 'export')
{
// Separators, quotes
$text .= "<tr><td class='forumheader3'>".ADSTAT_L59."</td><td class='forumheader3'>\n
<select class='tbox' name='export_char'>";
foreach ($separator_list as $k=>$v)
{
$selected = $export_char == $k ? " selected='selected'" : "";
$text .= "<option value='{$k}'{$selected}>{$v}</option>\n";
}
$text .= "</select>\n&nbsp;&nbsp;&nbsp;&nbsp;<select class='tbox' name='export_quote'>\n";
foreach ($quote_list as $k=>$v)
{
$selected = $export_quote == $k ? " selected='selected'" : "";
$text .= "<option value='{$k}'{$selected}>{$v}</option>\n";
}
$text .= "</select>\n</td></tr>";
$text .= "<tr>
<td class='forumheader3'>".ADSTAT_L60."<br /><span class='smalltext'>".ADSTAT_L61."</span></td>
<td class='forumheader3'>
<input type='checkbox' name='export_stripurl' value='1' ".($export_stripurl == 1 ? " checked='checked'" : "")."/>
</td>
</tr>";
}
if ($export_filter)
{
if (getperms('0')) $text .= "<tr><td class='forumheader3'>".ADSTAT_L65."</td><td class='forumheader3'>".$export_filter."</td></tr>";
$sql -> db_Select("logstats", "log_id", "{$export_filter} ");
$text .= "<tr><td class='forumheader3'>".ADSTAT_L64."</td><td class='forumheader3'>";
while($row = $sql -> db_Fetch())
{
$text .= $row['log_id']."<br />";
}
$text .= "</td></tr>";
}
$text .= "
<tr>
<td colspan='2' style='text-align:center' class='forumheader'>
<input class='button' type='submit' name='create_export' value='".($action == 'export' ? ADSTAT_L37 : ADSTAT_L66)."' />
</td>
</tr>
</table>
</form>
</div>";
// Set up the date display boxes
$text .= "<script type=\"text/javascript\"> settypebox('{$export_type}');</script>";
$ns->tablerender(ADSTAT_L40, $text);
break; // case 'export'
case 'history' :
//===========================================================
// DELETE HISTORY
//===========================================================
$text = "<div style='text-align:center'>
<form method='post' action='".e_SELF."?history'>
<table style='".ADMIN_WIDTH."' class='fborder'>
<colgroup>
<col style='width:50%' />
<col style='width:50%' />
</colgroup>";
$keep_month = varset($_POST['delete_month'],0);
$keep_year = varset($_POST['delete_year'],0);
if (isset($_POST['delete_history']))
{
$text .= "<tr><td class='forumheader3'>".ADSTAT_L72."</td><td class='forumheader3'>".nl_langinfo(constant('MON_'.$keep_month))." ".$keep_year."</td></tr>
<tr><td colspan='2' style='text-align:center' class='forumheader'>
<input type='hidden' name='delete_month' value='{$keep_month}' />
<input type='hidden' name='delete_year' value='{$keep_year}' />
<input class='button' type='submit' name='actually_delete' value='".ADSTAT_L73."' /><br />".ADSTAT_L74."
</td></tr>";
$text .= "<tr><td class='forumheader3'>".ADSTAT_L75."</td><td class='forumheader3'>".implode("<br />",get_for_delete($keep_year,$keep_month))."</td></tr>";
}
else
{
if (isset($_POST['actually_delete']))
{
$delete_list = get_for_delete($keep_year,$keep_month);
// $text .= "<tr><td class='forumheader3' colspan='2'>Data notionally deleted {$keep_month}-{$keep_year}</td></tr>";
$text .= "<tr><td class='forumheader3'>".ADSTAT_L77."</td><td class='forumheader3'>";
foreach ($delete_list as $k => $v)
{
$sql->db_Delete('logstats',"log_id='{$k}'");
$text .= $v."<br />";
}
$text .= "</td></tr>";
}
$text .= "<tr><td class='forumheader3'>".ADSTAT_L70."</td>";
$text .= "<td class='forumheader3'><select class='tbox' name='delete_month'>\n";
$match_month = date("n");
for ($i = 1; $i < 13; $i++)
{
$selected = $match_month == $i ? " selected='selected'" : "";
$text .= "<option value='{$i}'{$selected}>".nl_langinfo(constant('MON_'.$i))."</option>\n";
};
$text .= "</select>\n&nbsp;&nbsp;&nbsp;";
$this_year = date("Y");
$text .= "<select class='tbox' name='delete_year' id='export_year'>\n";
for ($i = $this_year; $i > $this_year - 6; $i--)
{
$selected = ($this_year - 2) == $i ? " selected='selected'" : "";
$text .= "<option value='{$i}'{$selected}>{$i}</option>\n";
};
$text .= "</select>\n</td></tr><tr>
<td colspan='2' style='text-align:center' class='forumheader'>
<input class='button' type='submit' name='delete_history' value='".ADSTAT_L71."' />
</td></tr>
<td colspan='2' style='text-align:center' class='forumheader3'><em>".ADSTAT_L76."</em>
</td></tr>";
}
$text .= "</table></form></div>";
$ns->tablerender(ADSTAT_L69, $text);
break; // case 'history'
}
require_once(e_ADMIN."footer.php");
function headerjs()
{
$script_js = "<script type=\"text/javascript\">
//<![CDATA[
var names = new Array();
names[0] = 'export_day';
names[1] = 'export_month';
names[2] = 'export_year';
names[3] = 'export_cumulative';
var dispinfo = new Array();
dispinfo[1] = new Array(); // Single day
dispinfo[1][0] = '';
dispinfo[1][1] = '';
dispinfo[1][2] = '';
dispinfo[1][3] = 'none';
dispinfo[2] = new Array(); // Month
dispinfo[2][0] = 'none';
dispinfo[2][1] = '';
dispinfo[2][2] = '';
dispinfo[2][3] = 'none';
dispinfo[3] = new Array(); // Year
dispinfo[3][0] = 'none';
dispinfo[3][1] = 'none';
dispinfo[3][2] = '';
dispinfo[3][3] = 'none';
dispinfo[4] = new Array(); // Specials
dispinfo[4][0] = 'none';
dispinfo[4][1] = 'none';
dispinfo[4][2] = 'none';
dispinfo[4][3] = '';
function setdatebox(disptype)
{
var target;
var j;
if (disptype > 4) disptype = 4;
for (j = 0; j < names.length; j++)
{
target = document.getElementById(names[j]).style;
target.display = dispinfo[disptype][j];
}
}
function settypebox(pagetype)
{
var newdateformat = 1;
var target1 = document.getElementById('export_date');
var target2 = document.getElementById('export2_date');
if (pagetype == 'page')
{
target1.style.display = '';
target2.style.display = 'none';
newdateformat = target1.value;
}
else
{
target1.style.display = 'none';
target2.style.display = '';
newdateformat = target2.value;
}
setdatebox(newdateformat);
}
//]]>
</script>\n";
return $script_js;
}
function get_for_delete($keep_year,$keep_month = 1, $filter='*')
{
global $sql, $stats_list;
$ret = array();
// Its tedious, but the filter criteria are sufficiently tricky that its probably best to read all records and decide what can go
if ($sql->db_Select('logstats','log_id'))
{
while ($row = $sql->db_Fetch())
{
$can_go = FALSE;
$check = FALSE;
$data_type = 'unknown';
$date_info = $row['log_id'];
if (($temp = strpos($date_info,':')) !== FALSE)
{ // its monthly browser stats and similar
// echo "Checking {$date_info}, posn = {$temp} ";
$data_type = substr($date_info,0,$temp);
$date_info = substr($date_info,$temp+1);
$check = TRUE;
// echo "Date string: {$date_info}, data type: {$data_type}<br />";
if (isset($stats_list[$data_type])) $data_type = $stats_list[$data_type];
}
list($poss_year,$poss_month,$poss_day) = explode('-',$date_info.'--',3);
if (!$check)
{
if (is_numeric($poss_year))
{
$check = TRUE;
if ($poss_day > 0) $data_type = 'daily'; else $data_type = 'monthly';
}
}
if ($check)
{
if ($keep_year == $poss_year)
{
if (($poss_month > 0) && ($poss_month < $keep_month)) $can_go = TRUE;
}
elseif ($keep_year > $poss_year) $can_go = TRUE;
}
if ($can_go)
{
$ret[$row['log_id']] = $row['log_id']." - ".$data_type;
}
}
}
return $ret;
}
//---------------------------------------------
// Remove page entries - prompt/list
//---------------------------------------------
function rempage()
{
global $sql, $ns;
@@ -250,9 +719,9 @@ function rempage()
{
$text .= "
<tr>
<td style='width:30%' class='forumheader3'>$key</td>
<td style='width:30%' class='forumheader3'>{$key}</td>
<td style='width:50%' class='forumheader3'>".$page['url']."</td>
<td style='width:30%; text-align: center;' class='forumheader3'><input type='checkbox' name='remcb[]' value='$key' /></td>
<td style='width:30%; text-align: center;' class='forumheader3'><input type='checkbox' name='remcb[]' value='{$key}' /></td>
</tr>
";
}
@@ -273,6 +742,9 @@ function rempage()
}
//---------------------------------------------
// Remove page entries - action
//---------------------------------------------
function rempagego()
{
global $sql;
@@ -326,11 +798,41 @@ function rempagego()
$data .= "\n);\n\n?". chr(62);
if ($handle = fopen($logfile, 'w')) {
fwrite($handle, $data);
if ($handle = fopen($logfile, 'w'))
{
fwrite($handle, $data);
}
fclose($handle);
}
function admin_config_adminmenu()
{
if (e_QUERY)
{
$tmp = explode(".", e_QUERY);
$action = $tmp[0];
}
if (!isset($action) || ($action == "")) $action = "config";
$var['config']['text'] = ADSTAT_L35;
$var['config']['link'] = 'admin_config.php';
$var['export']['text'] = ADSTAT_L36;
$var['export']['link'] ='admin_config.php?export';
// $var['datasets']['text'] = ADSTAT_L63;
// $var['datasets']['link'] ='admin_config.php?datasets';
$var['rempage']['text'] = ADSTAT_L26;
$var['rempage']['link'] ='admin_config.php?rempage';
$var['history']['text'] = ADSTAT_L69;
$var['history']['link'] ='admin_config.php?history';
show_admin_menu(ADSTAT_L39, $action, $var);
}
?>

View File

@@ -11,18 +11,19 @@
| GNU General Public License (http://gnu.org).
|
| $Source: /cvs_backup/e107_0.8/e107_plugins/log/consolidate.php,v $
| $Revision: 1.9 $
| $Date: 2007-02-10 15:54:47 $
| $Revision: 1.10 $
| $Date: 2007-11-01 20:28:21 $
| $Author: e107steved $
+----------------------------------------------------------------------------+
*/
/* first thing to do is check if the log file is out of date ... */
$pathtologs = e_PLUGIN."log/logs/";
$date = date("z.Y", time());
$yesterday = date("z.Y",(time() - 86400)); // This makes sure year wraps round OK
$date2 = date("Y-m-j", (time() -86400)); // Yesterday's date for the database summary
$date3 = date("Y-m"); // Current month's date for monthly summary
$date3 = date("Y-m", (time() -86400)); // Current month's date for monthly summary (we're working with yesterday's data)
$pfileprev = "logp_".$yesterday.".php"; // Yesterday's log file
$pfile = "logp_".$date.".php"; // Today's log file
@@ -38,7 +39,7 @@ else if(!file_exists($pathtologs.$pfileprev))
{ // See if any older log files
if (($retvalue = check_for_old_files($pathtologs)) === FALSE)
{ /* no logfile found at all - create - this will only ever happen once ... */
createLog("blank");
createLog($pathtologs);
return FALSE;
}
// ... if we've got files
@@ -47,19 +48,47 @@ else if(!file_exists($pathtologs.$pfileprev))
// List of the non-page-based info which is gathered - historically only 'all-time' stats, now we support monthly as well
$stats_list = array('statBrowser','statOs','statScreen','statDomain','statReferer','statQuery');
$qry = "`log_id` IN ('statTotal','statUnique'";
foreach ($stats_list as $s)
{
$qry .= ",'{$s}'"; // Always read the all-time stats
if ($pref[$s] == 2) $qry .= ",'{$s}:{$date3}'"; // Look for monthlys as well as cumulative
}
$qry .= ")";
/* log file is out of date - consolidation required */
/* get existing stats ... */
if($sql -> db_Select("logstats", "*", "log_id='statBrowser' OR log_id='statOs' OR log_id='statScreen' OR log_id='statDomain' OR log_id='statTotal' OR log_id='statUnique' OR log_id='statReferer' OR log_id='statQuery'")) {
$infoArray = array();
//if($sql -> db_Select("logstats", "*", "log_id='statBrowser' OR log_id='statOs' OR log_id='statScreen' OR log_id='statDomain' OR log_id='statTotal' OR log_id='statUnique' OR log_id='statReferer' OR log_id='statQuery'"))
if($sql -> db_Select("logstats", "*", $qry))
{ // That's read in all the stats we need to modify
while($row = $sql -> db_Fetch())
{
$$row[1] = unserialize($row[2]); // $row[1] is the stats type - save in a variable
if($row[1] == "statUnique") $statUnique = $row[2];
if($row[1] == "statTotal") $statTotal = $row[2];
if($row['log_id'] == "statUnique")
{
$statUnique = $row['log_data'];
}
elseif ($row['log_id'] == "statTotal")
{
$statTotal = $row['log_data'];
}
elseif (($pos = strpos($row['log_id'],':')) === FALSE)
{ // Its all-time stats
$$row['log_id'] = unserialize($row['log_data']); // $row['log_id'] is the stats type - save in a variable
}
else
{ // Its monthly stats
$row['log_id'] = 'mon_'.substr($row['log_id'],0,$pos); // Create a generic variable for each monthly stats
$$row['log_id'] = unserialize($row['log_data']); // $row['log_id'] is the stats type - save in a variable
}
}
}else{
/* this must be the first time a consolidation has happened - this will only ever happen once ... */
}
else
{
// this must be the first time a consolidation has happened - this will only ever happen once ...
$sql -> db_Insert("logstats", "0, 'statBrowser', ''");
$sql -> db_Insert("logstats", "0, 'statOs', ''");
$sql -> db_Insert("logstats", "0, 'statScreen', ''");
@@ -76,36 +105,58 @@ if($sql -> db_Select("logstats", "*", "log_id='statBrowser' OR log_id='statOs' O
$statQuery =array();
}
require_once($pathtologs.$pfileprev);
require_once($pathtologs.$ifileprev);
foreach($browserInfo as $name => $amount) {
foreach ($stats_list as $s)
{
$varname = 'mon_'.$s;
if (!isset($$varname)) $$varname = array(); // Create monthly arrays if they don't exist
}
require_once($pathtologs.$pfileprev); // Yesterday's page accesses - $pageInfo array
require_once($pathtologs.$ifileprev); // Yesterdays browser accesses etc
foreach($browserInfo as $name => $amount)
{
$statBrowser[$name] += $amount;
$mon_statBrowser[$name] += $amount;
}
foreach($osInfo as $name => $amount) {
foreach($osInfo as $name => $amount)
{
$statOs[$name] += $amount;
$mon_statOs[$name] += $amount;
}
foreach($screenInfo as $name => $amount) {
foreach($screenInfo as $name => $amount)
{
$statScreen[$name] += $amount;
$mon_statScreen[$name] += $amount;
}
foreach($domainInfo as $name => $amount) {
if(!is_numeric($name)) {
foreach($domainInfo as $name => $amount)
{
if(!is_numeric($name))
{
$statDomain[$name] += $amount;
$mon_statDomain[$name] += $amount;
}
}
foreach($refInfo as $name => $info) {
foreach($refInfo as $name => $info)
{
$statReferer[$name]['url'] = $info['url'];
$statReferer[$name]['ttl'] += $info['ttl'];
$mon_statReferer[$name]['url'] = $info['url'];
$mon_statReferer[$name]['ttl'] += $info['ttl'];
}
foreach($searchInfo as $name => $amount) {
foreach($searchInfo as $name => $amount)
{
$statQuery[$name] += $amount;
$mon_statQuery[$name] += $amount;
}
$browser = serialize($statBrowser);
@@ -118,18 +169,37 @@ $squery = serialize($statQuery);
$statTotal += $siteTotal;
$statUnique += $siteUnique;
$sql -> db_Update("logstats", "log_data='$browser' WHERE log_id='statBrowser'");
$sql -> db_Update("logstats", "log_data='$os' WHERE log_id='statOs'");
$sql -> db_Update("logstats", "log_data='$screen' WHERE log_id='statScreen'");
$sql -> db_Update("logstats", "log_data='$domain' WHERE log_id='statDomain'");
$sql -> db_Update("logstats", "log_data='$refer' WHERE log_id='statReferer'");
$sql -> db_Update("logstats", "log_data='$squery' WHERE log_id='statQuery'");
// Save cumulative results - always keep track of these, even if the $pref doesn't display them
$sql -> db_Update("logstats", "log_data='{$browser}' WHERE log_id='statBrowser'");
$sql -> db_Update("logstats", "log_data='{$os}' WHERE log_id='statOs'");
$sql -> db_Update("logstats", "log_data='{$screen}' WHERE log_id='statScreen'");
$sql -> db_Update("logstats", "log_data='{$domain}' WHERE log_id='statDomain'");
$sql -> db_Update("logstats", "log_data='{$refer}' WHERE log_id='statReferer'");
$sql -> db_Update("logstats", "log_data='{$squery}' WHERE log_id='statQuery'");
$sql -> db_Update("logstats", "log_data='".intval($statTotal)."' WHERE log_id='statTotal'");
$sql -> db_Update("logstats", "log_data='".intval($statUnique)."' WHERE log_id='statUnique'");
/* get monthly info from db */
if($sql -> db_Select("logstats", "*", "log_id='$date3' ")) {
// Now save the relevant monthly results - only where enabled
foreach ($stats_list as $s)
{
if (isset($pref[$s]) && ($pref[$s] > 1))
{ // Value 2 requires saving of monthly stats
$srcvar = 'mon_'.$s;
$destvar = 'smon_'.$s;
$$destvar = serialize($$srcvar);
if (!$sql -> db_Update("logstats", "log_data='".$$destvar."' WHERE log_id='".$s.":".$date3."'"))
{
$sql -> db_Insert("logstats", "0, '".$s.":".$date3."', '".$$destvar."'");
}
}
}
/* get page access monthly info from db */
if($sql -> db_Select("logstats", "*", "log_id='{$date3}' "))
{
$tmp = $sql -> db_Fetch();
$monthlyInfo = unserialize($tmp['log_data']);
unset($tmp);
@@ -146,10 +216,13 @@ foreach($pageInfo as $key => $info)
$monthlyinfo = serialize($monthlyInfo);
if($MonthlyExistsFlag) {
$sql -> db_Update("logstats", "log_data='$monthlyinfo' WHERE log_id='$date3'");
} else {
$sql->db_Insert("logstats", "0, '$date3', '$monthlyinfo'");
if($MonthlyExistsFlag)
{
$sql -> db_Update("logstats", "log_data='{$monthlyinfo}' WHERE log_id='{$date3}'");
}
else
{
$sql->db_Insert("logstats", "0, '{$date3}', '{$monthlyinfo}'");
}
@@ -174,9 +247,9 @@ foreach($pageInfo as $key => $info)
$pagetotal = serialize($pageTotal);
if(!$sql -> db_Update("logstats", "log_data='$pagetotal' WHERE log_id='pageTotal' "))
if(!$sql -> db_Update("logstats", "log_data='{$pagetotal}' WHERE log_id='pageTotal' "))
{
$sql -> db_Insert("logstats", "0, 'pageTotal', '$pagetotal' ");
$sql -> db_Insert("logstats", "0, 'pageTotal', '{$pagetotal}' ");
}
@@ -215,16 +288,17 @@ if(!unlink($pathtologs.$ifileprev))
}
/* and finally, we need to create new logfiles for today ... */
createLog();
createLog($pathtologs);
/* done! */
function createLog($mode="default")
function createLog($pathtologs)
{
global $pathtologs, $statTotal, $statUnique, $pfile, $ifile;
global $statTotal, $statUnique, $pfile, $ifile;
if(!is_writable($pathtologs))
{
echo "Log directory is not writable - please CHMOD ".e_PLUGIN."log/logs to 777";
echo '<br />Path to logs: '.$pathtologs;
return FALSE;
}

View File

@@ -11,8 +11,8 @@
| GNU General Public License (http://gnu.org).
|
| $Source: /cvs_backup/e107_0.8/e107_plugins/log/languages/English.php,v $
| $Revision: 1.3 $
| $Date: 2007-08-14 19:27:22 $
| $Revision: 1.4 $
| $Date: 2007-11-01 20:28:22 $
| $Author: e107steved $
+----------------------------------------------------------------------------+
*/
@@ -43,7 +43,7 @@ define("ADSTAT_L21", "Total");
define("ADSTAT_L22", "Unique");
define("ADSTAT_L23", "Total Visits");
define("ADSTAT_L24", "Total Unique Visits");
define("ADSTAT_L25", "No statistics yet.");
define("ADSTAT_L25", "No statistics available.");
define("ADSTAT_L26", "Browser");
define("ADSTAT_L27", "Operating System");
define("ADSTAT_L28", "Countries / Domains");
@@ -67,8 +67,18 @@ define("ADSTAT_L44", "All-time page errors");
define("ADSTAT_L45", "Stats deleted for: ");
define("ADSTAT_L46", "Note: any stats for today will not be deleted");
define("ADSTAT_L47", "No stats found for: ");
define("ADSTAT_L48", "");
define("ADSTAT_L49", "");
define("ADSTAT_L50", "");
define("ADSTAT_L48", "sort by total");
define("ADSTAT_L49", "sort alphabetically");
define("ADSTAT_L50", "All-time stats");
define("ADSTAT_L51", "Current month stats");
define("ADSTAT_L52", "Previous month stats");
define("ADSTAT_L53", "");
define("ADSTAT_L54", "");
define("ADSTAT_L55", "");
define("ADSTAT_L56", "");
define("ADSTAT_L57", "");
define("ADSTAT_L58", "");
define("ADSTAT_L59", "");
define("ADSTAT_L60", "");
?>

View File

@@ -11,8 +11,8 @@
| GNU General Public License (http://gnu.org).
|
| $Source: /cvs_backup/e107_0.8/e107_plugins/log/languages/admin/English.php,v $
| $Revision: 1.3 $
| $Date: 2007-05-30 20:49:13 $
| $Revision: 1.4 $
| $Date: 2007-11-01 20:28:22 $
| $Author: e107steved $
+----------------------------------------------------------------------------+
*/
@@ -31,7 +31,7 @@ define("ADSTAT_L9", "Countries/domains visited from");
define("ADSTAT_L10", "Referrers");
define("ADSTAT_L11", "Search queries");
define("ADSTAT_L12", "Reset stats");
define("ADSTAT_L13", "this will erase stats - careful!");
define("ADSTAT_L13", "this will erase the all-time stats - careful!<br />There is a separate menu option to delete selected historical data");
define("ADSTAT_L14", "Page counts");
define("ADSTAT_L15", "Update Statistic Settings");
define("ADSTAT_L16", "Site Statistic Settings");
@@ -53,6 +53,52 @@ define("ADSTAT_L31", "Remove selected pages");
define("ADSTAT_L32", "Page Tidy");
define("ADSTAT_L33", "Configure Statistics Logging");
define("ADSTAT_L34", "Site Stats");
define ('ADSTAT_L35', 'Options');
define ('ADSTAT_L36', 'Data Export');
define ('ADSTAT_L37', 'Create export file');
define ('ADSTAT_L38', "You must set the permissions of the e107_plugins/log/logs folder to 777 (chmod 777)");
define ('ADSTAT_L39', 'Stats Logging Functions');
define ('ADSTAT_L40', 'Export log data');
define ('ADSTAT_L41', 'Date selection');
define ('ADSTAT_L42', 'Single Day');
define ('ADSTAT_L43', 'Daily for a month');
define ('ADSTAT_L44', 'Monthly for a year');
define ('ADSTAT_L45', 'All-time');
define ('ADSTAT_L46', 'Date:');
define ('ADSTAT_L47', 'Invalid date chosen');
define ('ADSTAT_L48', 'Monthly and All-time');
define ('ADSTAT_L49', 'All-time Only');
define ('ADSTAT_L50', 'None');
define ('ADSTAT_L51', 'Output Data');
define ('ADSTAT_L52', 'Page Data');
define ('ADSTAT_L53', 'No selection possible');
define ('ADSTAT_L54', 'Invalid type selection');
define ('ADSTAT_L55', 'Single quote');
define ('ADSTAT_L56', 'Double quote');
define ('ADSTAT_L57', 'Comma');
define ('ADSTAT_L58', 'Pipe (|)');
define ('ADSTAT_L59', 'CSV separator, quotes');
define ('ADSTAT_L60', 'Strip site address from URLs');
define ('ADSTAT_L61', '(if checked, just gives page reference)');
define ('ADSTAT_L62', 'All-time (detailed)');
define ('ADSTAT_L63', 'Available Datasets');
define ('ADSTAT_L64', 'Database records found:');
define ('ADSTAT_L65', 'DB filter string:');
define ('ADSTAT_L66', 'Show Datasets');
define ('ADSTAT_L67', 'Generate a CSV (Comma Separated Variable) file of historical statistics which meets the specified criteria');
define ('ADSTAT_L68', 'Show the statistics database entries which actually exist and meet the selection criteria');
define ('ADSTAT_L69', 'Delete historical data');
define ('ADSTAT_L70', 'Delete data older than:');
define ('ADSTAT_L71', 'Delete Data');
define ('ADSTAT_L72', 'Confirm deletion of data older than first day of:');
define ('ADSTAT_L73', 'Confirm');
define ('ADSTAT_L74', '(List of data entries which will be deleted below)');
define ('ADSTAT_L75', 'Records for deletion');
define ('ADSTAT_L76', 'Caution! Once deleted, the data cannot be recovered. Backup or export your database first');
define ('ADSTAT_L77', 'Records deleted:');
define ('ADSTAT_L78', 'Show previous month as well as current month for non-page access stats');
define ('ADSTAT_L79', '(Only used if monthly stats collected)');
define ('ADSTAT_L80', '');
?>

View File

@@ -10,11 +10,9 @@
| Released under the terms and conditions of the
| GNU General Public License (http://gnu.org).
|
| File locking, modified getip() 18.01.07
|
| $Source: /cvs_backup/e107_0.8/e107_plugins/log/log.php,v $
| $Revision: 1.3 $
| $Date: 2007-08-14 19:27:22 $
| $Revision: 1.4 $
| $Date: 2007-11-01 20:28:21 $
| $Author: e107steved $
+----------------------------------------------------------------------------+
*/
@@ -25,27 +23,12 @@
// color= colord
// eself= eself
// res= res
// err_direct - optional error flag
// err_referer - referrer if came via error page
define("log_INIT", TRUE);
$colour = strip_tags((isset($_REQUEST['color']) ? $_REQUEST['color'] : ''));
$res = strip_tags((isset($_REQUEST['res']) ? $_REQUEST['res'] : ''));
$self = strip_tags((isset($_REQUEST['eself']) ? $_REQUEST['eself'] : ''));
$ref = addslashes(strip_tags((isset($_REQUEST['referer']) ? $_REQUEST['referer'] : '')));
$date = date("z.Y", time());
$logPfile = "logs/logp_".$date.".php";
if ($err_code = strip_tags((isset($_REQUEST['err_direct']) ? $_REQUEST['err_direct'] : '')))
{
$ref = addslashes(strip_tags(isset($_REQUEST['err_referer']) ? $_REQUEST['err_referer'] : ''));
$log_string = $err_code.",".$self.",".$ref;
// Uncomment the next two lines to create a separate CSV format log of invalid accesses - error code, entered URL, referrer
// $logname = "logs/errpages.csv";
// $logfp = fopen($logname, 'a+'); fwrite($logfp, $log_string."\n\r"); fclose($logfp);
$err_code .= ':';
}
if(strstr($ref, "admin"))
{
@@ -75,29 +58,24 @@ $pageName = substr($match[1], (strrpos($match[1], "/")+1));
$PN = $pageName;
$pageName = preg_replace("/".$tagRemove."/si", "", $pageName);
if($pageName == "") $pageName = "index";
$pageName = $err_code.$pageName; // Add the error code at the beginning, so its treated uniquely
if(preg_match("/".$pageDisallow."/i", $pageName)) return;
$p_handle = fopen($logPfile, 'r+');
if($p_handle && flock( $p_handle, LOCK_EX ) )
$logPfile = "logs/logp_".$date.".php";
$handle = fopen($logPfile, 'r+');
if($handle && flock( $handle, LOCK_EX ) )
{
$log_file_contents = '';
while (!feof($p_handle))
{ // Assemble a string of data
$log_file_contents.= fgets($p_handle,1000);
}
$log_file_contents = str_replace(array('<'.'?php','?'.'>'),'',$log_file_contents);
if (eval($log_file_contents) === FALSE) echo "error in log file contents<br /><br /><br /><br />";
$log_file_contents = get_file_contents($handle);
$log_file_contents = str_replace(array('<'.'?php','?>'),'',$log_file_contents);
if (eval($log_file_contents) === FALSE) echo "error in log file contents<br />";
}
else
{
echo "Couldn't log data<br /><br /><br /><br />";
echo "Couldn't log data<br />";
exit;
}
//require_once($logPfile);
$flag = FALSE;
if(array_key_exists($pageName, $pageInfo))
@@ -139,12 +117,13 @@ $data = "<?php
?>";
if ($p_handle)
if ($handle)
{
ftruncate( $p_handle, 0 );
fseek( $p_handle, 0 );
fwrite($p_handle, $data);
fclose($p_handle);
ftruncate( $handle, 0 );
// fwrite( $handle, $part_one );
// sleep( 10 ); // for test purpose, assume the whole writing process takes 10 seconds
fwrite($handle, $data);
fclose($handle);
}
@@ -154,15 +133,16 @@ function getip($mode=TRUE)
if (getenv('HTTP_X_FORWARDED_FOR'))
{
$ip = $_SERVER['REMOTE_ADDR'];
if (preg_match("#^(\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})#", getenv('HTTP_X_FORWARDED_FOR'), $ip3))
// Shouldn't this be: "#((?:\d{1,3}\.){3}\d{1,3})#" or "#(\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})#"
if (preg_match("/^([0-9]+\.[0-9]+\.[0-9]+\.[0-9]+)/", getenv('HTTP_X_FORWARDED_FOR'), $ip3))
{
$ip2 = array('#^0\..*#',
$ip2 = array('#^0\..*#',
'#^127\..*#', // Local loopbacks
'#^192\.168\..*#', // RFC1918 - Private Network
'#^172\.(?:1[6789]|2\d|3[01])\..*#', // RFC1918 - Private network
'#^10\..*#', // RFC1918 - Private Network
'#^192\.168\..*#', // Private Network
'#^172\.(?:1[6789]|2\d|3[01])\..*#', // Private network
'#^10\..*#', // Private Network
'#^169\.254\..*#', // RFC3330 - Link-local, auto-DHCP
'#^2(?:2[456789]|[345][0-9])\..*#' // Single check for Class D and Class E
'#^2[45][0-9]\..*#' // Single check for Class D and Class E
);
$ip = preg_replace($ip2, $ip, $ip3[1]);
}

View File

@@ -11,8 +11,8 @@
| GNU General Public License (http://gnu.org).
|
| $Source: /cvs_backup/e107_0.8/e107_plugins/log/plugin.php,v $
| $Revision: 1.3 $
| $Date: 2007-05-30 20:49:13 $
| $Revision: 1.4 $
| $Date: 2007-11-01 20:28:21 $
| $Author: e107steved $
+----------------------------------------------------------------------------+
*/
@@ -24,7 +24,7 @@ if (!defined('e107_INIT')) { exit; }
// Plugin info -------------------------------------------------------------------------------------------------------
$eplug_name = ADSTAT_L3;
$eplug_version = "2.0";
$eplug_version = "2.1";
$eplug_author = "jalist";
$eplug_url = "http://e107.org";
$eplug_email = "jalist@e107.org";
@@ -52,14 +52,14 @@ $eplug_prefTable = "menu_pref";
$eplug_prefs = array(
"statActivate" => 0,
"statUserclass" => "",
"statClass" => 0,
"statBrowser" => 1,
"statOs" => 1,
"statScreen" => 1,
"statDomain" => 1,
"statRefer" => 1,
"statQuery" => 1,
"statRecent" => 1
"statRecent" => 1,
"statPrevMonth" => 0
);
// List of table names -----------------------------------------------------------------------------------------------
@@ -85,5 +85,8 @@ $eplug_link_url = e_PLUGIN."log/stats.php?1";
// Text to display after plugin successfully installed ------------------------------------------------------------------
$eplug_done = ADSTAT_L2;
$upgrade_add_prefs = array("statPrevMonth" => 0);
$upgrade_remove_prefs = array("statClass");
?>

View File

@@ -11,8 +11,8 @@
| GNU General Public License (http://gnu.org).
|
| $Source: /cvs_backup/e107_0.8/e107_plugins/log/stats.php,v $
| $Revision: 1.4 $
| $Date: 2007-08-14 19:27:22 $
| $Revision: 1.5 $
| $Date: 2007-11-01 20:28:21 $
| $Author: e107steved $
+----------------------------------------------------------------------------+
*/
@@ -21,7 +21,6 @@ require_once("../../class2.php");
@include_once(e_PLUGIN."log/languages/".e_LANGUAGE.".php");
@include_once(e_PLUGIN."log/languages/English.php");
$stat = new siteStats();
function core_head() {
$bar = (file_exists(THEME."images/bar.png") ? THEME."images/bar.png" : e_IMAGE."generic/bar.png");
@@ -52,11 +51,13 @@ if (!$pref['statActivate']) {
$qs = explode('.', e_QUERY, 3);
$action = varset($qs[0],1);
$sec_action = varset($qs[1],FALSE);
$order = varset($qs[2],0);
$order = varset($qs[1],0); // Sort order
$toremove = $order;
$toremove = varset($qs[2],'');
$order = intval($order);
$stat = new siteStats();
if($stat -> error)
{
$ns->tablerender(ADSTAT_L6, $stat -> error);
@@ -393,6 +394,19 @@ $country["zw"] = "Zimbabwe";
8: search engine strings
*/
function display_pars($rec_pars, $disp_pars = '*')
{
global $pref;
switch ($rec_pars)
{
case 1 : return array(1);
case 2 : if (varset($pref['statPrevMonth'],0)) return array(2,3,1); else return array(2,1);
case 3 : return array(2,3,1);
default : return array();
}
}
$text = '';
if ((ADMIN == TRUE) && ($sec_action == "rem"))
{
@@ -425,61 +439,83 @@ switch($action)
if (ADMIN == TRUE)
$text .= $stat -> renderAlltimeVisits(TRUE);
break;
case 3:
if($pref['statBrowser']) {
$text .= $stat -> renderBrowsers();
} else {
case 3 :
case 14 :
if($pref['statBrowser'])
{
$text .= $stat -> renderBrowsers(display_pars($pref['statBrowser']), $action==3);
}
else
{
$text .= ADSTAT_L7;
}
break;
}
break;
case 4:
if($pref['statOs']) {
$text .= $stat -> renderOses();
} else {
if($pref['statOs'])
{
$text .= $stat -> renderOses(display_pars($pref['statOs']));
}
else
{
$text .= ADSTAT_L7;
}
break;
}
break;
case 5:
if($pref['statDomain']) {
$text .= $stat -> renderDomains();
} else {
if($pref['statDomain'])
{
$text .= $stat -> renderDomains(display_pars($pref['statDomain']));
}
else
{
$text .= ADSTAT_L7;
}
break;
}
break;
case 6:
if($pref['statScreen']) {
$text .= $stat -> renderScreens();
} else {
if($pref['statScreen'])
{
$text .= $stat -> renderScreens(display_pars($pref['statScreen']));
}
else
{
$text .= ADSTAT_L7;
}
break;
}
break;
case 7:
if($pref['statRefer']) {
$text .= $stat -> renderRefers();
} else {
if ($pref['statRefer'])
{
$text .= $stat -> renderRefers(display_pars($pref['statRefer']));
}
else
{
$text .= ADSTAT_L7;
}
break;
}
break;
case 8:
if($pref['statQuery']) {
$text .= $stat -> renderQueries();
} else {
if ($pref['statQuery'])
{
$text .= $stat -> renderQueries(display_pars($pref['statQuery']));
}
else
{
$text .= ADSTAT_L7;
}
break;
}
break;
case 9:
if($pref['statRecent']) {
if ($pref['statRecent'])
{
$text .= $stat -> recentVisitors();
} else {
}
else
{
$text .= ADSTAT_L7;
}
break;
}
break;
case 10:
$text .= $stat -> renderDaily();
break;
$text .= $stat -> renderDaily();
break;
case 11:
$text .= $stat -> renderMonthly();
break;
$text .= $stat -> renderMonthly();
break;
default :
$text .= $stat -> renderTodaysVisits(FALSE);
}
@@ -500,6 +536,7 @@ switch($action)
11 - Monthly stats
12 - Today's error page visits
13 - All-time error page visits
14 - Consolidated browser view (not listed as a menu option)
*/
$path = e_PLUGIN."log/stats.php";
@@ -527,7 +564,40 @@ $links .= "</div><br /><br />";
$ns->tablerender(ADSTAT_L6, $links.$text);
require_once(FOOTERF);
class siteStats {
function make_bits($prefix, $act)
{
$ret = array();
$now = getdate();
$ret['hdg_extra'] = '';
switch ($act)
{
case 1 :
$ret['query'] = "log_id='{$prefix}'";
break;
case 2 :
$ret['query'] = "log_id='{$prefix}:".date("Y-m")."'";
$ret['hdg_extra'] = " (".$now['mon']."-".$now['year'].")";
break;
case 3 :
$now['mon']--;
if ($now['mon']==0)
{
$now['mon'] = 12;
$now['year']--;
}
$ret['query'] = "log_id='{$prefix}:".sprintf("%04d-%02d",$now['year'],$now['mon'])."'";
$ret['hdg_extra'] = " (".$now['mon']."-".$now['year'].")";
break;
default: $ret = "Invalid selection: {$act}<br />";
}
return $ret;
}
class siteStats
{
var $browser_headings = array(1 => ADSTAT_L50, 2 => ADSTAT_L51, 3 => ADSTAT_L52);
var $dbPageInfo;
var $fileInfo;
@@ -706,11 +776,12 @@ class siteStats {
<col style='width: 10%;' />
</colgroup>
<tr>\n<td class='fcaption' >".ADSTAT_L19."</td>\n
<td class='fcaption' colspan='2'>".ADSTAT_L23."</td>\n<td class='fcaption' text-align: center;'>%</td>\n</tr>\n";
<td class='fcaption' colspan='2'>".ADSTAT_L23."</td>\n<td class='fcaption' style='text-align: center;'>%</td>\n</tr>\n";
foreach($totalArray as $key => $info)
{
if($info['ttlv'])
{
if (!$info['url'] && (($key == 'index') || (strpos($key,':index') !== FALSE))) $info['url'] = e_BASE.'index.php'; // Avoids empty link
$percentage = round(($info['ttlv']/$total) * 100, 2);
$text .= "<tr>
<td class='forumheader3' >
@@ -723,7 +794,7 @@ class siteStats {
</tr>\n";
}
}
$text .= "<tr><td class='forumheader' colspan='2'>".ADSTAT_L21."</td><td class='forumheader' style='text-align: center;'>$total</td><td class='forumheader'></td></tr>\n</table>";
$text .= "<tr><td class='forumheader' colspan='2'>".ADSTAT_L21."</td><td class='forumheader' style='text-align: center;'>{$total}</td><td class='forumheader'></td></tr>\n</table>";
$uniqueArray = array();
@@ -744,6 +815,7 @@ class siteStats {
{
if($info['ttlv'])
{
if (!$info['url'] && (($key == 'index') || (strpos($key,':index') !== FALSE))) $info['url'] = e_BASE.'index.php'; // Avoids empty link
$percentage = round(($info['unqv']/$totalv) * 100, 2);
$text .= "<tr>
<td class='forumheader3' style='width: 20%;'><img src='".e_PLUGIN."log/images/html.png' alt='' style='vertical-align: middle;' /> <a href='".$info['url']."'>".$key."</a></td>
@@ -758,88 +830,177 @@ class siteStats {
/* -----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------*/
function renderBrowsers() {
global $sql, $browser_map;
// List browsers. $selection is an array of the info required - '2' = current month's stats, '1' = all-time stats (default)
// If $show_version is FALSE, browsers are consolidated across versions - e.g. 1 line for Firefox
function renderBrowsers($selection, $show_version=TRUE)
{
global $sql, $browser_map;
if (!$selection) $selection = array(1);
if (!is_array($selection)) $selection = array(1);
$text = '';
if($entries = $sql -> db_Select("logstats", "*", "log_id='statBrowser'")) {
echo "Show browsers; expanded = ".($show_version ? 'TRUE' : 'FALSE')."<br />";
foreach ($selection as $act)
{
unset($statBrowser);
$statBrowser = array();
$pars = make_bits('statBrowser',$act); // Get the query, plus maybe date for heading
if (!is_array($pars)) return $pars; // Return error if necessary
if ($entries = $sql -> db_Select("logstats", "*", $pars['query']))
{
$row = $sql -> db_Fetch();
$statBrowser = unserialize($row['log_data']);
}
/* temp consolidate today's data ... */
foreach($this -> fileBrowserInfo as $name => $count) {
if (($act == 1) || ($act == 2))
{
foreach($this -> fileBrowserInfo as $name => $count)
{
$statBrowser[$name] += $count;
}
}
if(!is_array($statBrowser)) {
return "<div style='text-align: center;'>".ADSTAT_L25."</div>";
if ($show_version == FALSE)
{
$temp_array = array();
foreach ($statBrowser as $b_full=>$v)
{
$b_type = '';
foreach ($browser_map as $name => $file)
{
if(stristr($b_full, $name) === 0)
{ // Match here
$b_type = $name;
break;
}
}
if (!$b_type) $b_type = $b_full; // Default is an unsupported browser - use the whole name
if (array_key_exists($temp_array,$b_type))
{
$temp_array[$b_type] += $v;
}
else
{
$temp_array[$b_type] = $v; // New browser found
}
}
$statBrowser = $temp_array;
unset($temp_array);
}
if(is_array($statBrowser)) {
if($this -> order) {
if ($this -> order)
{
ksort($statBrowser);
reset ($statBrowser);
$browserArray = $statBrowser;
} else {
}
else
{
$browserArray = $this -> arraySort($statBrowser, 0);
}
$total = array_sum($browserArray);
$text = "<table class='fborder' style='width: 100%;'>\n<tr>\n<td class='fcaption' style='width: 20%;'><a title='".($this -> order ? "sort by total" : "sort alphabetically")."'href='".e_SELF."?3".($this -> order ? "" : ".1" )."'>".ADSTAT_L26."</a></td>\n<td class='fcaption' style='width: 70%;' colspan='2'>".ADSTAT_L21."</td>\n<td class='fcaption' style='width: 10%; text-align: center;'>%</td>\n</tr>\n";
foreach($browserArray as $key => $info) {
$total = array_sum($browserArray);
$text .= "<table class='fborder' style='width: 100%;'>\n
<tr><td class='fcaption' colspan='4' style='text-align:center'>".$this->browser_headings[$act].$pars['hdg_extra']."</td></tr>\n
<tr><td class='fcaption' style='width: 20%;'>
<a title='".($this -> order ? ADSTAT_L48 : ADSTAT_L49)."' href='".e_SELF."?3".($this -> order ? "" : ".1" )."'>".ADSTAT_L26."</a>
</td>\n<td class='fcaption' style='width: 70%;' colspan='2'>".ADSTAT_L21."</td>\n
<td class='fcaption' style='width: 10%; text-align: center;'>%</td>\n</tr>\n";
if (count($browserArray))
{
foreach($browserArray as $key => $info)
{
$image = "";
foreach ($browser_map as $name => $file) {
if(strstr($key, $name)) {
foreach ($browser_map as $name => $file)
{
if(strstr($key, $name))
{
$image = "{$file}.png";
break;
}
}
if($image == "") {
if($image == "")
{
$image = "unknown.png";
}
$percentage = round(($info/$total) * 100, 2);
$text .= "<tr>
<td class='forumheader3' style='width: 20%;'>".($image ? "<img src='".e_PLUGIN."log/images/$image' alt='' style='vertical-align: middle;' /> " : "").$key."</td>".
<td class='forumheader3' style='width: 20%;'>".($image ? "<img src='".e_PLUGIN."log/images/{$image}' alt='' style='vertical-align: middle;' /> " : "").$key."</td>".
($entries == 1 ? "<td class='forumheader3' style='width: 70%;'>".$this -> bar($percentage, $info)."</td>" : "<td class='forumheader3' style='width: 70%;'>".$this -> bar($percentage, $info)."</td>")."
<td class='forumheader3' style='width: 10%; text-align: center;'>".$percentage."%</td>
</tr>\n";
}
$text .= "<tr><td class='forumheader' colspan='2'>".ADSTAT_L21."</td><td class='forumheader' style='text-align: center;'>{$total}</td>
<td class='forumheader'></td></tr>\n";
}
$text .= "<tr><td class='forumheader' colspan='2'>".ADSTAT_L21."</td><td class='forumheader' style='text-align: center;'>$total</td><td class='forumheader'></td></tr>\n</table>";
}
return $text;
else
{
$text .= "<tr><td class='fcaption' colspan='4' style='text-align:center'>".ADSTAT_L25."</td></tr>\n";
}
$text .= "</table><br />";
}
return $text;
}
/* -----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------*/
function renderOses() {
global $sql;
function renderOses($selection)
{
global $sql;
if (!$selection) $selection = array(1);
if (!is_array($selection)) $selection = array(1);
$text = '';
if($entries = $sql -> db_Select("logstats", "*", "log_id='statOs'")) {
$statOs = array();
foreach ($selection as $act)
{
$pars = make_bits('statOs',$act); // Get the query, plus maybe date for heading
if (!is_array($pars)) return $pars; // Return error if necessary
if ($entries = $sql -> db_Select("logstats", "*", $pars['query']))
{
$row = $sql -> db_Fetch();
$statOs = unserialize($row['log_data']);
}
/* temp consolidate today's data ... */
foreach($this -> fileOsInfo as $name => $count) {
if (($act == 1) || ($act == 2))
{
foreach($this -> fileOsInfo as $name => $count)
{
$statOs[$name] += $count;
}
}
if(!is_array($statOs)) {
return "<div style='text-align: center;'>".ADSTAT_L25.".</div>";
}
if($this -> order) {
if($this -> order)
{
ksort($statOs);
reset ($statOs);
$osArray = $statOs;
} else {
$osArray = $this -> arraySort($statOs, 0);
}
else
{
$osArray = $this -> arraySort($statOs, 0);
}
$total = array_sum($osArray);
$text = "<table class='fborder' style='width: 100%;'>\n<tr>\n<td class='fcaption' style='width: 20%;'><a title='".($this -> order ? "sort by total" : "sort alphabetically")."'href='".e_SELF."?4".($this -> order ? "" : ".1" )."'>".ADSTAT_L27."</a></td>\n<td class='fcaption' style='width: 70%;' colspan='2'>".ADSTAT_L21."</td>\n<td class='fcaption' style='width: 10%; text-align: center;'>%</td>\n</tr>\n";
foreach($osArray as $key => $info) {
$text .= "<table class='fborder' style='width: 100%;'>\n
<tr><td class='fcaption' colspan='4' style='text-align:center'>".$this->browser_headings[$act].$pars['hdg_extra']."</td></tr>\n
<tr>\n<td class='fcaption' style='width: 20%;'>
<a title='".($this -> order ? "sort by total" : "sort alphabetically")."' href='".e_SELF."?4".($this -> order ? "" : ".1" )."'>".ADSTAT_L27."</a></td>\n
<td class='fcaption' style='width: 70%;' colspan='2'>".ADSTAT_L21."</td>\n<td class='fcaption' style='width: 10%; text-align: center;'>%</td>\n</tr>\n";
if (count($osArray))
{
foreach($osArray as $key => $info)
{
$image = "";
if(strstr($key, "Windows")) { $image = "windows.png"; }
if(strstr($key, "Mac")) { $image = "mac.png"; }
@@ -858,42 +1019,73 @@ class siteStats {
($entries == 1 ? "<td class='forumheader3' style='width: 70%;'>".$this -> bar($percentage, $info)."</td>" : "<td class='forumheader3' style='width: 70%;'>".$this -> bar($percentage, $info)."</td>")."
<td class='forumheader3' style='width: 10%; text-align: center;'>".$percentage."%</td>
</tr>\n";
}
$text .= "<tr><td class='forumheader' colspan='2'>".ADSTAT_L21."</td><td class='forumheader' style='text-align: center;'>{$total}</td><td class='forumheader'>&nbsp;</td></tr>\n";
}
$text .= "<tr><td class='forumheader' colspan='2'>".ADSTAT_L21."</td><td class='forumheader' style='text-align: center;'>$total</td><td class='forumheader'></tr></tr>\n</table>";
return $text;
else
{
$text .= "<tr><td class='fcaption' colspan='4' style='text-align:center'>".ADSTAT_L25."</td></tr>\n";
}
$text .= "</table><br />";
}
return $text;
}
/* -----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------*/
function renderDomains() {
function renderDomains($selection)
{
global $sql;
if($sql -> db_Select("logstats", "*", "log_id='statDomain'")) {
if (!$selection) $selection = array(1);
if (!is_array($selection)) $selection = array(1);
$text = '';
$statDom = array();
foreach ($selection as $act)
{
$pars = make_bits('statDomain',$act); // Get the query, plus maybe date for heading
if (!is_array($pars)) return $pars; // Return error if necessary
if ($entries = $sql -> db_Select("logstats", "*", $pars['query']))
{
$row = $sql -> db_Fetch();
$statDom = unserialize($row['log_data']);
}
/* temp consolidate today's data ... */
foreach($this -> fileDomainInfo as $name => $count) {
if (($act == 1) || ($act == 2))
{
foreach($this -> fileDomainInfo as $name => $count)
{
$statDom[$name] += $count;
}
}
if(!count($statDom)) {
return "<div style='text-align: center;'>".ADSTAT_L25.".</div>";
}
if($this -> order) {
if($this -> order)
{
ksort($statDom);
reset ($statDom);
$domArray = $statDom;
} else {
$domArray = $this -> arraySort($statDom, 0);
}
else
{
$domArray = $this -> arraySort($statDom, 0);
}
$total = array_sum($domArray);
$text = "<table class='fborder' style='width: 100%;'>\n<tr>\n<td class='fcaption' style='width: 20%;'><a title='".($this -> order ? "sort by total" : "sort alphabetically")."'href='".e_SELF."?5".($this -> order ? "" : ".1" )."'>".ADSTAT_L28."</a></td>\n<td class='fcaption' style='width: 70%;' colspan='2'>".ADSTAT_L21."</td>\n<td class='fcaption' style='width: 10%; text-align: center;'>%</td>\n</tr>\n";
foreach($domArray as $key => $info) {
if($key = $this -> getcountry($key)) {
$text .= "<table class='fborder' style='width: 100%;'>\n
<tr><td class='fcaption' colspan='4' style='text-align:center'>".$this->browser_headings[$act].$pars['hdg_extra']."</td></tr>\n
<tr>\n<td class='fcaption' style='width: 20%;'>
<a title='".($this -> order ? "sort by total" : "sort alphabetically")."' href='".e_SELF."?5".($this -> order ? "" : ".1" )."'>".ADSTAT_L28."</a></td>\n
<td class='fcaption' style='width: 70%;' colspan='2'>".ADSTAT_L21."</td>\n<td class='fcaption' style='width: 10%; text-align: center;'>%</td>\n</tr>\n";
if (count($domArray))
{
foreach($domArray as $key => $info)
{
if($key = $this -> getcountry($key))
{
$percentage = round(($info/$total) * 100, 2);
$text .= "<tr>
<td class='forumheader3' style='width: 20%;'>".$key."</td>
@@ -901,31 +1093,52 @@ class siteStats {
<td class='forumheader3' style='width: 10%; text-align: center;'>".$percentage."%</td>
</tr>\n";
}
}
$text .= "<tr><td class='forumheader' colspan='2'>".ADSTAT_L21."</td><td class='forumheader' style='text-align: center;'>$total</td><td class='forumheader'></td></tr>\n";
}
$text .= "<tr><td class='forumheader' colspan='2'>".ADSTAT_L21."</td><td class='forumheader' style='text-align: center;'>$total</td><td class='forumheader'></td></tr>\n</table>";
else
{
$text .= "<tr><td class='fcaption' colspan='4' style='text-align:center'>".ADSTAT_L25."</td></tr>\n";
}
$text .= "</table><br />";
}
return $text;
}
/* -----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------*/
function renderScreens() {
function renderScreens($selection)
{
global $sql;
if($entries = $sql -> db_Select("logstats", "*", "log_id='statScreen'")) {
if (!$selection) $selection = array(1);
if (!is_array($selection)) $selection = array(1);
$text = '';
$statScreen = array();
foreach ($selection as $act)
{
$pars = make_bits('statScreen',$act); // Get the query, plus maybe date for heading
if (!is_array($pars)) return $pars; // Return error if necessary
if ($entries = $sql -> db_Select("logstats", "*", $pars['query']))
{
$row = $sql -> db_Fetch();
$statScreen = unserialize($row['log_data']);
}
/* temp consolidate today's data ... */
foreach($this -> fileScreenInfo as $name => $count) {
if (($act == 1) || ($act == 2))
{
foreach($this -> fileScreenInfo as $name => $count)
{
$statScreen[$name] += $count;
}
}
if(!is_array($statScreen)) {
return "<div style='text-align: center;'>".ADSTAT_L25."</div>";
}
if($this -> order) {
if($this -> order)
{
$nsarray = array();
foreach($statScreen as $key => $info) {
if(preg_match("/(\d+)x/", $key, $match)) {
@@ -939,14 +1152,23 @@ class siteStats {
$screenArray[$key] = $info['info'];
}
} else {
}
else
{
$screenArray = $this -> arraySort($statScreen, 0);
}
$total = array_sum($screenArray);
$text = "<table class='fborder' style='width: 100%;'>\n<tr>\n<td class='fcaption' style='width: 20%;'><a title='".($this -> order ? "sort by total" : "sort alphabetically")."'href='".e_SELF."?6".($this -> order ? "" : ".1" )."'>".ADSTAT_L29."</a></td>\n<td class='fcaption' style='width: 70%;' colspan='2'>".ADSTAT_L21."</td>\n<td class='fcaption' style='width: 10%; text-align: center;'>%</td>\n</tr>\n";
foreach($screenArray as $key => $info) {
if(strstr($key, "@") && !strstr($key, "undefined") && preg_match("/(\d+)x(\d+)@(\d+)/", $key)) {
$text .= "<table class='fborder' style='width: 100%;'>\n
<tr><td class='fcaption' colspan='4' style='text-align:center'>".$this->browser_headings[$act].$pars['hdg_extra']."</td></tr>\n
<tr>\n<td class='fcaption' style='width: 20%;'><a title='".($this -> order ? "sort by total" : "sort alphabetically")."' href='".e_SELF."?6".($this -> order ? "" : ".1" )."'>".ADSTAT_L29."</a></td>\n<td class='fcaption' style='width: 70%;' colspan='2'>".ADSTAT_L21."</td>\n<td class='fcaption' style='width: 10%; text-align: center;'>%</td>\n</tr>\n";
if (count($screenArray))
{
foreach($screenArray as $key => $info)
{
if(strstr($key, "@") && !strstr($key, "undefined") && preg_match("/(\d+)x(\d+)@(\d+)/", $key))
{
$percentage = round(($info/$total) * 100, 2);
$text .= "<tr>
<td class='forumheader3' style='width: 20%;'><img src='".e_PLUGIN."log/images/screen.png' alt='' style='vertical-align: middle;' /> ".$key."</td>".
@@ -954,45 +1176,68 @@ class siteStats {
<td class='forumheader3' style='width: 10%; text-align: center;'>".$percentage."%</td>
</tr>\n";
}
}
$text .= "<tr><td class='forumheader' colspan='2'>".ADSTAT_L21."</td><td class='forumheader' style='text-align: center;'>{$total}</td><td class='forumheader'></td></tr>\n";
}
$text .= "<tr><td class='forumheader' colspan='2'>".ADSTAT_L21."</td><td class='forumheader' style='text-align: center;'>$total</td><td class='forumheader'></td></tr>\n</table>";
return $text;
else
{
$text .= "<tr><td class='fcaption' colspan='4' style='text-align:center'>".ADSTAT_L25."</td></tr>\n";
}
$text .= "</table><br />";
}
return $text;
}
/* -----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------*/
function renderRefers() {
function renderRefers($selection)
{
global $sql, $pref;
if($sql -> db_Select("logstats", "*", "log_id='statReferer'")) {
if (!$selection) $selection = array(1);
if (!is_array($selection)) $selection = array(1);
$text = '';
$statRefer = array();
foreach ($selection as $act)
{
$pars = make_bits('statReferer',$act); // Get the query, plus maybe date for heading
if (!is_array($pars)) return $pars; // Return error if necessary
if ($entries = $sql -> db_Select("logstats", "*", $pars['query']))
{
$row = $sql -> db_Fetch();
$statRefer = unserialize($row['log_data']);
}
/* temp consolidate today's data ... */
foreach($this -> fileReferInfo as $name => $count) {
if (($act == 1) || ($act == 2))
{
foreach($this -> fileReferInfo as $name => $count)
{
$statRefer[$name]['url'] = $count['url'];
$statRefer[$name]['ttl'] += $count['ttl'];
}
//echo "<pre>"; print_r($statRefer); echo "</pre>"; exit;
if(!is_array($statRefer) || !count($statRefer)) {
return "<div style='text-align: center;'>".ADSTAT_L25.".</div>";
}
}
$statArray = $this -> arraySort($statRefer, 'ttl');
$total = 0;
foreach($statArray as $key => $info) {
foreach ($statArray as $key => $info)
{
$total += $info['ttl'];
}
$text = "<table class='fborder' style='width: 100%;'>\n<tr>\n<td class='fcaption' style='width: 40%;'><a title='".($this -> order ? "show cropped url" : "show full url")."'href='".e_SELF."?7".($this -> order ? "" : ".1" )."'>".ADSTAT_L30."</a></td>\n<td class='fcaption' style='width: 50%;' colspan='2'>".ADSTAT_L21."</td>\n<td class='fcaption' style='width: 10%; text-align: center;'>%</td>\n</tr>\n";
$text .= "<table class='fborder' style='width: 100%;'>\n
<tr><td class='fcaption' colspan='4' style='text-align:center'>".$this->browser_headings[$act].$pars['hdg_extra']."</td></tr>\n
<tr>\n<td class='fcaption' style='width: 40%;'><a title='".($this -> order ? "show cropped url" : "show full url")."' href='".e_SELF."?7".($this -> order ? "" : ".1" )."'>".ADSTAT_L30."</a></td>\n<td class='fcaption' style='width: 50%;' colspan='2'>".ADSTAT_L21."</td>\n<td class='fcaption' style='width: 10%; text-align: center;'>%</td>\n</tr>\n";
$count = 0;
foreach($statArray as $key => $info) {
if (count($statArray))
{
foreach($statArray as $key => $info)
{
$percentage = round(($info['ttl']/$total) * 100, 2);
if (!$this -> order && strlen($key) > 50) {
if (!$this -> order && strlen($key) > 50)
{
$key = substr($key, 0, 50)." ...";
}
$text .= "<tr>
@@ -1001,38 +1246,64 @@ class siteStats {
<td class='forumheader3' style='text-align: center;'>".$percentage."%</td>
</tr>\n";
$count++;
if($count == $pref['statDisplayNumber']) {
break;
if($count == $pref['statDisplayNumber'])
{
break;
}
}
$text .= "<tr><td class='forumheader' colspan='2'>".ADSTAT_L21."</td><td class='forumheader' style='text-align: center;'>{$total}</td><td class='forumheader'></td></tr>\n";
}
$text .= "<tr><td class='forumheader' colspan='2'>".ADSTAT_L21."</td><td class='forumheader' style='text-align: center;'>$total</td><td class='forumheader'></td></tr>\n</table>";
return $text;
else
{
$text .= "<tr><td class='fcaption' colspan='4' style='text-align:center'>".ADSTAT_L25."</td></tr>\n";
}
$text .= "</table><br />";
}
return $text;
}
/* -----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------*/
function renderQueries() {
function renderQueries($selection)
{
global $sql;
if($sql -> db_Select("logstats", "*", "log_id='statQuery'")) {
if (!$selection) $selection = array(1);
if (!is_array($selection)) $selection = array(1);
$text = '';
$statQuery = array();
foreach ($selection as $act)
{
$pars = make_bits('statQuery',$act); // Get the query, plus maybe date for heading
if (!is_array($pars)) return $pars; // Return error if necessary
if ($entries = $sql -> db_Select("logstats", "*", $pars['query']))
{
$row = $sql -> db_Fetch();
$statQuery = unserialize($row['log_data']);
}
/* temp consolidate today's data ... */
foreach($this -> fileQueryInfo as $name => $count) {
if (($act == 1) || ($act == 2))
{
foreach ($this -> fileQueryInfo as $name => $count)
{
$statQuery[$name] += $count;
}
}
if(!is_array($statQuery) || !count($statQuery)) {
return "<div style='text-align: center;'>".ADSTAT_L25."</div>";
}
$queryArray = $this -> arraySort($statQuery, 0);
$total = array_sum($queryArray);
$text = "<table class='fborder' style='width: 100%;'>\n<tr>\n<td class='fcaption' style='width: 60%;'>".ADSTAT_L31."</td>\n<td class='fcaption' style='width: 30%;' colspan='2'>".ADSTAT_L21."</td>\n<td class='fcaption' style='width: 10%; text-align: center;'>%</td>\n</tr>\n";
$text .= "<table class='fborder' style='width: 100%;'>\n
<tr><td class='fcaption' colspan='4' style='text-align:center'>".$this->browser_headings[$act].$pars['hdg_extra']."</td></tr>\n
<tr>\n<td class='fcaption' style='width: 60%;'>".ADSTAT_L31."</td>\n<td class='fcaption' style='width: 30%;' colspan='2'>".ADSTAT_L21."</td>\n<td class='fcaption' style='width: 10%; text-align: center;'>%</td>\n</tr>\n";
$count = 1;
foreach($queryArray as $key => $info) {
if (count($queryArray))
{
foreach ($queryArray as $key => $info)
{
$percentage = round(($info/$total) * 100, 2);
$key = str_replace("%20", " ", $key);
$text .= "<tr>
@@ -1041,17 +1312,26 @@ class siteStats {
<td class='forumheader3' style='width: 10%; text-align: center;'>".$percentage."%</td>
</tr>\n";
$count ++;
if($count == $pref['statDisplayNumber']) {
if($count == $pref['statDisplayNumber'])
{
break;
}
}
$text .= "<tr><td class='forumheader' colspan='2'>".ADSTAT_L21."</td><td class='forumheader' style='text-align: center;'>{$total}</td><td class='forumheader'></td></tr>\n";
}
$text .= "<tr><td class='forumheader' colspan='2'>".ADSTAT_L21."</td><td class='forumheader' style='text-align: center;'>$total</td><td class='forumheader'></td></tr>\n</table>";
return $text;
else
{
$text .= "<tr><td class='fcaption' colspan='4' style='text-align:center'>".ADSTAT_L25."</td></tr>\n";
}
$text .= "</table><br />";
}
return $text;
}
/* -----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------*/
function recentVisitors() {
function recentVisitors()
{
if(!is_array($this -> fileRecent) || !count($this -> fileRecent)) {
return "<div style='text-align: center;'>".ADSTAT_L25.".</div>";
}

View File

@@ -6,8 +6,8 @@
| Released under the terms and conditions of the GNU General Public License (http://gnu.org).
|
| $Source: /cvs_backup/e107_0.8/e107_themes/templates/header_default.php,v $
| $Revision: 1.14 $
| $Date: 2007-09-27 20:58:11 $
| $Revision: 1.15 $
| $Date: 2007-11-01 20:28:29 $
| $Author: e107steved $
+-----------------------------------------------------------------------------------------------+
*/
@@ -141,14 +141,14 @@ if (function_exists('headerjs')){echo headerjs(); }
if (isset($eplug_css) && $eplug_css) {
if(is_array($eplug_css))
{
foreach($eplug_css as $kcss)
{
echo "<link rel='stylesheet' href='{$kcss}' type='text/css' />\n";
}
foreach($eplug_css as $kcss)
{ // Allow inline style definition - but only if $eplug_css is an array (maybe require an array later)
if ('<style' == substr($kcss,0,6)) echo $kcss; else echo "<link rel='stylesheet' href='{$kcss}' type='text/css' />\n";
}
}
else
{
echo "<link rel='stylesheet' href='{$eplug_css}' type='text/css' />\n";
echo "<link rel='stylesheet' href='{$eplug_css}' type='text/css' />\n";
}
}
@@ -194,11 +194,9 @@ if(defined("PREVIEWTHEME")) {
}
}
//
// DEPRECATED!!! This is used in log/stats.php to generate some css. We'll clean this up in a future release.
//
// Deprecated function finally removed
//if(function_exists('core_head')){ echo core_head(); }
if(function_exists('core_head')){ echo core_head(); }
//
// F: Send Meta Tags and Icon links