Portions created by the Initial Developer are Copyright (C) 2008-2016 the Initial Developer. All Rights Reserved. Contributor(s): Mark J Crane */ //includes require_once "root.php"; require_once "resources/require.php"; require_once "resources/check_auth.php"; //check permissions if (permission_exists('gateway_view')) { //access granted } else { echo "access denied"; exit; } //add multi-lingual support $language = new text; $text = $language->get(); //additional includes require_once "resources/header.php"; require_once "resources/paging.php"; //get variables used to control the order $order_by = check_str($_GET["order_by"]); $order = check_str($_GET["order"]); //connect to event socket $fp = event_socket_create($_SESSION['event_socket_ip_address'], $_SESSION['event_socket_port'], $_SESSION['event_socket_password']); if ($fp) { if (strlen($_GET["a"]) > 0) { $profile = check_str($_GET["profile"]); if (strlen($profile) == 0) { $profile = 'external'; } if ($_GET["a"] == "stop") { $gateway_uuid = check_str($_GET["gateway"]); $cmd = 'api sofia profile '.$profile.' killgw '.$gateway_uuid; $response = trim(event_socket_request($fp, $cmd)); $msg = 'Stop Gateway:
'.$response.'
'; } if ($_GET["a"] == "start") { $gateway_uuid = $_GET["gateway"]; $cmd = 'api sofia profile '.$profile.' rescan'; $response = trim(event_socket_request($fp, $cmd)); $msg = 'Start Gateway:
'.$response.'
'; } } if (!function_exists('switch_gateway_status')) { function switch_gateway_status($gateway_uuid, $result_type = 'xml') { $fp = event_socket_create($_SESSION['event_socket_ip_address'], $_SESSION['event_socket_port'], $_SESSION['event_socket_password']); $cmd = 'api sofia xmlstatus gateway '.$gateway_uuid; $response = trim(event_socket_request($fp, $cmd)); if ($response == "Invalid Gateway!") { $cmd = 'api sofia xmlstatus gateway '.strtoupper($gateway_uuid); $response = trim(event_socket_request($fp, $cmd)); } return $response; } } } //show the content echo "\n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo "
".$text['title-gateways'].""; echo " \n"; echo "
\n"; echo " \n"; echo " ".$text['description-gateway']."\n"; echo " \n"; echo "
\n"; echo "
\n"; //get total gateway count from the database $sql = "select count(*) as num_rows from v_gateways "; $sql .= "where ( domain_uuid = '".$_SESSION['domain_uuid']."' "; if (permission_exists('gateway_domain')) { $sql .= "or domain_uuid is null "; } $sql .= ");"; $prep_statement = $db->prepare($sql); if ($prep_statement) { $prep_statement->execute(); $row = $prep_statement->fetch(PDO::FETCH_ASSOC); $total_gateways = $row['num_rows']; } unset($sql, $prep_statement, $row); //prepare to page the results $rows_per_page = ($_SESSION['domain']['paging']['numeric'] != '') ? $_SESSION['domain']['paging']['numeric'] : 50; $param = "&order_by=".$order_by."&order=".$order; if (!isset($_GET['page'])) { $_GET['page'] = 0; } $_GET['page'] = check_str($_GET['page']); list($paging_controls, $rows_per_page, $var_3) = paging($total_gateways, $param, $rows_per_page); $offset = $rows_per_page * $_GET['page']; //get the list $sql = "select * from v_gateways "; $sql .= "where ( domain_uuid = '".$_SESSION['domain_uuid']."' "; if (permission_exists('gateway_domain')) { $sql .= "or domain_uuid is null "; } $sql .= ") "; if (strlen($order_by) == 0) { $sql .= "order by gateway asc "; } else { $sql .= "order by $order_by $order "; } $sql .= "limit $rows_per_page offset $offset "; $prep_statement = $db->prepare(check_sql($sql)); $prep_statement->execute(); $gateways = $prep_statement->fetchAll(PDO::FETCH_NAMED); unset ($prep_statement, $sql); $c = 0; $row_style["0"] = "row_style0"; $row_style["1"] = "row_style1"; echo "\n"; echo "\n"; echo th_order_by('gateway', $text['label-gateway'], $order_by, $order); echo th_order_by('context', $text['label-context'], $order_by, $order); if ($fp) { echo "\n"; echo "\n"; echo "\n"; } echo th_order_by('hostname', $text['label-hostname'], $order_by, $order); echo th_order_by('enabled', $text['label-enabled'], $order_by, $order); echo th_order_by('description', $text['label-description'], $order_by, $order); echo "\n"; echo "\n"; if ($total_gateways > 0) { foreach($gateways as $row) { $tr_link = (permission_exists('gateway_edit')) ? "href='gateway_edit.php?id=".$row['gateway_uuid']."'" : null; echo "\n"; echo " \n"; echo " \n"; if ($fp) { if ($row["enabled"] == "true") { $response = switch_gateway_status($row["gateway_uuid"]); if ($response == "Invalid Gateway!") { //not running echo " \n"; echo " \n"; echo " \n"; } else { //running try { $xml = new SimpleXMLElement($response); $state = $xml->state; echo " \n"; echo " \n"; echo " \n"; //REGED, NOREG, UNREGED } catch(Exception $e) { //echo $e->getMessage(); } } } else { echo " \n"; echo " \n"; echo " \n"; } echo " \n"; if ($row["enabled"] == "true") { echo " \n"; } else { echo " \n"; } echo " \n"; echo " \n"; echo "\n"; } if ($c==0) { $c=1; } else { $c=0; } } //end foreach unset($sql, $gateways, $row_count); } //end if results echo "\n"; echo "
".$text['label-status']."".$text['label-action']."".$text['label-state'].""; if (permission_exists('gateway_add')) { if ($_SESSION['limit']['gateways']['numeric'] == '' || ($_SESSION['limit']['gateways']['numeric'] != '' && $total_gateways < $_SESSION['limit']['gateways']['numeric'])) { echo "".$v_link_label_add.""; } } echo "
"; if (permission_exists('gateway_edit')) { echo "".$row["gateway"].""; } else { echo $row["gateway"]; } echo "".$row["context"]."".$text['label-status-stopped']."".$text['label-action-start']." ".$text['label-status-running']."".$text['label-action-stop']."".$state."   ".$row["hostname"]."".$text['label-true']."".$text['label-false']."".$row["description"]." "; if (permission_exists('gateway_edit')) { echo "$v_link_label_edit"; } if (permission_exists('gateway_delete')) { echo "$v_link_label_delete"; } echo "
\n"; echo "
\n"; echo $paging_controls."\n"; echo "

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