Fork of FusionPBX but with LDAP kinda working
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

91 lines
2.4 KiB

<?php
/**
* Logging class:
* - contains lfile, lwrite and lclose public methods
* - lfile sets path and name of log file
* - lwrite writes message to the log file (and implicitly opens log file)
* - lclose closes log file
* - first call of lwrite method will open log file implicitly
* - message is written with the following format: [d/M/Y:H:i:s] (script name) message
*/
class Logging
{
// declare log file and file pointer as private properties
private $log_file, $fp;
// set log file (path and name)
public function lfile($path)
{
$this->log_file = $path;
}
// write message to the log file
public function lwrite($message)
{
// if file pointer doesn't exist, then open log file
if (!$this->fp) {
$this->lopen();
}
// define script name
$script_name = pathinfo($_SERVER['PHP_SELF'], PATHINFO_FILENAME);
// define current time and suppress E_WARNING if using the system TZ settings
// (don't forget to set the INI setting date.timezone)
$time = @date('[d/M/Y:H:i:s]');
// write current time, script name and message to the log file
fwrite($this->fp, "$time ($script_name) $message" . PHP_EOL);
}
// close log file (it's always a good idea to close a file when you're done with it)
private function lopen()
{
// in case of Windows set default log file
if (strtoupper(substr(PHP_OS, 0, 3)) === 'WIN') {
$log_file_default = 'c:/php/logfile.txt';
} // set default log file for Linux and other systems
else {
$log_file_default = '/tmp/logfile.txt';
}
// define log file from lfile method or use previously set default
$lfile = $this->log_file ? $this->log_file : $log_file_default;
// open log file for writing only and place file pointer at the end of the file
// (if the file does not exist, try to create it)
$this->fp = fopen($lfile, 'a') or exit("Can't open $lfile!");
}
// open log file (private method)
public function lclose()
{
fclose($this->fp);
}
public function log($level, $msg){
$log_file = $_SESSION['logging']['log']['logfile'];
$log_level = $_SESSION['logging']['log']['loglevel'];
if ($log_level !== $level) {
return;
}
if ($log_file) {
$this->lfile($log_file);
}
$this->lopen();
$this->lwrite("[".strtoupper($level)."] ".$msg);
//close handle
$this->lclose();
}
}
//$log = new Logging();
//$log->log("debug", "passed validation, ".__line__);
//$log->log("debug", check_str($_POST["ivr_menu_uuid"]));
?>