瀏覽代碼

added new log function

Nuno Miguel Reis 11 年之前
父節點
當前提交
603ef1439c
共有 1 個文件被更改,包括 76 次插入43 次删除
  1. 76 43
      resources/classes/logging.php

+ 76 - 43
resources/classes/logging.php

@@ -1,5 +1,5 @@
- <?php
- /**
+<?php
+/**
  * Logging class:
  * - contains lfile, lwrite and lclose public methods
  * - lfile sets path and name of log file
@@ -8,46 +8,79 @@
  * - 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)
-    public function lclose() {
-        fclose($this->fp);
-    }
-    // open log file (private method)
-    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!");
-    }
+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_file) {
+			$this->lfile($log_file);
+		}
+		else {
+			$this->lopen();
+		}
+
+		if ($log_level === $level) {
+			$this->lwrite("[".strtoupper($level)."] ".$msg);
+		}
+
+		//close handle
+		$this->lclose();
+	}
 }
+
 ?>