add incoming/outgoing type to calls
authorChristian Weiske <cweiske@cweiske.de>
Thu, 2 Aug 2012 05:39:00 +0000 (07:39 +0200)
committerChristian Weiske <cweiske@cweiske.de>
Thu, 2 Aug 2012 05:39:00 +0000 (07:39 +0200)
src/callnotifier/CLI.php
src/callnotifier/CallMonitor.php
src/callnotifier/CallMonitor/Call.php
src/callnotifier/Log.php
src/callnotifier/Logger/CallEcho.php

index 6ec9a7e..2a6d3ca 100644 (file)
@@ -32,7 +32,7 @@ class CLI
             }
         }
         $log->addLogger(
-            new Logger_CallEcho(), array('incomingCall', 'finishedCall')
+            new Logger_CallEcho(), array('startingCall', 'finishedCall')
         );
 
         $callMonitor = new CallMonitor($this->config, $log);
index af72e0a..29ee5a2 100644 (file)
@@ -43,6 +43,12 @@ class CallMonitor
     {
         $call = $this->currentCalls[$callId];
         $call->start = time();
+        if ($msg->tei == 127) {
+            $call->type = CallMonitor_Call::INCOMING;
+        } else {
+            $call->type = CallMonitor_Call::OUTGOING;
+        }
+
         $this->handleParams($call, $msg);
     }
 
@@ -56,7 +62,7 @@ class CallMonitor
             $this->handleParams($call, $msg);
             break;
         case EDSS1_Message::CALL_PROCEEDING:
-            $this->log->log('incomingCall', array('call' => $call));
+            $this->log->log('startingCall', array('call' => $call));
             break;
 
         case EDSS1_Message::RELEASE:
index 3ebd251..0f16ead 100644 (file)
@@ -3,6 +3,17 @@ namespace callnotifier;
 
 class CallMonitor_Call
 {
+    const INCOMING = 'i';
+    const OUTGOING = 'o';
+
+    /**
+     * Type of call: "i"ncoming or "o"utgoing
+     *
+     * @var string
+     */
+    public $type;
+
+
     /**
      * Telephone number of caller
      *
index 8a6b79a..d2ee0c8 100644 (file)
@@ -13,7 +13,7 @@ class Log
     protected $logger = array(
         'msgData' => array(),
         'edss1msg' => array(),
-        'incomingCall' => array(),
+        'startingCall' => array(),
         'finishedCall' => array(),
     );
 
index fe8b9b4..825bc24 100644 (file)
@@ -6,8 +6,8 @@ class Logger_CallEcho implements Logger
     public function log($type, $arData)
     {
         switch ($type) {
-        case 'incomingCall':
-            $this->displayIncoming($arData['call']);
+        case 'startingCall':
+            $this->displayStart($arData['call']);
             break;
         case 'finishedCall':
             $this->displayFinished($arData['call']);
@@ -16,18 +16,26 @@ class Logger_CallEcho implements Logger
     }
 
 
-    protected function displayIncoming(CallMonitor_Call $call)
+    protected function displayStart(CallMonitor_Call $call)
     {
-        echo 'Incoming call from ' . $call->from
+        echo 'Starting ' . $this->getTypeName($call)
+            . ' call from ' . $call->from
             . ' to ' . $call->to . "\n";
     }
 
     protected function displayFinished(CallMonitor_Call $call)
     {
-        echo 'Finished call from ' . $call->from
+        echo 'Finished ' . $this->getTypeName($call)
+            . ' call from ' . $call->from
             . ' to ' . $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';
+    }
 }
 ?>