MessageLogPlugin::__construct()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 15

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
dl 0
loc 15
rs 9.7666
c 0
b 0
f 0
cc 1
nc 1
nop 2
1
<?php
2
3
namespace Nopolabs\Yabot\Plugin;
4
5
6
use Nopolabs\Yabot\Message\Message;
7
use Nopolabs\Yabot\Yabot;
8
use Psr\Log\LoggerInterface;
9
10
class MessageLogPlugin implements PluginInterface
11
{
12
    use PluginTrait;
13
14
    private $yabot;
15
16
    public function __construct(Yabot $yabot, LoggerInterface $logger = null)
17
    {
18
        $this->setLog($logger);
19
        $this->yabot = $yabot;
20
21
        $this->setConfig([
22
            'help' => "<prefix> start\n<prefix> stop\n",
23
            'prefix' => 'messagelog',
24
            'messageLogFile' => 'logs/message.log',
25
            'matchers' => [
26
                'start' => "/^start\\b/",
27
                'stop' => "/^stop\\b/",
28
            ],
29
        ]);
30
    }
31
32
    public function status(): string
33
    {
34
        if ($file = $this->yabot->getMessageLog()) {
35
            return "logging messages in $file";
36
        }
37
38
        return 'not logging messages';
39
    }
40
41
    public function start(Message $msg)
42
    {
43
        $this->yabot->setMessageLog($this->get('messageLogFile'));
44
        $msg->setHandled(true);
45
    }
46
47
    public function stop(Message $msg)
48
    {
49
        $this->yabot->setMessageLog(null);
50
        $msg->setHandled(true);
51
    }
52
}