Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Show DNSSEC status icon (if applicable) #3185

Open
wants to merge 5 commits into
base: development
Choose a base branch
from
Open
Changes from 4 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
83 changes: 43 additions & 40 deletions scripts/js/queries.js
Original file line number Diff line number Diff line change
Expand Up @@ -245,30 +245,41 @@ function formatReplyTime(replyTime, type) {
return replyTime;
}

function formatInfo(data) {
// DNSSEC status
var dnssecStatus = data.dnssec,
dnssecClass;
switch (data.dnssec) {
// Parse DNSSEC status
function parseDNSSEC(data) {
var icon = "", // Icon to display
color = "", // Class to apply to text
text = data.dnssec; // Text to display
switch (text) {
case "SECURE":
dnssecClass = "text-green";
icon = "fa-solid fa-lock";
yubiuser marked this conversation as resolved.
Show resolved Hide resolved
color = "text-green";
break;
case "INSECURE":
dnssecClass = "text-orange";
icon = "fa-solid fa-lock-open";
color = "text-orange";
break;
case "BOGUS":
dnssecClass = "text-red";
icon = "fa-solid fa-exclamation-triangle";
color = "text-red";
break;
case "ABANDONED":
dnssecClass = "text-red";
icon = "fa-solid fa-exclamation-triangle";
color = "text-red";
break;
default:
// No DNSSEC or UNKNOWN
dnssecStatus = "N/A";
dnssecClass = false;
text = "N/A";
color = "";
icon = "";
}

return { text: text, icon: icon, color: color };
}

function formatInfo(data) {
// Parse Query Status
var dnssec = parseDNSSEC(data);
var queryStatus = parseQueryStatus(data);
var divStart = '<div class="col-xl-2 col-lg-4 col-md-6 col-12 overflow-wrap">';
var statusInfo = "";
Expand Down Expand Up @@ -321,13 +332,13 @@ function formatInfo(data) {

// Show DNSSEC status if applicable
var dnssecInfo = "";
if (dnssecClass !== false) {
if (dnssec.color !== "") {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
if (dnssec.color !== "") {
if (dnssec.text !== "N/A") {

While being logical equivalent, it feels strange to base the decision on the color status.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actually dnssec.icon and dnssec.color store strings containing CSS classes for the icon shape and icon color.

No color means no icon and text = N/A. No icon means no color and text = N/A. Text=N/A means no icon and no color.

The 3 tests are 100% equivalent:

  • if (dnssec.color !== "");
  • if (dnssec.icon !== "");
  • if (dnssec.text !== "N/A");

dnssecInfo =
divStart +
'DNSSEC status:&nbsp&nbsp;<strong><span class="' +
dnssecClass +
dnssec.color +
'">' +
dnssecStatus +
dnssec.text +
"</span></strong></div>";
}

Expand Down Expand Up @@ -397,30 +408,6 @@ function addSelectSuggestion(name, dict, data) {
}
}

/*
function addChkboxSuggestion(name, data) {
var obj = $("#" + name + "_filter");
obj.empty();

// Add data obtained from API
for (var key in data) {
if (!Object.prototype.hasOwnProperty.call(data, key)) {
continue;
}

var text = data[key];
obj.append(
'<div class="checkbox"><label><input type="checkbox" checked id="' +
name +
"_" +
key +
'">' +
text +
"</label></div>"
);
}
}
*/
function getSuggestions(dict) {
$.get(
"/api/queries/suggestions",
Expand Down Expand Up @@ -579,6 +566,7 @@ $(function () {
},
rowCallback: function (row, data) {
var querystatus = parseQueryStatus(data);
const dnssec = parseDNSSEC(data);

// Remove HTML from querystatus.fieldtext
var rawtext = $("<div/>").html(querystatus.fieldtext).text();
Expand All @@ -603,11 +591,26 @@ $(function () {
// Substitute domain by "." if empty
var domain = data.domain === 0 ? "." : data.domain;

// Append colored icon to domain text
rdwebdesign marked this conversation as resolved.
Show resolved Hide resolved
var dnssecIcon = "";
dnssecIcon =
'<i class="fa fa-fw ' +
dnssec.icon +
" " +
dnssec.color +
'" title="DNSSEC: ' +
dnssec.text +
'"></i>&nbsp;&nbsp;';

// Escape HTML in domain
domain = dnssecIcon + utils.escapeHtml(domain);

if (querystatus.isCNAME) {
// Add domain in CNAME chain causing the query to have been blocked
$("td:eq(3)", row).text(domain + "\n(blocked " + data.cname + ")");
data.cname = utils.escapeHtml(data.cname);
$("td:eq(3)", row).html(domain + "\n(blocked " + data.cname + ")");
} else {
$("td:eq(3)", row).text(domain);
$("td:eq(3)", row).html(domain);
}

// Show hostname instead of IP if available
Expand Down
Loading