$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 = "
			
		
			
			";
	 		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, 
oldest date = {$old_string} 
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 = "
					
			
				";
			
				$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
			'', //FIXME - should be the blue icon.  // More important than informative, but less important than notice
			'', // Not anything serious, but important information
		 	'', //  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, ''.$match[1].'');
					}
					else
					{
						preg_match("/\[!br!\]TABLE: ([\w]*)/i", $remark, $m);
						if(!empty($m[1]))
						{
							$val = $tp->lanVars($val, ''.$m[1].'');
						}
					}
				}
				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 ="".RL_LAN_087."";
					$ret .= "";
					$text = str_replace("
","\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 .= "
";
					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.'
Function: '.$routine.'
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 '
';
				case 'link':
					$temp = substr($matches[2], 1);
					return "{$temp}";
				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, "".$text."
");
	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 = "
		
	";
	$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."
";
	// 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 = "";
	// Hours
	$ret .= " ";
	// Minutes
	$ret .= " ";
	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 = "
	
	";
	$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 = "
		
	";
	// 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 .= "
		
	";
	// Next-Previous. ==========================
	$text .= sprintf(str_replace("[x]", "%d", RL_LAN_126), $num_entry);
	if($num_entry > $amount)
	{
		$parms = "{$num_entry},{$amount},{$from},".e_SELF."?".$action.".[FROM]";
		$text .= "".$tp->parseTemplate("{NEXTPREV={$parms}}")."
";
	}
	$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 = "
		
		
	";
	return $ret;
}*/
?>