2019-03-29 19:13:32 -05:00
< ? 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 );
if ( is_array ( $pref [ 'lan_log_list' ])) //... and for any plugins which support it
{
foreach ( $pref [ 'lan_log_list' ] as $path => $file )
{
2020-03-03 13:11:48 -08:00
// $file = str_replace('--LAN--', e_LANGUAGE, $file);
2019-03-29 19:13:32 -05:00
//e107::lan($path,'log',true);
2020-03-03 13:11:48 -08:00
// 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 " );
2019-03-29 19:13:32 -05:00
}
}
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 :: getAdminLog ();
$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 -> log_event ( $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+?)(=.+?) { 0,1}!]# " , '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 ( substr ( $text , 0 , 2 ) == '\n' ) // 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 -> db_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+?)(=.+?) { 0,1}!]# " , '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 ;
} */
?>