{
protected $dumpHdl;
- /**
- * Array of logger object arrays.
- * Key is the notification type, value is an array of logger objects
- * that want to get notified about the type.
- *
- * @var array
- */
- protected $logger = array(
- 'msgData' => array(),
- 'incomingCall' => array(),
- 'edss1msg' => array(),
- );
-
- public function __construct($config)
+ public function __construct($config, $log, $callMonitor)
{
$this->config = $config;
$this->prepareDump();
- }
-
- /**
- * Add a logger
- *
- * @param Logger $logger Logger object to register
- * @param array|string $types Single notification type or array of such
- * types. "*" means "register for all types".
- *
- * @return self
- */
- public function addLogger(Logger $logger, $types)
- {
- if ($types == '*') {
- $types = array_keys($this->logger);
- }
- $types = (array)$types;
-
- foreach ($types as $type) {
- if (!isset($this->logger[$type])) {
- throw new \Exception('Unknown log type: ' . $type);
- }
- $this->logger[$type][] = $logger;
- }
+ $this->log = $log;
+ $this->callMonitor = $callMonitor;
}
public function handle($msg)
return false;
}
list(, $type, $someid, $details) = $matches;
- $this->log(
+ $this->log->log(
'msgData',
array(
'type' => $type,
)
);
- if ($type != 'Info') {
- $this->parseEDSS1($details);
- return;
- }
- //Vegw/Ets-Cref:[0xffef]/[0x64] - VEGW_SETUP from upper layer to internal destination: CGPN[**22]->CDPN[41],
- $regex = '#CGPN\\[([^\\]]+)\\]->CDPN\\[([^\\]]+)\\]#';
- if (preg_match($regex, $details, $matches)) {
- list(, $from, $to) = $matches;
- $this->log('incomingCall', array('from' => $from, 'to' => $to));
+ if ($type == 'Debug') {
+ $msg = $this->parseEDSS1($details);
+ if (is_object($msg)) {
+ $this->log->log('edss1msg', array('msg' => $msg));
+ $this->callMonitor->handle($msg);
+ }
}
}
*
* @param string $details Detail string of a debug message
*
+ * @return EDSS1_Message The retrieved message, NULL if none.
*/
protected function parseEDSS1($details)
{
}
$bytestring = substr($details, 5);
- $bytes = '';
- foreach (explode(' ', $bytestring) as $strbyte) {
- $bytes .= chr(hexdec($strbyte));
- }
-
- $msgtype = $bytes{7};
- static $interestingTyps = array(
- EDSS1_Message::SETUP,
- EDSS1_Message::CONNECT,
- EDSS1_Message::INFORMATION
- );
- if (!in_array($msgtype, $interestingTyps)) {
- //return;
- }
+ $bytes = static::getBytesFromHexString($bytestring);
$mp = new EDSS1_Parser();
- $msg = $mp->parse($bytes);
-
- $this->log('edss1msg', array('msg' => $msg));
+ return $mp->parse($bytes);
}
- protected function log($type, $arData)
+ public static function getBytesFromHexString($bytestring)
{
- if (!isset($this->logger[$type])) {
- throw new \Exception('Unknown log type: ' . $type);
- }
-
- if (count($this->logger[$type])) {
- foreach ($this->logger[$type] as $logger) {
- $logger->log($type, $arData);
- }
+ $bytes = '';
+ foreach (explode(' ', $bytestring) as $strbyte) {
+ $bytes .= chr(hexdec($strbyte));
}
+ return $bytes;
}
protected function prepareDump()
}
$this->dumpHdl = fopen($this->config->dumpFile, 'w');
if (!$this->dumpHdl) {
- throw new Exception('Cannot open replay file for reading');
+ throw new Exception('Cannot open dump file for writing');
}
}