Portions created by the Initial Developer are Copyright (C) 2008-2016 the Initial Developer. All Rights Reserved. Contributor(s): Mark J Crane */ //if the number of rows is 0 then read the sip profile xml into the database if ($domains_processed == 1) { //add the sip profiles to the database $sql = "select count(*) as num_rows from v_sip_profiles "; $prep_statement = $db->prepare(check_sql($sql)); if ($prep_statement) { $prep_statement->execute(); $row = $prep_statement->fetch(PDO::FETCH_ASSOC); if ($row['num_rows'] == 0) { if (file_exists('/usr/share/examples/fusionpbx/resources/templates/conf/sip_profiles')) { $sip_profile_dir = '/usr/share/examples/fusionpbx/resources/templates/conf/sip_profiles/*.xml.noload'; } elseif (file_exists('/usr/local/share/fusionpbx/resources/templates/conf/sip_profiles')) { $sip_profile_dir = '/usr/local/share/fusionpbx/resources/templates/conf/sip_profiles/*.xml.noload'; } else { $sip_profile_dir = $_SERVER["DOCUMENT_ROOT"].PROJECT_PATH.'/resources/templates/conf/sip_profiles/*.xml.noload'; } $db->beginTransaction(); $xml_files = glob($sip_profile_dir); foreach ($xml_files as &$xml_file) { //load the sip profile xml and save it into an array $sip_profile_xml = file_get_contents($xml_file); $xml = simplexml_load_string($sip_profile_xml); $json = json_encode($xml); $sip_profile = json_decode($json, true); $sip_profile_name = $sip_profile['@attributes']['name']; $sip_profile_enabled = $sip_profile['@attributes']['enabled']; //echo "sip profile name: ".$sip_profile_name."\n"; if ($sip_profile_name != "{v_sip_profile_name}") { //prepare the description switch ($sip_profile_name) { case "internal": $sip_profile_description = "The Internal profile by default requires registration which is used by the endpoints. "; $sip_profile_description .= "By default the Internal profile binds to port 5060. "; break; case "internal-ipv6": $sip_profile_description = "The Internal IPV6 profile binds to the IP version 6 address and is similar to the Internal profile.\n"; break; case "external": $sip_profile_description = "The External profile external provides anonymous calling in the public context. "; $sip_profile_description .= "By default the External profile binds to port 5080. "; $sip_profile_description .= "Calls can be sent using a SIP URL \"voip.domain.com:5080\" "; break; case "external-ipv6": $sip_profile_description = "The External IPV6 profile binds to the IP version 6 address and is similar to the External profile.\n"; break; case "lan": $sip_profile_description = "The LAN profile is the same as the Internal profile except that it is bound to the LAN IP.\n"; break; default: $sip_profile_description = ''; } //add the sip profile if it is not false if ($sip_profile_enabled != "false") { //insert the sip profile name, description $sip_profile_uuid = uuid(); $sql = "insert into v_sip_profiles"; $sql .= "("; $sql .= "sip_profile_uuid, "; $sql .= "sip_profile_name, "; $sql .= "sip_profile_description "; $sql .= ") "; $sql .= "values "; $sql .= "( "; $sql .= "'".check_str($sip_profile_uuid)."', "; $sql .= "'".check_str($sip_profile_name)."', "; $sql .= "'".check_str($sip_profile_description)."' "; $sql .= ")"; //echo $sql."\n\n"; $db->exec(check_sql($sql)); unset($sql); //get the domain, alias and parse values and set as variables $sip_profile_domain_name = $sip_profile['domains']['domain']['@attributes']['name']; $sip_profile_domain_alias = $sip_profile['domains']['domain']['@attributes']['alias']; $sip_profile_domain_parse = $sip_profile['domains']['domain']['@attributes']['parse']; //add the sip profile domains name, alias and parse $sip_profile_domain_uuid = uuid(); $sql = "insert into v_sip_profile_domains"; $sql .= "("; $sql .= "sip_profile_domain_uuid, "; $sql .= "sip_profile_uuid, "; $sql .= "sip_profile_domain_name, "; $sql .= "sip_profile_domain_alias, "; $sql .= "sip_profile_domain_parse "; $sql .= ") "; $sql .= "values "; $sql .= "( "; $sql .= "'".$sip_profile_domain_uuid."', "; $sql .= "'".$sip_profile_uuid."', "; $sql .= "'".check_str($sip_profile_domain_name)."', "; $sql .= "'".check_str($sip_profile_domain_alias)."', "; $sql .= "'".check_str($sip_profile_domain_parse)."' "; $sql .= ")"; $db->exec(check_sql($sql)); unset($sql); //add the sip profile settings foreach ($sip_profile['settings']['param'] as $row) { //get the name and value pair $sip_profile_setting_name = $row['@attributes']['name']; $sip_profile_setting_value = $row['@attributes']['value']; $sip_profile_setting_enabled = $row['@attributes']['enabled']; if ($sip_profile_setting_enabled != "false") { $sip_profile_setting_enabled = "true"; } //echo "name: $name value: $value\n"; //add the profile settings into the database $sip_profile_setting_uuid = uuid(); $sql = "insert into v_sip_profile_settings "; $sql .= "("; $sql .= "sip_profile_setting_uuid, "; $sql .= "sip_profile_uuid, "; $sql .= "sip_profile_setting_name, "; $sql .= "sip_profile_setting_value, "; $sql .= "sip_profile_setting_enabled "; $sql .= ") "; $sql .= "values "; $sql .= "( "; $sql .= "'".check_str($sip_profile_setting_uuid)."', "; $sql .= "'".check_str($sip_profile_uuid)."', "; $sql .= "'".check_str($sip_profile_setting_name)."', "; $sql .= "'".check_str($sip_profile_setting_value)."', "; $sql .= "'".$sip_profile_setting_enabled."' "; $sql .= ")"; //echo $sql."\n\n"; $db->exec(check_sql($sql)); } } } } $db->commit(); //save the sip profile xml save_sip_profile_xml(); //apply settings reminder $_SESSION["reload_xml"] = true; } unset($prep_statement); } //upgrade - add missing sip profiles domain settings $sql = "select count(*) as num_rows from v_sip_profile_domains "; $prep_statement = $db->prepare(check_sql($sql)); if ($prep_statement) { $prep_statement->execute(); $row = $prep_statement->fetch(PDO::FETCH_ASSOC); if ($row['num_rows'] == 0) { if (file_exists('/usr/share/examples/fusionpbx/resources/templates/conf/sip_profiles')) { $sip_profile_dir = '/usr/share/examples/fusionpbx/resources/templates/conf/sip_profiles/*.xml.noload'; } elseif (file_exists('/usr/local/share/fusionpbx/resources/templates/conf/sip_profiles')) { $sip_profile_dir = '/usr/local/share/fusionpbx/resources/templates/conf/sip_profiles/*.xml.noload'; } else { $sip_profile_dir = $_SERVER["DOCUMENT_ROOT"].PROJECT_PATH.'/resources/templates/conf/sip_profiles/*.xml.noload'; } $db->beginTransaction(); $xml_files = glob($sip_profile_dir); foreach ($xml_files as &$xml_file) { //load the sip profile xml and save it into an array $sip_profile_xml = file_get_contents($xml_file); $xml = simplexml_load_string($sip_profile_xml); $json = json_encode($xml); $sip_profile = json_decode($json, true); $sip_profile_name = $sip_profile['@attributes']['name']; $sip_profile_enabled = $sip_profile['@attributes']['enabled']; //echo "sip profile name: ".$sip_profile_name."\n"; //get the domain, alias and parse values and set as variables $sip_profile_domain_name = $sip_profile['domains']['domain']['@attributes']['name']; $sip_profile_domain_alias = $sip_profile['domains']['domain']['@attributes']['alias']; $sip_profile_domain_parse = $sip_profile['domains']['domain']['@attributes']['parse']; //get the sip_profile_uuid using the sip profile name $sql = "select sip_profile_uuid from v_sip_profiles "; $sql .= "where sip_profile_name = '$sip_profile_name' "; $prep_statement = $db->prepare(check_sql($sql)); $prep_statement->execute(); $result = $prep_statement->fetchAll(PDO::FETCH_NAMED); $sip_profile_uuid = $result[0]["sip_profile_uuid"]; unset ($prep_statement); //add the sip profile domains name, alias and parse if ($sip_profile_uuid) { $sip_profile_domain_uuid = uuid(); $sql = "insert into v_sip_profile_domains"; $sql .= "("; $sql .= "sip_profile_domain_uuid, "; $sql .= "sip_profile_uuid, "; $sql .= "sip_profile_domain_name, "; $sql .= "sip_profile_domain_alias, "; $sql .= "sip_profile_domain_parse "; $sql .= ") "; $sql .= "values "; $sql .= "( "; $sql .= "'".$sip_profile_domain_uuid."', "; $sql .= "'".$sip_profile_uuid."', "; $sql .= "'".check_str($sip_profile_domain_name)."', "; $sql .= "'".check_str($sip_profile_domain_alias)."', "; $sql .= "'".check_str($sip_profile_domain_parse)."' "; $sql .= ")"; $db->exec(check_sql($sql)); unset($sql); } //unset the sip_profile_uuid unset($sip_profile_uuid); } $db->commit(); //save the sip profile xml save_sip_profile_xml(); //apply settings reminder $_SESSION["reload_xml"] = true; } unset($prep_statement); } } //if empty, set sip_profile_enabled = true if ($domains_processed == 1) { $sql = "update v_sip_profiles set "; $sql .= "sip_profile_enabled = 'true' "; $sql .= "where sip_profile_enabled is null "; $sql .= "or sip_profile_enabled = '' "; $db->exec(check_sql($sql)); unset($sql); } ?>