diff options
Diffstat (limited to 'html/local.js')
-rw-r--r-- | html/local.js | 279 |
1 files changed, 279 insertions, 0 deletions
diff --git a/html/local.js b/html/local.js new file mode 100644 index 0000000..cefb0a4 --- /dev/null +++ b/html/local.js @@ -0,0 +1,279 @@ +"use strict"; + +var gdata={} + +$(document).ready(function() { + $.ajaxSetup({ cache: false }); + + var qpsgraph = new Rickshaw.Graph( { + element: document.getElementById("qpschart"), + width: 400, + height: 200, + renderer: 'line', + series: new Rickshaw.Series.FixedDuration([{ name: 'servfailps' }, {name: 'qps'}], undefined, { + timeInterval: 1000, + maxDataPoints: 100, + timeBase: new Date().getTime() / 1000 + }) + } ); + var y_ticks = new Rickshaw.Graph.Axis.Y( { + graph: qpsgraph, + orientation: 'left', + tickFormat: Rickshaw.Fixtures.Number.formatKMBT, + element: document.getElementById('qpsy_axis') + } ); + + qpsgraph.render(); + + var cpugraph = new Rickshaw.Graph( { + element: document.getElementById("cpuchart"), + width: 400, + height: 200, + renderer: 'line', + series: new Rickshaw.Series.FixedDuration([{ name: 'one' }, {name: 'two'}], undefined, { + timeInterval: 1000, + maxDataPoints: 100, + timeBase: new Date().getTime() / 1000 + }) + } ); + var y_ticks = new Rickshaw.Graph.Axis.Y( { + graph: cpugraph, + orientation: 'left', + tickFormat: Rickshaw.Fixtures.Number.formatKMBT, + element: document.getElementById('cpuy_axis') + } ); + + cpugraph.render(); + var intervalcount=0; + + function updateRingBuffers() + { + var filtered=$("#filter1").is(':checked') + var qstring='jsonstat?command=get-query-ring&name=queries'; + if(filtered) + qstring=qstring+"&public-filtered=1"; + + $.getJSON(qstring, + function(data) { + console.log(data); + var bouw="<table><tr><th>Number</th><th>Domain</th><th>Type</th></tr>"; + var num=0; + var total=0, rest=0; + $.each(data["entries"], function(a,b) { + total+=b[0]; + if(num++ > 10) { + rest+=b[0]; + return; + } + if(b[1].length > 25) + b[1]=b[1].substring(0,25); + + bouw=bouw+("<tr><td>"+b[0]+"</td><td>"+b[1]+"</td><td>"+b[2]+"</td></tr>"); + }); + bouw+="<tr><td>"+rest+"</td><td>Rest</td></tr>"; + bouw=bouw+"</table>"; + $("#queryring").html(bouw); + + }); + + filtered=$("#filter2").is(':checked') + qstring='jsonstat?command=get-query-ring&name=servfail-queries'; + if(filtered) + qstring=qstring+"&public-filtered=1"; + + $.getJSON(qstring, + function(data) { + var bouw="<table><tr><th>Number</th><th>Servfail domain</th><th>Type</th></tr>"; + var num=0, total=0, rest=0; + $.each(data["entries"], function(a,b) { + total+=b[0]; + if(num++ > 10) { + rest+=b[0]; + return; + } + if(b[1].length > 25) + b[1]=b[1].substring(0,25); + bouw=bouw+("<tr><td>"+b[0]+"</td><td>"+b[1]+"</td><td>"+b[2]+"</td></tr>"); + }); + bouw+="<tr><td>"+rest+"</td><td>Rest</td></tr>"; + bouw=bouw+"</table>"; + $("#servfailqueryring").html(bouw); + + }); + + $.getJSON('jsonstat?command=get-remote-ring&name=remotes', + function(data) { + var bouw="<table><tr><th>Number</th><th>Remote</th></tr>"; + var num=0, total=0, rest=0; + $.each(data["entries"], function(a,b) { + total+=b[0]; + if(num++ > 10) { + rest +=b[0]; + return; + } + bouw=bouw+("<tr><td>"+b[0]+"</td><td>"+b[1]+"</td></tr>"); + }); + bouw+="<tr><td>"+rest+"</td><td>Rest</td></tr>"; + bouw=bouw+"</table>"; + $("#remotering").html(bouw); + + }); + + $.getJSON('jsonstat?command=get-remote-ring&name=servfail-remotes', + function(data) { + var bouw="<table><tr><th>Number</th><th>Servfail Remote</th></tr>"; + var num=0, total=0, rest=0; + $.each(data["entries"], function(a,b) { + total+=b[0]; + if(num++ > 10) { + rest += b[0]; + return; + } + bouw=bouw+("<tr><td>"+b[0]+"</td><td>"+b[1]+"</td></tr>"); + }); + bouw+="<tr><td>"+rest+"</td><td>Rest</td></tr>"; + bouw=bouw+"</table>"; + $("#servfailremotering").html(bouw); + }); + } + + function update() + { + $.ajax({ + url: 'jsonstat?command=stats', + type: 'GET', + dataType: 'json', + jsonp: false, + success: function(data, x, y) { + $("#questions").text(data["queries"]); + $("#acl-drops").text(data["acl-drops"]); + $("#dyn-drops").text(data["dyn-blocked"]); + $("#rule-drops").text(data["rule-drop"]); + $("#uptime").text(moment.duration(data["uptime"]*1000.0).humanize()); + $("#latency").text((data["latency-avg10000"]/1000.0).toFixed(2)); + $("#latency-tcp").text((data["latency-tcp-avg10000"]/1000.0).toFixed(2)); + $("#latency-dot").text((data["latency-dot-avg10000"]/1000.0).toFixed(2)); + $("#latency-doh").text((data["latency-doh-avg10000"]/1000.0).toFixed(2)); + if(!gdata["cpu-sys-msec"]) + gdata=data; + + var cpu=((1.0*data["cpu-sys-msec"]+1.0*data["cpu-user-msec"] - 1.0*gdata["cpu-sys-msec"]-1.0*gdata["cpu-user-msec"])/10.0); + + $("#cpu").text(cpu.toFixed(2)); + var qps=1.0*data["queries"]-1.0*gdata["queries"]; + $("#qps").text(qps.toFixed(2)); + $("#server-policy").text(data["server-policy"]); + + var servfailps=1.0*data["servfail-responses"]-1.0*gdata["servfail-responses"]; + + var totpcache=1.0*data["cache-hits"]-1.0*gdata["cache-hits"]+1.0*data["cache-misses"]-1.0*gdata["cache-misses"]; + var hitrate=0; + if(totpcache > 0) { + hitrate=100.0*(data["cache-hits"]-1.0*gdata["cache-hits"])/totpcache; + $("#phitrate").text(hitrate.toFixed(2)); + } + else + $("#phitrate").text(0); + + qpsgraph.series.addData({ qps: qps, servfailps: servfailps}); + qpsgraph.render(); + + cpugraph.series.addData({ one: cpu, two: hitrate}); + cpugraph.render(); + + gdata=data; + }, + error: function() { + + }, + }); + + $.ajax({ url: 'api/v1/servers/localhost', type: 'GET', dataType: 'json', jsonp: false, + success: function(data) { + $("#version").text(data["daemon_type"]+" "+data["version"]); + $("#acl").text(data["acl"]); + $("#local").text(data["local"]); + var bouw='<table width="100%"><tr align=right><th>#</th><th align=left>Name</th><th align=left>Address</th><th>Status</th><th>UDP Latency</th><th>TCP Latency</th><th>Queries</th><th>Drops</th><th>QPS</th><th>Out</th><th>Weight</th><th>Order</th><th align=left>Pools</th></tr>'; + $.each(data["servers"], function(a,b) { + bouw = bouw + ("<tr align=right><td>"+b["id"]+"</td><td align=left>"+b["name"]+"</td><td align=left>"+b["address"]+"</td><td>"+b["state"]+"</td>"); + var latency = (b["latency"] === null || b["latency"] === 0.0) ? "-" : b["latency"].toFixed(2); + var tcpLatency = (b["tcpLatency"] === null || b["tcpLatency"] === 0.0) ? "-" : b["tcpLatency"].toFixed(2); + bouw = bouw + ("<td>"+latency+"</td><td>"+tcpLatency+"</td><td>"+b["queries"]+"</td><td>"+b["reuseds"]+"</td><td>"+(b["qps"]).toFixed(2)+"</td><td>"+b["outstanding"]+"</td>"); + bouw = bouw + ("<td>"+b["weight"]+"</td><td>"+b["order"]+"</td><td align=left>"+b["pools"]+"</td></tr>"); + }); + bouw = bouw + "</table>"; + $("#downstreams").html(bouw); + + bouw='<table width="100%"><tr align=left><th>#</th><th align=left>Rule</th><th>Action</th><th>Matches</th></tr>'; + if(data["rules"].length) { + $.each(data["rules"], function(a,b) { + bouw = bouw + ("<tr align=left><td>"+b["id"]+"</td><td align=left>"+b["rule"]+"</td><td>"+b["action"]+"</td>"); + bouw = bouw + ("<td>"+b["matches"]+"</td></tr>"); + }); + } + else + bouw = bouw + '<tr><td align="center" colspan="4"><font color="#aaaaaa">No rules defined</font></td></tr>'; + bouw = bouw + "</table>"; + $("#rules").html(bouw); + + bouw='<table width="100%"><tr align=left><th>#</th><th align=left>Response Rule</th><th>Action</th><th>Matches</th></tr>'; + if(data["response-rules"].length) { + $.each(data["response-rules"], function(a,b) { + bouw = bouw + ("<tr align=left><td>"+b["id"]+"</td><td align=left>"+b["rule"]+"</td><td>"+b["action"]+"</td>"); + bouw = bouw + ("<td>"+b["matches"]+"</td></tr>"); + }); + } + else + bouw = bouw + '<tr><td align="center" colspan="4"><font color="#aaaaaa">No response rules defined</font></td></tr>'; + bouw = bouw + "</table>"; + $("#response-rules").html(bouw); + } + }); + + +// if((intervalcount++)%5) + // return; + // updateRingBuffers(); + + $.ajax({ url: 'jsonstat?command=dynblocklist', type: 'GET', dataType: 'json', jsonp: false, + success: function(data) { + var bouw='<table width="100%"><tr align=left><th>Dyn blocked netmask</th><th>Seconds</th><th>Blocks</th><th>eBPF</th><th align=left>Reason</th></tr>'; + var gotsome=false; + $.each(data, function(a,b) { + bouw=bouw+("<tr><td>"+a+"</td><td>"+b.seconds+"</td><td>"+b.blocks+"</td><td>"+b.ebpf+"</td><td>"+b.reason+"</td></tr>"); + gotsome=true; + }); + + if(!gotsome) + bouw = bouw + '<tr><td align="center" colspan="4"><font color="#aaaaaa">No dynamic blocks active</font></td></tr>'; + + bouw=bouw+"</table>"; + $("#dynblock").html(bouw); + + }}); + + $.ajax({ url: 'jsonstat?command=ebpfblocklist', type: 'GET', dataType: 'json', jsonp: false, + success: function(data) { + var bouw='<table width="100%"><tr align=left><th>Kernel-based dyn blocked netmask</th><th>Seconds</th></th><th>Blocks</th></tr>'; + var gotsome=false; + $.each(data, function(a,b) { + bouw=bouw+("<tr><td>"+a+"</td><td>"+b.seconds+"</td><td>"+b.blocks+"</td></tr>"); + gotsome=true; + }); + + if(!gotsome) + bouw = bouw + '<tr><td align="center" colspan="4"><font color="#aaaaaa">No eBPF blocks active</font></td></tr>'; + + bouw=bouw+"</table>"; + $("#ebpfblock").html(bouw); + + }}); + + }; + + $("#filter1").click(updateRingBuffers); + $("#filter2").click(updateRingBuffers); + + update(); + setInterval(update, 1000); +}); |