Portions created by the Initial Developer are Copyright (C) 2008-2020 the Initial Developer. All Rights Reserved. */ //includes require_once "root.php"; require_once "resources/require.php"; //check permissions require_once "resources/check_auth.php"; if (permission_exists('device_add') || permission_exists('device_edit')) { //access granted } else { echo "access denied"; exit; } //add multi-lingual support $language = new text; $text = $language->get(); //include the device class require_once "app/devices/resources/classes/device.php"; //action add or update if (is_uuid($_REQUEST["id"])) { $action = "update"; $device_uuid = $_REQUEST["id"]; } else { $action = "add"; } //get total device count from the database, check limit, if defined if ($action == 'add') { if ($_SESSION['limit']['devices']['numeric'] != '') { $sql = "select count(*) from v_devices where domain_uuid = :domain_uuid "; $parameters['domain_uuid'] = $_SESSION['domain_uuid']; $database = new database; $total_devices = $database->select($sql, $parameters, 'column'); if ($total_devices >= $_SESSION['limit']['devices']['numeric']) { message::add($text['message-maximum_devices'].' '.$_SESSION['limit']['devices']['numeric'], 'negative'); header('Location: devices.php'); exit; } unset($sql, $parameters, $total_devices); } } //get http post variables and set them to php variables if (count($_POST) > 0) { //process the http post data by submitted action if ($_POST['action'] != '' && is_uuid($_POST['device_uuid'])) { $array[0]['checked'] = 'true'; $array[0]['uuid'] = $_POST['device_uuid']; switch ($_POST['action']) { case 'delete': if (permission_exists('device_delete')) { $obj = new device; $obj->delete($array); } break; } header('Location: devices.php'); exit; } //device mac address if (permission_exists('device_mac_address')) { $device_mac_address = $_POST["device_mac_address"]; } else { $sql = "select * from v_devices "; $sql .= "where device_uuid = :device_uuid "; $parameters['device_uuid'] = $device_uuid; $database = new database; $row = $database->select($sql, $parameters, 'row'); if (is_array($row) && @sizeof($row) != 0) { $device_mac_address = $row["device_mac_address"]; } unset($sql, $parameters, $row); } //devices $domain_uuid = $_POST["domain_uuid"]; $device_uuid = $_POST["device_uuid"]; //$device_provisioned_ip = $_POST["device_provisioned_ip"]; $domain_uuid = $_POST["domain_uuid"]; $device_label = $_POST["device_label"]; $device_label = $_POST["device_label"]; $device_user_uuid = $_POST["device_user_uuid"]; $device_username = $_POST["device_username"]; $device_password = $_POST["device_password"]; $device_vendor = $_POST["device_vendor"]; $device_uuid_alternate = $_POST["device_uuid_alternate"]; $device_model = $_POST["device_model"]; $device_firmware_version = $_POST["device_firmware_version"]; $device_enabled = $_POST["device_enabled"]; $device_template = $_POST["device_template"]; $device_description = $_POST["device_description"]; //lines $device_lines = $_POST["device_lines"]; $device_lines_delete = $_POST["device_lines_delete"]; //$line_number = $_POST["line_number"]; //$server_address = $_POST["server_address"]; //$outbound_proxy_primary = $_POST["outbound_proxy_primary"]; //$outbound_proxy_secondary = $_POST["outbound_proxy_secondary"]; //$display_name = $_POST["display_name"]; //$user_id = $_POST["user_id"]; //$auth_id = $_POST["auth_id"]; //$password = $_POST["password"]; //profile $device_profile_uuid = $_POST["device_profile_uuid"]; //keys $device_keys = $_POST["device_keys"]; $device_keys_delete = $_POST["device_keys_delete"]; //$device_key_category = $_POST["device_key_category"]; //$device_key_id = $_POST["device_key_id"]; //$device_key_type = $_POST["device_key_type"]; //$device_key_line = $_POST["device_key_line"]; //$device_key_value = $_POST["device_key_value"]; //$device_key_extension = $_POST["device_key_extension"]; //$device_key_label = $_POST["device_key_label"]; //$device_key_icon = $_POST["device_key_icon"]; //settings $device_settings = $_POST["device_settings"]; $device_settings_delete = $_POST["device_settings_delete"]; //$device_setting_category = $_POST["device_setting_category"]); //$device_setting_subcategory = $_POST["device_setting_subcategory"]; //$device_setting_name = $_POST["device_setting_name"]; //$device_setting_value = $_POST["device_setting_value"]; //$device_setting_enabled = $_POST["device_setting_enabled"]; //$device_setting_description = $_POST["device_setting_description"]; //normalize the mac address if (isset($device_mac_address) && strlen($device_mac_address) > 0) { $device_mac_address = strtolower($device_mac_address); $device_mac_address = preg_replace('#[^a-fA-F0-9./]#', '', $device_mac_address); } } //use the mac address to get the vendor if (strlen($device_vendor) == 0) { $device_vendor = device::get_vendor($device_mac_address); } //add or update the database if (count($_POST) > 0 && strlen($_POST["persistformvar"]) == 0) { //validate the token $token = new token; if (!$token->validate($_SERVER['PHP_SELF'])) { message::add($text['message-invalid_token'],'negative'); header('Location: devices.php'); exit; } //check for all required data $msg = ''; if (strlen($device_mac_address) == 0) { $msg .= $text['message-required'].$text['label-device_mac_address']."
\n"; } //if (strlen($device_label) == 0) { $msg .= "Please provide: Label
\n"; } //if (strlen($device_vendor) == 0) { $msg .= "Please provide: Vendor
\n"; } //if (strlen($device_model) == 0) { $msg .= "Please provide: Model
\n"; } //if (strlen($device_firmware_version) == 0) { $msg .= "Please provide: Firmware Version
\n"; } //if (strlen($device_enabled) == 0) { $msg .= "Please provide: Enabled
\n"; } //if (strlen($device_template) == 0) { $msg .= "Please provide: Template
\n"; } //if (strlen($device_username) == 0) { $msg .= "Please provide: Username
\n"; } //if (strlen($device_password) == 0) { $msg .= "Please provide: Password
\n"; } //if (strlen($device_description) == 0) { $msg .= "Please provide: Description
\n"; } if (strlen($msg) > 0) { require_once "resources/header.php"; require_once "resources/persist_form_var.php"; echo "
\n"; echo "
\n"; echo $msg."
"; echo "
\n"; persistformvar($_POST); echo "
\n"; require_once "resources/footer.php"; return; } //check for duplicates if ($action == 'add' && $device_mac_address != "000000000000") { $sql = "select "; $sql .= "d2.domain_name "; $sql .= "from "; $sql .= "v_devices as d1, "; $sql .= "v_domains as d2 "; $sql .= "where "; $sql .= "d1.domain_uuid = d2.domain_uuid and "; $sql .= "d1.device_mac_address = :device_mac_address "; if (is_uuid($_GET["device_uuid"])) { $sql .= " and d1.device_uuid <> :device_uuid "; } $parameters['device_mac_address'] = $device_mac_address; $database = new database; $domain_name = $database->select($sql, $parameters, 'column'); if ($domain_name != '') { $message = $text['message-duplicate'].(if_group("superadmin") && $_SESSION["domain_name"] != $domain_name ? ": ".$domain_name : null); message::add($message,'negative'); header('Location: devices.php'); exit; } unset($sql, $parameters, $domain_name); } //add or update the database if ($_POST["persistformvar"] != "true") { //set the device uuid if (!is_uuid($device_uuid)) { $device_uuid = uuid(); } //prepare the array $array['devices'][0]['domain_uuid'] = $domain_uuid; $array['devices'][0]['device_uuid'] = $device_uuid; if (permission_exists('device_mac_address')) { $array['devices'][0]['device_mac_address'] = $device_mac_address; } //$array['devices'][0]['device_provisioned_ip'] = $device_provisioned_ip; if (permission_exists('device_label')) { $array['devices'][0]['device_label'] = $device_label; } if (permission_exists('device_user') && is_uuid($device_user_uuid)) { $array['devices'][0]['device_user_uuid'] = $device_user_uuid; } if (permission_exists('device_username_password')) { $array['devices'][0]['device_username'] = $device_username; $array['devices'][0]['device_password'] = $device_password; } if (permission_exists('device_vendor')) { $array['devices'][0]['device_vendor'] = $device_vendor; } if (permission_exists('device_alternate') && is_uuid($device_uuid_alternate)) { $array['devices'][0]['device_uuid_alternate'] = $device_uuid_alternate; } if (permission_exists('device_model')) { $array['devices'][0]['device_model'] = $device_model; } if (permission_exists('device_firmware')) { $array['devices'][0]['device_firmware_version'] = $device_firmware_version; } if (permission_exists('device_enable')) { $array['devices'][0]['device_enabled'] = $device_enabled; $array['devices'][0]['device_enabled_date'] = 'now()'; } if (permission_exists('device_template')) { $array['devices'][0]['device_template'] = $device_template; } if (permission_exists('device_profile_edit')) { $array['devices'][0]['device_profile_uuid'] = is_uuid($device_profile_uuid) ? $device_profile_uuid : null; } if (permission_exists('device_description')) { $array['devices'][0]['device_description'] = $device_description; } if (permission_exists('device_line_edit')) { $y = 0; foreach ($device_lines as $row) { if (strlen($row['line_number']) > 0) { $new_line = false; if (is_uuid($row["device_line_uuid"])) { $device_line_uuid = $row["device_line_uuid"]; } else { $device_line_uuid = uuid(); $new_line = true; } $array['devices'][0]['device_lines'][$y]['domain_uuid'] = $domain_uuid; $array['devices'][0]['device_lines'][$y]['device_uuid'] = $device_uuid; $array['devices'][0]['device_lines'][$y]['device_line_uuid'] = $device_line_uuid; $array['devices'][0]['device_lines'][$y]['line_number'] = $row["line_number"]; $array['devices'][0]['device_lines'][$y]['server_address'] = $row["server_address"]; if (permission_exists('device_line_outbound_proxy_primary')) { $array['devices'][0]['device_lines'][$y]['outbound_proxy_primary'] = $row["outbound_proxy_primary"]; } else if ($new_line && isset($_SESSION['provision']['outbound_proxy_primary'])) { $array['devices'][0]['device_lines'][$y]['outbound_proxy_primary'] = $_SESSION['provision']['outbound_proxy_primary']['text']; } if (permission_exists('device_line_outbound_proxy_secondary')) { $array['devices'][0]['device_lines'][$y]['outbound_proxy_secondary'] = $row["outbound_proxy_secondary"]; } else if ($new_line && isset($_SESSION['provision']['outbound_proxy_secondary'])) { $array['devices'][0]['device_lines'][$y]['outbound_proxy_secondary'] = $_SESSION['provision']['outbound_proxy_secondary']['text']; } if (permission_exists('device_line_server_address_primary')) { $array['devices'][0]['device_lines'][$y]['server_address_primary'] = $row["server_address_primary"]; } else if ($new_line && isset($_SESSION['provision']['server_address_primary'])) { $array['devices'][0]['device_lines'][$y]['server_address_primary'] = $_SESSION['provision']['server_address_primary']['text']; } if (permission_exists('device_line_server_address_secondary')) { $array['devices'][0]['device_lines'][$y]['server_address_secondary'] = $row["server_address_secondary"]; } else if ($new_line && isset($_SESSION['provision']['server_address_secondary'])) { $array['devices'][0]['device_lines'][$y]['server_address_secondary'] = $_SESSION['provision']['server_address_secondary']['text']; } $array['devices'][0]['device_lines'][$y]['display_name'] = $row["display_name"]; $array['devices'][0]['device_lines'][$y]['user_id'] = $row["user_id"]; if (permission_exists('device_line_auth_id')) { $array['devices'][0]['device_lines'][$y]['auth_id'] = $row["auth_id"]; } if (permission_exists('device_line_password')) { $array['devices'][0]['device_lines'][$y]['password'] = $row["password"]; } $array['devices'][0]['device_lines'][$y]['shared_line'] = $row["shared_line"]; $array['devices'][0]['device_lines'][$y]['enabled'] = $row["enabled"]; $array['devices'][0]['device_lines'][$y]['sip_port'] = $row["sip_port"]; $array['devices'][0]['device_lines'][$y]['sip_transport'] = $row["sip_transport"]; $array['devices'][0]['device_lines'][$y]['register_expires'] = $row["register_expires"]; $y++; } } } if (permission_exists('device_key_edit')) { $y = 0; foreach ($device_keys as $row) { if (strlen($row['device_key_category']) > 0) { if (is_uuid($row["device_key_uuid"])) { $device_key_uuid = $row["device_key_uuid"]; } else { $device_key_uuid = uuid(); } $array['devices'][0]['device_keys'][$y]['domain_uuid'] = $domain_uuid; $array['devices'][0]['device_keys'][$y]['device_uuid'] = $device_uuid; $array['devices'][0]['device_keys'][$y]['device_key_uuid'] = $device_key_uuid; $array['devices'][0]['device_keys'][$y]['device_key_category'] = $row["device_key_category"]; $array['devices'][0]['device_keys'][$y]['device_key_vendor'] = $row["device_key_vendor"]; if (permission_exists('device_key_id')) { $array['devices'][0]['device_keys'][$y]['device_key_id'] = $row["device_key_id"]; } $array['devices'][0]['device_keys'][$y]['device_key_type'] = $row["device_key_type"]; if (permission_exists('device_key_line')) { $array['devices'][0]['device_keys'][$y]['device_key_line'] = $row["device_key_line"]; } $array['devices'][0]['device_keys'][$y]['device_key_value'] = $row["device_key_value"]; if (permission_exists('device_key_extension')) { $array['devices'][0]['device_keys'][$y]['device_key_extension'] = $row["device_key_extension"]; } //$array['devices'][0]['device_keys'][$y]['device_key_protected'] = $row["device_key_protected"]; $array['devices'][0]['device_keys'][$y]['device_key_label'] = $row["device_key_label"]; $array['devices'][0]['device_keys'][$y]['device_key_icon'] = $row["device_key_icon"]; $y++; } } } if (permission_exists('device_setting_edit')) { $y = 0; foreach ($device_settings as $row) { if (strlen($row['device_setting_subcategory']) > 0) { if (is_uuid($row["device_setting_uuid"])) { $device_setting_uuid = $row["device_setting_uuid"]; } else { $device_setting_uuid = uuid(); } $array['devices'][0]['device_settings'][$y]['domain_uuid'] = $domain_uuid; $array['devices'][0]['device_settings'][$y]['device_uuid'] = $device_uuid; $array['devices'][0]['device_settings'][$y]['device_setting_uuid'] = $device_setting_uuid; $array['devices'][0]['device_settings'][$y]['device_setting_category'] = $row["device_setting_category"]; $array['devices'][0]['device_settings'][$y]['device_setting_subcategory'] = $row["device_setting_subcategory"]; $array['devices'][0]['device_settings'][$y]['device_setting_name'] = $row["device_setting_name"]; $array['devices'][0]['device_settings'][$y]['device_setting_value'] = $row["device_setting_value"]; $array['devices'][0]['device_settings'][$y]['device_setting_enabled'] = $row["device_setting_enabled"]; $array['devices'][0]['device_settings'][$y]['device_setting_description'] = $row["device_setting_description"]; $y++; } } } //save the device $database = new database; $database->app_name = 'devices'; $database->app_uuid = '4efa1a1a-32e7-bf83-534b-6c8299958a8e'; $database->save($array); //remove checked lines if ( $action == 'update' && permission_exists('device_line_delete') && is_array($device_lines_delete) && @sizeof($device_lines_delete) != 0 ) { $obj = new device; $obj->device_uuid = $device_uuid; $obj->delete_lines($device_lines_delete); } //remove checked keys if ( $action == 'update' && permission_exists('device_key_delete') && is_array($device_keys_delete) && @sizeof($device_keys_delete) != 0 ) { $obj = new device; $obj->device_uuid = $device_uuid; $obj->delete_keys($device_keys_delete); } //remove checked settings if ( $action == 'update' && permission_exists('device_setting_delete') && is_array($device_settings_delete) && @sizeof($device_settings_delete) != 0 ) { $obj = new device; $obj->device_uuid = $device_uuid; $obj->delete_settings($device_settings_delete); } //write the provision files if (strlen($_SESSION['provision']['path']['text']) > 0) { $prov = new provision; $prov->domain_uuid = $domain_uuid; $response = $prov->write(); } //set the message if (isset($action)) { if ($action == "add") { //save the message to a session variable message::add($text['message-add']); } if ($action == "update") { //save the message to a session variable message::add($text['message-update']); } //redirect the browser header("Location: device_edit.php?id=".urlencode($device_uuid)); exit; } } } //pre-populate the form if (count($_GET) > 0 && $_POST["persistformvar"] != "true") { $sql = "select * from v_devices "; $sql .= "where device_uuid = :device_uuid "; $parameters['device_uuid'] = $device_uuid; $database = new database; $row = $database->select($sql, $parameters, 'row'); if (is_array($row) && @sizeof($row) != 0) { $device_mac_address = $row["device_mac_address"]; $device_provisioned_ip = $row["device_provisioned_ip"]; $domain_uuid = $row["domain_uuid"]; $device_label = $row["device_label"]; //$device_mac_address = substr($device_mac_address, 0,2).'-'.substr($device_mac_address, 2,2).'-'.substr($device_mac_address, 4,2).'-'.substr($device_mac_address, 6,2).'-'.substr($device_mac_address, 8,2).'-'.substr($device_mac_address, 10,2); $device_label = $row["device_label"]; $device_user_uuid = $row["device_user_uuid"]; $device_username = $row["device_username"]; $device_password = $row["device_password"]; $device_vendor = $row["device_vendor"]; $device_uuid_alternate = $row["device_uuid_alternate"]; $device_model = $row["device_model"]; $device_firmware_version = $row["device_firmware_version"]; $device_enabled = $row["device_enabled"]; $device_template = $row["device_template"]; $device_profile_uuid = $row["device_profile_uuid"]; $device_description = $row["device_description"]; } unset($sql, $parameters, $row); } //use the mac address to get the vendor if (strlen($device_vendor) == 0) { $template_array = explode("/", $device_template); $device_vendor = $template_array[0]; } //set the sub array index $x = "999"; //alternate device settings if (is_uuid($device_uuid_alternate)) { $sql = "select * from v_devices "; $sql .= "where (domain_uuid = :domain_uuid or domain_uuid is null) "; $sql .= "and device_uuid = :device_uuid "; $parameters['domain_uuid'] = $domain_uuid; $parameters['device_uuid'] = $device_uuid_alternate; $database = new database; $device_alternate = $database->select($sql, $parameters, 'all'); unset($sql, $parameters); } //get device lines $sql = "select * from v_device_lines "; $sql .= "where device_uuid = :device_uuid "; $sql .= "order by cast(line_number as int) asc "; $parameters['device_uuid'] = $device_uuid; $database = new database; $device_lines = $database->select($sql, $parameters, 'all'); unset($sql, $parameters); $device_lines[$x]['line_number'] = ''; $device_lines[$x]['server_address'] = ''; $device_lines[$x]['outbound_proxy_primary'] = $_SESSION['provision']['outbound_proxy_primary']['text']; $device_lines[$x]['outbound_proxy_secondary'] = $_SESSION['provision']['outbound_proxy_secondary']['text']; $device_lines[$x]['server_address_primary'] = $_SESSION['provision']['server_address_primary']['text']; $device_lines[$x]['server_address_secondary'] = $_SESSION['provision']['server_address_secondary']['text']; $device_lines[$x]['display_name'] = ''; $device_lines[$x]['user_id'] = ''; $device_lines[$x]['auth_id'] = ''; $device_lines[$x]['password'] = ''; $device_lines[$x]['shared_line'] = ''; $device_lines[$x]['enabled'] = ''; $device_lines[$x]['sip_port'] = $_SESSION['provision']['line_sip_port']['numeric']; $device_lines[$x]['sip_transport'] = $_SESSION['provision']['line_sip_transport']['text']; $device_lines[$x]['register_expires'] = $_SESSION['provision']['line_register_expires']['numeric']; //get device keys $sql = "select * from v_device_keys "; $sql .= "where device_uuid = :device_uuid "; $sql .= "order by "; $sql .= "device_key_vendor asc, "; $sql .= "case device_key_category "; $sql .= "when 'line' then 1 "; $sql .= "when 'memory' then 2 "; $sql .= "when 'programmable' then 3 "; $sql .= "when 'expansion' then 4 "; $sql .= "when 'expansion-1' then 5 "; $sql .= "when 'expansion-2' then 6 "; $sql .= "when 'expansion-3' then 7 "; $sql .= "when 'expansion-4' then 8 "; $sql .= "when 'expansion-5' then 9 "; $sql .= "when 'expansion-6' then 10 "; $sql .= "else 100 end, "; $sql .= $db_type == "mysql" ? "device_key_id asc " : "cast(device_key_id as numeric) asc "; $parameters['device_uuid'] = $device_uuid; $database = new database; $device_keys = $database->select($sql, $parameters, 'all'); unset($sql, $parameters); $device_keys[$x]['device_key_category'] = ''; $device_keys[$x]['device_key_id'] = ''; $device_keys[$x]['device_key_type'] = ''; $device_keys[$x]['device_key_line'] = ''; $device_keys[$x]['device_key_value'] = ''; $device_keys[$x]['device_key_extension'] = ''; $device_keys[$x]['device_key_label'] = ''; $device_keys[$x]['device_key_icon'] = ''; //get the device vendors $sql = "select name "; $sql .= "from v_device_vendors "; $sql .= "where enabled = 'true' "; $sql .= "order by name asc "; $database = new database; $device_vendors = $database->select($sql, null, 'all'); unset($sql); //get the vendor functions $sql = "select v.name as vendor_name, f.name, f.value "; $sql .= "from v_device_vendors as v, v_device_vendor_functions as f "; $sql .= "where v.device_vendor_uuid = f.device_vendor_uuid "; $sql .= "and v.enabled = 'true' "; $sql .= "and f.enabled = 'true' "; $sql .= "order by v.name asc, f.name asc "; $database = new database; $vendor_functions = $database->select($sql, null, 'all'); unset($sql); //get device settings $sql = "select * from v_device_settings "; $sql .= "where device_uuid = :device_uuid "; $sql .= "order by device_setting_subcategory asc "; $parameters['device_uuid'] = $device_uuid; $database = new database; $device_settings = $database->select($sql, $parameters, 'all'); unset($sql, $parameters); $device_settings[$x]['device_setting_name'] = ''; $device_settings[$x]['device_setting_value'] = ''; $device_settings[$x]['enabled'] = ''; $device_settings[$x]['device_setting_description'] = ''; //get the users $sql = "select * from v_users "; $sql .= "where domain_uuid = :domain_uuid "; $sql .= "and user_enabled = 'true' "; $sql .= "order by username asc "; $parameters['domain_uuid'] = $domain_uuid; $database = new database; $users = $database->select($sql, $parameters, 'all'); unset($sql, $parameters); //use the mac address to get the vendor if (strlen($device_vendor) == 0) { $device_vendor = device::get_vendor($device_mac_address); } //get the device line info for provision button foreach($device_lines as $row) { if (strlen($row['user_id']) > 0) { $user_id = $row['user_id']; } if (strlen($row['server_address']) > 0) { $server_address = $row['server_address']; } } //create token $object = new token; $token = $object->create($_SERVER['PHP_SELF']); //show the header $document['title'] = $text['title-device']; require_once "resources/header.php"; //select file download javascript if (permission_exists("device_files")) { echo ""; } //add the QR code if (permission_exists("device_line_password") && $device_template == "grandstream/wave") { //set the mode if (isset($_SESSION['theme']['qr_image'])) { if (strlen($_SESSION['theme']['qr_image']) > 0) { $mode = '4'; } else { $mode = '0'; } } else { $mode = '4'; } //get the device line settings $row = $device_lines[0]; //set the outbound proxy settings if (strlen($row['outbound_proxy_primary']) == 0) { $outbound_proxy_primary = $row['server_address']; } else { $outbound_proxy_primary = $row['outbound_proxy_primary']; } $outbound_proxy_secondary = $row['outbound_proxy_secondary']; //build the xml $xml = ""; $xml .= ""; $xml .= ""; $xml .= "".$row['server_address'].""; $xml .= "".$outbound_proxy_primary.":".$row['sip_port'].""; $xml .= "".$outbound_proxy_secondary.":".$row['sip_port'].""; $xml .= "".$row['user_id'].""; $xml .= "".$row['auth_id'].""; $xml .= "".$row['password'].""; $xml .= "".$row['user_id'].""; $xml .= "".$row['display_name'].""; $xml .= "{x+|*x+|*++}"; $xml .= "0"; $xml .= "*97"; $xml .= ""; $xml .= ""; //qr code generation $_GET['type'] = "text"; echo ""; echo ""; echo ""; echo ""; if (isset($_SESSION['theme']['qr_image'])) { echo ""; } else { echo ""; } } //show the content echo "
\n"; echo "\n"; echo "
\n"; echo "
".$text['header-device']."
\n"; echo "
\n"; echo button::create(['type'=>'button','label'=>$text['button-back'],'icon'=>$_SESSION['theme']['button_icon_back'],'id'=>'btn_back','link'=>'devices.php']); if ($action == 'update') { $button_margin = 'margin-left: 15px;'; if (permission_exists("device_line_password") && $device_template == "grandstream/wave") { echo button::create(['type'=>'button','label'=>$text['button-qr_code'],'icon'=>'qrcode','style'=>$button_margin,'onclick'=>"$('#qr_code_container').fadeIn(400);"]); unset($button_margin); } echo button::create(['type'=>'button','label'=>$text['button-provision'],'icon'=>'fax','style'=>$button_margin,'link'=>PROJECT_PATH."/app/devices/cmd.php?cmd=check_sync"."&user=".urlencode($user_id)."@".urlencode($server_address)."&domain=".urlencode($server_address)."&agent=".urlencode($device_vendor)]); unset($button_margin); if (permission_exists("device_files")) { //get the template directory $prov = new provision; $prov->domain_uuid = $domain_uuid; $template_dir = $prov->template_dir; $files = glob($template_dir.'/'.$device_template.'/*'); //add file buttons and the file list echo button::create(['type'=>'button','id'=>'button_files','label'=>$text['button-files'],'icon'=>$_SESSION['theme']['button_icon_download'],'onclick'=>'show_files()']); echo ""; } if (permission_exists('device_add')) { echo button::create(['type'=>'button','label'=>$text['button-copy'],'icon'=>$_SESSION['theme']['button_icon_copy'],'name'=>'btn_copy','onclick'=>"modal_open('modal-copy','new_mac_address');"]); } if ( permission_exists('device_delete') || permission_exists('device_line_delete') || permission_exists('device_key_delete') || permission_exists('device_setting_delete') ) { echo button::create(['type'=>'button','label'=>$text['button-delete'],'icon'=>$_SESSION['theme']['button_icon_delete'],'name'=>'btn_delete','onclick'=>"modal_open('modal-delete','btn_delete');"]); } } echo button::create(['type'=>'button','label'=>$text['button-save'],'icon'=>$_SESSION['theme']['button_icon_save'],'id'=>'btn_save','style'=>'margin-left: 15px;','onclick'=>'submit_form();']); echo "
\n"; echo "
\n"; echo "
\n"; if (permission_exists('device_add')) { echo modal::create([ 'id'=>'modal-copy', 'type'=>'general', 'message'=>$text['message_device']."...

