1 | <?php |
---|
2 | /** |
---|
3 | * File Storage stream for Logging |
---|
4 | * |
---|
5 | * PHP versions 4 and 5 |
---|
6 | * |
---|
7 | * CakePHP(tm) : Rapid Development Framework (http://cakephp.org) |
---|
8 | * Copyright 2005-2011, Cake Software Foundation, Inc. (http://cakefoundation.org) |
---|
9 | * |
---|
10 | * Licensed under The MIT License |
---|
11 | * Redistributions of files must retain the above copyright notice. |
---|
12 | * |
---|
13 | * @copyright Copyright 2005-2011, Cake Software Foundation, Inc. (http://cakefoundation.org) |
---|
14 | * @link http://www.cakefoundation.org/projects/info/cakephp CakePHP(tm) Project |
---|
15 | * @package cake |
---|
16 | * @subpackage cake.cake.libs.log |
---|
17 | * @since CakePHP(tm) v 1.3 |
---|
18 | * @license MIT License (http://www.opensource.org/licenses/mit-license.php) |
---|
19 | */ |
---|
20 | if (!class_exists('File')) { |
---|
21 | require LIBS . 'file.php'; |
---|
22 | } |
---|
23 | /** |
---|
24 | * File Storage stream for Logging. Writes logs to different files |
---|
25 | * based on the type of log it is. |
---|
26 | * |
---|
27 | * @package cake |
---|
28 | * @subpackage cake.cake.libs.log |
---|
29 | */ |
---|
30 | class FileLog { |
---|
31 | |
---|
32 | /** |
---|
33 | * Path to save log files on. |
---|
34 | * |
---|
35 | * @var string |
---|
36 | */ |
---|
37 | var $_path = null; |
---|
38 | |
---|
39 | /** |
---|
40 | * Constructs a new File Logger. |
---|
41 | * |
---|
42 | * Options |
---|
43 | * |
---|
44 | * - `path` the path to save logs on. |
---|
45 | * |
---|
46 | * @param array $options Options for the FileLog, see above. |
---|
47 | * @return void |
---|
48 | */ |
---|
49 | function FileLog($options = array()) { |
---|
50 | $options += array('path' => LOGS); |
---|
51 | $this->_path = $options['path']; |
---|
52 | } |
---|
53 | |
---|
54 | /** |
---|
55 | * Implements writing to log files. |
---|
56 | * |
---|
57 | * @param string $type The type of log you are making. |
---|
58 | * @param string $message The message you want to log. |
---|
59 | * @return boolean success of write. |
---|
60 | */ |
---|
61 | function write($type, $message) { |
---|
62 | $debugTypes = array('notice', 'info', 'debug'); |
---|
63 | |
---|
64 | if ($type == 'error' || $type == 'warning') { |
---|
65 | $filename = $this->_path . 'error.log'; |
---|
66 | } elseif (in_array($type, $debugTypes)) { |
---|
67 | $filename = $this->_path . 'debug.log'; |
---|
68 | } else { |
---|
69 | $filename = $this->_path . $type . '.log'; |
---|
70 | } |
---|
71 | $output = date('Y-m-d H:i:s') . ' ' . ucfirst($type) . ': ' . $message . "\n"; |
---|
72 | $log = new File($filename, true); |
---|
73 | if ($log->writable()) { |
---|
74 | return $log->append($output); |
---|
75 | } |
---|
76 | } |
---|
77 | } |
---|