?? phpagi-asmanager.php
字號:
<?php /** * phpagi-asmanager.php : PHP Asterisk Manager functions * Website: http://phpagi.sourceforge.net * * $Id: phpagi-asmanager.php,v 1.10 2005/05/25 18:43:48 pinhole Exp $ * * Copyright (c) 2004, 2005 Matthew Asham <matthewa@bcwireless.net>, David Eder <david@eder.us> * All Rights Reserved. * * This software is released under the terms of the GNU Lesser General Public License v2.1 * A copy of which is available from http://www.gnu.org/copyleft/lesser.html * * We would be happy to list your phpagi based application on the phpagi * website. Drop me an Email if you'd like us to list your program. * * @package phpAGI * @version 2.0 */ /** * Written for PHP 4.3.4, should work with older PHP 4.x versions. * Please submit bug reports, patches, etc to http://sourceforge.net/projects/phpagi/ * Gracias. :) * */ if(!class_exists('AGI')) { require_once(dirname(__FILE__) . DIRECTORY_SEPARATOR . 'phpagi.php'); } /** * Asterisk Manager class * * @link http://www.voip-info.org/wiki-Asterisk+config+manager.conf * @link http://www.voip-info.org/wiki-Asterisk+manager+API * @example examples/sip_show_peer.php Get information about a sip peer * @package phpAGI */ class AGI_AsteriskManager { /** * Config variables * * @var array * @access public */ var $config; /** * Socket * * @access public */ var $socket = NULL; /** * Server we are connected to * * @access public * @var string */ var $server; /** * Port on the server we are connected to * * @access public * @var integer */ var $port; /** * Parent AGI * * @access private * @var AGI */ var $pagi; /** * Event Handlers * * @access private * @var array */ var $event_handlers; /** * Constructor * * @param string $config is the name of the config file to parse or a parent agi from which to read the config * @param array $optconfig is an array of configuration vars and vals, stuffed into $this->config['asmanager'] */ function AGI_AsteriskManager($config=NULL, $optconfig=array()) { // load config if(!is_null($config) && file_exists($config)) $this->config = parse_ini_file($config, true); elseif(file_exists(DEFAULT_PHPAGI_CONFIG)) $this->config = parse_ini_file(DEFAULT_PHPAGI_CONFIG, true); // If optconfig is specified, stuff vals and vars into 'asmanager' config array. foreach($optconfig as $var=>$val) $this->config['asmanager'][$var] = $val; // add default values to config for uninitialized values if(!isset($this->config['asmanager']['server'])) $this->config['asmanager']['server'] = 'localhost'; if(!isset($this->config['asmanager']['port'])) $this->config['asmanager']['port'] = 5038; if(!isset($this->config['asmanager']['username'])) $this->config['asmanager']['username'] = 'phpagi'; if(!isset($this->config['asmanager']['secret'])) $this->config['asmanager']['secret'] = 'phpagi'; } /** * Send a request * * @param string $action * @param array $parameters * @return array of parameters */ function send_request($action, $parameters=array()) { $req = "Action: $action\r\n"; foreach($parameters as $var=>$val) $req .= "$var: $val\r\n"; $req .= "\r\n"; fwrite($this->socket, $req); return $this->wait_response(); } /** * Wait for a response * * If a request was just sent, this will return the response. * Otherwise, it will loop forever, handling events. * * @param boolean $allow_timeout if the socket times out, return an empty array * @return array of parameters, empty on timeout */ function wait_response($allow_timeout=false) { $timeout = false; do { $type = NULL; $parameters = array(); $buffer = trim(fgets($this->socket, 4096)); while($buffer != '') { $a = strpos($buffer, ':'); if($a) { if(!count($parameters)) // first line in a response? { $type = strtolower(substr($buffer, 0, $a)); if(substr($buffer, $a + 2) == 'Follows') { // A follows response means there is a miltiline field that follows. $parameters['data'] = ''; $buff = fgets($this->socket, 4096); while(substr($buff, 0, 6) != '--END ') { $parameters['data'] .= $buff; $buff = fgets($this->socket, 4096); } } } // store parameter in $parameters $parameters[substr($buffer, 0, $a)] = substr($buffer, $a + 2); } $buffer = trim(fgets($this->socket, 4096)); } // process response switch($type) { case '': // timeout occured $timeout = $allow_timeout; break; case 'event': $this->process_event($parameters); break; case 'response': break; default: $this->log('Unhandled response packet from Manager: ' . print_r($parameters, true)); break; } } while($type != 'response' && !$timeout); return $parameters; } /** * Connect to Asterisk * * @example examples/sip_show_peer.php Get information about a sip peer * * @param string $server * @param string $username * @param string $secret * @return boolean true on success */ function connect($server=NULL, $username=NULL, $secret=NULL) { // use config if not specified if(is_null($server)) $server = $this->config['asmanager']['server']; if(is_null($username)) $username = $this->config['asmanager']['username']; if(is_null($secret)) $secret = $this->config['asmanager']['secret']; // get port from server if specified if(strpos($server, ':') !== false) { $c = explode(':', $server); $this->server = $c[0]; $this->port = $c[1]; } else { $this->server = $server; $this->port = $this->config['asmanager']['port']; } // connect the socket $errno = $errstr = NULL; $this->socket = @fsockopen($this->server, $this->port, $errno, $errstr); if($this->socket == false) { $this->log("Unable to connect to manager {$this->server}:{$this->port} ($errno): $errstr"); return false; } // read the header $str = fgets($this->socket); if($str == false) { // a problem. $this->log("Asterisk Manager header not received."); return false; } else { // note: don't $this->log($str) until someone looks to see why it mangles the logging } // login $res = $this->send_request('login', array('Username'=>$username, 'Secret'=>$secret)); if($res['Response'] != 'Success') { $this->log("Failed to login."); $this->disconnect(); return false; } return true; } /** * Disconnect * * @example examples/sip_show_peer.php Get information about a sip peer */ function disconnect() { $this->logoff(); fclose($this->socket); } // ********************************************************************************************************* // ** COMMANDS ** // ********************************************************************************************************* /** * Set Absolute Timeout * * Hangup a channel after a certain time. * * @link http://www.voip-info.org/wiki-Asterisk+Manager+API+Action+AbsoluteTimeout * @param string $channel Channel name to hangup * @param integer $timeout Maximum duration of the call (sec) */ function AbsoluteTimeout($channel, $timeout) { return $this->send_request('AbsoluteTimeout', array('Channel'=>$channel, 'Timeout'=>$timeout)); } /** * Change monitoring filename of a channel * * @link http://www.voip-info.org/wiki-Asterisk+Manager+API+Action+ChangeMonitor * @param string $channel the channel to record. * @param string $file the new name of the file created in the monitor spool directory. */ function ChangeMonitor($channel, $file) { return $this->send_request('ChangeMontior', array('Channel'=>$channel, 'File'=>$file)); } /** * Execute Command * * @example examples/sip_show_peer.php Get information about a sip peer * @link http://www.voip-info.org/wiki-Asterisk+Manager+API+Action+Command * @link http://www.voip-info.org/wiki-Asterisk+CLI * @param string $command * @param string $actionid message matching variable */ function Command($command, $actionid=NULL) { $parameters = array('Command'=>$command); if($actionid) $parameters['ActionID'] = $actionid; return $this->send_request('Command', $parameters); } /** * Enable/Disable sending of events to this manager * * @link http://www.voip-info.org/wiki-Asterisk+Manager+API+Action+Events * @param string $eventmask is either 'on', 'off', or 'system,call,log' */ function Events($eventmask) { return $this->send_request('Events', array('EventMask'=>$eventmask)); } /** * Check Extension Status * * @link http://www.voip-info.org/wiki-Asterisk+Manager+API+Action+ExtensionState * @param string $exten Extension to check state on * @param string $context Context for extension * @param string $actionid message matching variable */ function ExtensionState($exten, $context, $actionid=NULL) { $parameters = array('Exten'=>$exten, 'Context'=>$context); if($actionid) $parameters['ActionID'] = $actionid; return $this->send_request('ExtensionState', $parameters); } /** * Gets a Channel Variable * * @link http://www.voip-info.org/wiki-Asterisk+Manager+API+Action+GetVar * @link http://www.voip-info.org/wiki-Asterisk+variables * @param string $channel Channel to read variable from * @param string $variable * @param string $actionid message matching variable */ function GetVar($channel, $variable, $actionid=NULL) { $parameters = array('Channel'=>$channel, 'Variable'=>$variable); if($actionid) $parameters['ActionID'] = $actionid; return $this->send_request('GetVar', $parameters); } /** * Hangup Channel * * @link http://www.voip-info.org/wiki-Asterisk+Manager+API+Action+Hangup * @param string $channel The channel name to be hungup */ function Hangup($channel) { return $this->send_request('Hangup', array('Channel'=>$channel)); } /** * List IAX Peers * * @link http://www.voip-info.org/wiki-Asterisk+Manager+API+Action+IAXpeers */ function IAXPeers() { return $this->send_request('IAXPeers'); } /** * List available manager commands * * @link http://www.voip-info.org/wiki-Asterisk+Manager+API+Action+ListCommands * @param string $actionid message matching variable */ function ListCommands($actionid=NULL) { if($actionid) return $this->send_request('ListCommands', array('ActionID'=>$actionid)); else return $this->send_request('ListCommands'); } /** * Logoff Manager * * @link http://www.voip-info.org/wiki-Asterisk+Manager+API+Action+Logoff */ function Logoff() { return $this->send_request('Logoff'); } /** * Check Mailbox Message Count * * Returns number of new and old messages.
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -