Passed
Push — master ( 856966...11e739 )
by Oleg
03:58
created

FileDriver   A

Complexity

Total Complexity 7

Size/Duplication

Total Lines 61
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 2

Importance

Changes 1
Bugs 0 Features 0
Metric Value
wmc 7
c 1
b 0
f 0
lcom 1
cbo 2
dl 0
loc 61
rs 10

3 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 10 3
A sendMessage() 0 8 2
A __destruct() 0 6 2
1
<?php /** MicroFileDriver */
2
3
namespace Micro\Logger\Driver;
4
5
use Micro\Base\Exception;
6
use Micro\Base\IContainer;
7
8
/**
9
 * FileDriver logger class file.
10
 *
11
 * Writer logs in file
12
 *
13
 * @author Oleg Lunegov <[email protected]>
14
 * @link https://github.com/linpax/microphp-framework
15
 * @copyright Copyright &copy; 2013 Oleg Lunegov
16
 * @license /LICENSE
17
 * @package Micro
18
 * @subpackage Logger\Driver
19
 * @version 1.0
20
 * @since 1.0
21
 */
22
class FileDriver extends LoggerDriver
23
{
24
    /** @var resource $connect File handler */
25
    protected $connect;
26
27
28
    /**
29
     * Open file for write messages
30
     *
31
     * @access public
32
     *
33
     * @param IContainer $container
34
     * @param array $params configuration params
35
     *
36
     * @result void
37
     * @throws Exception
38
     */
39
    public function __construct(IContainer $container, array $params = [])
40
    {
41
        parent::__construct($container, $params);
42
43
        if (is_writable($params['filename']) || is_writable(dirname($params['filename']))) {
44
            $this->connect = fopen($params['filename'], 'a+');
45
        } else {
46
            throw new Exception('Directory or file "'.$params['filename'].'" is read-only');
47
        }
48
    }
49
50
    /**
51
     * Send message in log
52
     *
53
     * @access public
54
     *
55
     * @param integer $level level number
56
     * @param string $message message to write
57
     *
58
     * @result void
59
     * @throws \Micro\Base\Exception
60
     */
61
    public function sendMessage($level, $message)
62
    {
63
        if (is_resource($this->connect)) {
64
            fwrite($this->connect, '['.date('H:i:s d.m.Y').'] '.ucfirst($level).": {$message}\n");
65
        } else {
66
            throw new Exception('Error write log in file.');
67
        }
68
    }
69
70
    /**
71
     * Close opened for messages file
72
     *
73
     * @access public
74
     * @result void
75
     */
76
    public function __destruct()
77
    {
78
        if (is_resource($this->connect)) {
79
            fclose($this->connect);
80
        }
81
    }
82
}
83