Portions created by the Initial Developer are Copyright (C) 2017 the Initial Developer. All Rights Reserved. Contributor(s): Mark J Crane */ /** * providers class provides methods for providing an overview * * @method boolean add */ if (!class_exists('providers')) { class providers { //define variables public $db; public $debug; public $domain_uuid; public $array; /** * Called when the object is created */ public function __construct() { //connect to the database if not connected if (!$this->db) { require_once "resources/classes/database.php"; $database = new database; $database->connect(); $this->db = $database->db; } } /** * Called when there are no references to a particular object * unset the variables used in the class */ public function __destruct() { if (isset($this)) foreach ($this as $key => $value) { unset($this->$key); } } /** * nodes array */ public function nodes($provider) { //build the skyetel node array if ($provider == 'skyetel') { $x = 0; $nodes[$x]['uuid'] = 'af26484f-03a1-4f93-857b-b8cef1ac28f5'; $nodes[$x]['cidr'] = '52.41.52.34/32'; $nodes[$x]['description'] = 'Skyetel - North West'; $x++; $nodes[$x]['uuid'] = '87eb7803-9b96-41d3-ac5a-42ed3f213777'; $nodes[$x]['cidr'] = '52.8.201.128/32'; $nodes[$x]['description'] = 'Skyetel - South West'; $x++; $nodes[$x]['uuid'] = 'cf61ab01-1465-4eca-9152-2e6fd4a02073'; $nodes[$x]['cidr'] = '52.60.138.31/32'; $nodes[$x]['description'] = 'Skyetel - North East'; $x++; $nodes[$x]['uuid'] = 'b43ebeef-c214-492b-8f22-4bfc6b647668'; $nodes[$x]['cidr'] = '50.17.48.216/32'; $nodes[$x]['description'] = 'Skyetel - South East'; $x++; $nodes[$x]['uuid'] = '28615834-4517-4515-b474-5ca54ee958fc'; $nodes[$x]['cidr'] = '35.156.192.164/32'; $nodes[$x]['description'] = 'Skyetel - Europe'; } //build the voicetel node array if ($provider == 'voicetel') { $x = 0; $nodes[$x]['uuid'] = 'dae9ab41-73c1-4792-bfdb-eccbedeebac9'; $nodes[$x]['cidr'] = '104.225.6.160/29'; $nodes[$x]['description'] = 'VoiceTel'; $x++; $nodes[$x]['uuid'] = '3167d47d-0679-4336-b4c4-be68cdc28e5b'; $nodes[$x]['cidr'] = '104.225.13.72/29'; $nodes[$x]['description'] = 'VoiceTel'; $x++; $nodes[$x]['uuid'] = 'e3d2e9b8-5807-4175-9ffc-57480ac94f83'; $nodes[$x]['cidr'] = '148.59.176.0/23'; $nodes[$x]['description'] = 'VoiceTel'; $x++; $nodes[$x]['uuid'] = 'a1d70666-ab25-425a-9884-60530f4dd8b7'; $nodes[$x]['cidr'] = '192.73.246.104/29'; $nodes[$x]['description'] = 'VoiceTel'; $x++; $nodes[$x]['uuid'] = '0bf5450f-c23b-4139-9e89-884bd0972912'; $nodes[$x]['cidr'] = '192.73.250.96/29'; $nodes[$x]['description'] = 'VoiceTel'; $x++; $nodes[$x]['uuid'] = '181dcaf8-f990-4869-90e3-97de7d2daa5a'; $nodes[$x]['cidr'] = '192.73.251.104/29'; $nodes[$x]['description'] = 'VoiceTel'; $x++; $nodes[$x]['uuid'] = 'b32db3ae-4ce8-4793-ad30-fbb6478b9249'; $nodes[$x]['cidr'] = '192.254.70.144/29'; $nodes[$x]['description'] = 'VoiceTel'; $x++; $nodes[$x]['uuid'] = '5782acb1-845c-4d33-8241-569f83854283'; $nodes[$x]['cidr'] = '192.254.76.220/30'; $nodes[$x]['description'] = 'VoiceTel'; } //return the array return $nodes; } /** * gateways array */ public function gateways($provider) { //build the array if ($provider == 'skyetel') { $x=0; $gateways[$x]['uuid'] = '22245a48-552c-463a-a723-ce01ebbd69a2'; $gateways[$x]['name'] = 'term.skyetel.com'; $gateways[$x]['proxy'] = 'term.skyetel.com'; $gateways[$x]['username'] = 'username'; $gateways[$x]['password'] = 'password'; $gateways[$x]['register'] = 'false'; $gateways[$x]['caller_id_in_from'] = 'true'; $gateways[$x]['supress_cng'] = 'true'; $gateways[$x]['sip_cid_type'] = 'pid'; $x++; $gateways[$x]['uuid'] = 'b171ba70-06a5-4560-82be-596ed9d00041'; $gateways[$x]['name'] = 'skyetel.34'; $gateways[$x]['proxy'] = '52.41.52.34'; $gateways[$x]['username'] = 'username'; $gateways[$x]['password'] = 'password'; $gateways[$x]['register'] = 'false'; $gateways[$x]['caller_id_in_from'] = 'true'; $gateways[$x]['supress_cng'] = 'true'; $gateways[$x]['sip_cid_type'] = 'pid'; $x++; $gateways[$x]['uuid'] = '4864ac6e-9e50-4fff-8381-2c508f8912b5'; $gateways[$x]['name'] = 'skyetel.128'; $gateways[$x]['proxy'] = '52.8.201.128'; $gateways[$x]['username'] = 'username'; $gateways[$x]['password'] = 'password'; $gateways[$x]['register'] = 'false'; $gateways[$x]['caller_id_in_from'] = 'true'; $gateways[$x]['supress_cng'] = 'true'; $gateways[$x]['sip_cid_type'] = 'pid'; $x++; $gateways[$x]['uuid'] = '5553606b-e543-4427-bb63-ebed16001937'; $gateways[$x]['name'] = 'skyetel.216'; $gateways[$x]['proxy'] = '50.17.48.216'; $gateways[$x]['username'] = 'username'; $gateways[$x]['password'] = 'password'; $gateways[$x]['register'] = 'false'; $gateways[$x]['caller_id_in_from'] = 'true'; $gateways[$x]['supress_cng'] = 'true'; $gateways[$x]['sip_cid_type'] = 'pid'; $x++; } if ($provider == 'voicetel') { $x=0; $gateways[$x]['uuid'] = 'd61be0f0-3a4c-434a-b9f6-4fef15e1a634'; $gateways[$x]['name'] = 'voicetel'; $gateways[$x]['proxy'] = 'sbc.voicetel.com'; $gateways[$x]['username'] = 'username'; $gateways[$x]['password'] = 'password'; $gateways[$x]['register'] = 'false'; $x++; } //return the array return $gateways; } /** * setup the provider */ public function setup($provider) { //validate the provider switch ($provider) { case 'voicetel': break; case 'skyetel': break; default: $provider = ''; } //get the domains access control uuid $sql = "select access_control_uuid from v_access_controls "; $sql .= "where access_control_name = 'domains'; "; if ($this->debug) { echo $sql."
\n"; } $prep_statement = $this->db->prepare($sql); if ($prep_statement) { $prep_statement->execute(); $result = $prep_statement->fetch(PDO::FETCH_ASSOC); $access_control_uuid = $result['access_control_uuid']; } unset($prep_statement); //get the existing nodes $sql = "select * from v_access_control_nodes "; $sql .= "where access_control_uuid = '".$access_control_uuid."' "; $sql .= "and node_cidr <> '' "; if ($this->debug) { echo $sql."
\n"; } $prep_statement = $this->db->prepare(check_sql($sql)); if ($prep_statement) { $prep_statement->execute(); $access_control_nodes = $prep_statement->fetchAll(PDO::FETCH_ASSOC); //echo "
\n";
					//print_r($access_control_nodes);
					//echo "
\n"; } //get the existing nodes $sql = "select * from v_sip_profiles "; $sql .= "where sip_profile_enabled = 'true' "; $sql .= "order by sip_profile_name asc "; $sql .= "limit 1; "; if ($this->debug) { echo $sql."
\n"; } $prep_statement = $this->db->prepare(check_sql($sql)); if ($prep_statement) { $prep_statement->execute(); $result = $prep_statement->fetch(PDO::FETCH_ASSOC); $sip_profile_name = $result['sip_profile_name']; } //get the nodes array $nodes = $this->nodes($provider); //add gateways $x = 0; foreach ($nodes as $row) { $array['access_control_nodes'][$x]['access_control_node_uuid'] = $row['uuid']; $array['access_control_nodes'][$x]['access_control_uuid'] = $access_control_uuid; $array['access_control_nodes'][$x]['node_type'] = 'allow'; $array['access_control_nodes'][$x]['node_cidr'] = $row['cidr']; $array['access_control_nodes'][$x]['node_description']= $row['description']; $x++; } //get the gateways array $gateways = $this->gateways($provider); //gateways array if ($provider == 'skyetel') { //dialplan settings $dialplan_expression = '^\+?1?(\d{10})$'; $dialplan_prefix = '1'; } if ($provider == 'voicetel') { //dialplan settings $dialplan_expression = '^\+?1?(\d{10})$'; $dialplan_prefix = '1'; } //add gateways $x = 0; foreach ($gateways as $row) { $array['gateways'][$x]['gateway_uuid'] = $row['uuid']; $array['gateways'][$x]['gateway'] = $row['name']; $array['gateways'][$x]['username'] = $row['username']; $array['gateways'][$x]['password'] = $row['password']; $array['gateways'][$x]['proxy'] = $row['proxy']; $array['gateways'][$x]['register'] = $row['register']; $array['gateways'][$x]['retry_seconds'] = '30'; $array['gateways'][$x]['ping'] = '90'; $array['gateways'][$x]['expire_seconds'] = '800'; if (isset($row['supress_cng'])) { $array['gateways'][$x]['caller_id_in_from'] = $row['caller_id_in_from']; } if (isset($row['supress_cng'])) { $array['gateways'][$x]['supress_cng'] = $row['supress_cng']; } if (isset($row['sip_cid_type'])) { $array['gateways'][$x]['sip_cid_type'] = $row['sip_cid_type']; } $array['gateways'][$x]['context'] = 'public'; $array['gateways'][$x]['profile'] = $sip_profile_name; $array['gateways'][$x]['enabled'] = 'true'; $array['gateways'][$x]['description'] = ''; $x++; } //set the dialplan variables if ($provider == 'skyetel') { $dialplan_uuid = '777bf012-9746-4ccb-a7cc-95c1714f15fe'; } if ($provider == 'voicetel') { $dialplan_uuid = '513e3710-1cbd-48da-b8f1-792eae471d3a'; } $app_uuid = '8c914ec3-9fc0-8ab5-4cda-6c9288bdc9a3'; $dialplan_name = $provider; $dialplan_order = '100'; $dialplan_continue = 'false'; $dialplan_context = '${domain_name}'; $dialplan_enabled = 'true'; $dialplan_description = '10-11 digits'; //add outbound routes $x = 0; //$array['dialplans'][$x]['domain_uuid'] = $_SESSION['domain_uuid']; $array['dialplans'][$x]['dialplan_uuid'] = $dialplan_uuid; $array['dialplans'][$x]['app_uuid'] = $app_uuid; $array['dialplans'][$x]['dialplan_name'] = $dialplan_name; $array['dialplans'][$x]['dialplan_order'] = $dialplan_order; $array['dialplans'][$x]['dialplan_continue'] = $dialplan_continue; $array['dialplans'][$x]['dialplan_context'] = $dialplan_context; $array['dialplans'][$x]['dialplan_enabled'] = $dialplan_enabled; $array['dialplans'][$x]['dialplan_description'] = $dialplan_description; $y = 0; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_uuid'] = uuid(); $array['dialplans'][$x]['dialplan_details'][$y]['domain_uuid'] = $_SESSION['domain_uuid']; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_uuid'] = $dialplan_uuid; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_tag'] = 'condition'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_type'] = '${user_exists}'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_data'] = 'false'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_order'] = $y * 10; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_group'] = '0'; $y++; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_uuid'] = uuid(); $array['dialplans'][$x]['dialplan_details'][$y]['domain_uuid'] = $_SESSION['domain_uuid']; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_uuid'] = $dialplan_uuid; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_tag'] = 'condition'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_type'] = 'destination_number'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_data'] = $dialplan_expression; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_order'] = $y * 10; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_group'] = '0'; $y++; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_uuid'] = uuid(); $array['dialplans'][$x]['dialplan_details'][$y]['domain_uuid'] = $_SESSION['domain_uuid']; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_uuid'] = $dialplan_uuid; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_tag'] = 'action'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_type'] = 'set'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_data'] = 'sip_h_X-accountcode=${accountcode}'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_order'] = $y * 10; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_group'] = '0'; $y++; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_uuid'] = uuid(); $array['dialplans'][$x]['dialplan_details'][$y]['domain_uuid'] = $_SESSION['domain_uuid']; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_uuid'] = $dialplan_uuid; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_tag'] = 'action'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_type'] = 'set'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_data'] = 'call_direction=outbound'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_order'] = $y * 10; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_group'] = '0'; $y++; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_uuid'] = uuid(); $array['dialplans'][$x]['dialplan_details'][$y]['domain_uuid'] = $_SESSION['domain_uuid']; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_uuid'] = $dialplan_uuid; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_tag'] = 'action'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_type'] = 'unset'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_data'] = 'call_timeout'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_order'] = $y * 10; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_group'] = '0'; $y++; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_uuid'] = uuid(); $array['dialplans'][$x]['dialplan_details'][$y]['domain_uuid'] = $_SESSION['domain_uuid']; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_uuid'] = $dialplan_uuid; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_tag'] = 'action'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_type'] = 'set'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_data'] = 'hangup_after_bridge=true'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_order'] = $y * 10; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_group'] = '0'; $y++; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_uuid'] = uuid(); $array['dialplans'][$x]['dialplan_details'][$y]['domain_uuid'] = $_SESSION['domain_uuid']; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_uuid'] = $dialplan_uuid; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_tag'] = 'action'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_type'] = 'set'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_data'] = 'effective_caller_id_name=${outbound_caller_id_name}'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_order'] = $y * 10; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_group'] = '0'; $y++; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_uuid'] = uuid(); $array['dialplans'][$x]['dialplan_details'][$y]['domain_uuid'] = $_SESSION['domain_uuid']; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_uuid'] = $dialplan_uuid; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_tag'] = 'action'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_type'] = 'set'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_data'] = 'effective_caller_id_number=${outbound_caller_id_number}'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_order'] = $y * 10; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_group'] = '0'; $y++; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_uuid'] = uuid(); $array['dialplans'][$x]['dialplan_details'][$y]['domain_uuid'] = $_SESSION['domain_uuid']; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_uuid'] = $dialplan_uuid; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_tag'] = 'action'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_type'] = 'set'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_data'] = 'inherit_codec=true'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_order'] = $y * 10; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_group'] = '0'; $y++; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_uuid'] = uuid(); $array['dialplans'][$x]['dialplan_details'][$y]['domain_uuid'] = $_SESSION['domain_uuid']; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_uuid'] = $dialplan_uuid; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_tag'] = 'action'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_type'] = 'set'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_data'] = 'ignore_display_updates=true'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_order'] = $y * 10; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_group'] = '0'; $y++; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_uuid'] = uuid(); $array['dialplans'][$x]['dialplan_details'][$y]['domain_uuid'] = $_SESSION['domain_uuid']; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_uuid'] = $dialplan_uuid; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_tag'] = 'action'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_type'] = 'set'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_data'] = 'callee_id_number=$1'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_order'] = $y * 10; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_group'] = '0'; $y++; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_uuid'] = uuid(); $array['dialplans'][$x]['dialplan_details'][$y]['domain_uuid'] = $_SESSION['domain_uuid']; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_uuid'] = $dialplan_uuid; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_tag'] = 'action'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_type'] = 'set'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_data'] = 'continue_on_fail=true'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_order'] = $y * 10; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_group'] = '0'; $y++; foreach ($gateways as $row) { $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_uuid'] = uuid(); $array['dialplans'][$x]['dialplan_details'][$y]['domain_uuid'] = $_SESSION['domain_uuid']; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_uuid'] = $dialplan_uuid; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_tag'] = 'action'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_type'] = 'bridge'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_data'] = 'sofia/gateway/'.$row['uuid'].'/'.$dialplan_prefix.'$1'; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_order'] = $y * 10; $array['dialplans'][$x]['dialplan_details'][$y]['dialplan_detail_group'] = '0'; $y++; } //save to the data $database = new database; $database->app_name = 'outbound_routes'; $database->app_uuid = '8c914ec3-9fc0-8ab5-4cda-6c9288bdc9a3'; $database->save($array); $message = $database->message; //debug //echo "
\n";
				//print_r($array);
				//echo "
\n";
				//exit;

			//update the dialplan xml
				$dialplans = new dialplan;
				$dialplans->source = "details";
				$dialplans->destination = "database";
				$dialplans->uuid = $dialplan_uuid;
				$dialplans->xml();

			//create the event socket connection
				$fp = event_socket_create($_SESSION['event_socket_ip_address'], $_SESSION['event_socket_port'], $_SESSION['event_socket_password']);

			//get the hostname
				if ($fp) {  $sip_profile_hostname = event_socket_request($fp, 'api switchname'); }

			//clear the cache
				$cache = new cache;
				$cache->delete("configuration:acl.conf");
				$cache->delete("configuration:sofia.conf:".$sip_profile_hostname);

			//reload acl and rescan the sip profile
				if ($fp) { event_socket_request($fp, "api reloadacl"); }
				if ($fp) { event_socket_request($fp, "api sofia profile ".$sip_profile_name." rescan"); }
		}

		/**
		 * delete the provider
		 */
		public function delete($provider) {

			//validate the provider
				switch ($provider) {
					case 'voicetel':
						break;
					case 'skyetel': 
						break;
					default: 
						$provider = '';
				}

			//set the dialplan_uuid
				if ($provider == 'skyetel') { $dialplan_uuid = '777bf012-9746-4ccb-a7cc-95c1714f15fe'; }
				if ($provider == 'voicetel') { $dialplan_uuid = '513e3710-1cbd-48da-b8f1-792eae471d3a'; }

			//delete child data
				$sql = "delete from v_dialplan_details ";
				$sql .= "where dialplan_uuid = '".$dialplan_uuid."'; ";
				$this->db->query($sql);
				unset($sql);

			//delete parent data
				$sql = "delete from v_dialplans ";
				$sql .= "where dialplan_uuid = '".$dialplan_uuid."'; ";
				$this->db->query($sql);
				unset($sql);

			//get the nodes array
				$nodes = $this->nodes($provider);

			//delete each node
				foreach ($nodes as $row) {
					$sql = "delete from v_access_control_nodes ";
					$sql .= "where access_control_node_uuid = '".$row['uuid']."'; ";
					$this->db->query($sql);
					unset($sql);
				}

			//get the gateways array
				$gateways = $this->gateways($provider);

			//get the existing nodes
				$sql = "select * from v_sip_profiles ";
				$sql .= "where sip_profile_enabled = 'true' ";
				$sql .= "order by sip_profile_name asc ";
				$sql .= "limit 1; ";
				if ($this->debug) {
					echo $sql."
\n"; } $prep_statement = $this->db->prepare(check_sql($sql)); if ($prep_statement) { $prep_statement->execute(); $result = $prep_statement->fetch(PDO::FETCH_ASSOC); $sip_profile_name = $result['sip_profile_name']; } //create the event socket connection $fp = event_socket_create($_SESSION['event_socket_ip_address'], $_SESSION['event_socket_port'], $_SESSION['event_socket_password']); //get the hostname if ($fp) { $sip_profile_hostname = event_socket_request($fp, 'api switchname'); } //delete each gateway foreach ($gateways as $row) { //stop the gateway $cmd = "sofia profile ".$sip_profile_name." killgw ".$row['uuid']; if ($fp) { event_socket_request($fp, "api ".$cmd); } //delete the gateway $sql = "delete from v_gateways "; $sql .= "where gateway_uuid = '".$row['uuid']."'; "; $this->db->query($sql); unset($sql); } //clear the cache $cache = new cache; $cache->delete("configuration:acl.conf"); $cache->delete("configuration:sofia.conf:".$sip_profile_hostname); //reload acl and rescan the sip profile if ($fp) { event_socket_request($fp, "api reloadacl"); } if ($fp) { event_socket_request($fp, "api sofia profile ".$sip_profile_name." rescan"); } } } //end scripts class } /* //example use $provider = new providers; $reports->domain_uuid = $_SESSION['domain_uuid']; $provider->setup(); */ ?>