diff options
author | Renato Botelho <garga@FreeBSD.org> | 2013-07-24 09:10:20 -0300 |
---|---|---|
committer | Renato Botelho <garga@FreeBSD.org> | 2013-07-24 09:10:20 -0300 |
commit | 0e4eefc67dc0240ba47034e1d5822f0993bbddc1 (patch) | |
tree | 799d6f9940e9a1e53a8bd5b53734a3242f3c04af /config/openbgpd | |
parent | 1a28161d11cd9f6895b362a3297f5f737701c145 (diff) | |
download | pfsense-packages-0e4eefc67dc0240ba47034e1d5822f0993bbddc1.tar.gz pfsense-packages-0e4eefc67dc0240ba47034e1d5822f0993bbddc1.tar.bz2 pfsense-packages-0e4eefc67dc0240ba47034e1d5822f0993bbddc1.zip |
Implement ajax call for routing limit and filter
Diffstat (limited to 'config/openbgpd')
-rw-r--r-- | config/openbgpd/openbgpd_status.php | 54 |
1 files changed, 52 insertions, 2 deletions
diff --git a/config/openbgpd/openbgpd_status.php b/config/openbgpd/openbgpd_status.php index 6570213d..7ce6e19a 100644 --- a/config/openbgpd/openbgpd_status.php +++ b/config/openbgpd/openbgpd_status.php @@ -78,12 +78,37 @@ function doCmdT($command, $limit = "all", $filter = "") { return $result; } +function countCmdT($command) { + $fd = popen("{$command} 2>&1", "r"); + $c = 0; + while (fgets($fd) !== FALSE) + $c++; + + return $c; +} + function showCmdT($idx, $title, $command) { echo "<p>\n"; echo "<a name=\"" . $title . "\"> </a>\n"; echo "<table width=\"100%\" border=\"0\" cellpadding=\"0\" cellspacing=\"0\">\n"; - echo "<tr><td class=\"listtopic\">" . $title . "</td></tr>\n"; - echo "<tr><td class=\"listlr\"><pre>"; /* no newline after pre */ + echo "<tr><td colspan=\"2\" class=\"listtopic\">" . $title . "</td></tr>\n"; + + if ($idx == "routing") { + $limit_options = array("10", "50", "100", "200", "500", "1000", "all"); + $limit_default = "100"; + + echo "<tr><td class=\"listhdr\" style=\"font-weight:bold;\">\n"; + echo "Display <select onchange=\"update_routing();\" name=\"routing_limit\" id=\"routing_limit\">\n"; + foreach ($limit_options as $item) + echo "<option value='{$item}' " . ($item == $limit_default ? "selected" : "") . ">{$item}</option>\n"; + echo "</select> of " . countCmdT($command) . " routes</td>\n"; + echo "<td class=\"listhdr\" align=\"right\" style=\"font-weight:bold;\">Filter expression: \n"; + echo "<input type=\"text\" name=\"routing_filter\" id=\"routing_filter\" class=\"formfld search\" value=\"" . htmlspecialchars($_REQUEST['routing_filter']) . "\" size=\"30\" />\n"; + echo "<input type=\"button\" class=\"formbtn\" value=\"Filter\" onclick=\"update_routing();\" />\n"; + echo "</td></tr>\n"; + } + + echo "<tr><td colspan=\"2\" class=\"listlr\"><pre id=\"{$idx}\">"; /* no newline after pre */ echo doCmdT($command); echo "</pre></td></tr>\n"; echo "</table>\n"; @@ -157,6 +182,31 @@ function execCmds() { </table> </div> +<script type="text/javascript"> +//<![CDATA[ + + function update_routing() { + var url = "openbgpd_status.php"; + var index = document.getElementById("routing_limit").selectedIndex; + var limit = document.getElementById("routing_limit").options[index].value; + var filter = document.getElementById("routing_filter").value; + var params = "isAjax=true&cmd=routing&limit=" + limit + "&filter=" + filter; + var myAjax = new Ajax.Request( + url, + { + method: 'post', + parameters: params, + onComplete: update_routing_callback + }); + } + + function update_routing_callback(transport) { + document.getElementById("routing").textContent = transport.responseText; + } + +//]]> +</script> + <?php include("fend.inc"); ?> </body> |