Extension Copy more complete and includes voicemail.

This commit is contained in:
Nate Jones 2014-05-01 02:48:25 +00:00
parent e1ca4951d3
commit 5237fc7d00
3 changed files with 117 additions and 26 deletions

View File

@ -582,10 +582,15 @@
$text['message-copy']['pt-pt'] = "Cópia Efectuada";
$text['message-copy']['fr-fr'] = "Copié";
$text['message_extension']['en-us'] = "Enter the new Extension.";
$text['message_extension']['es-cl'] = "Ingrese la nueva Extensión.";
$text['message_extension']['pt-pt'] = "Introuza a nova Extensão.";
$text['message_extension']['fr-fr'] = "Insérer la nouvelle Extension.";
$text['message-extension']['en-us'] = "Enter the new Extension...";
$text['message-extension']['es-cl'] = "Ingrese la nueva Extensión...";
$text['message-extension']['pt-pt'] = "Introuza a nova Extensão...";
$text['message-extension']['fr-fr'] = "Insérer la nouvelle Extension...";
$text['message-number_alias']['en-us'] = "Enter the new Number Alias...";
$text['message-number_alias']['es-cl'] = "Ingrese la nueva Alias de Número...";
$text['message-number_alias']['pt-pt'] = "Introuza a nova Alias númérico...";
$text['message-number_alias']['fr-fr'] = "Insérer la nouvelle Alias...";
$text['message-required']['en-us'] = "Please provide: ";
$text['message-required']['es-cl'] = "Por favor ingrese: ";

View File

