-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathchatLog.php
47 lines (40 loc) · 1.54 KB
/
chatLog.php
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
<?
/*
WebChat2.0 Copyright (C) 2006-2007, Chris Chabot <chabotc@xs4all.nl>
This program 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 2
of the License, or (at your option) any later version.
This program 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 this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
error_reporting(E_ALL | E_STRICT);
set_error_handler('chat_log_php_error',E_ALL | E_STRICT);
set_exception_handler('chat_log_php_exception');
function chat_dump_log($file, $line)
{
$time = date('m-d-Y_H:i:s');
$fp = "/tmp/chat_{$file}:{$line}_{$time}.backtrace";
if (@fopen($fp,"w+")) {
fwrite($fp, print_r(debug_backtrace(),true));
fclose($fp);
}
}
function chat_log_php_error($error_code, $error_msg, $error_file, $error_line)
{
echo "[ERROR] {$error_file}:{$error_line} $error_msg\n";
chat_dump_log($error_file, $error_line);
}
function chat_log_php_exception($exception)
{
$error_msg = $exception->getMessage();
$error_file = $exception->getFile();
$error_line = $exception->getLine();
echo "[ERROR] {$error_file}:{$error_line} $error_msg\n";
chat_dump_log($error_file, $error_line);
}