mirror of
https://github.com/fusionpbx/fusionpbx.git
synced 2025-12-30 00:53:50 +00:00
* Change the data type to boolean
* Use boolean values in SQL and Conditional Statements
* Schema Data Types: Drop views so that alter tables statements complete
* Update settings.php
* Add extension for call_screen_enabled
* Gateway handle boolean
Add the boolean toggle
- distinct_to
- caller_id_in_from
- supress_cng
- extension_in_contact
- contact_in_ping
* Update gateways.php
* Update voicemail_edit.php
* Replace the ${caller_id_name} with the extensions caller id name
* Phrase - Edit: Update slide toggle with new select beneath.
* Update the input toggle style
* Set the input_toggle_style_switch as boolean
* Update the input toggle style
* Theme: Adjust CSS to wrap description text on form fields.
* Add domain_uuid and domain_name to the SQL SELECT
* Unset the parameters to fix the next query
* Gateway: Integrate new slide toggle switch.
* Dashboard: Update the input toggle style (#7499)
* Dashboard: Update the input toggle style
* Update dashboard_widget_edit.php
* Update dashboard_edit.php
* Inbound Route - Add: Integrate new slide toggle switch and boolean.
* User Settings: Integrate new slide toggle switch.
* Call Block Edit: Update the input toggle style (#7500)
* Bridge Edit: Update the input toggle style (#7501)
* Update phrases.php
* Update domain_edit.php
* Domain Settings Edit: Update the input toggle style
* User Edit: Update the input toggle style
* Update install.php
* Remove fields marked as deprecated
* Use boolean in the select statement
* Streams: New slide toggle and boolean.
* Streams: Remove unnecessary default.
* Queues (FIFO): New slide toggle.
* Call Detail Records: Update the input toggle style (#7503)
* Call Detail Records: Update the input toggle style
* Update xml_cdr_extension_summary.php
* Update xml_cdr_extension_summary.php
* Update xml_cdr_extension_summary.php
* Call Centers: Update the input toggle style (#7502)
* Call Centers: Update the input toggle style
* Update call_center_agent_edit.php
* Conference Centers: Update the input toggle style (#7506)
* Conference Centers: Update the input toggle style
* Update app_config.php
* Update conference_center_edit.php
* Use boolean data type (#7505)
* Call Flow Edit: Update the input toggle style (#7504)
* Devices: Update the input toggle style
* IVR Menus: New slide toggle.
* IVR Menu: Remove deprected file.
* SIP Profile - Edit: New slide toggle.
* Device Profiles: Update the input toggle style
* Ring Groups - List: Fix syntax.
* Theme: Fire onchange event when switching slide toggle control.
* Device Vendors: Update the input toggle style
* Update enabled boolean
* Update device_edit.php
* Ring Groups: New slide toggle.
* Update domain_edit.php
* Email Templates: Update the input toggle style
* Header: Correct default value on input toggle style.
* Default/Domain/User Settings: Adjust Select option label for better clarity.
* Use true boolean types for switch theme toggle or drop-down box (#7507)
* Groups: Update the input toggle style
* Conference Controls: Update the input toggle style (#7509)
* Conference Controls: Update the input toggle style
* Update conference_control_edit.php
* Update conference_control_details.php
* Update conference_control_detail_edit.php
* Conferences: Update the input toggle style (#7511)
* Use true boolean types for switch theme toggle or drop-down box (#7513)
* Dialplans: Update the input toggle style
Also updated outbound route add
* Ring Group: Only adjust ring group forward destination top margin when slide toggle enabled.
* Default/Domain/User Settings - List: Adjust for new 'Select Box' label on input_toggle_style value.
* Use true boolean types for switch theme toggle or drop-down box (#7514)
* Call Forward / Follow Me: Minor javascript adjustments to mirror previous behavior.
* Ring Groups [Dashboard]: New slide toggle.
* Get the contacts details with a seperate SQL Query
* Remove debug info
* Destinations: Update the input toggle style
* Conference Profiles: Update the input toggle style (#7515)
* Conference Profiles: Update the input toggle style
* Update conference_profiles.php
* Update conference_profile_params.php
* Update conference_profile_param_edit.php
* Update conference_profile_edit.php
* Extensions: Update the input toggle style
* Contacts: Update the input toggle style (#7517)
* Contacts: Update the input toggle style
* Update contact_address_edit.php
* Update contact_attachment_edit.php
* Update contact_edit.php
* Update contact_email_edit.php
* Update contact_phone_edit.php
* Update contact_relation_edit.php
* Update contact_setting_edit.php
* Update contact_url_edit.php
* Update contacts.php
* Voicemails: New slide toggle.
* Voicemail Greeting: New slide toggle.
* Modules: New slide toggle.
* Recordings: New slide toggle
* Variables: New slide toggle.
* Time Conditions: New slide toggle.
* Extensions - List: Remove invalid column name.
* Extension Settings: New slide toggle.
* Number Translations: New slide toggle and boolean.
* Sofia global settings: Update the input toggle style
* Update alter table convert to boolean
* Fix contact relation search (#7518)
* Sip Profile Edit: Fix setting enabled labels (#7519)
* Sip Profile Edit: Fix setting enabled labels
* Update sip_profile_edit.php
* Update dialplan_edit.php (#7520)
* Update SQL queries to use true/false for contact primary settings (#7521)
* Update SQL queries to use true/false for contact primary settings
* Update contacts_vcard.php
* Update email.php
* Update totp.php
* Update contact_url_edit.php
* Update contact_email_edit.php
* Update contact_address_edit.php
* Update contact_attachment_edit.php
* Update contact_phone_edit.php
* Add a database views method
* Add database view groups
* Add database users view
* Add database call_recordings view
* Update users.php
* Add database view call block
* Update schema to use the database views method
* Update conference.conf.lua boolean
* Update directory.lua boolean
* Update callcenter.conf.lua agent_status boolean
* Update sofia.conf.lua boolean
* Update number translations lua boolean
* Update directory.lua boolean
* Update group_call.lua fix the cache
* Update reverse-auth-lookup.lua boolean
* Update directory.lua boolean
* Use concat instead of ||
* Update index.lua
---------
Co-authored-by: fusionate <nate@fusionpbx.com>
Co-authored-by: Alex <alex@fusionpbx.com>
Co-authored-by: frytimo <tim@fusionpbx.com>
592 lines
23 KiB
PHP
592 lines
23 KiB
PHP
<?php
|
|
/*
|
|
FusionPBX
|
|
Version: MPL 1.1
|
|
|
|
The contents of this file are subject to the Mozilla Public License Version
|
|
1.1 (the "License"); you may not use this file except in compliance with
|
|
the License. You may obtain a copy of the License at
|
|
http://www.mozilla.org/MPL/
|
|
|
|
Software distributed under the License is distributed on an "AS IS" basis,
|
|
WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
|
for the specific language governing rights and limitations under the
|
|
License.
|
|
|
|
The Original Code is FusionPBX
|
|
|
|
The Initial Developer of the Original Code is
|
|
Mark J Crane <markjcrane@fusionpbx.com>
|
|
Portions created by the Initial Developer are Copyright (C) 2008-2024
|
|
the Initial Developer. All Rights Reserved.
|
|
|
|
Contributor(s):
|
|
Mark J Crane <markjcrane@fusionpbx.com>
|
|
Luis Daniel Lucio Quiroz <dlucio@okay.com.mx>
|
|
*/
|
|
|
|
//includes files
|
|
require_once dirname(__DIR__, 2) . "/resources/require.php";
|
|
require_once "resources/check_auth.php";
|
|
|
|
//check permissions
|
|
if (permission_exists('call_broadcast_edit')) {
|
|
//access granted
|
|
}
|
|
else {
|
|
echo "access denied";
|
|
exit;
|
|
}
|
|
|
|
//add multi-lingual support
|
|
$language = new text;
|
|
$text = $language->get();
|
|
|
|
//set the action with add or update
|
|
if (!empty($_REQUEST["id"]) && is_uuid($_REQUEST["id"])) {
|
|
$action = "update";
|
|
$call_broadcast_uuid = $_REQUEST["id"];
|
|
}
|
|
else {
|
|
$action = "add";
|
|
}
|
|
|
|
//set the defaults
|
|
$broadcast_name = '';
|
|
$broadcast_start_time = '';
|
|
$broadcast_timeout = '';
|
|
$broadcast_concurrent_limit = '';
|
|
$broadcast_caller_id_name = '';
|
|
$broadcast_caller_id_number = '';
|
|
$broadcast_accountcode = '';
|
|
$broadcast_destination_data = '';
|
|
$broadcast_description = '';
|
|
$broadcast_toll_allow = '';
|
|
|
|
//function to Upload CSV/TXT file
|
|
function upload_file($sql, $broadcast_phone_numbers) {
|
|
$upload_csv = $sql = '';
|
|
if (isset($_FILES['broadcast_phone_numbers_file']) && !empty($_FILES['broadcast_phone_numbers_file']) && $_FILES['broadcast_phone_numbers_file']['size'] > 0) {
|
|
$filename=$_FILES["broadcast_phone_numbers_file"]["tmp_name"];
|
|
$file_extension = array('application/octet-stream','application/vnd.ms-excel','text/plain','text/csv','text/tsv');
|
|
if (in_array($_FILES['broadcast_phone_numbers_file']['type'],$file_extension)) {
|
|
$file = fopen($filename, "r");
|
|
$count = 0;
|
|
while (($getData = fgetcsv($file, 0, "\n")) !== FALSE)
|
|
{
|
|
$count++;
|
|
if ($count == 1) { continue; }
|
|
$getData = preg_split('/[ ,|]/', $getData[0], null, PREG_SPLIT_NO_EMPTY);
|
|
$separator = $getData[0];
|
|
$separator .= (isset($getData[1]) && $getData[1] != '')? '|'.$getData[1] : '';
|
|
$separator .= (isset($getData[2]) && $getData[2] != '')? ','.$getData[2] : '';
|
|
$separator .= PHP_EOL;
|
|
$upload_csv .= $separator;
|
|
}
|
|
fclose($file);
|
|
}
|
|
else {
|
|
return array('code'=>false,'sql'=>'');
|
|
}
|
|
}
|
|
if (!empty($broadcast_phone_numbers) && !empty($upload_csv)) {
|
|
$sql .= $broadcast_phone_numbers.'\n'.$upload_csv;
|
|
}
|
|
elseif (empty($broadcast_phone_numbers) && !empty($upload_csv)) {
|
|
$sql .= $upload_csv;
|
|
}
|
|
else {
|
|
$sql .= $broadcast_phone_numbers;
|
|
}
|
|
return array('code'=>true,'sql'=> $sql);
|
|
}
|
|
|
|
//get the http post variables and set them to php variables
|
|
if (!empty($_POST)) {
|
|
$broadcast_name = $_POST["broadcast_name"];
|
|
$broadcast_start_time = $_POST["broadcast_start_time"];
|
|
$broadcast_timeout = $_POST["broadcast_timeout"];
|
|
$broadcast_concurrent_limit = $_POST["broadcast_concurrent_limit"];
|
|
$broadcast_caller_id_name = $_POST["broadcast_caller_id_name"];
|
|
$broadcast_caller_id_number = $_POST["broadcast_caller_id_number"];
|
|
//$broadcast_destination_type = $_POST["broadcast_destination_type"];
|
|
$broadcast_phone_numbers = $_POST["broadcast_phone_numbers"];
|
|
$broadcast_avmd = $_POST["broadcast_avmd"];
|
|
$broadcast_destination_data = $_POST["broadcast_destination_data"];
|
|
$broadcast_description = $_POST["broadcast_description"];
|
|
$broadcast_toll_allow = $_POST["broadcast_toll_allow"];
|
|
|
|
if (if_group("superadmin")) {
|
|
$broadcast_accountcode = $_POST["broadcast_accountcode"];
|
|
}
|
|
else if (if_group("admin") && file_exists($_SERVER["PROJECT_ROOT"]."/app/billing/app_config.php")){
|
|
$sql = "select count(*) ";
|
|
$sql .= "from v_billings ";
|
|
$sql .= "where domain_uuid = :domain_uuid ";
|
|
$sql .= "and type_value = :type_value ";
|
|
$parameters['domain_uuid'] = $_SESSION['domain_uuid'];
|
|
$parameters['type_value'] = $_POST['accountcode'];
|
|
$database = new database;
|
|
$num_rows = $database->select($sql, $parameters, 'column');
|
|
$broadcast_accountcode = $num_rows > 0 ? $_POST["broadcast_accountcode"] : $_SESSION['domain_name'];
|
|
unset($sql, $parameters, $num_rows);
|
|
}
|
|
else{
|
|
$broadcast_accountcode = $_SESSION['domain_name'];
|
|
}
|
|
}
|
|
|
|
if (!empty($_POST) && empty($_POST["persistformvar"])) {
|
|
|
|
//delete the call broadcast
|
|
if (permission_exists('call_broadcast_delete')) {
|
|
if (!empty($_POST['action']) && $_POST['action'] == 'delete' && is_uuid($call_broadcast_uuid)) {
|
|
//prepare
|
|
$call_broadcasts[0]['checked'] = 'true';
|
|
$call_broadcasts[0]['uuid'] = $call_broadcast_uuid;
|
|
//delete
|
|
$obj = new call_broadcast;
|
|
$obj->delete($call_broadcasts);
|
|
//redirect
|
|
header('Location: call_broadcast.php');
|
|
exit;
|
|
}
|
|
}
|
|
|
|
$msg = '';
|
|
if ($action == "update") {
|
|
$call_broadcast_uuid = $_POST["call_broadcast_uuid"];
|
|
}
|
|
|
|
//validate the token
|
|
$token = new token;
|
|
if (!$token->validate($_SERVER['PHP_SELF'])) {
|
|
message::add($text['message-invalid_token'],'negative');
|
|
header('Location: call_broadcast.php');
|
|
exit;
|
|
}
|
|
|
|
//check for all required data
|
|
if (empty($broadcast_name)) { $msg .= "".$text['confirm-name']."<br>\n"; }
|
|
//if (empty($broadcast_description)) { $msg .= "Please provide: Description<br>\n"; }
|
|
//if (empty($broadcast_timeout)) { $msg .= "Please provide: Timeout<br>\n"; }
|
|
//if (empty($broadcast_concurrent_limit)) { $msg .= "Please provide: Concurrent Limit<br>\n"; }
|
|
//if (empty($recording_uuid)) { $msg .= "Please provide: Recording<br>\n"; }
|
|
//if (empty($broadcast_caller_id_name)) { $msg .= "Please provide: Caller ID Name<br>\n"; }
|
|
//if (empty($broadcast_caller_id_number)) { $msg .= "Please provide: Caller ID Number<br>\n"; }
|
|
//if (empty($broadcast_destination_type)) { $msg .= "Please provide: Type<br>\n"; }
|
|
//if (empty($broadcast_phone_numbers)) { $msg .= "Please provide: Phone Number List<br>\n"; }
|
|
//if (empty($broadcast_avmd)) { $msg .= "Please provide: Voicemail Detection<br>\n"; }
|
|
//if (empty($broadcast_destination_data)) { $msg .= "Please provide: Destination<br>\n"; }
|
|
if (!empty($msg) && empty($_POST["persistformvar"])) {
|
|
require_once "resources/header.php";
|
|
require_once "resources/persist_form_var.php";
|
|
echo "<div align='center'>\n";
|
|
echo "<table><tr><td>\n";
|
|
echo $msg."<br />";
|
|
echo "</td></tr></table>\n";
|
|
persistformvar($_POST);
|
|
echo "</div>\n";
|
|
require_once "resources/footer.php";
|
|
return;
|
|
}
|
|
|
|
//add or update the database
|
|
if (empty($_POST["persistformvar"])) {
|
|
|
|
//prep insert
|
|
if ($action == "add" && permission_exists('call_broadcast_add')) {
|
|
//begin insert array
|
|
$call_broadcast_uuid = uuid();
|
|
$array['call_broadcasts'][0]['call_broadcast_uuid'] = $call_broadcast_uuid;
|
|
|
|
//set message
|
|
message::add($text['confirm-add']);
|
|
|
|
//set return url on error
|
|
$error_return_url = "call_broadcast_edit.php";
|
|
}
|
|
|
|
//prep update
|
|
if ($action == "update" && permission_exists('call_broadcast_edit')) {
|
|
//begin update array
|
|
$array['call_broadcasts'][0]['call_broadcast_uuid'] = $call_broadcast_uuid;
|
|
|
|
//set message
|
|
message::add($text['confirm-update']);
|
|
|
|
//set return url on error
|
|
$error_return_url = "call_broadcast_edit.php?id=".urlencode($_GET['id']);
|
|
}
|
|
|
|
//execute
|
|
if (!empty($array)) {
|
|
|
|
//add file selection and download sample
|
|
$file_res = upload_file($sql ?? '', $broadcast_phone_numbers);
|
|
if ($file_res['code'] != true) {
|
|
$_SESSION["message_mood"] = "negative";
|
|
$_SESSION["message"] = $text['file-error'];
|
|
header("Location: ".$error_return_url);
|
|
exit;
|
|
}
|
|
$broadcast_phone_numbers = $file_res['sql'];
|
|
|
|
//build the database array
|
|
$array['call_broadcasts'][0]['domain_uuid'] = $domain_uuid;
|
|
$array['call_broadcasts'][0]['broadcast_name'] = $broadcast_name;
|
|
if (permission_exists('call_broadcast_start_time')) {
|
|
$array['call_broadcasts'][0]['broadcast_start_time'] = strtotime($broadcast_start_time) - strtotime('now') >= 0 ? strtotime($broadcast_start_time) - strtotime('now') : null;
|
|
}
|
|
if (permission_exists('call_broadcast_accountcode')) {
|
|
$array['call_broadcasts'][0]['broadcast_accountcode'] = $broadcast_accountcode;
|
|
}
|
|
if (permission_exists('call_broadcast_timeout')) {
|
|
$array['call_broadcasts'][0]['broadcast_timeout'] = strlen($broadcast_timeout) != 0 ? $broadcast_timeout : null;
|
|
}
|
|
if (permission_exists('call_broadcast_concurrent_limit')) {
|
|
$array['call_broadcasts'][0]['broadcast_concurrent_limit'] = strlen($broadcast_concurrent_limit) != 0 ? $broadcast_concurrent_limit : null;
|
|
}
|
|
if (permission_exists("call_broadcast_caller_id")) {
|
|
$array['call_broadcasts'][0]['broadcast_caller_id_name'] = $broadcast_caller_id_name;
|
|
$array['call_broadcasts'][0]['broadcast_caller_id_number'] = $broadcast_caller_id_number;
|
|
}
|
|
if (permission_exists('call_broadcast_destination_number')) {
|
|
$array['call_broadcasts'][0]['broadcast_destination_data'] = $broadcast_destination_data;
|
|
}
|
|
//$array['call_broadcasts'][0]['broadcast_destination_type'] = $broadcast_destination_type;
|
|
if (permission_exists('call_broadcast_phone_numbers')) {
|
|
$array['call_broadcasts'][0]['broadcast_phone_numbers'] = $broadcast_phone_numbers;
|
|
}
|
|
if (permission_exists('call_broadcast_voicemail_detection')) { //broadcast_avmd
|
|
$array['call_broadcasts'][0]['broadcast_avmd'] = $broadcast_avmd;
|
|
}
|
|
if (permission_exists('call_broadcast_toll_allow')) {
|
|
$array['call_broadcasts'][0]['broadcast_toll_allow'] = $broadcast_toll_allow;
|
|
}
|
|
$array['call_broadcasts'][0]['broadcast_description'] = $broadcast_description;
|
|
|
|
//execute
|
|
$database = new database;
|
|
$database->app_name = 'call_broadcast';
|
|
$database->app_uuid = 'efc11f6b-ed73-9955-4d4d-3a1bed75a056';
|
|
$database->save($array);
|
|
unset($array);
|
|
|
|
//redirect
|
|
header("Location: call_broadcast.php");
|
|
exit;
|
|
|
|
}
|
|
|
|
}
|
|
}
|
|
|
|
//pre-populate the form
|
|
if (!empty($_GET) && empty($_POST["persistformvar"])) {
|
|
$call_broadcast_uuid = $_GET["id"];
|
|
$sql = "select * from v_call_broadcasts ";
|
|
$sql .= "where domain_uuid = :domain_uuid ";
|
|
$sql .= "and call_broadcast_uuid = :call_broadcast_uuid ";
|
|
$parameters['domain_uuid'] = $domain_uuid;
|
|
$parameters['call_broadcast_uuid'] = $call_broadcast_uuid;
|
|
$database = new database;
|
|
$row = $database->select($sql, $parameters, 'row');
|
|
if (!empty($row)) {
|
|
$broadcast_name = $row["broadcast_name"];
|
|
$broadcast_start_time = $row["broadcast_start_time"];
|
|
$broadcast_timeout = $row["broadcast_timeout"];
|
|
$broadcast_concurrent_limit = $row["broadcast_concurrent_limit"];
|
|
$broadcast_caller_id_name = $row["broadcast_caller_id_name"];
|
|
$broadcast_caller_id_number = $row["broadcast_caller_id_number"];
|
|
//$broadcast_destination_type = $row["broadcast_destination_type"];
|
|
$broadcast_phone_numbers = $row["broadcast_phone_numbers"];
|
|
$broadcast_avmd = $row["broadcast_avmd"];
|
|
$broadcast_destination_data = $row["broadcast_destination_data"];
|
|
$broadcast_accountcode = $row["broadcast_accountcode"];
|
|
$broadcast_description = $row["broadcast_description"];
|
|
$broadcast_toll_allow = $row["broadcast_toll_allow"];
|
|
$insert_date = $row["insert_date"];
|
|
$update_date = $row["update_date"];
|
|
|
|
//determine start date and time based on insert or update date and 'start time' delay (in seconds)
|
|
$broadcast_start_reference = $update_date ?: $insert_date;
|
|
if ($broadcast_start_time && $broadcast_start_reference) {
|
|
$broadcast_start_time = date('Y-m-d H:i', strtotime($broadcast_start_reference) + $broadcast_start_time);
|
|
}
|
|
|
|
}
|
|
unset($sql, $parameters, $row);
|
|
}
|
|
|
|
//create token
|
|
$object = new token;
|
|
$token = $object->create($_SERVER['PHP_SELF']);
|
|
|
|
//begin header
|
|
$document['title'] = $text['title-call_broadcast'];
|
|
require_once "resources/header.php";
|
|
|
|
//begin content
|
|
echo "<form name='frm' id='frm' method='post' enctype='multipart/form-data'>\n";
|
|
|
|
echo "<div class='action_bar' id='action_bar'>\n";
|
|
echo " <div class='heading'><b>".$text['title-call_broadcast']."</b></div>\n";
|
|
echo " <div class='actions'>\n";
|
|
echo button::create(['type'=>'button','label'=>$text['button-back'],'icon'=>$settings->get('theme', 'button_icon_back'),'id'=>'btn_back','link'=>'call_broadcast.php']);
|
|
if ($action == "update") {
|
|
echo button::create(['type'=>'button','label'=>$text['button-start'],'icon'=>$settings->get('theme', 'button_icon_start'),'style'=>'margin-left: 15px;','link'=>'call_broadcast_send.php?id='.urlencode($call_broadcast_uuid)]);
|
|
echo button::create(['type'=>'button','label'=>$text['button-stop'],'icon'=>$settings->get('theme', 'button_icon_stop'),'link'=>'call_broadcast_stop.php?id='.urlencode($call_broadcast_uuid)]);
|
|
if (permission_exists('call_broadcast_delete')) {
|
|
echo button::create(['type'=>'button','label'=>$text['button-delete'],'icon'=>$settings->get('theme', 'button_icon_delete'),'name'=>'btn_delete','style'=>'margin-left: 15px;','onclick'=>"modal_open('modal-delete','btn_delete');"]);
|
|
}
|
|
}
|
|
echo button::create(['type'=>'submit','label'=>$text['button-save'],'icon'=>$settings->get('theme', 'button_icon_save'),'id'=>'btn_save','style'=>'margin-left: 15px;']);
|
|
echo " </div>\n";
|
|
echo " <div style='clear: both;'></div>\n";
|
|
echo "</div>\n";
|
|
|
|
if ($action == 'update' && permission_exists('call_broadcast_delete')) {
|
|
echo modal::create(['id'=>'modal-delete','type'=>'delete','actions'=>button::create(['type'=>'submit','label'=>$text['button-continue'],'icon'=>'check','id'=>'btn_delete','style'=>'float: right; margin-left: 15px;','collapse'=>'never','name'=>'action','value'=>'delete','onclick'=>"modal_close();"])]);
|
|
}
|
|
|
|
echo "<div class='card'>\n";
|
|
echo "<table width='100%' border='0' cellpadding='0' cellspacing='0'>\n";
|
|
|
|
echo "<tr>\n";
|
|
echo "<td width='30%' class='vncellreq' valign='top' align='left' nowrap>\n";
|
|
echo " ".$text['label-name']."\n";
|
|
echo "</td>\n";
|
|
echo "<td width='70%' class='vtable' align='left'>\n";
|
|
echo " <input class='formfld' type='text' name='broadcast_name' maxlength='255' value=\"".escape($broadcast_name)."\" required='required'>\n";
|
|
echo "<br />\n";
|
|
echo "".$text['description-name']."\n";
|
|
echo "</td>\n";
|
|
echo "</tr>\n";
|
|
|
|
if (permission_exists('call_broadcast_start_time')) {
|
|
echo "<tr>\n";
|
|
echo "<td class='vncell' valign='top' align='left' nowrap>\n";
|
|
echo " ".$text['label-start_time']."\n";
|
|
echo "</td>\n";
|
|
echo "<td class='vtable' align='left' style='position: relative;'>\n";
|
|
echo " <input class='formfld datetimepicker-future' type='text' id='broadcast_start_time' name='broadcast_start_time' value=\"".escape($broadcast_start_time)."\" data-toggle='datetimepicker' data-target='#broadcast_start_time' onblur=\"$(this).datetimepicker('hide');\">\n";
|
|
echo "<br />\n";
|
|
echo "".$text['description-start_time']."\n";
|
|
echo "</td>\n";
|
|
echo "</tr>\n";
|
|
}
|
|
|
|
if (permission_exists('call_broadcast_accountcode')) {
|
|
echo "<tr>\n";
|
|
echo "<td class='vncell' valign='top' align='left' nowrap='nowrap'>\n";
|
|
echo " ".$text['label-accountcode']."\n";
|
|
echo "</td>\n";
|
|
echo "<td class='vtable' align='left'>\n";
|
|
if ($action == "add") { $accountcode=$_SESSION['domain_name']; }
|
|
echo " <input class='formfld' type='text' name='broadcast_accountcode' maxlength='255' value=\"".escape($broadcast_accountcode)."\">\n";
|
|
echo "<br />\n";
|
|
echo $text['description-accountcode']."\n";
|
|
echo "</td>\n";
|
|
echo "</tr>\n";
|
|
}
|
|
|
|
if (permission_exists('call_broadcast_timeout')) {
|
|
echo "<tr>\n";
|
|
echo "<td class='vncell' valign='top' align='left' nowrap>\n";
|
|
echo " ".$text['label-timeout']."\n";
|
|
echo "</td>\n";
|
|
echo "<td class='vtable' align='left'>\n";
|
|
echo " <input class='formfld' type='number' name='broadcast_timeout' maxlength='255' min='1' step='1' value=\"".escape($broadcast_timeout)."\">\n";
|
|
echo "<br />\n";
|
|
echo "".$text['description-timeout']."\n";
|
|
echo "</td>\n";
|
|
echo "</tr>\n";
|
|
}
|
|
|
|
if (permission_exists('call_broadcast_concurrent_limit')) {
|
|
echo "<tr>\n";
|
|
echo "<td class='vncell' valign='top' align='left' nowrap>\n";
|
|
echo " ".$text['label-concurrent-limit']."\n";
|
|
echo "</td>\n";
|
|
echo "<td class='vtable' align='left'>\n";
|
|
echo " <input class='formfld' type='number' name='broadcast_concurrent_limit' maxlength='255' min='1' step='1' value=\"".escape($broadcast_concurrent_limit)."\">\n";
|
|
echo "<br />\n";
|
|
echo "".$text['description-concurrent-limit']."\n";
|
|
echo "</td>\n";
|
|
echo "</tr>\n";
|
|
}
|
|
|
|
//echo "<tr>\n";
|
|
//echo "<td class='vncell' valign='top' align='left' nowrap>\n";
|
|
//echo " Recording\n";
|
|
//echo "</td>\n";
|
|
//echo "<td class='vtable' align='left'>\n";
|
|
//echo " <select name='recording_uuid' class='formfld'>\n";
|
|
//echo " <option></option>\n";
|
|
//$sql = "";
|
|
//$sql .= "select * from v_recordings ";
|
|
//$sql .= "where domain_uuid = :domain_uuid ";
|
|
//$parameters['domain_uuid'] = $domain_uuid;
|
|
//$database = new database;
|
|
//$rows = $database->select($sql, $parameters, 'all');
|
|
//if (!empty($rows)) {
|
|
// foreach ($rows as $row) {
|
|
// if ($recording_uuid == $row['recording_uuid']) {
|
|
// echo " <option value='".$row['recording_uuid']."' selected='yes'>".escape($row['recordingname'])."</option>\n";
|
|
// }
|
|
// else {
|
|
// echo " <option value='".$row['recording_uuid']."'>".escape($row['recordingname'])."</option>\n";
|
|
// }
|
|
// }
|
|
//}
|
|
//unset($sql, $parameters, $rows, $row);
|
|
//echo " </select>\n";
|
|
//echo "<br />\n";
|
|
//echo "Recording to play when the call is answered.<br />\n";
|
|
//echo "\n";
|
|
//echo "</td>\n";
|
|
//echo "</tr>\n";
|
|
|
|
if (permission_exists("call_broadcast_caller_id")) {
|
|
echo "<tr>\n";
|
|
echo "<td class='vncell' valign='top' align='left' nowrap>\n";
|
|
echo " ".$text['label-caller-id-name']."\n";
|
|
echo "</td>\n";
|
|
echo "<td class='vtable' align='left'>\n";
|
|
echo " <input class='formfld' type='text' name='broadcast_caller_id_name' maxlength='255' value=\"".escape($broadcast_caller_id_name)."\">\n";
|
|
echo "<br />\n";
|
|
echo "".$text['description-caller-id-name']."\n";
|
|
echo "</td>\n";
|
|
echo "</tr>\n";
|
|
|
|
echo "<tr>\n";
|
|
echo "<td class='vncell' valign='top' align='left' nowrap>\n";
|
|
echo " ".$text['label-callerid-number']."\n";
|
|
echo "</td>\n";
|
|
echo "<td class='vtable' align='left'>\n";
|
|
echo " <input class='formfld' type='number' name='broadcast_caller_id_number' maxlength='255' min='0' step='1' value=\"".escape($broadcast_caller_id_number)."\">\n";
|
|
echo "<br />\n";
|
|
echo "".$text['description-caller-id-number']."\n";
|
|
echo "</td>\n";
|
|
echo "</tr>\n";
|
|
}
|
|
|
|
/*
|
|
echo "<tr>\n";
|
|
echo "<td class='vncell' valign='top' align='left' nowrap>\n";
|
|
echo " Type\n";
|
|
echo "</td>\n";
|
|
echo "<td class='vtable' align='left'>\n";
|
|
echo " <input class='formfld' type='text' name='broadcast_destination_type' maxlength='255' value=\"".escape($broadcast_destination_type)."\">\n";
|
|
echo "<br />\n";
|
|
echo "Optional, Destination Type: bridge, transfer, voicemail, conference, fifo, etc.\n";
|
|
echo "</td>\n";
|
|
echo "</tr>\n";
|
|
|
|
echo "<tr>\n";
|
|
echo "<td class='vncell' valign='top' align='left' nowrap>\n";
|
|
echo " Destination\n";
|
|
echo "</td>\n";
|
|
echo "<td class='vtable' align='left'>\n";
|
|
echo " <input class='formfld' type='text' name='broadcast_destination_data' maxlength='255' value=\"".escape($broadcast_destination_data)."\">\n";
|
|
echo "<br />\n";
|
|
echo "Optional, send the call to an auto attendant, conference room, or any other destination. <br /><br />\n";
|
|
echo "conference (8khz): 01-\${domain}@default <br />\n";
|
|
echo "bridge (external number): sofia/gateway/gatewayname/12081231234 <br />\n";
|
|
echo "bridge (auto attendant): sofia/internal/5002@\${domain} <br />\n";
|
|
echo "transfer (external number): 12081231234 XML default <br />\n";
|
|
echo "</td>\n";
|
|
echo "</tr>\n";
|
|
*/
|
|
|
|
if (permission_exists('call_broadcast_destination_number')) {
|
|
echo "<tr>\n";
|
|
echo "<td class='vncell' valign='top' align='left' nowrap>\n";
|
|
echo " ".$text['label-destination']."\n";
|
|
echo "</td>\n";
|
|
echo "<td class='vtable' align='left'>\n";
|
|
echo " <input class='formfld' type='text' name='broadcast_destination_data' maxlength='255' value=\"".escape($broadcast_destination_data)."\">\n";
|
|
echo "<br />\n";
|
|
echo "".$text['description-destination']." <br /><br />\n";
|
|
echo "</td>\n";
|
|
echo "</tr>\n";
|
|
}
|
|
if (permission_exists('call_broadcast_phone_numbers')) {
|
|
echo "<tr>\n";
|
|
echo "<td class='vncell' valign='top' align='left' nowrap>\n";
|
|
echo " ".$text['label-phone']."\n";
|
|
echo "</td>\n";
|
|
echo "<td class='vtable' align='left'>\n";
|
|
|
|
echo " <textarea class='formfld' style='width: 300px; height: 200px;' type='text' name='broadcast_phone_numbers' placeholder=\"".$text['label-list_example']."\">".str_replace('\n', "\n", $broadcast_phone_numbers ?? '')."</textarea>";
|
|
echo "<br><br>";
|
|
echo " <input type='file' name='broadcast_phone_numbers_file' accept='.csv,.txt' style=\"display:inline-block;\"><a href='sample.csv' download><i class='fas fa-cloud-download-alt' style='margin-right: 5px;'></i>".$text['label-sample_file']."</a>";
|
|
echo "<br /><br />";
|
|
|
|
echo "".$text['description-phone']." <br /><br />\n";
|
|
echo "</td>\n";
|
|
echo "</tr>\n";
|
|
}
|
|
if (permission_exists('call_broadcast_voicemail_detection')) {
|
|
echo "<tr>\n";
|
|
echo "<td class='vncell' valign='top' align='left' nowrap='nowrap'>\n";
|
|
echo " ".$text['label-avmd']."\n";
|
|
echo "</td>\n";
|
|
echo "<td class='vtable' align='left'>\n";
|
|
if ($input_toggle_style_switch) {
|
|
echo " <span class='switch'>\n";
|
|
}
|
|
echo " <select class='formfld' id='broadcast_avmd' name='broadcast_avmd'>\n";
|
|
echo " <option value='true' ".($broadcast_avmd === true ? "selected='selected'" : null).">".$text['option-true']."</option>\n";
|
|
echo " <option value='false' ".($broadcast_avmd === false ? "selected='selected'" : null).">".$text['option-false']."</option>\n";
|
|
echo " </select>\n";
|
|
if ($input_toggle_style_switch) {
|
|
echo " <span class='slider'></span>\n";
|
|
echo " </span>\n";
|
|
}
|
|
echo "<br />\n";
|
|
echo $text['description-avmd']."\n";
|
|
echo "</td>\n";
|
|
echo "</tr>\n";
|
|
}
|
|
if (permission_exists('call_broadcast_toll_allow')) {
|
|
echo "<tr>\n";
|
|
echo "<td class='vncell' valign='top' align='left' nowrap='nowrap'>\n";
|
|
echo " ".$text['label-broadcast_toll_allow']."\n";
|
|
echo "</td>\n";
|
|
echo "<td class='vtable' align='left'>\n";
|
|
echo " <input class='formfld' type='text' name='broadcast_toll_allow' maxlength='255' value=".escape($broadcast_toll_allow).">\n";
|
|
echo "<br />\n";
|
|
echo $text['description-broadcast_toll_allow']."\n";
|
|
echo "</td>\n";
|
|
echo "</tr>\n";
|
|
}
|
|
|
|
echo "<tr>\n";
|
|
echo "<td class='vncell' valign='top' align='left' nowrap>\n";
|
|
echo " ".$text['label-description']."\n";
|
|
echo "</td>\n";
|
|
echo "<td class='vtable' align='left'>\n";
|
|
echo " <input class='formfld' type='text' name='broadcast_description' maxlength='255' value=\"".escape($broadcast_description)."\">\n";
|
|
echo "<br />\n";
|
|
echo "".$text['description-info']."\n";
|
|
echo "</td>\n";
|
|
echo "</tr>\n";
|
|
|
|
echo "</table>";
|
|
echo "</div>\n";
|
|
echo "<br><br>";
|
|
|
|
if ($action == "update") {
|
|
echo "<input type='hidden' name='call_broadcast_uuid' value='".escape($call_broadcast_uuid)."'>\n";
|
|
}
|
|
echo "<input type='hidden' name='".$token['name']."' value='".$token['hash']."'>\n";
|
|
|
|
echo "</form>";
|
|
|
|
//include the footer
|
|
require_once "resources/footer.php";
|
|
|
|
?>
|