2020-05-28 10:42:36 +02:00
|
|
|
<main class="container">
|
|
|
|
<div id="diagnostics-block" class="my-3 p-3 bg-white rounded shadow">
|
|
|
|
<h6 class="border-bottom pb-2 mb-2">Diagnostics</h6>
|
|
|
|
|
|
|
|
<h3>Version</h3>
|
|
|
|
<div class="row">
|
|
|
|
<div class="col-md">
|
|
|
|
<dl class="row">
|
2020-05-28 20:25:25 +02:00
|
|
|
<dt class="col-sm-5">Server Installed
|
|
|
|
<span class="badge badge-success d-none" id="server-success" title="Latest version is installed.">Ok</span>
|
|
|
|
<span class="badge badge-warning d-none" id="server-warning" title="There seems to be an update available.">Update</span>
|
2020-06-04 17:05:17 +02:00
|
|
|
<span class="badge badge-info d-none" id="server-branch" title="This is a branched version.">Branched</span>
|
2020-05-28 20:25:25 +02:00
|
|
|
</dt>
|
2020-05-28 10:42:36 +02:00
|
|
|
<dd class="col-sm-7">
|
|
|
|
<span id="server-installed">{{version}}</span>
|
|
|
|
</dd>
|
2020-06-03 17:07:32 +02:00
|
|
|
<dt class="col-sm-5">Server Latest
|
|
|
|
<span class="badge badge-danger d-none" id="server-failed" title="Unable to determine latest version.">Unknown</span>
|
|
|
|
</dt>
|
2020-05-28 20:25:25 +02:00
|
|
|
<dd class="col-sm-7">
|
|
|
|
<span id="server-latest">{{diagnostics.latest_release}}<span id="server-latest-commit" class="d-none">-{{diagnostics.latest_commit}}</span></span>
|
|
|
|
</dd>
|
|
|
|
<dt class="col-sm-5">Web Installed
|
|
|
|
<span class="badge badge-success d-none" id="web-success" title="Latest version is installed.">Ok</span>
|
|
|
|
<span class="badge badge-warning d-none" id="web-warning" title="There seems to be an update available.">Update</span>
|
|
|
|
</dt>
|
2020-05-28 10:42:36 +02:00
|
|
|
<dd class="col-sm-7">
|
|
|
|
<span id="web-installed">{{diagnostics.web_vault_version}}</span>
|
|
|
|
</dd>
|
2020-06-03 17:07:32 +02:00
|
|
|
<dt class="col-sm-5">Web Latest
|
|
|
|
<span class="badge badge-danger d-none" id="web-failed" title="Unable to determine latest version.">Unknown</span>
|
|
|
|
</dt>
|
2020-05-28 20:25:25 +02:00
|
|
|
<dd class="col-sm-7">
|
|
|
|
<span id="web-latest">{{diagnostics.latest_web_build}}</span>
|
|
|
|
</dd>
|
2020-05-28 10:42:36 +02:00
|
|
|
</dl>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<h3>Checks</h3>
|
|
|
|
<div class="row">
|
|
|
|
<div class="col-md">
|
|
|
|
<dl class="row">
|
|
|
|
<dt class="col-sm-5">DNS (github.com)
|
|
|
|
<span class="badge badge-success d-none" id="dns-success" title="DNS Resolving works!">Ok</span>
|
|
|
|
<span class="badge badge-danger d-none" id="dns-warning" title="DNS Resolving failed. Please fix.">Error</span>
|
|
|
|
</dt>
|
|
|
|
<dd class="col-sm-7">
|
|
|
|
<span id="dns-resolved">{{diagnostics.dns_resolved}}</span>
|
|
|
|
</dd>
|
|
|
|
|
|
|
|
<dt class="col-sm-5">Date & Time (UTC)
|
|
|
|
<span class="badge badge-success d-none" id="time-success" title="Time offsets seem to be correct.">Ok</span>
|
|
|
|
<span class="badge badge-danger d-none" id="time-warning" title="Time offsets are too mouch at drift.">Error</span>
|
|
|
|
</dt>
|
|
|
|
<dd class="col-sm-7">
|
|
|
|
<span id="time-server" class="d-block"><b>Server:</b> <span id="time-server-string">{{diagnostics.server_time}}</span></span>
|
|
|
|
<span id="time-browser" class="d-block"><b>Browser:</b> <span id="time-browser-string"></span></span>
|
|
|
|
</dd>
|
|
|
|
</dl>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</main>
|
|
|
|
|
|
|
|
<script>
|
2020-05-28 20:25:25 +02:00
|
|
|
(() => {
|
|
|
|
const d = new Date();
|
|
|
|
const year = d.getUTCFullYear();
|
2020-06-04 17:05:17 +02:00
|
|
|
const month = String(d.getUTCMonth()+1).padStart(2, '0');
|
2020-05-28 20:25:25 +02:00
|
|
|
const day = String(d.getUTCDate()).padStart(2, '0');
|
|
|
|
const hour = String(d.getUTCHours()).padStart(2, '0');
|
|
|
|
const minute = String(d.getUTCMinutes()).padStart(2, '0');
|
|
|
|
const seconds = String(d.getUTCSeconds()).padStart(2, '0');
|
|
|
|
const browserUTC = year + '-' + month + '-' + day + ' ' + hour + ':' + minute + ':' + seconds;
|
|
|
|
document.getElementById("time-browser-string").innerText = browserUTC;
|
|
|
|
|
|
|
|
const serverUTC = document.getElementById("time-server-string").innerText;
|
|
|
|
const timeDrift = (Date.parse(serverUTC) - Date.parse(browserUTC)) / 1000;
|
|
|
|
if (timeDrift > 30 || timeDrift < -30) {
|
|
|
|
document.getElementById('time-warning').classList.remove('d-none');
|
|
|
|
} else {
|
|
|
|
document.getElementById('time-success').classList.remove('d-none');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Check if the output is a valid IP
|
|
|
|
const isValidIp = value => (/^(?:(?:^|\.)(?:2(?:5[0-5]|[0-4]\d)|1?\d?\d)){4}$/.test(value) ? true : false);
|
|
|
|
if (isValidIp(document.getElementById('dns-resolved').innerText)) {
|
|
|
|
document.getElementById('dns-success').classList.remove('d-none');
|
|
|
|
} else {
|
|
|
|
document.getElementById('dns-warning').classList.remove('d-none');
|
|
|
|
}
|
|
|
|
|
|
|
|
let serverInstalled = document.getElementById('server-installed').innerText;
|
|
|
|
let serverLatest = document.getElementById('server-latest').innerText;
|
2020-06-04 17:05:17 +02:00
|
|
|
let serverLatestCommit = document.getElementById('server-latest-commit').innerText.replace('-', '');
|
|
|
|
if (serverInstalled.indexOf('-') !== -1 && serverLatest !== '-' && serverLatestCommit !== '-') {
|
2020-05-28 20:25:25 +02:00
|
|
|
document.getElementById('server-latest-commit').classList.remove('d-none');
|
|
|
|
}
|
|
|
|
|
|
|
|
const webInstalled = document.getElementById('web-installed').innerText;
|
|
|
|
const webLatest = document.getElementById('web-latest').innerText;
|
|
|
|
|
2020-06-04 17:05:17 +02:00
|
|
|
checkVersions('server', serverInstalled, serverLatest, serverLatestCommit);
|
2020-05-28 20:25:25 +02:00
|
|
|
checkVersions('web', webInstalled, webLatest);
|
2020-05-28 10:42:36 +02:00
|
|
|
|
2020-06-04 17:05:17 +02:00
|
|
|
function checkVersions(platform, installed, latest, commit=null) {
|
2020-05-28 20:25:25 +02:00
|
|
|
if (installed === '-' || latest === '-') {
|
|
|
|
document.getElementById(platform + '-failed').classList.remove('d-none');
|
|
|
|
return;
|
|
|
|
}
|
2020-05-28 10:42:36 +02:00
|
|
|
|
2020-06-04 17:05:17 +02:00
|
|
|
// Only check basic versions, no commit revisions
|
|
|
|
if (commit === null || installed.indexOf('-') === -1) {
|
|
|
|
if (installed !== latest) {
|
|
|
|
document.getElementById(platform + '-warning').classList.remove('d-none');
|
|
|
|
} else {
|
|
|
|
document.getElementById(platform + '-success').classList.remove('d-none');
|
|
|
|
}
|
2020-05-28 20:25:25 +02:00
|
|
|
} else {
|
2020-06-04 17:05:17 +02:00
|
|
|
// Check if this is a branched version.
|
|
|
|
const branchRegex = /(?:\s)\((.*?)\)/;
|
|
|
|
const branchMatch = installed.match(branchRegex);
|
|
|
|
if (branchMatch !== null) {
|
|
|
|
document.getElementById(platform + '-branch').classList.remove('d-none');
|
|
|
|
}
|
|
|
|
|
|
|
|
// This will remove branch info and check if there is a commit hash
|
|
|
|
const installedRegex = /(\d+\.\d+\.\d+)-(\w+)/;
|
|
|
|
const instMatch = installed.match(installedRegex);
|
|
|
|
|
|
|
|
// It could be that a new tagged version has the same commit hash.
|
|
|
|
// In this case the version is the same but only the number is different
|
|
|
|
if (instMatch !== null) {
|
|
|
|
if (instMatch[2] === commit) {
|
|
|
|
// The commit hashes are the same, so latest version is installed
|
|
|
|
document.getElementById(platform + '-success').classList.remove('d-none');
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (installed === latest) {
|
|
|
|
document.getElementById(platform + '-success').classList.remove('d-none');
|
|
|
|
} else {
|
|
|
|
document.getElementById(platform + '-warning').classList.remove('d-none');
|
|
|
|
}
|
2020-05-28 20:25:25 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
})();
|
2020-05-28 10:42:36 +02:00
|
|
|
</script>
|