-
Notifications
You must be signed in to change notification settings - Fork 8
/
DbLog.class.php
70 lines (65 loc) · 2.04 KB
/
DbLog.class.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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
<?php
/* *
* DbLog Una clase log para manejar las excepciones de la clase DbPDO.
* @author A. Cedano
* @git https://github.com/padrecedano/PHP-PDO
* @version 1.0
*/
class DbLog {
# @string, Directorio para el archivo log
private $path = '/logs/';
# @void, Constructor que asigna la zona horaria y la ruta del archivo log.
public function __construct() {
date_default_timezone_set('Europe/Madrid');
$this->path = dirname(__FILE__) . $this->path;
}
/**
* @void
* Crear el log
*
* @param string $mensaje El mensaje que será escrito en el log.
* @descripción:
* 1. Verifica que existe el directorio, si no existe lo crea.
* 2. Verifica si el archivo log existe.
* 3. Si no existe crea un archivo log.
* 4. Le asigna el nombre de la fecha actual(Año - Mes - Día).
* 5. Si el log existe llama al método edit ().
* 6. El método edit modifica el log actual.
*/
public function write($mensaje) {
$date = new DateTime();
$log = $this->path . $date->format('Y-m-d').".log";
if(is_dir($this->path)) {
if(!file_exists($log)) {
$fh = fopen($log, 'a+') or die("!Error Fatal!");
$logcontent = "Hora : " . $date->format('H:i:s')."\r\n" . $mensaje ."\r\n";
fwrite($fh, $logcontent);
fclose($fh);
}
else {
$this->edit($log,$date, $mensaje);
}
}
else {
if(mkdir($this->path,0777) === true)
{
$this->write($mensaje);
}
}
}
/**
* @void
* Este método es llamado cuando el log existe.
* Modifica el log actual añadiendo el contenido del mensaje.
*
* @param string $log
* @param DateTimeObject $date
* @param string $mensaje
*/
private function edit($log,$date,$mensaje) {
$logcontent = "Hora : " . $date->format('H:i:s')."\r\n" . $mensaje ."\r\n\r\n";
$logcontent = $logcontent . file_get_contents($log);
file_put_contents($log, $logcontent);
}
}
?>