Copyright (C) 2008-2019 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) { //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); } //get assigned user $device_user_uuid = $_POST["device_user_uuid"]; //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_profile_uuid = $_POST["device_profile_uuid"]; $device_description = $_POST["device_description"]; //lines $device_lines = $_POST["device_lines"]; //$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_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_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; $array['devices'][0]['device_mac_address'] = $device_mac_address; //$array['devices'][0]['device_provisioned_ip'] = $device_provisioned_ip; $array['devices'][0]['domain_uuid'] = $domain_uuid; $array['devices'][0]['device_label'] = $device_label; $array['devices'][0]['device_user_uuid'] = $device_user_uuid; $array['devices'][0]['device_username'] = $device_username; $array['devices'][0]['device_password'] = $device_password; $array['devices'][0]['device_vendor'] = $device_vendor; $array['devices'][0]['device_uuid_alternate'] = $device_uuid_alternate; $array['devices'][0]['device_model'] = $device_model; $array['devices'][0]['device_firmware_version'] = $device_firmware_version; $array['devices'][0]['device_enabled'] = $device_enabled; $array['devices'][0]['device_enabled_date'] = 'now()'; $array['devices'][0]['device_template'] = $device_template; $array['devices'][0]['device_profile_uuid'] = $device_profile_uuid; $array['devices'][0]['device_description'] = $device_description; $y = 0; foreach ($device_lines as $row) { if (strlen($row['line_number']) > 0) { if (is_uuid($row["device_line_uuid"])) { $device_line_uuid = $row["device_line_uuid"]; } else { $device_line_uuid = uuid(); } $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"]; $array['devices'][0]['device_lines'][$y]['outbound_proxy_primary'] = $row["outbound_proxy_primary"]; $array['devices'][0]['device_lines'][$y]['outbound_proxy_secondary'] = $row["outbound_proxy_secondary"]; $array['devices'][0]['device_lines'][$y]['server_address_primary'] = $row["server_address_primary"]; $array['devices'][0]['device_lines'][$y]['server_address_secondary'] = $row["server_address_secondary"]; $array['devices'][0]['device_lines'][$y]['display_name'] = $row["display_name"]; $array['devices'][0]['device_lines'][$y]['user_id'] = $row["user_id"]; $array['devices'][0]['device_lines'][$y]['auth_id'] = $row["auth_id"]; $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++; } } $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"]; $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"]; $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"]; $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++; } } $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); //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; } } //if ($_POST["persistformvar"] != "true") } //(count($_POST) > 0 && strlen($_POST["persistformvar"]) == 0) //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']; } } //get the sip profile name $fp = event_socket_create($_SESSION['event_socket_ip_address'], $_SESSION['event_socket_port'], $_SESSION['event_socket_password']); if ($fp) { $command = "sofia_contact */".$user_id."@".$server_address; $contact_string = event_socket_request($fp, "api ".$command); if (substr($contact_string, 0, 5) == "sofia") { $contact_array = explode("/", $contact_string); $sip_profile_name = $contact_array[1]; } else { $sip_profile_name = 'internal'; } } //create token $object = new token; $token = $object->create($_SERVER['PHP_SELF']); //show the header 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'],'style'=>'margin-right: 15px;','link'=>'devices.php']); if (permission_exists("device_line_password") && $device_template == "grandstream/wave") { echo button::create(['type'=>'button','label'=>$text['button-qr_code'],'icon'=>'qrcode','onclick'=>"$('#qr_code_container').fadeIn(400);"]); } echo button::create(['type'=>'button','label'=>$text['button-provision'],'icon'=>'fax','link'=>PROJECT_PATH."/app/devices/cmd.php?cmd=check_sync&profile=".urlencode($sip_profile_name)."&user=".urlencode($user_id)."@".urlencode($server_address)."&domain=".urlencode($server_address)."&agent=".urlencode($device_vendor)]); 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') && $action != "add") { echo button::create(['type'=>'button','label'=>$text['button-copy'],'icon'=>$_SESSION['theme']['button_icon_copy'],'onclick'=>"var new_mac = prompt('".$text['message_device']."'); if (new_mac != null) { window.location='device_copy.php?id=".escape($device_uuid)."&mac=' + new_mac; }"]); } echo button::create(['type'=>'button','label'=>$text['button-save'],'icon'=>$_SESSION['theme']['button_icon_save'],'style'=>'margin-left: 15px;','onclick'=>'submit_form()']); echo "
\n"; echo "
\n"; echo "
\n"; 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_view')) { 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"; } 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"; 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')) { if (permission_exists('device_line_outbound_proxy_secondary')) { $placeholder_label = $text['label-primary']; } echo " \n"; unset($placeholder_label); } 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"; } 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"; echo " \n"; echo " \n"; $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"; $selected = "selected=\"selected\" "; 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"; 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"; if (is_uuid($row['device_line_uuid'])) { if (permission_exists('device_delete')) { echo " $v_link_label_delete\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"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; if (permission_exists('device_key_extension')) { echo " \n"; } echo " \n"; echo " \n"; 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"; echo " \n"; if ($vendor_count > 1 && strlen($row['device_key_vendor']) > 0) { echo " \n"; } else { echo " \n"; } echo " \n"; echo " \n"; if (permission_exists('device_key_extension')) { echo " \n"; } echo " \n"; echo " \n"; 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"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; if (permission_exists('device_key_extension')) { echo "\n"; } echo "\n"; echo "\n"; //echo " \n"; 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']." 
".$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 " \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; } ?> \n"; echo " \n"; $previous_vendor = ''; $i=0; foreach ($vendor_functions as $function) { if (strlen($row['device_key_vendor']) == 0 && $function['vendor_name'] != $previous_vendor) { if ($i > 0) { echo " \n"; } echo " \n"; } $selected = ''; if (strtolower($row['device_key_vendor']) == $function['vendor_name'] && $row['device_key_type'] == $function['value']) { $selected = "selected='selected'"; } if (strlen($row['device_key_vendor']) == 0) { echo " \n"; } if (strlen($row['device_key_vendor']) > 0 && strtolower($row['device_key_vendor']) == $function['vendor_name']) { echo " \n"; } $previous_vendor = $function['vendor_name']; $i++; } if (strlen($row['device_key_vendor']) == 0) { 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 (is_uuid($row['device_key_uuid'])) { if (permission_exists('device_key_delete')) { echo " $v_link_label_delete\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"; 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 (strlen($text['description-settings']) > 0) { echo "
".$text['description-settings']."\n"; } echo " "; 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 " \n"; echo "\n"; echo " \n"; echo "\n"; echo " \n"; echo "\n"; echo " \n"; echo "\n"; if (is_uuid($row['device_setting_uuid'])) { if (permission_exists('device_edit')) { echo " $v_link_label_edit\n"; } if (permission_exists('device_delete')) { echo " $v_link_label_delete\n"; } } echo "
\n"; echo " \n"; */ echo "
\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"; ?>