123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310 |
- <%#
- Copyright 2017-2019 Dirk Brenken (dev@brenken.org)
- This is free software, licensed under the Apache License, Version 2.0
- -%>
- <%+header%>
- <%+adblock/adblock_css%>
- <script type="text/javascript">
- //<![CDATA[
- function report_json(json)
- {
- document.getElementById("value_1").innerHTML = json.data.start_date + ", " + json.data.start_time || "-";
- document.getElementById("value_2").innerHTML = json.data.end_date + ", " + json.data.end_time || "-";
- document.getElementById("value_3").innerHTML = json.data.total || "-";
- document.getElementById("value_4").innerHTML = json.data.blocked + " (" + json.data.percent + ")" || "-";
- var a_cnt;
- var b_cnt;
- var c_cnt;
- var a_val;
- var b_val;
- var c_val;
- var s = '<div class="tr table-titles">';
- s += '<div class="th left"><%:Count%></div>';
- s += '<div class="th left"><%:Name / IP-Address%></div>';
- s += '<div class="th left"><%:Count%></div>';
- s += '<div class="th left"><%:Domain%></div>';
- s += '<div class="th left"><%:Count%></div>';
- s += '<div class="th left"><%:Blocked Domain%></div></div>';
- for(var i=0;i<10;i++)
- {
- if (i < json.top_clients.length)
- {
- a_cnt = json.top_clients[i].count;
- a_val = json.top_clients[i].address;
- }
- else
- {
- a_cnt = "-";
- a_val = "";
- }
- if (i < json.top_domains.length)
- {
- b_cnt = json.top_domains[i].count;
- b_val = json.top_domains[i].address;
- }
- else
- {
- b_cnt = "-";
- b_val = "";
- }
- if (i < json.top_blocked.length)
- {
- c_cnt = json.top_blocked[i].count;
- c_val = json.top_blocked[i].address;
- }
- else
- {
- c_cnt = "-";
- c_val = "";
- }
- s += '<div class="tr left">';
- s += '<div class="td left" data-title="<%:Count%>">' + a_cnt + '</div>';
- s += '<div class="td left" data-title="<%:Name / IP-Address%>">' + a_val + '</div>';
- s += '<div class="td left" data-title="<%:Count%>">' + b_cnt + '</div>';
- s += '<div class="td left" data-title="<%:Domain%>">' + b_val + '</div>';
- s += '<div class="td left" data-title="<%:Count%>">' + c_cnt + '</div>';
- s += '<div class="td left" data-title="<%:Blocked Domain%>">' + c_val + '</div></div>';
- }
- document.getElementById("value_5").innerHTML = s;
- }
- function report_text(text)
- {
- var s = '<div class="tr table-titles">';
- s += '<div class="th left"><%:Date%></div>';
- s += '<div class="th left"><%:Time%></div>';
- s += '<div class="th left"><%:Client%></div>';
- s += '<div class="th left"><%:Domain%></div>';
- s += '<div class="th left"><%:Answer%></div>';
- s += '<div class="th left"><%:Action%></div></div>';
- var btn1;
- var record;
- var title_arr = ["<%:Date%>", "<%:Time%>", "<%:Client%>", "<%:Domain%>", "<%:Answer%>", "<%:Action%>"];
- var array = text.split("\n");
- for (var i=0;i<array.length;i++)
- {
- record = array[i].split("\t");
- if (record[0] && record[0] != "undefined")
- {
- s += '<div class="tr left">';
- for (var j=0;j<5;j++)
- {
- s += '<div class="td left" data-title="' + title_arr[j] + '">' + record[j] + '</div>';
- if (record[4] === "NX")
- {
- btn1 = '<div class="td left" data-title="' + title_arr[5] + '"><input type="button" class="cbi-button cbi-button-edit" name="add_whitelist,' + record[3] + '" value="<%:Whitelist%>" onclick="btn_action(this)" /></div>';
- }
- else if (record[4] === "OK")
- {
- btn1 = '<div class="td left" data-title="' + title_arr[5] + '"><input type="button" class="cbi-button cbi-button-remove" name="add_blacklist,' + record[3] + '" value="<%:Blacklist%>" onclick="btn_action(this)" /></div>';
- }
- else
- {
- btn1 = '-'
- }
- }
- s += btn1 + '</div>'
- }
- }
- document.getElementById("value_6").innerHTML = s;
- }
- function btn_action(value)
- {
- var action = value.name.split(",");
- if (action[0] === "do_report")
- {
- var btn1 = document.getElementById("btn1");
- var btn1_running = document.getElementById("btn1_running");
- btn1.disabled = true;
- running(btn1_running, 1);
- document.getElementById("filter_search").value = '';
- document.getElementById("filter_count").selectedIndex = 1;
- XHR.get('<%=luci.dispatcher.build_url("admin", "services", "adblock")%>/action/' + action[0], null,
- function(x)
- {
- if (!x)
- {
- return;
- }
- XHR.get('<%=luci.dispatcher.build_url("admin", "services", "adblock", "report_json")%>', null,
- function(x, json_info)
- {
- if (!x || !json_info || !json_info.data)
- {
- running(btn1_running, 0);
- btn1.disabled = false;
- return;
- }
- report_json(json_info);
- });
- XHR.get('<%=luci.dispatcher.build_url("admin", "services", "adblock", "report_text")%>', null,
- function(x)
- {
- if (!x || !x.responseText)
- {
- return;
- }
- report_text(x.responseText);
- running(btn1_running, 0);
- btn1.disabled = false;
- });
- });
- }
- else if (action[0] === "do_filter")
- {
- var btn2 = document.getElementById("btn2");
- var btn2_running = document.getElementById("btn2_running");
- var search = document.getElementById("filter_search").value.replace(/[^\x00-\x7F]|[\s!@#$%^&*()+=\[\]{};'"\\|,<>\/?]/g,'') || "\"+\"";
- var count = document.getElementById("filter_count").value;
- btn2.disabled = true;
- running(btn2_running, 1);
- if (search != "\"+\"")
- {
- document.getElementById("filter_search").value = search;
- }
- XHR.get('<%=luci.dispatcher.build_url("admin", "services", "adblock")%>/action/' + action[0] + "/" + "-" + "/" + search + "/" + count + "/" + "true" + "/" + "false", null,
- function(x)
- {
- if (!x)
- {
- return;
- }
- XHR.get('<%=luci.dispatcher.build_url("admin", "services", "adblock", "report_text")%>', null,
- function(x)
- {
- if (!x || !x.responseText)
- {
- return;
- }
- report_text(x.responseText);
- running(btn2_running, 0);
- btn2.disabled = false;
- });
- });
- }
- else if (action[0] === "add_blacklist" || action[0] === "add_whitelist")
- {
- XHR.get('<%=luci.dispatcher.build_url("admin", "services", "adblock")%>/action/' + action[0] + "/" + action[1], null,
- function(x)
- {
- if (!x)
- {
- return;
- }
- btn3 = document.getElementsByName(value.name);
- for (var i=0; i<btn3.length; i++)
- {
- btn3[i].disabled = true;
- }
- });
- }
- }
- function running(element, state)
- {
- if (state === 1)
- {
- var running_html = '<img src="<%=resource%>/icons/loading.gif" alt="<%:Loading%>" width="16" height="16" style="vertical-align:middle" />';
- element.innerHTML = running_html;
- }
- else
- {
- element.innerHTML = '';
- }
- }
- XHR.get('<%=luci.dispatcher.build_url("admin", "services", "adblock", "report_json")%>', null,
- function(x, json_info)
- {
- if (!x || !json_info || !json_info.data)
- {
- running(btn1_running, 0);
- btn1.disabled = false;
- return;
- }
- report_json(json_info);
- });
- XHR.get('<%=luci.dispatcher.build_url("admin", "services", "adblock", "report_text")%>', null,
- function(x)
- {
- if (!x || !x.responseText)
- {
- return;
- }
- report_text(x.responseText);
- });
- //]]>
- </script>
- <div class="cbi-section">
- <div class="cbi-value" id="status_1">
- <label class="cbi-value-title" for="status_1"><%:Start Date%></label>
- <div class="cbi-value-field">
- <span class="runtime" id="value_1">-</span>
- </div>
- </div>
- <div class="cbi-value" id="status_2">
- <label class="cbi-value-title" for="status_2"><%:End Date%></label>
- <div class="cbi-value-field">
- <span class="runtime" id="value_2">-</span>
- </div>
- </div>
- <div class="cbi-value" id="status_3">
- <label class="cbi-value-title" for="status_3"><%:Total DNS Queries%></label>
- <div class="cbi-value-field">
- <span class="runtime" id="value_3">-</span>
- </div>
- </div>
- <div class="cbi-value" id="status_4">
- <label class="cbi-value-title" for="status_4"><%:Blocked DNS Queries%></label>
- <div class="cbi-value-field">
- <span class="runtime" id="value_4">-</span>
- </div>
- </div>
- <br />
- <div id="button">
- <input type="button" class="cbi-button cbi-button-action important" id="btn1" name="do_report" value="<%:Refresh Report%>" onclick="btn_action(this)" />
- <span id="btn1_running" class="btn1_running"></span>
- </div>
- </div>
- <br />
- <div class="cbi-section">
- <h3><%:Top 10 Reporting%></h3>
- <div class="table" id="value_5"></div>
- </div>
- <hr />
- <div class="cbi-section">
- <div class="cbi-section-descr"><%:Filter the DNS Query result set for a particular domain, client or time frame.%></div>
- <div style="float:left;">
- <input type="text" placeholder="<%:Domain/Client/Date/Time%>" id="filter_search" name="filter_search" />
- <select name="filter_count" id="filter_count">
- <option value="25">25</option>
- <option value="50" selected="selected">50</option>
- <option value="100">100</option>
- <option value="250">250</option>
- <option value="500">500</option>
- </select>
- <input type="button" class="cbi-button cbi-button-action" id="btn2" name="do_filter" value="<%:Filter%>" onclick="btn_action(this)" />
- <span id="btn2_running" class="btn2_running"></span>
- </div>
- <br />
- <br />
- <h3><%:Latest DNS Queries%></h3>
- <div class="table" id="value_6"></div>
- </div>
- <%+footer%>
|