", 'actions'=>button::create([ 'type'=>'button', 'label'=>$text['button-continue'], 'icon'=>'check', 'id'=>'btn_copy', 'style'=>'float: right; margin-left: 15px;', 'collapse'=>'never', 'onclick'=>"modal_close(); if (document.getElementById('new_mac_address').value != '') { window.location='device_copy.php?id=".urlencode($device_uuid)."&mac=' + document.getElementById('new_mac_address').value; }" ]), 'onclose'=>"document.getElementById('new_mac_address').value = '';", ]); } if ( permission_exists('device_delete') || permission_exists('device_line_delete') || permission_exists('device_key_delete') || permission_exists('device_setting_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 $text['description-device']."\n"; echo "

\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; if (permission_exists('device_template')) { echo "\n"; echo "\n"; echo "\n"; echo "\n"; } if (permission_exists('device_line_edit')) { echo " "; echo " "; echo " "; echo " "; } if (permission_exists('device_profile_edit')) { //device profile $sql = "select * from v_device_profiles "; $sql .= "where (domain_uuid = :domain_uuid or domain_uuid is null) "; $sql .= "order by device_profile_name asc "; $parameters['domain_uuid'] = $domain_uuid; $database = new database; $result = $database->select($sql, $parameters, 'all'); if (is_array($result) && @sizeof($result) != 0) { echo " "; echo " "; echo " "; echo " "; } unset($sql, $parameters, $result); } if (permission_exists('device_key_edit')) { $vendor_count = 0; foreach($device_keys as $row) { if ($previous_vendor != $row['device_key_vendor']) { $previous_vendor = $row['device_key_vendor']; $vendor_count++; } } echo " "; echo " "; echo " "; echo " "; } //device settings if (permission_exists('device_setting_edit')) { echo " "; echo " "; echo " \n"; echo "\n"; } if (permission_exists('device_user')) { echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; } if (permission_exists('device_alternate') && is_uuid($device_uuid_alternate)) { echo "\n"; echo "\n"; echo "\n"; echo "\n"; } if (permission_exists('device_vendor')) { echo "\n"; echo "\n"; echo "\n"; echo "\n"; } if (permission_exists('device_model')) { echo "\n"; echo "\n"; echo "\n"; echo "\n"; } if (permission_exists('device_firmware')) { echo "\n"; echo "\n"; echo "\n"; echo "\n"; } if (permission_exists('device_domain')) { echo "\n"; echo "\n"; echo "\n"; echo "\n"; } else { echo " \n"; } if (permission_exists('device_enable')) { echo "\n"; echo "\n"; echo "\n"; echo "\n"; } echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo " \n"; echo " \n"; echo " "; echo "
\n"; echo " ".$text['label-device_mac_address']."\n"; echo "\n"; if (permission_exists('device_mac_address')) { echo " \n"; echo "
\n"; echo $text['description-device_mac_address']."\n"; } else { echo escape($device_mac_address); } echo " \n"; echo " ".escape($device_provisioned_ip)."(http|https)\n"; echo "
\n"; echo " ".$text['label-device_label']."\n"; echo "\n"; if (permission_exists('device_label')) { echo " \n"; echo "
\n"; echo $text['description-device_label']."\n"; } else { echo escape($device_label); } echo "
\n"; echo " ".$text['label-device_template']."\n"; echo "\n"; $device = new device; $template_dir = $device->get_template_dir(); echo " \n"; echo "
\n"; echo " ".$text['description-device_template']."\n"; echo "
".$text['label-lines'].""; echo " \n"; echo " \n"; echo " \n"; if (permission_exists('device_line_server_address')) { echo " \n"; } if (permission_exists('device_line_server_address_primary')) { echo " \n"; } if (permission_exists('device_line_server_address_secondary')) { echo " \n"; } if (permission_exists('device_line_outbound_proxy_primary')) { echo " \n"; } if (permission_exists('device_line_outbound_proxy_secondary')) { echo " \n"; } echo " \n"; echo " \n"; if (permission_exists('device_line_auth_id')) { echo " \n"; } if (permission_exists('device_line_password')) { echo " \n"; } if (permission_exists('device_line_port')) { echo " \n"; } if (permission_exists('device_line_transport')) { echo " \n"; } if (permission_exists('device_line_register_expires')) { echo " \n"; } if (permission_exists('device_line_shared')) { echo " \n"; } echo " \n"; if (is_array($device_lines) && @sizeof($device_lines) > 1 && permission_exists('device_line_delete')) { echo " \n"; } echo " \n"; $x = 0; foreach($device_lines as $row) { //set the defaults if (!permission_exists('device_line_server_address')) { if (strlen($row['server_address']) == 0) { $row['server_address'] = $_SESSION['domain_name']; } } if (strlen($row['sip_transport']) == 0) { $row['sip_transport'] = $_SESSION['provision']['line_sip_transport']['text']; } if (strlen($row['sip_port']) == 0) { $row['sip_port'] = $_SESSION['provision']['line_sip_port']['numeric']; } if (strlen($row['register_expires']) == 0) { $row['register_expires'] = $_SESSION['provision']['line_register_expires']['numeric']; } //determine whether to hide the element if (!is_uuid($device_line_uuid)) { $element['hidden'] = false; $element['visibility'] = "visibility:visible;"; } else { $element['hidden'] = true; $element['visibility'] = "visibility:hidden;"; } //add the primary key uuid if (is_uuid($row['device_line_uuid'])) { echo " \n"; } //show each row in the array echo " \n"; echo " \n"; if (permission_exists('device_line_server_address')) { echo " \n"; } else { echo " \n"; } if (permission_exists('device_line_server_address_primary')) { echo " \n"; } if (permission_exists('device_line_server_address_secondary')) { echo " \n"; } if (permission_exists('device_line_outbound_proxy_primary')) { echo " \n"; } if (permission_exists('device_line_outbound_proxy_secondary')) { echo " \n"; } echo " \n"; echo " \n"; if (permission_exists('device_line_auth_id')) { echo " \n"; } if (permission_exists('device_line_password')) { echo " \n"; } if (permission_exists('device_line_port')) { echo " \n"; } if (permission_exists('device_line_transport')) { echo " \n"; } else { echo " \n"; } if (permission_exists('device_line_register_expires')) { echo " \n"; } else { echo " \n"; } if (permission_exists('device_line_shared')) { echo " \n"; } else { echo " \n"; } echo " \n"; if (is_array($device_lines) && @sizeof($device_lines) > 1 && permission_exists('device_line_delete') && is_uuid($row['device_line_uuid'])) { echo " \n"; //increment counter $x++; } echo "
".$text['label-line']."".$text['label-server_address']."".$text['label-server_address_primary']."".$text['label-server_address_secondary']."".$text['label-outbound_proxy_primary']."".$text['label-outbound_proxy_secondary']."".$text['label-display_name']."".$text['label-user_id']."".$text['label-auth_id']."".$text['label-password']."".$text['label-sip_port']."".$text['label-sip_transport']."".$text['label-register_expires']."".$text['label-shared_line']."".$text['label-enabled']."\n"; echo " ".$text['label-delete']."\n"; echo " \n"; echo "
\n"; $selected = "selected=\"selected\" "; echo " \n"; echo " \n"; echo " \n"; echo " \n"; if (isset($_SESSION['provision']['server_address_primary']) && !isset($_SESSION['provision']['server_address_primary']['text'])) { echo " \n"; } else { echo " \n"; } echo " \n"; if (isset($_SESSION['provision']['server_address_secondary']) && !isset($_SESSION['provision']['server_address_secondary']['text'])) { echo " \n"; } else { echo " \n"; } echo " \n"; if (isset($_SESSION['provision']['outbound_proxy_primary']) && !isset($_SESSION['provision']['outbound_proxy_primary']['text'])) { echo " \n"; } else { echo " \n"; } echo " \n"; if (isset($_SESSION['provision']['outbound_proxy_secondary']) && !isset($_SESSION['provision']['outbound_proxy_secondary']['text'])) { echo " \n"; } else { echo " \n"; } echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; //help defeat browser auto-fill echo " \n"; echo " "; //help defeat browser auto-fill echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; } echo "
\n"; if (strlen($text['description-lines']) > 0) { echo "
".$text['description-lines']."\n"; } echo "
".$text['label-profile'].""; echo " \n"; echo " "; echo " "; echo "
".$text['description-profile2']."\n"; echo "
".$text['label-keys'].""; echo " \n"; if ($vendor_count == 0) { echo " \n"; echo " \n"; if (permission_exists('device_key_id')) { echo " \n"; } echo " \n"; if (permission_exists('device_key_line')) { echo " \n"; } echo " \n"; if (permission_exists('device_key_extension')) { echo " \n"; } echo " \n"; echo " \n"; if (is_array($device_keys) && @sizeof($device_keys) > 1 && permission_exists('device_key_delete')) { echo " \n"; } echo " \n"; } $x = 0; foreach($device_keys as $row) { //set the column names if ($previous_device_key_vendor != $row['device_key_vendor']) { echo " \n"; echo " \n"; if (permission_exists('device_key_id')) { echo " \n"; } if ($vendor_count > 1 && strlen($row['device_key_vendor']) > 0) { echo " \n"; } else { echo " \n"; } if (permission_exists('device_key_line')) { echo " \n"; } echo " \n"; if (permission_exists('device_key_extension')) { echo " \n"; } echo " \n"; echo " \n"; if (is_array($device_keys) && @sizeof($device_keys) > 1 && permission_exists('device_key_delete')) { echo " \n"; } echo " \n"; } //determine whether to hide the element if (!is_uuid($device_key_uuid)) { $element['hidden'] = false; $element['visibility'] = "visibility:visible;"; } else { $element['hidden'] = true; $element['visibility'] = "visibility:hidden;"; } //add the primary key uuid if (is_uuid($row['device_key_uuid'])) { echo " \n"; } //show all the rows in the array echo " \n"; echo "\n"; if (permission_exists('device_key_id')) { echo "\n"; } echo "\n"; if (permission_exists('device_key_line')) { echo "\n"; } echo "\n"; if (permission_exists('device_key_extension')) { echo "\n"; } echo "\n"; echo "\n"; if (is_array($device_keys) && @sizeof($device_keys) > 1 && permission_exists('device_key_delete')) { if (is_uuid($row['device_key_uuid'])) { echo " \n"; echo " \n"; //set the previous vendor $previous_device_key_vendor = $row['device_key_vendor']; //increment the array key $x++; } echo "
".$text['label-device_key_category']."".$text['label-device_key_id']."".$text['label-device_key_type']."".$text['label-device_key_line']."".$text['label-device_key_value']."".$text['label-device_key_extension']."".$text['label-device_key_label']."".$text['label-device_key_icon']."\n"; echo " ".$text['label-delete']."\n"; echo " \n"; echo "
".$text['label-device_key_category']."".$text['label-device_key_id']."".ucwords($row['device_key_vendor'])."".$text['label-device_key_type']."".$text['label-device_key_line']."".$text['label-device_key_value']."".$text['label-device_key_extension']."".$text['label-device_key_label']."".$text['label-device_key_icon']."\n"; echo " ".$text['label-delete']."\n"; echo " \n"; echo "
\n"; echo " \n"; echo "\n"; $selected = "selected='selected'"; echo " \n"; echo "\n"; //echo " \n"; if (strlen($row['device_key_vendor']) > 0) { $device_key_vendor = $row['device_key_vendor']; } else { $device_key_vendor = $device_vendor; } echo "\n"; echo "\n"; echo "\n"; echo " \n"; echo "\n"; echo " \n"; echo "\n"; echo " \n"; echo "\n"; echo " \n"; echo "\n"; echo " \n"; echo "\n"; echo " \n"; echo " \n"; } else { echo " \n"; } } echo "
\n"; if (strlen($text['description-keys']) > 0) { echo "
".$text['description-keys']."\n"; } echo "
".$text['label-settings'].""; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; if (is_array($device_settings) && @sizeof($device_settings) > 1 && permission_exists('device_setting_delete')) { echo " \n"; } echo " \n"; $x = 0; foreach($device_settings as $row) { //determine whether to hide the element if (!is_uuid($device_setting_uuid)) { $element['hidden'] = false; $element['visibility'] = "visibility:visible;"; } else { $element['hidden'] = true; $element['visibility'] = "visibility:hidden;"; } //add the primary key uuid if (is_uuid($row['device_setting_uuid'])) { echo " \n"; } //show alls rows in the array echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; if (is_array($device_settings) && @sizeof($device_settings) > 1 && permission_exists('device_setting_delete')) { if (is_uuid($row['device_setting_uuid'])) { echo "\n"; } echo "\n"; $x++; } echo "
".$text['label-device_setting_name']."".$text['label-device_setting_value']."".$text['label-enabled']."".$text['label-device_setting_description']."\n"; echo " ".$text['label-delete']."\n"; echo " \n"; echo "
\n"; echo " \n"; echo "\n"; echo " \n"; echo "\n"; echo " \n"; echo "\n"; echo " \n"; echo "\n"; echo " \n"; echo " \n"; } else { echo "\n"; } echo "
\n"; if (strlen($text['description-settings']) > 0) { echo "
".$text['description-settings']."\n"; } echo "
\n"; echo " ".$text['label-user']."\n"; echo "\n"; echo " "; unset($users); echo "
\n"; echo " ".$text['description-user']."\n"; } if (permission_exists('device_username_password')) { echo "
\n"; echo " ".$text['label-device']."\n"; echo "\n"; echo " \n"; echo " \n"; echo " \n"; echo "
\n"; echo $text['description-device']."\n"; echo "
\n"; echo " ".$text['label-device_uuid_alternate']."\n"; echo "\n"; $label = $device_alternate[0]['device_label']; if (strlen($label) == 0) { $label = $device_alternate[0]['device_description']; } if (strlen($label) == 0) { $label = $device_alternate[0]['device_mac_address']; } echo " \n"; echo " \n"; echo " "; echo " \n"; echo " \n"; echo "
".escape($label)." $v_link_label_delete
\n"; unset($label); echo $text['description-device_uuid_alternate']."\n"; echo "
\n"; echo " ".$text['label-device_vendor']."\n"; echo "\n"; echo " \n"; echo "
\n"; echo $text['description-device_vendor']."\n"; echo "
\n"; echo " ".$text['label-device_model']."\n"; echo "\n"; echo " \n"; echo "
\n"; echo $text['description-device_model']."\n"; echo "
\n"; echo " ".$text['label-device_firmware_version']."\n"; echo "\n"; echo " \n"; echo "
\n"; echo $text['description-device_firmware_version']."\n"; echo "
\n"; echo " ".$text['label-domain']."\n"; echo "\n"; echo " \n"; echo "
\n"; echo $text['description-domain_name']."\n"; echo "
\n"; echo " ".$text['label-device_enabled']."\n"; echo "\n"; echo " \n"; echo "
\n"; echo $text['description-device_enabled']."\n"; echo "
\n"; echo " ".$text['label-device_description']."\n"; echo "\n"; if (permission_exists('device_description')) { echo " \n"; echo "
\n"; echo $text['description-device_description']."\n"; } else { echo escape($device_description)."\n"; } echo "
\n"; if ($action == "update") { echo " \n"; } echo " \n"; echo "
"; echo "

"; echo "
"; echo "\n"; //show the footer require_once "resources/footer.php"; ?>