mirror of
https://github.com/e107inc/e107.git
synced 2025-01-17 20:58:30 +01:00
1893 lines
62 KiB
PHP
1893 lines
62 KiB
PHP
<?php
|
|
/*
|
|
* e107 website system
|
|
*
|
|
* Copyright (C) 2008-2013 e107 Inc (e107.org)
|
|
* Released under the terms and conditions of the
|
|
* GNU General Public License (http://www.gnu.org/licenses/gpl.txt)
|
|
*
|
|
* Administration Area - Admin Log
|
|
*
|
|
*/
|
|
|
|
/*
|
|
* Preferences:
|
|
* 'sys_log_perpage' - number of events per page
|
|
*
|
|
* 'user_audit_opts' - which user-related events to log
|
|
* 'user_audit_class' - user class whose actions can be logged
|
|
*
|
|
* 'roll_log_days' (default 7) - number of days for which entries retained in rolling log
|
|
* 'roll_log_active' - set to '1' to enable
|
|
*
|
|
*/
|
|
|
|
require_once ('../class2.php');
|
|
if(! getperms('S'))
|
|
{
|
|
e107::redirect('admin');
|
|
exit();
|
|
}
|
|
|
|
e107::coreLan('admin_log', true);
|
|
e107::coreLan('log_messages', true);
|
|
|
|
$logList = e107::pref('core', 'lan_log_list');
|
|
|
|
if(is_array($logList)) //... and for any plugins which support it
|
|
{
|
|
foreach($logList as $path => $file)
|
|
{
|
|
// $file = str_replace('--LAN--', e_LANGUAGE, $file);
|
|
|
|
//e107::lan($path,'log',true);
|
|
// e107::includeLan(e_PLUGIN.$path.'/languages/'.$file);
|
|
e107::includeLan(e_PLUGIN.$path.'/languages/'.e_LANGUAGE."_log.php");
|
|
e107::includeLan(e_PLUGIN.$path.'/languages/'.e_LANGUAGE."/".e_LANGUAGE."_log.php");
|
|
}
|
|
}
|
|
|
|
define('AL_DATE_TIME_FORMAT', 'y-m-d H:i:s');
|
|
|
|
|
|
|
|
class adminlog_admin extends e_admin_dispatcher
|
|
{
|
|
|
|
protected $modes = array(
|
|
|
|
'main' => array(
|
|
'controller' => 'admin_log_ui',
|
|
'path' => null,
|
|
'ui' => 'admin_log_form_ui',
|
|
'uipath' => null
|
|
),
|
|
|
|
|
|
'audit' => array(
|
|
'controller' => 'audit_log_ui',
|
|
'path' => null,
|
|
'ui' => 'admin_log_form_ui',
|
|
'uipath' => null
|
|
),
|
|
|
|
|
|
'rolling' => array(
|
|
'controller' => 'dblog_ui',
|
|
'path' => null,
|
|
'ui' => 'admin_log_form_ui',
|
|
'uipath' => null
|
|
),
|
|
|
|
|
|
);
|
|
|
|
//$page_title = array('adminlog' => RL_LAN_030, 'auditlog' => RL_LAN_062, 'rolllog' => RL_LAN_002, 'downlog' => RL_LAN_067, 'detailed' => RL_LAN_094, 'online' => RL_LAN_120);
|
|
|
|
|
|
protected $adminMenu = array(
|
|
|
|
'main/list' => array('caption'=> RL_LAN_030, 'perm' => '5'),
|
|
'audit/list' => array('caption'=> RL_LAN_062, 'perm' => '5'),
|
|
'rolling/list' => array('caption'=> RL_LAN_002, 'perm' => '5'),
|
|
'divider/01' => array('divider'=>true),
|
|
'main/prefs' => array('caption'=> LAN_PREFS, 'perm' => '5'),
|
|
'main/maintenance' => array('caption'=> LAN_OPTIONS, 'perm' => '5')
|
|
|
|
// 'main/custom' => array('caption'=> 'Custom Page', 'perm' => 'P')
|
|
);
|
|
|
|
protected $adminMenuAliases = array(
|
|
'main/edit' => 'main/list'
|
|
);
|
|
|
|
protected $adminMenuIcon = 'e-adminlogs-24';
|
|
|
|
protected $menuTitle = ADLAN_155;
|
|
|
|
function init()
|
|
{
|
|
|
|
e107::css('inline', "
|
|
|
|
.fa { font-size:130% }
|
|
.fa-question-circle { }
|
|
.fa-exclamation-circle { color: #FAA732 }
|
|
.fa-warning { color: red }
|
|
|
|
|
|
|
|
");
|
|
|
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
class admin_log_ui extends e_admin_ui
|
|
{
|
|
|
|
protected $pluginTitle = ADLAN_155;
|
|
protected $pluginName = 'core';
|
|
protected $table = 'admin_log';
|
|
protected $pid = 'dblog_id';
|
|
protected $perPage = 10;
|
|
// protected $listQry = "SELECT f.*, u.* FROM #admin_log AS f LEFT JOIN #user AS u ON f.dblog_user_id = u.user_id "; // Should not be necessary.
|
|
|
|
protected $listQry = "SELECT SQL_CALC_FOUND_ROWS f.*, u.user_id, u.user_name FROM #admin_log AS f LEFT JOIN #user AS u ON f.dblog_user_id = u.user_id "; // Should not be required but be auto-calculated.
|
|
protected $listOrder = 'f.dblog_id DESC';
|
|
|
|
protected $batchDelete = false;
|
|
protected $batchDeleteLog = false; //TODO - AdminUI option to disable logging of changes.
|
|
|
|
protected $fields = array (
|
|
// 'checkboxes' => array ( 'title' => '', 'type' => null, 'data' => null, 'nolist'=>true, 'width' => '5%', 'thclass' => 'center', 'forced' => '1', 'class' => 'center', 'toggle' => 'e-multiselect', ),
|
|
'dblog_id' => array ( 'title' => LAN_ID, 'data' => 'int', 'width' => '5%', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
'dblog_datestamp' => array ( 'title' => LAN_DATESTAMP, 'type' => 'datestamp', 'data' => 'int', 'width' => '12%', 'filter' => true, 'help' => '', 'readParms' => array('mask'=>'dd MM yyyy hh:ii:ss'), 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
// 'dblog_microtime' => array ( 'title' => 'Microtime', 'type' => 'method', 'data' => 'int', 'width' => 'auto', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'center', 'thclass' => 'center', ),
|
|
'dblog_type' => array ( 'title' => RL_LAN_032, 'type' => 'method', 'data' => 'int', 'width' => '5%', 'filter' => true, 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'center', 'thclass' => 'center', ),
|
|
'dblog_ip' => array ( 'title' => LAN_IP, 'type' => 'ip', 'data' => 'str', 'width' => 'auto', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
|
|
'dblog_user_id' => array ( 'title' => LAN_USER, 'type' => 'user', 'data' => 'int', 'width' => 'auto', 'filter' => true, 'help' => '', 'readParms'=>'link=1', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
'dblog_eventcode' => array ( 'title' => RL_LAN_023, 'type' => 'method', 'data' => 'str', 'width' => 'auto', 'filter' => true, 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
|
|
'dblog_title' => array ( 'title' => LAN_TITLE, 'type' => 'method', 'data' => 'str', 'width' => 'auto', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
'dblog_remarks' => array ( 'title' => RL_LAN_033, 'type' => 'method', 'data' => 'str', 'width' => '35%', 'filter'=>true, 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
'options' => array ( 'title' => LAN_OPTIONS, 'type' => null, 'nolist'=>true, 'data' => null, 'width' => '10%', 'thclass' => 'center last', 'class' => 'center last', 'forced' => '1', ),
|
|
);
|
|
|
|
protected $fieldpref = array( 'dblog_datestamp', 'dblog_type', 'dblog_eventcode', 'dblog_user_id', 'dblog_ip', 'dblog_title', 'dblog_remarks');
|
|
|
|
//'adminlog' => array(RL_LAN_019, RL_LAN_032, RL_LAN_020, RL_LAN_104, LAN_USER, RL_LAN_023, LAN_TITLE, RL_LAN_033),
|
|
|
|
|
|
protected $prefs = array(
|
|
'sys_log_perpage' => array('title'=> RL_LAN_044, 'type'=>'dropdown', 'data' => 'int','help'=> RL_LAN_064,'writeParms'=>''),
|
|
'user_audit_class' => array('title'=> RL_LAN_123, 'type'=>'userclass', 'data' => 'int','help'=>''),
|
|
'user_audit_opts' => array('title'=> RL_LAN_031, 'type'=>'method', 'data' => 'array','help'=>''),
|
|
'roll_log_active' => array('title'=> RL_LAN_008, 'type'=>'boolean', 'data' => 'int','help'=>''),
|
|
'roll_log_days' => array('title'=> RL_LAN_009, 'type'=>'number', 'data' => 'string','help'=>''),
|
|
// 'Delete admin log events older than ' => array('title'=> RL_LAN_045, 'type'=>'method', 'data' => 'string','help'=>'Help Text goes here'),
|
|
// 'Delete user audit trail log events older' => array('title'=> 'Delete user audit trail log events older', 'type'=>'method', 'data' => 'string','help'=>'Help Text goes here'),
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public $eventTypes = array();
|
|
|
|
// optional
|
|
public function init()
|
|
{
|
|
$perPage = e107::getConfig()->get('sys_log_perpage');
|
|
$this->perPage = vartrue($perPage,10);
|
|
|
|
$this->prefs['sys_log_perpage']['writeParms'] = array(10=>10, 15=>15, 20=>20, 30=>30, 40=>40, 50=>50);
|
|
|
|
|
|
$sql = e107::getDb();
|
|
$row = $sql->retrieve("SELECT dblog_eventcode,dblog_title FROM #admin_log WHERE dblog_eventcode !='' AND dblog_title !='' GROUP BY dblog_eventcode",true);
|
|
foreach($row as $val)
|
|
{
|
|
$id = $val['dblog_eventcode'];
|
|
$def = strpos($val['dblog_title'], "LAN") !== false ? $id : $val['dblog_title'];
|
|
$this->eventTypes[$id] = str_replace(': [x]', '', deftrue($val['dblog_title'],$def));
|
|
}
|
|
|
|
asort($this->eventTypes);
|
|
|
|
if(getperms('0'))
|
|
{
|
|
|
|
$arr = array_reverse($this->fields, true);
|
|
$arr['checkboxes'] = array ( 'title' => '', 'type' => null, 'data' => null, 'width' => '5%', 'thclass' => 'center', 'forced' => '1', 'class' => 'center', 'toggle' => 'e-multiselect' );
|
|
|
|
$this->fields = array_reverse($arr, true);
|
|
$this->batchDelete = true;
|
|
}
|
|
}
|
|
|
|
|
|
function gen_log_delete($selectname)
|
|
{
|
|
$values = array(360, 180, 90, 60, 30, 21, 20, 14, 10, 7, 6, 5, 4, 3, 2, 1);
|
|
return e107::getForm()->select($selectname, $values, '', 'useValues=1&size=small');
|
|
}
|
|
|
|
|
|
function maintenancePage()
|
|
{
|
|
|
|
if(!empty($_POST['deleteoldadmin']) || !empty($_POST['deleteoldaudit']))
|
|
{
|
|
$this->maintenanceProcess();
|
|
|
|
}
|
|
|
|
$frm = e107::getForm();
|
|
|
|
|
|
|
|
// Admin log maintenance
|
|
//==================
|
|
$text = "
|
|
<form method='post' action='".e_SELF."?mode=main&action=maintenance'>
|
|
<fieldset id='core-admin-log-maintenance'>
|
|
<legend>".RL_LAN_125."</legend>
|
|
<table class='table adminform'>
|
|
<colgroup>
|
|
<col class='col-label' />
|
|
<col class='col-control' />
|
|
</colgroup>
|
|
<tbody>
|
|
<tr>
|
|
<td>".RL_LAN_045." </td>
|
|
<td class='form-inline'>".$this->gen_log_delete('rolllog_clearadmin')." ".RL_LAN_046." ".$frm->admin_button('deleteoldadmin', 'no-value', 'delete', RL_LAN_049)."</td>
|
|
</tr>
|
|
";
|
|
|
|
// User log maintenance
|
|
//====================
|
|
$text .= "
|
|
<tr>
|
|
<td>".RL_LAN_066." </td>
|
|
<td class='form-inline'>".$this->gen_log_delete('rolllog_clearaudit')." ".RL_LAN_046." ".$frm->admin_button('deleteoldaudit', 'no-value', 'delete', RL_LAN_049)."</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
</fieldset>
|
|
</form>
|
|
|
|
</fieldset>
|
|
";
|
|
return $text;
|
|
|
|
}
|
|
|
|
|
|
function maintenanceProcess()
|
|
{
|
|
$mes = e107::getMessage();
|
|
$ns = e107::getRender();
|
|
$log = e107::getLog();
|
|
$frm = e107::getForm();
|
|
$sql = e107::getDb();
|
|
|
|
// print_a($_POST);
|
|
|
|
if(!empty($_POST['deleteoldadmin']) && isset($_POST['rolllog_clearadmin']))
|
|
{
|
|
$back_count = intval($_POST['rolllog_clearadmin']);
|
|
$_POST['backdeltype'] = 'confdel';
|
|
$action = 'backdel';
|
|
}
|
|
elseif(!empty($_POST['deleteoldaudit']) && isset($_POST['rolllog_clearaudit']))
|
|
{
|
|
$back_count = intval($_POST['rolllog_clearaudit']);
|
|
$action = 'backdel';
|
|
$_POST['backdeltype'] = 'auditdel';
|
|
}
|
|
|
|
/*
|
|
if(isset($back_count))
|
|
{
|
|
if(($back_count >= 1) && ($back_count <= 90))
|
|
{
|
|
$temp_date = getdate();
|
|
$old_date = intval(mktime(0, 0, 0, $temp_date['mon'], $temp_date['mday'] - $back_count, $temp_date['year']));
|
|
$old_string = strftime("%d %B %Y", $old_date);
|
|
// $message = "Back delete ".$back_count." days. Oldest date = ".$old_string;
|
|
$action = $next_action;
|
|
$qs[1] = $old_date;
|
|
$qs[2] = $back_count;
|
|
}
|
|
else
|
|
{
|
|
$mes->addWarning(RL_LAN_050);
|
|
}
|
|
}
|
|
*/
|
|
|
|
$old_date = strtotime($back_count.' days ago');
|
|
|
|
|
|
// Actually delete back events - admin or user audit log
|
|
if(($action == "backdel") && isset($_POST['backdeltype']))
|
|
{
|
|
// $old_date = intval($qs[1]);
|
|
$old_string = strftime("%d %B %Y", $old_date);
|
|
$qry = "dblog_datestamp < ".$old_date; // Same field for both logs
|
|
|
|
switch($_POST['backdeltype'])
|
|
{
|
|
case 'confdel':
|
|
$db_table = 'admin_log';
|
|
$db_name = RL_LAN_052;
|
|
$db_msg = "ADLOG_02";
|
|
break;
|
|
case 'auditdel':
|
|
$db_table = 'audit_log';
|
|
$db_name = RL_LAN_053;
|
|
$db_msg = "ADLOG_03";
|
|
break;
|
|
default:
|
|
exit(); // Someone fooling around!
|
|
}
|
|
|
|
|
|
e107::getMessage()->addDebug("Back delete, <br />oldest date = {$old_string} <br />Query = {$qry}");
|
|
|
|
if($del_count = $sql->delete($db_table, $qry))
|
|
{
|
|
// Add in a log event
|
|
$message = $db_name.str_replace(array('[x]', '[y]'), array($old_string, $del_count), RL_LAN_057);
|
|
$mes->addSuccess($message);
|
|
$log->add($db_msg, "db_Delete - earlier than {$old_string} (past {$back_count} days)[!br!]".$message.'[!br!]'.$db_table.' '.$qry, E_LOG_INFORMATIVE, '');
|
|
}
|
|
else
|
|
{
|
|
$mes->addWarning(RL_LAN_054." : ".$sql->mySQLresult);
|
|
}
|
|
|
|
}
|
|
|
|
// Prompt to delete back events
|
|
/*
|
|
if(($action == "confdel") || ($action == "auditdel"))
|
|
{
|
|
$old_string = strftime("%d %B %Y", $qs[1]);
|
|
$text = "
|
|
<form method='post' action='".e_SELF."?backdel.{$qs[1]}.{$qs[2]}'>
|
|
<fieldset id='core-admin-log-confirm-delete'>
|
|
<legend class='e-hideme'>".LAN_CONFDELETE."</legend>
|
|
<table class='table adminform'>
|
|
<tr>
|
|
<td class='center'>
|
|
<strong>".(($action == "confdel") ? RL_LAN_047 : RL_LAN_065).$old_string."</strong>
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
<div class='buttons-bar center'>
|
|
<input type='hidden' name='backdeltype' value='{$action}' />
|
|
".$frm->admin_button('confirmdeleteold', 'no-value', 'delete', RL_LAN_049)."
|
|
".$frm->admin_button('confirmcancelold', 'no-value', 'delete', LAN_CANCEL)."
|
|
</div>
|
|
</fieldset>
|
|
</form>
|
|
|
|
";
|
|
|
|
$ns->tablerender(LAN_CONFDELETE, $text);
|
|
}
|
|
|
|
*/
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
class admin_log_form_ui extends e_admin_form_ui
|
|
{
|
|
|
|
function sys_log_perpage($curVal,$mode)
|
|
{
|
|
$frm = e107::getForm();
|
|
switch($mode)
|
|
{
|
|
case 'write': // Edit Page
|
|
return $frm->text('sys_log_perpage',$curVal);
|
|
break;
|
|
}
|
|
}
|
|
|
|
function user_audit_opts($curVal,$mode)
|
|
{
|
|
|
|
$frm = e107::getForm();
|
|
|
|
// User Audit log options (for info)
|
|
//=======================
|
|
// define('USER_AUDIT_SIGNUP',11); // User signed up
|
|
// define('USER_AUDIT_EMAILACK',12); // User responded to registration email
|
|
// define('USER_AUDIT_LOGIN',13); // User logged in
|
|
// define('USER_AUDIT_LOGOUT',14); // User logged out
|
|
// define('USER_AUDIT_NEW_DN',15); // User changed display name
|
|
// define('USER_AUDIT_NEW_PW',16); // User changed password
|
|
// define('USER_AUDIT_NEW_EML',17); // User changed email
|
|
// define('USER_AUDIT_NEW_SET',19); // User changed other settings (intentional gap in numbering)
|
|
// define('USER_AUDIT_ADD_ADMIN', 20); // User added by admin
|
|
// define('USER_AUDIT_MAIL_BOUNCE', 21); // User mail bounce
|
|
// define('USER_AUDIT_BANNED', 22); // User banned
|
|
// define('USER_AUDIT_BOUNCE_RESET', 23); // User bounce reset
|
|
// define('USER_AUDIT_TEMP_ACCOUNT', 24); // User temporary account
|
|
|
|
|
|
$audit_checkboxes = array(USER_AUDIT_SIGNUP => RL_LAN_071, USER_AUDIT_EMAILACK => RL_LAN_072,
|
|
USER_AUDIT_LOGIN => LAN_AUDIT_LOG_013, USER_AUDIT_LOGOUT => LAN_AUDIT_LOG_014, // Logout is lumped in with login
|
|
USER_AUDIT_NEW_DN => RL_LAN_075, USER_AUDIT_NEW_PW => RL_LAN_076, USER_AUDIT_PW_RES => RL_LAN_078, USER_AUDIT_NEW_EML => RL_LAN_077, USER_AUDIT_NEW_SET => RL_LAN_079,
|
|
USER_AUDIT_ADD_ADMIN => RL_LAN_080, USER_AUDIT_MAIL_BOUNCE => RL_LAN_081, USER_AUDIT_BANNED => RL_LAN_082, USER_AUDIT_BOUNCE_RESET => RL_LAN_083,
|
|
USER_AUDIT_TEMP_ACCOUNT => RL_LAN_084);
|
|
|
|
$userAuditOpts = e107::getConfig()->get('user_audit_opts');
|
|
|
|
$text = "";
|
|
|
|
foreach($audit_checkboxes as $k => $t)
|
|
{
|
|
$checked = isset($userAuditOpts[$k]) ? true : false;
|
|
$text .= $frm->checkbox('user_audit_opts['.$k.']',$k, $checked, array('label'=>$t));
|
|
}
|
|
|
|
$text .= $frm->admin_button('check_all', 'jstarget:user_audit_opts', 'checkall', LAN_CHECKALL).$frm->admin_button('uncheck_all', 'jstarget:user_audit_opts', 'checkall', LAN_UNCHECKALL);
|
|
|
|
|
|
return $text;
|
|
}
|
|
|
|
|
|
|
|
|
|
// Custom Method/Function
|
|
/*
|
|
function dblog_datestamp($curVal,$mode)
|
|
{
|
|
$frm = e107::getForm();
|
|
|
|
switch($mode)
|
|
{
|
|
case 'read': // List Page
|
|
return date(AL_DATE_TIME_FORMAT, $curVal);
|
|
break;
|
|
|
|
case 'write': // Edit Page
|
|
return $frm->text('dblog_datestamp',$curVal);
|
|
break;
|
|
|
|
case 'filter':
|
|
case 'batch':
|
|
return $array;
|
|
break;
|
|
}
|
|
}
|
|
*/
|
|
|
|
// Custom Method/Function
|
|
function dblog_microtime($curVal,$mode)
|
|
{
|
|
$frm = e107::getForm();
|
|
|
|
switch($mode)
|
|
{
|
|
case 'read': // List Page
|
|
return date("H:i:s", intval($curVal) % 86400).'.'.str_pad(100000 * round($curVal - floor($curVal), 6), 6, '0');
|
|
break;
|
|
|
|
case 'write': // Edit Page
|
|
return $frm->text('dblog_microtime',$curVal);
|
|
break;
|
|
|
|
case 'filter':
|
|
case 'batch':
|
|
// return $array;
|
|
break;
|
|
}
|
|
}
|
|
|
|
|
|
// Custom Method/Function
|
|
function dblog_type($curVal,$mode)
|
|
{
|
|
$tp = e107::getParser();
|
|
/*
|
|
define("E_LOG_INFORMATIVE", 0); // Minimal Log Level, including really minor stuff
|
|
define("E_LOG_NOTICE", 1); // More important than informative, but less important than notice
|
|
define("E_LOG_WARNING", 2); // Not anything serious, but important information
|
|
define("E_LOG_FATAL", 3); // An event so bad your site ceased execution.
|
|
define("E_LOG_PLUGIN", 4); // Plugin information
|
|
*/
|
|
|
|
$array = array(
|
|
' ', // Minimal Log Level, including really minor stuff
|
|
'<i class="S16 e-info-16 e-tip" title="Notice"></i>', //FIXME - should be the blue icon. // More important than informative, but less important than notice
|
|
'<i class="S16 e-false-16 e-tip" title="Important"></i>', // Not anything serious, but important information
|
|
'<i class="S16 e-warning-16 e-tip" title="Warning"></i>', // An event so bad your site ceased execution.
|
|
' ' // Plugin information - Deprecated - Leave empty.
|
|
);
|
|
|
|
$array[1] = $tp->toGlyph('fa-question-circle');
|
|
$array[2] = $tp->toGlyph('fa-exclamation-circle');
|
|
$array[3] = $tp->toGlyph('fa-warning');
|
|
|
|
switch($mode)
|
|
{
|
|
case 'read': // List Page
|
|
return varset($array[$curVal], $curVal);
|
|
break;
|
|
|
|
case 'filter':
|
|
case 'batch':
|
|
return array(RL_LAN_132,RL_LAN_133,RL_LAN_134,RL_LAN_135);
|
|
break;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
// Custom Method/Function
|
|
function dblog_title($curVal,$mode)
|
|
{
|
|
$tp = e107::getParser();
|
|
|
|
switch($mode)
|
|
{
|
|
case 'read': // List Page
|
|
|
|
|
|
|
|
$val = trim($curVal);
|
|
if(defined($val))
|
|
{
|
|
$val = constant($val);
|
|
}
|
|
|
|
if(strpos($val,'[x]') !== false)
|
|
{
|
|
$remark = $this->getController()->getListModel()->get('dblog_remarks');
|
|
preg_match("/\[table\]\s=>\s([\w]*)/i",$remark, $match);
|
|
|
|
if(!empty($match[1]))
|
|
{
|
|
$val = $tp->lanVars($val, '<b>'.$match[1].'</b>');
|
|
}
|
|
else
|
|
{
|
|
preg_match("/\[!br!\]TABLE: ([\w]*)/i", $remark, $m);
|
|
if(!empty($m[1]))
|
|
{
|
|
$val = $tp->lanVars($val, '<b>'.$m[1].'</b>');
|
|
}
|
|
}
|
|
|
|
|
|
}
|
|
|
|
return $val;
|
|
break;
|
|
|
|
case 'filter':
|
|
case 'batch':
|
|
return null;
|
|
break;
|
|
}
|
|
}
|
|
|
|
|
|
function dblog_eventcode($curVal,$mode)
|
|
{
|
|
$array = $this->getController()->eventTypes;
|
|
|
|
switch($mode)
|
|
{
|
|
case 'read': // List Page
|
|
return $curVal;
|
|
break;
|
|
|
|
case 'filter':
|
|
case 'batch':
|
|
return $array;
|
|
break;
|
|
}
|
|
}
|
|
|
|
|
|
// Custom Method/Function
|
|
function dblog_remarks($curVal,$mode)
|
|
{
|
|
$frm = e107::getForm();
|
|
$tp = e107::getParser();
|
|
|
|
switch($mode)
|
|
{
|
|
case 'read': // List Page
|
|
|
|
$text = preg_replace_callback("#\[!(\w+?)(=.+?)?!]#", 'log_process', $curVal);
|
|
$text = $tp->toHTML($text,false,'E_BODY');
|
|
|
|
if(strpos($text,'Array')!==false || strlen($text)>300)
|
|
{
|
|
$id = $this->getController()->getListModel()->get('dblog_id');
|
|
$ret ="<a class='e-expandit' href='#rem-".$id."'>".RL_LAN_087."</a>";
|
|
$ret .= "<div style='display:none' id='rem-".$id."'>";
|
|
$text = str_replace("<br />","\n",$text);
|
|
$text = str_replace("\","/",$text);
|
|
|
|
if(strpos($text,'\n') === 0) // cleanup (not sure of the cause)
|
|
{
|
|
$text = substr($text,2);
|
|
}
|
|
|
|
if(substr($text,-2) == '\n') // cleanup (not sure of the cause)
|
|
{
|
|
$text = substr($text,0,-2);
|
|
}
|
|
|
|
$text = print_a($text,true);
|
|
$ret .= $text;
|
|
$ret .= "</div>";
|
|
return $ret;
|
|
}
|
|
|
|
return $text;
|
|
break;
|
|
|
|
|
|
case 'filter':
|
|
case 'batch':
|
|
// return $array;
|
|
break;
|
|
}
|
|
}
|
|
|
|
// Custom Method/Function
|
|
function dblog_caller($curVal,$mode)
|
|
{
|
|
|
|
switch($mode)
|
|
{
|
|
case 'read': // List Page
|
|
$val =$curVal;
|
|
if((strpos($val, '|') !== FALSE) && (strpos($val, '@') !== FALSE))
|
|
{
|
|
list($file, $rest) = explode('|', $val);
|
|
list($routine, $rest) = explode('@', $rest);
|
|
$val = $file.'<br />Function: '.$routine.'<br />Line: '.$rest;
|
|
}
|
|
return $val;
|
|
break;
|
|
|
|
|
|
case 'filter':
|
|
case 'batch':
|
|
// return $array;
|
|
break;
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
class audit_log_ui extends e_admin_ui
|
|
{
|
|
|
|
protected $pluginTitle = ADLAN_155;
|
|
protected $pluginName = 'adminlog';
|
|
protected $table = 'audit_log';
|
|
protected $pid = 'dblog_id';
|
|
protected $perPage = 10;
|
|
protected $listOrder = 'dblog_id DESC';
|
|
protected $batchDelete = true;
|
|
|
|
protected $fields = array (
|
|
'checkboxes' => array ( 'title' => '', 'type' => null, 'data' => null, 'width' => '5%', 'thclass' => 'center', 'forced' => '1', 'class' => 'center', 'toggle' => 'e-multiselect', ),
|
|
'dblog_id' => array ( 'title' => LAN_ID, 'data' => 'int', 'width' => '5%', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
'dblog_datestamp' => array ( 'title' => LAN_DATESTAMP, 'type' => 'datestamp', 'data' => 'int', 'width' => 'auto', 'filter' => true, 'help' => '', 'readParms' => array('mask'=>'dd MM yyyy hh:ii:ss'), 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
'dblog_microtime' => array ( 'title' => 'Microtime', 'type' => 'text', 'data' => 'int', 'width' => 'auto', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'center', 'thclass' => 'center', ),
|
|
'dblog_eventcode' => array ( 'title' => 'Eventcode', 'type' => 'method', 'data' => 'str', 'width' => 'auto', 'filter' => true, 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'center', 'thclass' => 'center', ),
|
|
'dblog_user_id' => array ( 'title' => LAN_USER, 'type' => 'user', 'data' => 'int', 'width' => '5%', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
'dblog_user_name' => array ( 'title' => LAN_USER, 'type' => 'text', 'data' => 'str', 'width' => 'auto', 'filter' => true, 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
'dblog_ip' => array ( 'title' => LAN_IP, 'type' => 'ip', 'data' => 'str', 'width' => 'auto', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
'dblog_title' => array ( 'title' => LAN_TITLE, 'type' => 'method', 'data' => 'str', 'width' => 'auto', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
'dblog_remarks' => array ( 'title' => 'Remarks', 'type' => 'method', 'data' => 'str', 'width' => '30%', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
'options' => array ( 'title' => LAN_OPTIONS, 'type' => null, 'nolist'=>true, 'data' => null, 'width' => '10%', 'thclass' => 'center last', 'class' => 'center last', 'forced' => '1', ),
|
|
);
|
|
|
|
protected $fieldpref = array('dblog_id', 'dblog_datestamp', 'dblog_microtime', 'dblog_eventcode', 'dblog_user_id', 'dblog_user_name', 'dblog_ip', 'dblog_title','dblog_remarks');
|
|
|
|
|
|
|
|
// optional
|
|
public function init()
|
|
{
|
|
$perPage = e107::getConfig()->get('sys_log_perpage');
|
|
$this->perPage = vartrue($perPage,10);
|
|
}
|
|
|
|
/*
|
|
public function customPage()
|
|
{
|
|
$ns = e107::getRender();
|
|
$text = 'Hello World!';
|
|
$ns->tablerender('Hello',$text);
|
|
|
|
}
|
|
*/
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class dblog_ui extends e_admin_ui
|
|
{
|
|
|
|
protected $pluginTitle = ADLAN_155;
|
|
protected $pluginName = 'adminlog';
|
|
protected $table = 'dblog';
|
|
protected $pid = 'dblog_id';
|
|
protected $perPage = 15;
|
|
protected $listOrder = 'dblog_id desc';
|
|
|
|
protected $fields = array (
|
|
'checkboxes' => array ( 'title' => '', 'type' => null, 'data' => null, 'width' => '5%', 'thclass' => 'center', 'forced' => '1', 'class' => 'center', 'toggle' => 'e-multiselect', ),
|
|
// 'dblog_id' => array ( 'title' => LAN_ID, 'data' => 'int', 'width' => '5%', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
'dblog_datestamp' => array ( 'title' => LAN_DATESTAMP, 'type' => 'datestamp', 'data' => 'int', 'width' => 'auto', 'filter' => true, 'help' => '', 'readParms' => array('mask'=>'dd MM yyyy hh:ii:ss'), 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
'dblog_microtime' => array ( 'title' => 'Microtime', 'type' => 'method', 'data' => 'int', 'width' => 'auto', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'center', 'thclass' => 'center', ),
|
|
'dblog_type' => array ( 'title' => LAN_TYPE, 'type' => 'method', 'data' => 'int', 'width' => 'auto', 'batch' => true, 'filter' => true, 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
'dblog_eventcode' => array ( 'title' => 'Eventcode', 'type' => 'method', 'data' => 'str', 'width' => 'auto', 'filter' => true, 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'center', 'thclass' => 'center', ),
|
|
'dblog_user_id' => array ( 'title' => LAN_ID, 'type' => 'user', 'data' => 'int', 'width' => '5%', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
'dblog_user_name' => array ( 'title' => LAN_USER, 'type' => 'text', 'data' => 'str', 'width' => 'auto', 'filter' => true, 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
'dblog_ip' => array ( 'title' => LAN_IP, 'type' => 'ip', 'data' => 'str', 'width' => 'auto', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
'dblog_caller' => array ( 'title' => 'Caller', 'type' => 'method', 'data' => 'str', 'width' => 'auto', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'center', 'thclass' => 'center', ),
|
|
'dblog_title' => array ( 'title' => LAN_TITLE, 'type' => 'method', 'data' => 'str', 'width' => 'auto', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
'dblog_remarks' => array ( 'title' => 'Remarks', 'type' => 'method', 'data' => 'str', 'width' => '30%', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
'options' => array ( 'title' => LAN_OPTIONS, 'type' => null, 'nolist'=>true, 'data' => null, 'width' => '10%', 'thclass' => 'center last', 'class' => 'center last', 'forced' => '1', ),
|
|
);
|
|
|
|
protected $fieldpref = array('dblog_id', 'dblog_datestamp', 'dblog_microtime', 'dblog_type', 'dblog_eventcode', 'dblog_user_id', 'dblog_user_name', 'dblog_ip', 'dblog_caller', 'dblog_title', 'dblog_remarks');
|
|
|
|
|
|
// optional
|
|
public function init()
|
|
{
|
|
$perPage = e107::getConfig()->get('sys_log_perpage');
|
|
$this->perPage = vartrue($perPage,10);
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Routine to handle the simple bbcode-like codes for log body text
|
|
|
|
function log_process($matches)
|
|
{
|
|
switch($matches[1])
|
|
{
|
|
case 'br':
|
|
return '<br />';
|
|
case 'link':
|
|
$temp = substr($matches[2], 1);
|
|
return "<a href='{$temp}'>{$temp}</a>";
|
|
case 'test':
|
|
return '----TEST----';
|
|
default:
|
|
return $matches[0]; // No change
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
new adminlog_admin();
|
|
|
|
require_once(e_ADMIN."auth.php");
|
|
e107::getAdminUI()->runPage();
|
|
|
|
require_once(e_ADMIN."footer.php");
|
|
exit;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Everything below this point is currently unused, but left for reference in case of bugs.
|
|
// ----------------------------------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if(is_array($pref['lan_log_list'])) //... and for any plugins which support it
|
|
{
|
|
foreach($pref['lan_log_list'] as $path => $file)
|
|
{
|
|
$file = str_replace('--LAN--', e_LANGUAGE, $file);
|
|
|
|
// echo "orig = ".$file." ";
|
|
//e107::lan($path,'log',true);
|
|
e107::includeLan(e_PLUGIN.$path.'/languages/'.$file);
|
|
}
|
|
}
|
|
|
|
unset($qs);
|
|
|
|
require_once (e_ADMIN.'auth.php');
|
|
|
|
$mes = e107::getMessage();
|
|
$frm = e107::getForm();
|
|
|
|
define('AL_DATE_TIME_FORMAT', 'y-m-d H:i:s');
|
|
/*
|
|
if(isset($_POST['setoptions']))
|
|
{
|
|
unset($temp);
|
|
|
|
if(in_array((string) USER_AUDIT_LOGIN, $_POST['user_audit_opts']))
|
|
{
|
|
$_POST['user_audit_opts'][] = USER_AUDIT_LOGOUT;
|
|
}
|
|
foreach($_POST['user_audit_opts'] as $k => $v)
|
|
{
|
|
if(! is_numeric($v))
|
|
{
|
|
unset($_POST['user_audit_opts'][$k]);
|
|
}
|
|
}
|
|
$temp['roll_log_active'] = intval($_POST['roll_log_active']);
|
|
$temp['roll_log_days'] = intval($_POST['roll_log_days']);
|
|
$temp['sys_log_perpage'] = intval($_POST['sys_log_perpage']);
|
|
$temp['user_audit_opts'] = implode(',', $_POST['user_audit_opts']);
|
|
$temp['user_audit_class'] = intval($_POST['user_audit_class']);
|
|
|
|
if($admin_log->logArrayDiffs($temp, $pref, 'ADLOG_01') || $admin_log->logArrayDiffs($temp, $pref, 'ADLOG_04'))
|
|
{
|
|
save_prefs(); // Only save if changes
|
|
}
|
|
else
|
|
{
|
|
$mes->addInfo(LAN_NO_CHANGE);
|
|
}
|
|
|
|
}
|
|
*/
|
|
|
|
$ns->tablerender($caption, $mes->render() . $text);
|
|
|
|
if(e_QUERY)
|
|
{ // Must explode after calling auth.php
|
|
$qs = explode(".", e_QUERY);
|
|
}
|
|
|
|
$action = varset($qs[0], 'adminlog');
|
|
|
|
// Deprecated by Comments Manager
|
|
/*
|
|
if(isset($_POST['deleteitems']) && ($action == 'comments'))
|
|
{
|
|
$c_list = array();
|
|
foreach($_POST['del_item'] as $di)
|
|
{
|
|
if(intval($di) > 0)
|
|
$c_list[] = '`comment_id`='.intval($di);
|
|
}
|
|
if($count = $sql->db_Delete('comments', implode(' OR ', $c_list)))
|
|
{
|
|
//$text = str_replace('--NUMBER--', $count,RL_LAN_112);
|
|
$emessage->add(str_replace('--NUMBER--', $count, RL_LAN_112), E_MESSAGE_SUCCESS);
|
|
e107::getLog()->add('COMMENT_01', 'ID: '.implode(',', $_POST['del_item']), E_LOG_INFORMATIVE, '');
|
|
}
|
|
else
|
|
{
|
|
//$text = RL_LAN_113;
|
|
$emessage->add(RL_LAN_113, E_MESSAGE_WARNING);
|
|
}
|
|
//$ns -> tablerender(LAN_DELETE, "<div style='text-align:center'><b>".$text."</b></div>");
|
|
unset($c_list);
|
|
}
|
|
*/
|
|
|
|
// ****************** MAINTENANCE ******************
|
|
unset($back_count);
|
|
if(isset($_POST['deleteoldadmin']) && isset($_POST['rolllog_clearadmin']))
|
|
{
|
|
$back_count = intval($_POST['rolllog_clearadmin']);
|
|
$next_action = 'confdel';
|
|
}
|
|
elseif(isset($_POST['deleteoldaudit']) && isset($_POST['rolllog_clearaudit']))
|
|
{
|
|
$back_count = intval($_POST['rolllog_clearaudit']);
|
|
$next_action = 'auditdel';
|
|
}
|
|
|
|
if(isset($back_count) && isset($next_action))
|
|
{
|
|
if(($back_count >= 1) && ($back_count <= 90))
|
|
{
|
|
$temp_date = getdate();
|
|
$old_date = intval(mktime(0, 0, 0, $temp_date['mon'], $temp_date['mday'] - $back_count, $temp_date['year']));
|
|
$old_string = strftime("%d %B %Y", $old_date);
|
|
// $message = "Back delete ".$back_count." days. Oldest date = ".$old_string;
|
|
$action = $next_action;
|
|
$qs[1] = $old_date;
|
|
$qs[2] = $back_count;
|
|
}
|
|
else
|
|
{
|
|
$mes->addWarning(RL_LAN_050);
|
|
}
|
|
}
|
|
|
|
if(!isset($admin_log))
|
|
{
|
|
$mes->addWarning("Admin Log not valid");
|
|
}
|
|
|
|
|
|
// Actually delete back events - admin or user audit log
|
|
if(($action == "backdel") && isset($_POST['backdeltype']))
|
|
{
|
|
if(isset($_POST['confirmdeleteold']))
|
|
{
|
|
$old_date = intval($qs[1]);
|
|
$old_string = strftime("%d %B %Y", $old_date);
|
|
$qry = "dblog_datestamp < ".$old_date; // Same field for both logs
|
|
switch($_POST['backdeltype'])
|
|
{
|
|
case 'confdel':
|
|
$db_table = 'admin_log';
|
|
$db_name = RL_LAN_052;
|
|
$db_msg = "ADLOG_02";
|
|
break;
|
|
case 'auditdel':
|
|
$db_table = 'audit_log';
|
|
$db_name = RL_LAN_053;
|
|
$db_msg = "ADLOG_03";
|
|
break;
|
|
default:
|
|
exit(); // Someone fooling around!
|
|
}
|
|
// $message = "Back delete, oldest date = {$old_string} Query = {$qry}";
|
|
if($del_count = $sql->db_Delete($db_table, $qry))
|
|
{
|
|
// Add in a log event
|
|
$message = $db_name.str_replace(array('[x]', '[y]'), array($old_string, $del_count), RL_LAN_057);
|
|
$mes->addSuccess($message);
|
|
e107::getLog()->add($db_msg, "db_Delete - earlier than {$old_string} (past {$qs[2]} days)[!br!]".$message.'[!br!]'.$db_table.' '.$qry, E_LOG_INFORMATIVE, '');
|
|
}
|
|
else
|
|
{
|
|
$mes->addWarning(RL_LAN_054." : ".$sql->mySQLresult);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
$mes->addInfo(LAN_NO_CHANGE);
|
|
}
|
|
|
|
$action = "config";
|
|
unset($qs[1]);
|
|
unset($qs[2]);
|
|
}
|
|
|
|
// Prompt to delete back events
|
|
if(($action == "confdel") || ($action == "auditdel"))
|
|
{
|
|
$old_string = strftime("%d %B %Y", $qs[1]);
|
|
$text = "
|
|
<form method='post' action='".e_SELF."?backdel.{$qs[1]}.{$qs[2]}'>
|
|
<fieldset id='core-admin-log-confirm-delete'>
|
|
<legend class='e-hideme'>".LAN_CONFDELETE."</legend>
|
|
<table class='table adminform'>
|
|
<tr>
|
|
<td class='center'>
|
|
<strong>".(($action == "confdel") ? RL_LAN_047 : RL_LAN_065).$old_string."</strong>
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
<div class='buttons-bar center'>
|
|
<input type='hidden' name='backdeltype' value='{$action}' />
|
|
".$frm->admin_button('confirmdeleteold', 'no-value', 'delete', RL_LAN_049)."
|
|
".$frm->admin_button('confirmcancelold', 'no-value', 'delete', LAN_CANCEL)."
|
|
</div>
|
|
</fieldset>
|
|
</form>
|
|
|
|
";
|
|
|
|
$ns->tablerender(LAN_CONFDELETE, $text);
|
|
}
|
|
|
|
// Arrays of options for the various logs - the $page_title array is used to determine the allowable values for $action ('options' is a special case)
|
|
$log_db_table = array('adminlog' => 'admin_log', 'auditlog' => 'audit_log', 'rolllog' => 'dblog', 'downlog' => 'download_requests', 'online' => 'online');
|
|
$back_day_count = array('adminlog' => 30, 'auditlog' => 30, 'rolllog' => max(intval($pref['roll_log_days']), 1), 'downlog' => 60, 'detailed' => 20, 'online' => 30);
|
|
$page_title = array('adminlog' => RL_LAN_030, 'auditlog' => RL_LAN_062, 'rolllog' => RL_LAN_002, 'downlog' => RL_LAN_067, 'detailed' => RL_LAN_094, 'online' => RL_LAN_120);
|
|
|
|
// Set all the defaults for the data filter
|
|
$start_enabled = FALSE;
|
|
$end_enabled = FALSE;
|
|
$start_time = 0;
|
|
$end_time = 0;
|
|
$user_filter = '';
|
|
$event_filter = '';
|
|
$pri_filter_cond = "xx";
|
|
$pri_filter_val = "";
|
|
$sort_order = "DESC";
|
|
$downloadid_filter = '';
|
|
|
|
$last_noted_time = 0;
|
|
|
|
// Maintain the log view filter across pages
|
|
$rl_cookiename = $pref['cookie_name']."_rl_admin";
|
|
if(isset($_POST['updatefilters']) || isset($_POST['clearfilters']))
|
|
{ // Need to put the filter values into the cookie
|
|
if(! isset($_POST['clearfilters']))
|
|
{ // Only update filter values from $_POST[] if 'clear filters' not active
|
|
$start_time = intval($_POST['starttimedate'] + $_POST['starttimehours'] * 3600 + $_POST['starttimemins'] * 60);
|
|
$start_enabled = isset($_POST['start_enabled']);
|
|
if(isset($_POST['timelength']))
|
|
{
|
|
$end_time = intval($_POST['timelength']) * 60 + $start_time;
|
|
}
|
|
else
|
|
{
|
|
$end_time = intval($_POST['endtimedate'] + $_POST['endtimehours'] * 3600 + $_POST['endtimemins'] * 60);
|
|
}
|
|
$end_enabled = isset($_POST['end_enabled']);
|
|
$user_filter = trim(varset($_POST['roll_user_filter'], ''));
|
|
if($user_filter != '')
|
|
$user_filter = intval($user_filter);
|
|
$event_filter = $tp->toDB($_POST['roll_event_filter']);
|
|
$pri_filter_cond = $tp->toDB($_POST['roll_pri_cond']);
|
|
$pri_filter_val = $tp->toDB($_POST['roll_pri_val']);
|
|
$caller_filter = $tp->toDB($_POST['roll_caller_filter']);
|
|
$ipaddress_filter = $e107->ipEncode($tp->toDB($_POST['roll_ipaddress_filter']));
|
|
$downloadid_filter = $tp->toDB($_POST['roll_downloadid_filter']);
|
|
}
|
|
$cookie_string = implode("|", array($start_time, $start_enabled, $end_time, $end_enabled, $user_filter, $event_filter, $pri_filter_cond, $pri_filter_val, $caller_filter, $ipaddress_filter, $downloadid_filter));
|
|
// echo $cookie_string."<br />";
|
|
// Create session cookie to store values
|
|
cookie($rl_cookiename, $cookie_string, 0); // Use session cookie
|
|
}
|
|
else
|
|
{
|
|
// Now try and get the filters from the cookie
|
|
if(isset($_COOKIE[$rl_cookiename]))
|
|
list($start_time, $start_enabled, $end_time, $end_enabled, $user_filter, $event_filter, $pri_filter_cond, $pri_filter_val, $caller_filter, $ipaddress_filter, $downloadid_filter) = explode("|", $_COOKIE[$rl_cookiename]);
|
|
if(isset($qs[1]) && isset($qs[2]) && ($qs[1] == 'user') && (intval($qs[2]) > 0))
|
|
{
|
|
$user_filter = intval($qs[2]);
|
|
}
|
|
}
|
|
|
|
$timelength = 5;
|
|
if($start_time != 0 && $end_time != 0)
|
|
$timelength = intval(($end_time - $start_time) / 60);
|
|
|
|
function time_box($boxname, $this_time, $day_count, $inc_tomorrow = FALSE, $all_mins = FALSE)
|
|
{ // Generates boxes for date and time for today and the preceding days
|
|
// Appends 'date', 'hours', 'mins' to the specified boxname
|
|
|
|
|
|
$all_time = getdate(); // Date/time now
|
|
$sel_time = getdate($this_time); // Currently selected date/time
|
|
$sel_day = mktime(0, 0, 0, $sel_time['mon'], $sel_time['mday'], $sel_time['year']);
|
|
$today = mktime(0, 0, 0, $all_time['mon'], $all_time['mday'] + ($inc_tomorrow ? 1 : 0), $all_time['year']);
|
|
|
|
// Start with day
|
|
$ret = "<select name='{$boxname}date' class='tbox'>";
|
|
// Stick an extra day on the end, plus tomorrow if the flag set
|
|
for($i = ($inc_tomorrow ? - 2 : - 1); $i <= $day_count; $i ++)
|
|
{
|
|
$day_string = date("D d M", $today);
|
|
$sel = ($today == $sel_day) ? " selected='selected'" : "";
|
|
$ret .= "<option value='{$today}'{$sel}>{$day_string}</option>";
|
|
$today -= 86400; // Move to previous day
|
|
}
|
|
$ret .= "</select>";
|
|
|
|
// Hours
|
|
$ret .= " <select name='{$boxname}hours' class='tbox select time-offset'>";
|
|
for($i = 0; $i < 24; $i ++)
|
|
{
|
|
$sel = ($sel_time['hours'] == $i) ? " selected='selected'" : "";
|
|
$ret .= "<option value='{$i}'{$sel}>{$i}</option>";
|
|
}
|
|
$ret .= "</select>";
|
|
|
|
// Minutes
|
|
$ret .= " <select name='{$boxname}mins' class='tbox select time-offset'>";
|
|
for($i = 0; $i < 60; $i += ($all_mins ? 1 : 5))
|
|
{
|
|
$sel = ($sel_time['minutes'] == $i) ? " selected='selected'" : "";
|
|
$ret .= "<option value='{$i}'{$sel}>{$i}</option>";
|
|
}
|
|
$ret .= "</select>";
|
|
|
|
return $ret;
|
|
}
|
|
|
|
if(! defined("USER_WIDTH"))
|
|
{
|
|
define("USER_WIDTH", "width:97%");
|
|
}
|
|
|
|
//====================================================================
|
|
// CONFIGURATION OPTIONS MENU
|
|
//====================================================================
|
|
|
|
/*
|
|
if($action == "config")
|
|
{
|
|
// User Audit log options (for info)
|
|
//=======================
|
|
// define('USER_AUDIT_SIGNUP',11); // User signed up
|
|
// define('USER_AUDIT_EMAILACK',12); // User responded to registration email
|
|
// define('USER_AUDIT_LOGIN',13); // User logged in
|
|
// define('USER_AUDIT_LOGOUT',14); // User logged out
|
|
// define('USER_AUDIT_NEW_DN',15); // User changed display name
|
|
// define('USER_AUDIT_NEW_PW',16); // User changed password
|
|
// define('USER_AUDIT_NEW_EML',17); // User changed email
|
|
// define('USER_AUDIT_NEW_SET',19); // User changed other settings (intentional gap in numbering)
|
|
// define('USER_AUDIT_ADD_ADMIN', 20); // User added by admin
|
|
// define('USER_AUDIT_MAIL_BOUNCE', 21); // User mail bounce
|
|
// define('USER_AUDIT_BANNED', 22); // User banned
|
|
// define('USER_AUDIT_BOUNCE_RESET', 23); // User bounce reset
|
|
// define('USER_AUDIT_TEMP_ACCOUNT', 24); // User temporary account
|
|
|
|
|
|
$audit_checkboxes = array(USER_AUDIT_SIGNUP => RL_LAN_071, USER_AUDIT_EMAILACK => RL_LAN_072, USER_AUDIT_LOGIN => RL_LAN_073, // USER_AUDIT_LOGOUT => RL_LAN_074, // Logout is lumped in with login
|
|
USER_AUDIT_NEW_DN => RL_LAN_075, USER_AUDIT_NEW_PW => RL_LAN_076, USER_AUDIT_PW_RES => RL_LAN_078, USER_AUDIT_NEW_EML => RL_LAN_077, USER_AUDIT_NEW_SET => RL_LAN_079,
|
|
USER_AUDIT_ADD_ADMIN => RL_LAN_080, USER_AUDIT_MAIL_BOUNCE => RL_LAN_081, USER_AUDIT_BANNED => RL_LAN_082, USER_AUDIT_BOUNCE_RESET => RL_LAN_083,
|
|
USER_AUDIT_TEMP_ACCOUNT => RL_LAN_084);
|
|
|
|
if(! isset($e_userclass) && ! is_object($e_userclass))
|
|
{
|
|
require_once (e_HANDLER."userclass_class.php");
|
|
$e_userclass = new user_class();
|
|
}
|
|
|
|
$user_signup_opts = array_flip(explode(',', varset($pref['user_audit_opts'], '')));
|
|
|
|
// Common to all logs
|
|
$text = "
|
|
<fieldset id='core-admin-log-config'>
|
|
<legend class='e-hideme'>".RL_LAN_121."</legend>
|
|
<form method='post' action='".e_SELF."?config'>
|
|
<fieldset id='core-admin-log-options'>
|
|
<legend>".RL_LAN_122."</legend>
|
|
<table class='table adminform'>
|
|
<colgroup>
|
|
<col class='col-label' />
|
|
<col class='col-control' />
|
|
</colgroup>
|
|
<tbody>
|
|
<tr>
|
|
<td>".RL_LAN_044."</td>
|
|
<td>".$frm->select('sys_log_perpage', array(10, 20, 30, 40, 50), $pref['sys_log_perpage'])."<span class='field-help'>".RL_LAN_064."</span></td>
|
|
</tr>
|
|
";
|
|
|
|
// User Audit Trail Options
|
|
$text .= "
|
|
<tr>
|
|
<td>".RL_LAN_123."</td>
|
|
<td>
|
|
<select class='tbox' name='user_audit_class'>
|
|
".$e_userclass->vetted_tree('user_audit_class', array($e_userclass, 'select'), varset($pref['user_audit_class'], e_UC_MEMBER), 'nobody,admin,member,new,mods,main,classes, no-excludes')."
|
|
</select>
|
|
<span class='field-help'>".RL_LAN_026."</span>
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td>".RL_LAN_031."</td>
|
|
<td>";
|
|
|
|
foreach($audit_checkboxes as $k => $t)
|
|
{
|
|
$checked = isset($user_signup_opts[$k]) ? true : false;
|
|
$text .= $frm->checkbox('user_audit_opts[]',$k, $checked, array('label'=>$t));
|
|
}
|
|
|
|
|
|
$text .= $frm->admin_button('check_all', 'jstarget:user_audit_opts', 'checkall', LAN_CHECKALL).$frm->admin_button('uncheck_all', 'jstarget:user_audit_opts', 'checkall', LAN_UNCHECKALL)."
|
|
</td>
|
|
</tr>
|
|
";
|
|
|
|
|
|
// Rolling log options
|
|
//====================
|
|
$text .= "
|
|
<tr>
|
|
<td>".RL_LAN_008."</td>
|
|
<td>
|
|
<div class='auto-toggle-area autocheck'>
|
|
".$frm->checkbox('roll_log_active', 1, varset($pref['roll_log_active'],0))."
|
|
</div>
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td>".RL_LAN_009."</td>
|
|
<td>".$frm->text('roll_log_days', $pref['roll_log_days'], 5)."</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
<div class='buttons-bar center'>
|
|
".$frm->admin_button('setoptions', 'no-value', 'update', LAN_UPDATE)."
|
|
</div>
|
|
</fieldset>
|
|
</form>
|
|
";
|
|
|
|
// Admin log maintenance
|
|
//==================
|
|
$text .= "
|
|
<form method='post' action='".e_SELF."?config'>
|
|
<fieldset id='core-admin-log-maintenance'>
|
|
<legend>".RL_LAN_125."</legend>
|
|
<table class='table adminform'>
|
|
<colgroup>
|
|
<col class='col-label' />
|
|
<col class='col-control' />
|
|
</colgroup>
|
|
<tbody>
|
|
<tr>
|
|
<td>".RL_LAN_045." </td>
|
|
<td>".gen_log_delete('rolllog_clearadmin')." ".RL_LAN_046.$frm->admin_button('deleteoldadmin', 'no-value', 'delete', RL_LAN_049)."</td>
|
|
</tr>
|
|
";
|
|
|
|
// User log maintenance
|
|
//====================
|
|
$text .= "
|
|
<tr>
|
|
<td>".RL_LAN_066." </td>
|
|
<td>".gen_log_delete('rolllog_clearaudit')." ".RL_LAN_046.$frm->admin_button('deleteoldaudit', 'no-value', 'delete', RL_LAN_049)."</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
</fieldset>
|
|
</form>
|
|
|
|
</fieldset>
|
|
";
|
|
|
|
$ns->tablerender(ADLAN_155.SEP.LAN_OPTIONS, $mes->render().$text);
|
|
}
|
|
*/
|
|
|
|
//====================================================================
|
|
// LOG VIEW MENU
|
|
//====================================================================
|
|
if(isset($page_title[$action]))
|
|
{
|
|
$from = intval(varset($qs[1], 0)); // First entry to display
|
|
$amount = max(varset($pref['sys_log_perpage'], 20), 5); // Number of entries per page
|
|
|
|
|
|
// Array decides which filters are active for each log. There are 4 columns total. All but 'datetimes' occupy 2. Must specify multiple of 4 columns - add 'blank' if necessary
|
|
$active_filters = array(
|
|
'adminlog' => array('datetimes' => 0, 'ipfilter' => 0, 'userfilter' => 0, 'eventfilter' => 0, 'priority' => 0),
|
|
'auditlog' => array('datetimes' => 0, 'ipfilter' => 0, 'userfilter' => 0, 'eventfilter' => 0, 'blank' => 2),
|
|
'rolllog' => array('datetimes' => 0, 'ipfilter' => 0, 'userfilter' => 0, 'eventfilter' => 0, 'priority' => 0, 'callerfilter' => 0, 'blank' => 2),
|
|
'downlog' => array('datetimes' => 0, 'ipfilter' => 0, 'userfilter' => 0, 'downloadidfilter' => 0, 'blank' => 2),
|
|
'detailed' => array('datestart' => 0, 'ipfilter' => 0, 'userfilter' => 0, 'eventfilter' => 0, 'blank' => 2),
|
|
'online' => array('ipfilter' => 0, 'userfilter' => 0));
|
|
|
|
// Arrays determine column widths, headings, displayed fields for each log
|
|
$col_fields = array(
|
|
'adminlog' => array('cf_datestring', 'dblog_type', 'dblog_ip', 'dblog_user_id', 'user_name', 'dblog_eventcode', 'dblog_title', 'dblog_remarks'),
|
|
'auditlog' => array('cf_datestring', 'dblog_ip', 'dblog_user_id', 'dblog_user_name', 'dblog_eventcode', 'dblog_title', 'dblog_remarks'),
|
|
'rolllog' => array('cf_datestring', 'dblog_type', 'dblog_ip', 'dblog_user_id', 'dblog_user_name', 'dblog_eventcode', 'dblog_caller', 'dblog_title', 'dblog_remarks'),
|
|
'downlog' => array('cf_datestring', 'dblog_ip', 'dblog_user_id', 'user_name', 'download_request_download_id', 'download_name'),
|
|
'detailed' => array('cf_microtime', 'cf_microtimediff', 'source', 'dblog_type', 'dblog_ip', 'dblog_user_id', 'user_name', 'dblog_eventcode', 'dblog_title', 'dblog_remarks'),
|
|
'online' => array('cf_datestring', 'dblog_ip', 'dblog_user_id', 'user_name', 'online_location', 'online_pagecount', 'online_flag', 'online_active'));
|
|
$col_widths = array(
|
|
'adminlog' => array(18, 4, 14, 7, 15, 8, 14, 20), // Date - Pri - IP - UID - User - Code - Event - Info
|
|
'auditlog' => array(18, 14, 7, 15, 8, 14, 24),
|
|
'rolllog' => array(15, 4, 12, 6, 12, 7, 13, 13, 18), // Date - Pri - IP - UID - User - Code - Caller - Event - Info
|
|
'downlog' => array(18, 14, 7, 15, 8, 38),
|
|
'detailed' => array(10, 8, 6, 4, 14, 6, 17, 7, 17, 21),
|
|
'comments' => array(14, 7, 7, 7, 14, 3, 10, 12, 5, 17, 1, 1, 1),
|
|
'online' => array(18, 15, 7, 14, 32, 6, 4, 4));
|
|
$col_titles = array(
|
|
'adminlog' => array(RL_LAN_019, RL_LAN_032, RL_LAN_020, RL_LAN_104, LAN_USER, RL_LAN_023, LAN_TITLE, RL_LAN_033),
|
|
'auditlog' => array(RL_LAN_019, RL_LAN_020, RL_LAN_104, LAN_USER, RL_LAN_023, LAN_TITLE, RL_LAN_033),
|
|
'rolllog' => array(RL_LAN_019, RL_LAN_032, RL_LAN_020, RL_LAN_104, LAN_USER, RL_LAN_023, RL_LAN_024, LAN_TITLE, RL_LAN_033),
|
|
'downlog' => array(RL_LAN_019, RL_LAN_020, RL_LAN_104, LAN_USER, RL_LAN_068, RL_LAN_069),
|
|
'detailed' => array(LAN_TIME, RL_LAN_096, LAN_SOURCE, RL_LAN_032, RL_LAN_020, RL_LAN_104, LAN_USER, RL_LAN_023, LAN_TITLE, RL_LAN_033),
|
|
'online' => array(RL_LAN_019, RL_LAN_020, LAN_ID, LAN_USER, RL_LAN_116, RL_LAN_117, RL_LAN_118, RL_LAN_116));
|
|
|
|
|
|
|
|
// Only need to define entries in this array if the base DB query is non-standard (i.e. different field names and/or joins)
|
|
$base_query = array('downlog' => "SELECT SQL_CALC_FOUND_ROWS
|
|
dbl.download_request_id as dblog_id,
|
|
dbl.download_request_userid as dblog_user_id,
|
|
dbl.download_request_ip as dblog_ip,
|
|
dbl.download_request_download_id,
|
|
dbl.download_request_datestamp as dblog_datestamp,
|
|
d.download_name,
|
|
u.user_name
|
|
FROM #download_requests AS dbl
|
|
LEFT JOIN #user AS u ON dbl.download_request_userid=u.user_id
|
|
LEFT JOIN #download AS d ON dbl.download_request_download_id=d.download_id
|
|
", 'detailed' => "SELECT SQL_CALC_FOUND_ROWS cl.*, u.* FROM (
|
|
SELECT dblog_datestamp + (dblog_microtime/1000000) AS dblog_time, dblog_user_id, dblog_eventcode, dblog_title, dblog_remarks, dblog_type, dblog_ip, 'roll' AS source FROM `#dblog`
|
|
UNION
|
|
SELECT dblog_datestamp + (dblog_microtime/1000000) AS dblog_time, dblog_user_id, dblog_eventcode, dblog_title, dblog_remarks, '-' AS dblog_type, dblog_ip, 'audit' AS source FROM `#audit_log`
|
|
UNION
|
|
SELECT dblog_datestamp + (dblog_microtime/1000000) AS dblog_time, dblog_user_id, dblog_eventcode, dblog_title, dblog_remarks, dblog_type, dblog_ip, 'admin' AS source FROM `#admin_log`) AS cl
|
|
LEFT JOIN `#user` AS u ON cl.dblog_user_id=u.user_id ", 'comments' => "SELECT SQL_CALC_FOUND_ROWS *, comment_datestamp AS dblog_datestamp FROM `#comments` AS c", 'online' => "SELECT SQL_CALC_FOUND_ROWS online_timestamp AS dblog_datestamp,
|
|
online_ip AS dblog_ip,
|
|
SUBSTRING_INDEX(online_user_id,'.',1) AS dblog_user_id,
|
|
SUBSTRING(online_user_id FROM LOCATE('.',online_user_id)+1) AS user_name,
|
|
`online_location`, `online_pagecount`, `online_flag`, `online_active`
|
|
FROM `#online`");
|
|
|
|
// The filters have to use the 'actual' db field names. So the following table sets the defaults and the exceptions which vary across the range of tables supported
|
|
$map_filters = array('default' => array('datetimes' => '`dblog_datestamp`', 'ipfilter' => '`dblog_ip`', 'userfilter' => '`dblog_user_id`', 'eventfilter' => '`dblog_eventcode`'), 'downlog' => array('datetimes' => '`download_request_datestamp`', 'ipfilter' => '`download_request_ip`', 'userfilter' => '`download_request_userid`'), 'detailed' => array('datestart' => '`dblog_time`'), 'comments' => array('datetimes' => '`comment_datestamp`', 'ipfilter' => '`comment_ip`', 'eventfilter' => 'comment_type', 'userfilter' => '`comment_author_id`'), 'online' => array('online_ip' => '`dblog_ip`', 'online_user_id' => '`dblog_user_id`'));
|
|
|
|
// Field to sort table on
|
|
$sort_fields = array('default' => 'dblog_id', 'detailed' => 'dblog_time', 'comments' => 'comment_datestamp', 'online' => 'online_timestamp');
|
|
|
|
// Check things
|
|
if($start_time >= $end_time)
|
|
{ // Make end time beginning of tomorrow
|
|
$tempdate = getdate();
|
|
$end_time = mktime(0, 0, 0, $tempdate['mon'], $tempdate['mday'] + 1, $tempdate['year']); // Seems odd, but mktime will work this out OK
|
|
// (or so the manual says)
|
|
}
|
|
|
|
// Now work out the query - only use those filters which are displayed
|
|
$qry = '';
|
|
$and_array = array();
|
|
foreach($active_filters[$action] as $fname => $fpars)
|
|
{
|
|
$filter_field = varset($map_filters[$action][$fname], $map_filters['default'][$fname]);
|
|
switch($fname)
|
|
{
|
|
case 'datetimes':
|
|
if($start_enabled && ($start_time > 0))
|
|
$and_array[] = "{$filter_field} >= ".intval($start_time);
|
|
if($end_enabled && ($end_time > 0))
|
|
$and_array[] = "{$filter_field} <= ".intval($end_time);
|
|
break;
|
|
case 'datestart':
|
|
if($start_time == 0)
|
|
{
|
|
$end_time = time();
|
|
$start_time = $end_time - 300; // Default to last 5 mins
|
|
}
|
|
$and_array[] = "{$filter_field} >= ".intval($start_time);
|
|
$and_array[] = "{$filter_field} <= ".intval($end_time);
|
|
break;
|
|
case 'ipfilter':
|
|
if($ipaddress_filter != "")
|
|
{
|
|
if(substr($ipaddress_filter, - 1) == '*')
|
|
{ // Wildcard to handle - mySQL uses %
|
|
$and_array[] = "{$filter_field} LIKE '".substr($ipaddress_filter, 0, - 1)."%' ";
|
|
}
|
|
else
|
|
{
|
|
$and_array[] = "{$filter_field}= '".$ipaddress_filter."' ";
|
|
}
|
|
}
|
|
break;
|
|
case 'userfilter':
|
|
if($user_filter != '')
|
|
$and_array[] = "{$filter_field} = ".intval($user_filter);
|
|
break;
|
|
case 'eventfilter':
|
|
if($event_filter != '')
|
|
{
|
|
if(substr($event_filter, - 1) == '*')
|
|
{ // Wildcard to handle - mySQL uses %
|
|
$and_array[] = " {$filter_field} LIKE '".substr($event_filter, 0, - 1)."%' ";
|
|
}
|
|
else
|
|
{
|
|
$and_array[] = "{$filter_field}= '".$event_filter."' ";
|
|
}
|
|
}
|
|
break;
|
|
case 'callerfilter':
|
|
if($caller_filter != '')
|
|
{
|
|
if(substr($caller_filter, - 1) == '*')
|
|
{ // Wildcard to handle - mySQL uses %
|
|
$and_array[] = "dblog_caller LIKE '".substr($caller_filter, 0, - 1)."%' ";
|
|
}
|
|
else
|
|
{
|
|
$and_array[] = "dblog_caller= '".$caller_filter."' ";
|
|
}
|
|
}
|
|
break;
|
|
case 'priority':
|
|
if(($pri_filter_val != "") && ($pri_filter_cond != "") && ($pri_filter_cond != "xx"))
|
|
{
|
|
switch($pri_filter_cond)
|
|
{
|
|
case "lt":
|
|
$and_array[] = "dblog_type <= '{$pri_filter_val}' ";
|
|
break;
|
|
case "eq":
|
|
$and_array[] = "dblog_type = '{$pri_filter_val}' ";
|
|
break;
|
|
case "gt":
|
|
$and_array[] = "dblog_type >= '{$pri_filter_val}' ";
|
|
break;
|
|
}
|
|
}
|
|
break;
|
|
case 'downloadidfilter':
|
|
if($downloadid_filter != '')
|
|
$and_array[] = "download_request_download_id = ".intval($downloadid_filter);
|
|
break;
|
|
}
|
|
}
|
|
|
|
if(count($and_array))
|
|
$qry = " WHERE ".implode(' AND ', $and_array);
|
|
|
|
$limit_clause = " LIMIT {$from}, {$amount} ";
|
|
$sort_field = varset($sort_fields[$action], $sort_fields['default']);
|
|
|
|
if(isset($base_query[$action]))
|
|
{
|
|
$qry = $base_query[$action].$qry." ORDER BY {$sort_field} ".$sort_order;
|
|
}
|
|
else
|
|
{
|
|
$qry = "SELECT SQL_CALC_FOUND_ROWS dbl.*,u.user_name FROM #".$log_db_table[$action]." AS dbl LEFT JOIN #user AS u ON dbl.dblog_user_id=u.user_id".$qry." ORDER BY {$sort_field} ".$sort_order;
|
|
}
|
|
|
|
$num_entry = 0;
|
|
if($sql->gen($qry.$limit_clause))
|
|
{
|
|
$num_entry = $sql->total_results;
|
|
}
|
|
if($from > $num_entry)
|
|
{
|
|
$from = 0; // We may be on a later page
|
|
$limit_clause = " LIMIT {$from}, {$amount} ";
|
|
$sql->gen($qry.$limit_clause); // Re-run query with new value of $from
|
|
$num_entry = $sql->total_results;
|
|
}
|
|
|
|
// Start by putting up the filter boxes
|
|
$text = "
|
|
<form method='post' action='".e_SELF."?{$action}.{$from}'>
|
|
<fieldset id='core-admin-log-filter'>
|
|
<legend>".RL_LAN_012."</legend>
|
|
<table class='table adminform'>
|
|
<colgroup>
|
|
<col style='width:15%;vertical-align:top;' />
|
|
<col style='width:35%;vertical-align:top;' />
|
|
<col style='width:15%;vertical-align:top;' />
|
|
<col style='width:35%;vertical-align:top;' />
|
|
</colgroup>
|
|
";
|
|
$filter_cols = 0;
|
|
foreach($active_filters[$action] as $fname => $fpars)
|
|
{
|
|
if($filter_cols == 0)
|
|
$text .= '<tr>';
|
|
switch($fname)
|
|
{
|
|
case 'datetimes':
|
|
$text .= "
|
|
<td>".$frm->checkbox('start-enabled', 1, varset($pref['start-enabled'],0))."<label for='start-enabled'>".RL_LAN_013."</label></td>
|
|
<td>".time_box("starttime", $start_time, $back_day_count[$action], FALSE)."</td>
|
|
<td>".$frm->checkbox('end-enabled', 1, varset($pref['end-enabled'],0))."<label for='end-enabled'>".RL_LAN_014."</label></td>
|
|
<td>".time_box("endtime", $end_time, $back_day_count[$action], TRUE)."</td>
|
|
";
|
|
$filter_cols = 4;
|
|
break;
|
|
case 'datestart':
|
|
$text .= "
|
|
<td>".RL_LAN_013."</td>
|
|
<td>".time_box("starttime", $start_time, $back_day_count[$action], FALSE, TRUE)."</td>
|
|
<td>".RL_LAN_092."</td>
|
|
<td>
|
|
<select name='timelength' class='tbox select time-offset'>";
|
|
// for ($i = 1; $i <= 10; $i++)
|
|
foreach(array(1, 2, 3, 4, 5, 7, 10, 15, 20, 30) as $i)
|
|
{
|
|
$selected = ($timelength == $i) ? " selected='selected'" : '';
|
|
$text .= "
|
|
<option value='{$i}'{$selected}>{$i}</option>
|
|
";
|
|
}
|
|
$text .= "
|
|
</select> ".RL_LAN_093."
|
|
</td>";
|
|
$filter_cols = 4;
|
|
break;
|
|
case 'priority':
|
|
$text .= "
|
|
<td>".RL_LAN_058."</td>
|
|
<td>".$frm->select('roll_pri_cond', array('xx' => ' ', 'gt' => '>=', 'eq' => '==', 'lt' => '<='), $pri_filter_cond)."
|
|
<input class='tbox' type='text' name='roll_pri_val' id='roll-pri-val' size='20' value='{$pri_filter_val}' maxlength='10' />
|
|
</td>
|
|
";
|
|
$filter_cols += 2;
|
|
break;
|
|
case 'ipfilter':
|
|
$text .= "
|
|
<td>".RL_LAN_060."</td>
|
|
<td>
|
|
<input class='tbox' type='text' name='roll_ipaddress_filter' size='20' value='".e107::getIPHandler()->ipDecode($ipaddress_filter)."' maxlength='20' />
|
|
<span class='field-help'>".RL_LAN_061."</span>
|
|
</td>
|
|
";
|
|
$filter_cols += 2;
|
|
break;
|
|
case 'userfilter':
|
|
$text .= "
|
|
<td>".RL_LAN_015."</td>
|
|
<td>
|
|
<input class='tbox' type='text' name='roll_user_filter' size='20' value='".$user_filter."' maxlength='10' />
|
|
<span class='field-help'>".RL_LAN_016."</span>
|
|
</td>
|
|
";
|
|
$filter_cols += 2;
|
|
break;
|
|
case 'eventfilter':
|
|
$text .= "
|
|
<td>".RL_LAN_029."</td>
|
|
<td>
|
|
<input class='tbox' type='text' name='roll_event_filter' size='20' value='".$event_filter."' maxlength='10' />
|
|
<span class='field-help'>".RL_LAN_061."</span>
|
|
</td>
|
|
";
|
|
$filter_cols += 2;
|
|
break;
|
|
case 'callerfilter':
|
|
$text .= "
|
|
<td>".RL_LAN_059."</td>
|
|
<td>
|
|
<input class='tbox' type='text' name='roll_caller_filter' size='40' value='".$caller_filter."' maxlength='40' />
|
|
<span class='field-help'>".RL_LAN_061."</span>
|
|
</td>
|
|
";
|
|
$filter_cols += 2;
|
|
break;
|
|
case 'downloadidfilter':
|
|
$text .= "
|
|
<td>".RL_LAN_090."</td>
|
|
<td>
|
|
<input class='tbox' type='text' name='roll_downloadid_filter' size='20' value='".$downloadid_filter."' maxlength='10' />
|
|
</td>";
|
|
$filter_cols += 2;
|
|
break;
|
|
case 'blank': // Any number of blank cells
|
|
$text .= str_repeat("<td> </td>", $fpars);
|
|
$filter_cols += $fpars;
|
|
break;
|
|
}
|
|
if($filter_cols >= 4)
|
|
{
|
|
$text .= '</tr>';
|
|
$filter_cols = 0;
|
|
}
|
|
}
|
|
|
|
// $text .= "<tr><td colspan='4'>Query = ".$qry.$limit_clause."<br />{$_COOKIE[$rl_cookiename]}</td></tr>";
|
|
$text .= "
|
|
</table>
|
|
<div class='buttons-bar center'>
|
|
".$frm->admin_button('clearfilters', 'no-value', 'delete', RL_LAN_114)."
|
|
".$frm->admin_button('updatefilters', 'no-value', 'update', RL_LAN_028)."
|
|
</div>
|
|
</fieldset>
|
|
</form>
|
|
";
|
|
|
|
// Next bit is the actual log display - the arrays define column widths, titles, fields etc for each log
|
|
$column_count = count($col_widths[$action]);
|
|
$text .= "
|
|
<form method='post' action='".e_SELF."?{$action}.{$from}'>
|
|
<fieldset id='core-admin-log-list'>
|
|
<legend class='e-hideme'>{$page_title[$action]}</legend>
|
|
<table class='table adminlist'>
|
|
<colgroup>
|
|
";
|
|
|
|
foreach($col_widths[$action] as $i)
|
|
{
|
|
$text .= "
|
|
<col style='width:{$i}%; vertical-align:top;' />
|
|
";
|
|
}
|
|
|
|
$text .= "
|
|
</colgroup>
|
|
|
|
";
|
|
|
|
if($num_entry == 0)
|
|
{
|
|
$text .= "
|
|
<tbody>
|
|
<tr>
|
|
<td class='center' colspan='{$column_count}'><strong>".RL_LAN_017."</strong></td>
|
|
</tr>";
|
|
}
|
|
else
|
|
{ // Start with header
|
|
$text .= '
|
|
<thead>
|
|
<tr>
|
|
';
|
|
$count = 1;
|
|
foreach($col_titles[$action] as $ct)
|
|
{
|
|
count($col_titles[$action]);
|
|
$text .= "
|
|
<th".(($count == count($col_titles[$action])) ? " class='last'" : "").">{$ct}</th>
|
|
";
|
|
$count ++;
|
|
}
|
|
$text .= "
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
";
|
|
|
|
// Routine to handle the simple bbcode-like codes for log body text
|
|
function log_process($matches)
|
|
{
|
|
switch($matches[1])
|
|
{
|
|
case 'br':
|
|
return '<br />';
|
|
case 'link':
|
|
$temp = substr($matches[2], 1);
|
|
return "<a href='{$temp}'>{$temp}</a>";
|
|
case 'test':
|
|
return '----TEST----';
|
|
default:
|
|
return $matches[0]; // No change
|
|
}
|
|
}
|
|
// Now put up the events
|
|
$delete_button = FALSE;
|
|
while($row = $sql->fetch())
|
|
{
|
|
$text .= '<tr>';
|
|
foreach($col_fields[$action] as $cf)
|
|
{
|
|
switch($cf)
|
|
{
|
|
case 'cf_datestring':
|
|
$val = date(AL_DATE_TIME_FORMAT, $row['dblog_datestamp']);
|
|
break;
|
|
case 'cf_microtime':
|
|
$val = date("H:i:s", intval($row['dblog_time']) % 86400).'.'.str_pad(100000 * round($row['dblog_time'] - floor($row['dblog_time']), 6), 6, '0');
|
|
break;
|
|
case 'cf_microtimediff':
|
|
$val = ' ';
|
|
if($last_noted_time > 0)
|
|
{
|
|
$val = number_format($last_noted_time - $row['dblog_time'], 6, '.', '');
|
|
}
|
|
$last_noted_time = $row['dblog_time'];
|
|
break;
|
|
case 'cf_eventcode':
|
|
$val = 'ADMIN'.$row['dblog_eventcode'];
|
|
break;
|
|
case 'dblog_title': // Look up constants to give multi-language viewing
|
|
$val = trim($row['dblog_title']);
|
|
if(defined($val))
|
|
$val = constant($val);
|
|
break;
|
|
case 'dblog_user_name':
|
|
$val = $row['dblog_user_id'] ? $row['dblog_user_name'] : LAN_ANONYMOUS;
|
|
break;
|
|
case 'user_name':
|
|
$val = $row['dblog_user_id'] ? $row['user_name'] : LAN_ANONYMOUS;
|
|
break;
|
|
case 'dblog_caller':
|
|
$val = $row['dblog_caller'];
|
|
if((strpos($val, '|') !== FALSE) && (strpos($val, '@') !== FALSE))
|
|
{
|
|
list($file, $rest) = explode('|', $val);
|
|
list($routine, $rest) = explode('@', $rest);
|
|
$val = $file.'<br />Function: '.$routine.'<br />Line: '.$rest;
|
|
}
|
|
break;
|
|
case 'dblog_remarks':
|
|
// Look for pseudo-code for newlines, link insertion
|
|
$val = preg_replace_callback("#\[!(\w+?)(=.+?)?!]#", 'log_process', $row['dblog_remarks']);
|
|
break;
|
|
case 'dblog_ip':
|
|
$val = e107::getIPHandler()->ipDecode($row['dblog_ip']);
|
|
break;
|
|
case 'comment_ip':
|
|
$val = e107::getIPHandler()->ipDecode($row['comment_ip']);
|
|
/* if (strlen($val) == 8) // New decoder should handle this automatically
|
|
{
|
|
$hexip = explode('.', chunk_split($val, 2, '.'));
|
|
$val = hexdec($hexip[0]). '.'.hexdec($hexip[1]).'.'.hexdec($hexip[2]).'.'.hexdec($hexip[3]);
|
|
} */
|
|
break;
|
|
case 'comment_comment':
|
|
$val = $tp->text_truncate($row['comment_comment'], 100, '...'); // Just display first bit of comment
|
|
break;
|
|
case 'online_location':
|
|
$val = str_replace($e107->base_path, '', $row['online_location']); // Just display site-specific bit of path
|
|
break;
|
|
case 'del_check': // Put up a 'delete' checkbox
|
|
$val = "<input class='checkbox' type='checkbox' class='checkbox' name='del_item[]' value='{$row['comment_id']}' >";
|
|
$delete_button = TRUE;
|
|
break;
|
|
default:
|
|
$val = $row[$cf];
|
|
}
|
|
$text .= "<td>{$val}</td>";
|
|
}
|
|
$text .= "</tr>";
|
|
}
|
|
}
|
|
$text .= "
|
|
</tbody>
|
|
</table>
|
|
<div class='buttons-bar center'>
|
|
".$frm->admin_button('refreshlog', 'no-value', 'submit', RL_LAN_018)."
|
|
";
|
|
if($delete_button)
|
|
{
|
|
$text .= $frm->admin_button('deleteitems', 'no-value', 'delete', RL_LAN_11);
|
|
}
|
|
$text .= "
|
|
</div>
|
|
</fieldset>
|
|
</form>
|
|
";
|
|
|
|
// Next-Previous. ==========================
|
|
|
|
$text .= sprintf(str_replace("[x]", "<strong>%d</strong>", RL_LAN_126), $num_entry);
|
|
if($num_entry > $amount)
|
|
{
|
|
$parms = "{$num_entry},{$amount},{$from},".e_SELF."?".$action.".[FROM]";
|
|
$text .= "<div class='nextprev-bar'>".$tp->parseTemplate("{NEXTPREV={$parms}}")."</div>";
|
|
}
|
|
|
|
$ns->tablerender("{$page_title[$action]}", $mes->render().$text);
|
|
}
|
|
|
|
function admin_log_adminmenu()
|
|
{
|
|
if(e_QUERY)
|
|
{
|
|
$tmp = explode(".", e_QUERY);
|
|
$action = $tmp[0];
|
|
}
|
|
if($action == "")
|
|
{
|
|
$action = "adminlog";
|
|
}
|
|
$var['adminlog']['text'] = RL_LAN_030;
|
|
$var['adminlog']['link'] = "admin_log.php?adminlog";
|
|
|
|
$var['auditlog']['text'] = RL_LAN_062;
|
|
$var['auditlog']['link'] = "admin_log.php?auditlog";
|
|
|
|
$var['rolllog']['text'] = RL_LAN_002;
|
|
$var['rolllog']['link'] = "admin_log.php?rolllog";
|
|
|
|
$var['downlog']['text'] = RL_LAN_067;
|
|
$var['downlog']['link'] = "admin_log.php?downlog";
|
|
|
|
$var['detailed']['text'] = RL_LAN_091;
|
|
$var['detailed']['link'] = "admin_log.php?detailed";
|
|
|
|
// Deprecated by Comments Manager.
|
|
/*
|
|
$var['comments']['text'] = 'Comments';
|
|
$var['comments']['link'] = "admin_log.php?comments";
|
|
*/
|
|
$var['config']['text'] = LAN_OPTIONS;
|
|
$var['config']['link'] = "admin_log.php?config";
|
|
|
|
/* XXX - why?!
|
|
if($action == 'comments')
|
|
{
|
|
$var['users']['text'] = RL_LAN_115;
|
|
$var['users']['link'] = "users.php";
|
|
}
|
|
*/
|
|
e107::getNav()->admin(RL_LAN_005, $action, $var);
|
|
}
|
|
|
|
require_once (e_ADMIN."footer.php");
|
|
|
|
|
|
|
|
/**
|
|
* Handle page DOM within the page header
|
|
*
|
|
* @return string JS source
|
|
*//*
|
|
function headerjs()
|
|
{
|
|
require_once(e_HANDLER.'js_helper.php');
|
|
$ret = "
|
|
<script type='text/javascript'>
|
|
//add required core lan - delete confirm message
|
|
(".e_jshelper::toString(LAN_JSCONFIRM).").addModLan('core', 'delete_confirm');
|
|
</script>
|
|
|
|
";
|
|
|
|
return $ret;
|
|
}*/
|
|
|
|
?>
|