parse sapi and cr-bit
authorChristian Weiske <cweiske@cweiske.de>
Fri, 20 Jul 2012 16:24:29 +0000 (18:24 +0200)
committerChristian Weiske <cweiske@cweiske.de>
Fri, 20 Jul 2012 16:24:29 +0000 (18:24 +0200)
src/callnotifier/EDSS1/Message.php
src/callnotifier/EDSS1/Parser.php
tests/callnotifier/EDSS1/ParserTest.php

index 08fa44f..4c3bd68 100644 (file)
@@ -27,6 +27,19 @@ class EDSS1_Message
     public $callRef;
 
     /**
+     * Service AccessPoint Identifier
+     */
+    public $sapi;
+
+    /**
+     * Call/Response bit
+     *
+     * Is 1 when the message contains a command or
+     * the answer to a command.
+     */
+    public $callResponse;
+
+    /**
      * Terminal Endpoint Identifier (internal Telephone ID)
      *
      * @var integer
index 64a072e..fb70749 100644 (file)
@@ -10,10 +10,16 @@ class EDSS1_Parser
     public function parse($bytes)
     {
         $m = new EDSS1_Message();
-        $m->tei = ord($bytes{1}) >> 1;//1st bit is always 1 and needs to be removed
+        $m->sapi = ord($bytes{0}) >> 2;
+        $m->callResponse = (int) ((ord($bytes{0}) & 2) == 2);
+        $m->tei  = ord($bytes{1}) >> 1;
 
         $curpos = 4;
-        list($curpos, $m->callRef) = $this->readLengthDataInt($bytes, ++$curpos);
+        list($curpos, $cCallRef, $crLen) = $this->readLengthData($bytes, ++$curpos);
+        if ($crLen == 0xFF) {
+            return $m;
+        }
+        $m->callRef = ord($cCallRef);
         //var_dump($curpos, dechex($m->callRef));
         $m->type = ord($bytes{++$curpos});
 
@@ -50,7 +56,11 @@ class EDSS1_Parser
     {
         //var_dump('old' . $curpos);
         $length = ord($bytes{$curpos});
-        $data = substr($bytes, $curpos + 1, $length);
+        if ($length != 0xFF) {
+            $data = substr($bytes, $curpos + 1, $length);
+        } else {
+            $data = null;
+        }
         return array($curpos + $length, $data, $length);
     }
 
index 117a8d0..2846f7b 100644 (file)
@@ -3,7 +3,6 @@ namespace callnotifier;
 
 class EDSS1_ParserTest extends \PHPUnit_Framework_TestCase
 {
-
     public function testParse()
     {
         $bs = '00 A3 02 02 08 01 01 7B 70 0C 81 30 31 36 33 34 37 37 39 38 37 38 FF 0A';
@@ -11,6 +10,7 @@ class EDSS1_ParserTest extends \PHPUnit_Framework_TestCase
         $msg = $p->parse(MessageHandler::getBytesFromHexString($bs));
 
         self::assertInstanceOf('callnotifier\EDSS1_Message', $msg);
+        self::assertEquals(0, $msg->sapi, 'SAPI is wrong');
         self::assertEquals(81, $msg->tei, 'TEI is wrong');
         self::assertEquals(123, $msg->type, 'Message type is wrong');
         self::assertEquals(1, $msg->callRef, 'Call reference is wrong');
@@ -21,6 +21,29 @@ class EDSS1_ParserTest extends \PHPUnit_Framework_TestCase
         self::assertEquals("\x8101634779878", $p->data, 'Parameter data is wrong');
     }
 
+    public function testParseSAPI()
+    {
+        $bs = 'FC A3 02 02 08 FF 0A';
+        $p = new EDSS1_Parser();
+        $msg = $p->parse(MessageHandler::getBytesFromHexString($bs));
+
+        self::assertInstanceOf('callnotifier\EDSS1_Message', $msg);
+        //SAPI: 0xFC = 252. 252 >> 2 = 63
+        self::assertEquals(63, $msg->sapi, 'SAPI is wrong');
+        self::assertEquals(0, $msg->callResponse, 'CR-bit is wrong');
+    }
+
+    public function testParseCallResponse()
+    {
+        $bs = 'FE A3 02 02 08 FF 0A';
+        $p = new EDSS1_Parser();
+        $msg = $p->parse(MessageHandler::getBytesFromHexString($bs));
+
+        self::assertInstanceOf('callnotifier\EDSS1_Message', $msg);
+        //SAPI: 0xFE = 254. 254 & 2 = 2 -> cr bit set
+        self::assertEquals(63, $msg->sapi, 'SAPI is wrong');
+        self::assertEquals(1, $msg->callResponse, 'CR-bit is wrong');
+    }
 }
 
 ?>