From: Christian Weiske Date: Fri, 20 Jul 2012 16:24:29 +0000 (+0200) Subject: parse sapi and cr-bit X-Git-Tag: v1.0.0~82 X-Git-Url: https://git.cweiske.de/auerswald-callnotifier.git/commitdiff_plain/8cd74705cae43d0aff80de9c9eed57341cefb957 parse sapi and cr-bit --- diff --git a/src/callnotifier/EDSS1/Message.php b/src/callnotifier/EDSS1/Message.php index 08fa44f..4c3bd68 100644 --- a/src/callnotifier/EDSS1/Message.php +++ b/src/callnotifier/EDSS1/Message.php @@ -26,6 +26,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) * diff --git a/src/callnotifier/EDSS1/Parser.php b/src/callnotifier/EDSS1/Parser.php index 64a072e..fb70749 100644 --- a/src/callnotifier/EDSS1/Parser.php +++ b/src/callnotifier/EDSS1/Parser.php @@ -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); } diff --git a/tests/callnotifier/EDSS1/ParserTest.php b/tests/callnotifier/EDSS1/ParserTest.php index 117a8d0..2846f7b 100644 --- a/tests/callnotifier/EDSS1/ParserTest.php +++ b/tests/callnotifier/EDSS1/ParserTest.php @@ -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'); + } } ?>