@ -45,6 +45,9 @@ else {
if (isset($_REQUEST["id"]) && isset($_REQUEST["ext"])) {
$extension_uuid = check_str($_REQUEST["id"]);
$extension_new = check_str($_REQUEST["ext"]);
if (!is_numeric($extension_new)) {
$number_alias_new = check_str($_REQUEST["alias"]);
}
}
//get the v_extensions data
@ -55,28 +58,33 @@ else {
$prep_statement->execute();
$result = $prep_statement->fetchAll(PDO::FETCH_NAMED);
foreach ($result as &$row) {
$domain_uuid = $row["domain_uuid"];
$extension = $row["extension"];
$password = $row["password"];
//$vm_password = $row["vm_password"];
//$vm_password = str_replace("#", "", $vm_password); //preserves leading zeros
$number_alias = $row["number_alias"];
$accountcode = $row["accountcode"];
$effective_caller_id_name = $row["effective_caller_id_name"];
$effective_caller_id_number = $row["effective_caller_id_number"];
$outbound_caller_id_name = $row["outbound_caller_id_name"];
$outbound_caller_id_number = $row["outbound_caller_id_number"];
//$vm_enabled = $row["vm_enabled"];
//$vm_mailto = $row["vm_mailto"];
//$vm_attach_file = $row["vm_attach_file"];
//$vm_keep_local_after_email = $row["vm_keep_local_after_email"];
$emergency_caller_id_number = $row["emergency_caller_id_number"];
$directory_visible = $row["directory_visible"];
$directory_exten_visible = $row["directory_exten_visible"];
$limit_max = $row["limit_max"];
$limit_destination = $row["limit_destination"];
$user_context = $row["user_context"];
$toll_allow = $row["toll_allow"];
$call_timeout = $row["call_timeout"];
$call_group = $row["call_group"];
$hold_music = $row["hold_music"];
$auth_acl = $row["auth_acl"];
$cidr = $row["cidr"];
$sip_force_contact = $row["sip_force_contact"];
$nibble_account = $row["nibble_account"];
$sip_force_expires = $row["sip_force_expires"];
$mwi_account = $row["mwi_account"];
$sip_bypass_media = $row["sip_bypass_media"];
$dial_string = $row["dial_string"];
$enabled = $row["enabled"];
$description = 'copy: '.$row["description"];
$description = $text['button-copy'].': '.$row["description"];
}
unset ($prep_statement);
@ -88,23 +96,31 @@ else {
$sql .= "domain_uuid, ";
$sql .= "extension_uuid, ";
$sql .= "extension, ";
$sql .= "number_alias, ";
$sql .= "password, ";
//$sql .= "vm_password, ";
$sql .= "accountcode, ";
$sql .= "effective_caller_id_name, ";
$sql .= "effective_caller_id_number, ";
$sql .= "outbound_caller_id_name, ";
$sql .= "outbound_caller_id_number, ";
//$sql .= "vm_enabled, ";
//$sql .= "vm_mailto, ";
//$sql .= "vm_attach_file, ";
//$sql .= "vm_keep_local_after_email, ";
$sql .= "emergency_caller_id_number, ";
$sql .= "directory_visible, ";
$sql .= "directory_exten_visible, ";
$sql .= "limit_max, ";
$sql .= "limit_destination, ";
$sql .= "user_context, ";
$sql .= "toll_allow, ";
$sql .= "call_timeout, ";
$sql .= "call_group, ";
$sql .= "hold_music, ";
$sql .= "auth_acl, ";
$sql .= "cidr, ";
$sql .= "sip_force_contact, ";
$sql .= "nibble_account, ";
$sql .= "sip_force_expires, ";
$sql .= "mwi_account, ";
$sql .= "sip_bypass_media, ";
$sql .= "dial_string, ";
$sql .= "enabled, ";
$sql .= "description ";
$sql .= ")";
@ -113,29 +129,83 @@ else {
$sql .= "'$domain_uuid', ";
$sql .= "'$extension_uuid', ";
$sql .= "'$extension_new', ";
$sql .= "'$number_alias_new', ";
$sql .= "'$password', ";
//$sql .= "'".generate_password(4, 1)."', ";
$sql .= "'', ";
$sql .= "'$accountcode', ";
$sql .= "'$effective_caller_id_name', ";
$sql .= "'$effective_caller_id_number', ";
$sql .= "'$outbound_caller_id_name', ";
$sql .= "'$outbound_caller_id_number', ";
//$sql .= "'$vm_enabled', ";
//$sql .= "'$vm_mailto', ";
//$sql .= "'$vm_attach_file', ";
//$sql .= "'$vm_keep_local_after_email', ";
$sql .= "'$emergency_caller_id_number', ";
$sql .= "'$directory_visible', ";
$sql .= "'$directory_exten_visible', ";
$sql .= "'$limit_max', ";
$sql .= "'$limit_destination', ";
$sql .= "'$user_context', ";
$sql .= "'$toll_allow', ";
$sql .= "'$call_timeout', ";
$sql .= "'$call_group', ";
$sql .= "'$hold_music', ";
$sql .= "'$auth_acl', ";
$sql .= "'$cidr', ";
$sql .= "'$sip_force_contact', ";
$sql .= "'$nibble_account', ";
$sql .= "'$sip_force_expires', ";
$sql .= "'$mwi_account', ";
$sql .= "'$sip_bypass_media', ";
$sql .= "'$dial_string', ";
$sql .= "'$enabled', ";
$sql .= "'$description' ";
$sql .= ")";
$db->exec(check_sql($sql));
unset($sql);
//get the source extension voicemail data
if (is_dir($_SERVER["DOCUMENT_ROOT"].PROJECT_PATH.'/app/voicemails')) {
//get the voicemails
$sql = "select * from v_voicemails ";
$sql .= "where domain_uuid = '$domain_uuid' ";
if (is_numeric($extension)) {
$sql .= "and voicemail_id = '$extension' ";
}
else {
$sql .= "and voicemail_id = '$number_alias' ";
}
$prep_statement = $db->prepare(check_sql($sql));
$prep_statement->execute();
$result = $prep_statement->fetchAll(PDO::FETCH_NAMED);
foreach ($result as &$row) {
$vm_mailto = $row["voicemail_mail_to"];
$vm_attach_file = $row["voicemail_attach_file"];
$vm_keep_local_after_email = $row["voicemail_local_after_email"];
$vm_enabled = $row["voicemail_enabled"];
}
unset ($prep_statement);
//set the new voicemail password
if (strlen($vm_password) == 0) {
$vm_password = generate_password(9, 1);
}
//add voicemail via class
require_once "app/extensions/resources/classes/extension.php";
$ext = new extension;
$ext->db = $db;
$ext->domain_uuid = $domain_uuid;
$ext->extension = $extension_new;
$ext->number_alias = $number_alias_new;
$ext->vm_password = $vm_password;
$ext->vm_mailto = $vm_mailto;
$ext->vm_attach_file = $vm_attach_file;
$ext->vm_keep_local_after_email = $vm_keep_local_after_email;
$ext->vm_enabled = $vm_enabled;
$ext->description = $description;
$ext->voicemail();
unset($ext);
}
//synchronize configuration
if (is_writable($_SESSION['switch']['extensions']['dir'])) {
require_once "app/extensions/resources/classes/extension.php";
@ -144,7 +214,6 @@ else {
unset($ext);
}
$_SESSION["message"] = $text['message-copy'];
header("Location: extensions.php");
return;

View File

@ -775,6 +775,23 @@ if (count($_POST) > 0 && strlen($_POST["persistformvar"]) == 0) {
echo " aodiv = document.getElementById('show_advanced');\n";
echo " aodiv.style.display = \"none\";\n";
echo "}\n";
echo "\n";
echo "function copy_extension() {\n";
echo " var new_ext = prompt('".$text['message-extension']."');\n";
echo " if (new_ext != null) {\n";
echo " if (!isNaN(new_ext)) {\n";
echo " document.location.href='extension_copy.php?id=".$extension_uuid."&ext=' + new_ext;\n";
echo " }\n";
echo " else {\n";
echo " var new_number_alias = prompt('".$text['message-number_alias']."');\n";
echo " if (new_number_alias != null) {\n";
echo " if (!isNaN(new_number_alias)) {\n";
echo " document.location.href='extension_copy.php?id=".$extension_uuid."&ext=' + new_ext + '&alias=' + new_number_alias;\n";
echo " }\n";
echo " }\n";
echo " }\n";
echo " }\n";
echo "}\n";
echo "</script>";
echo "<div align='center'>";
@ -796,7 +813,7 @@ if (count($_POST) > 0 && strlen($_POST["persistformvar"]) == 0) {
echo "<td width='70%' align='right' valign='top'>\n";
echo " <input type='button' class='btn' name='' alt='".$text['button-back']."' onclick=\"window.location='extensions.php'\" value='".$text['button-back']."'>\n";
if ($action != "add") {
echo " <input type='button' class='btn' name='' alt='".$text['button-copy']."' onclick=\"var new_ext = prompt('".$text['message_extension']."'); if (new_ext != null) { window.location='extension_copy.php?id=".$extension_uuid."&ext=' + new_ext; }\" value='".$text['button-copy']."'>\n";
echo " <input type='button' class='btn' name='' alt='".$text['button-copy']."' onclick=\"copy_extension();\" value='".$text['button-copy']."'>\n";
}
echo " <input type='submit' class='btn' name='submit' value='".$text['button-save']."'>\n";
echo " <br /><br />\n";