CFDBErrorLog.php
2.75 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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
<?php
/*
"Contact Form to Database" Copyright (C) 2011-2015 Michael Simpson (email : michael.d.simpson@gmail.com)
This file is part of Contact Form to Database.
Contact Form to Database 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.
Contact Form to Database 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 Contact Form to Database.
If not, see <http://www.gnu.org/licenses/>.
*/
require_once('CFDBDateFormatter.php');
class CFDBErrorLog {
/**
* @var String path to file to write
*/
var $outputFilePath;
/**
* @var String email address
*/
var $emailAddress;
/**
* @var CFDBDateFormatter
*/
var $dateFormatter;
function __construct($dateFormatter = null, $destination = null) {
$this->dateFormatter = $dateFormatter;
if ($destination) {
if ($this->isEmailAddress($destination)) {
$this->emailAddress = $destination;
} else {
$this->outputFilePath = $destination;
}
}
}
/**
* @param $message String
*/
public function log($message) {
$date = time();
if ($this->dateFormatter) {
$date = $this->dateFormatter->formatDate($date);
}
$fullMessage = sprintf("CFDB Error (%s): %s\n", $date, $message);
if ($this->outputFilePath) {
error_log($fullMessage, 3, $this->outputFilePath);
} else if ($this->emailAddress) {
error_log($fullMessage, 1, $this->emailAddress);
} else {
error_log($fullMessage, 0);
}
}
/**
* @param $ex Exception
*/
public function logException($ex) {
$message = sprintf("%s\n\tat %s:%s\n%s", $ex->getMessage(),
$ex->getFile(), $ex->getLine(),
"\t" . str_replace("\n", "\n\t", $ex->getTraceAsString()));
$this->log($message);
}
public function isEmailAddress($email) {
$pattern = '/[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,6}/';
return (bool)preg_match($pattern, $email);
}
/**
* @return String
*/
public function getOutputFilePath() {
return $this->outputFilePath;
}
/**
* @return String
*/
public function getEmailAddress() {
return $this->emailAddress;
}
}