aboutsummaryrefslogtreecommitdiff
path: root/src/callnotifier/Logger/CallEcho.php
blob: 70fad4a4d99c7c788ee25045b7b92c336a179289 (plain)
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
<?php
namespace callnotifier;

class Logger_CallEcho extends Logger_CallBase
{
    public function log($type, $arData)
    {
        switch ($type) {
        case 'startingCall':
            $displayMethod = 'displayStart';
            break;
        case 'finishedCall':
            $displayMethod = 'displayFinished';
            break;
        default:
            return;
        }

        $call = $arData['call'];
        if (!$this->hasValidType($call)) {
            return;
        }
        if (!$this->hasValidMsn($call)) {
            return;
        }
        $this->$displayMethod($arData['call']);
    }


    protected function displayStart(CallMonitor_Call $call)
    {
        $this->addUnsetVars($call);
        echo 'Starting ' . $this->getTypeName($call)
            . ' call from ' . trim($this->getNumberString($call, 'from'))
            . ' to ' . trim($this->getNumberString($call, 'to')) . "\n";
    }

    protected function displayFinished(CallMonitor_Call $call)
    {
        $this->addUnsetVars($call);
        echo 'Finished ' . $this->getTypeName($call)
            . ' call from ' . trim($this->getNumberString($call, 'from'))
            . ' to ' . trim($this->getNumberString($call, 'to'))
            . ', length ' . date('H:i:s', $call->end - $call->start - 3600)
            . "\n";
    }

    protected function getTypeName($call)
    {
        return $call->type == CallMonitor_Call::INCOMING
            ? 'incoming' : 'outgoing';
    }
}
?>