00001 <?php
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031 if (!class_exists('File')) {
00032 require LIBS . 'file.php';
00033 }
00034
00035
00036
00037
00038
00039 if (!defined('LOG_WARNING')) {
00040 define('LOG_WARNING', 3);
00041 }
00042 if (!defined('LOG_NOTICE')) {
00043 define('LOG_NOTICE', 4);
00044 }
00045 if (!defined('LOG_DEBUG')) {
00046 define('LOG_DEBUG', 5);
00047 }
00048 if (!defined('LOG_INFO')) {
00049 define('LOG_INFO', 6);
00050 }
00051
00052
00053
00054
00055
00056
00057 class CakeLog {
00058
00059
00060
00061
00062
00063
00064
00065
00066
00067 function write($type, $msg) {
00068 if (!defined('LOG_ERROR')) {
00069 define('LOG_ERROR', 2);
00070 }
00071 if (!defined('LOG_ERR')) {
00072 define('LOG_ERR', LOG_ERROR);
00073 }
00074 $levels = array(
00075 LOG_WARNING => 'warning',
00076 LOG_NOTICE => 'notice',
00077 LOG_INFO => 'info',
00078 LOG_DEBUG => 'debug',
00079 LOG_ERR => 'error',
00080 LOG_ERROR => 'error'
00081 );
00082
00083 if (is_int($type) && isset($levels[$type])) {
00084 $type = $levels[$type];
00085 }
00086
00087 if ($type == 'error' || $type == 'warning') {
00088 $filename = LOGS . 'error.log';
00089 } elseif (in_array($type, $levels)) {
00090 $filename = LOGS . 'debug.log';
00091 } else {
00092 $filename = LOGS . $type . '.log';
00093 }
00094 $output = date('Y-m-d H:i:s') . ' ' . ucfirst($type) . ': ' . $msg . "\n";
00095 $log = new File($filename, true);
00096 if ($log->writable()) {
00097 return $log->append($output);
00098 }
00099 }
00100 }
00101 ?>