-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathlogging.php
More file actions
59 lines (45 loc) · 1.6 KB
/
logging.php
File metadata and controls
59 lines (45 loc) · 1.6 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
<?php
/*
Copyright 2011 John Mullee
This file is part of PhpUnixDaemon.
PhpUnixDaemon is free software: you can redistribute it and/or modify it under the terms of the
GNU General Public License as published by the Free Software Foundation, either version 3 of
the License, or (at your option) any later version.
PhpUnixDaemon is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with PhpUnixDaemon.
If not, see http://www.gnu.org/licenses/.
*/
// simple logging function
define('DEBUG',4);
define('WARN', 3);
define('ERROR',2);
define('FATAL',1);
$logfile='/tmp/logfile.log';
$logfilehandle = null;
$max_loglevel = DEBUG;
function logmsg($level, $msg, $file='', $line=0)
{
global $logfile, $max_loglevel, $logfilehandle;
$level_names = array(FATAL=>'FATAL', ERROR=>'ERROR',WARN=>'WARN',DEBUG=>'DEBUG');
// prepend level, filename and line-number to message
$lmsg = posix_getpid().':'.$level_names[$level].':('.$file.':'.$line.'):'.$msg."\n";
// open log file
if($logfilehandle==null)
{
$mode_append = 'a';
$logfilehandle=fopen($logfile,$mode_append);
}
// exit if logfile still not open
if($logfilehandle==null)
die('couldnt open logfile, to write '.$lmsg);
else
// if level less-or-equal to max desired level
if($level <= $max_loglevel)
// log the message
fwrite($logfilehandle, $lmsg);
// exit on fatal errors
if($level==FATAL)
die($lmsg);
}