2021-01-19 16:55:21 +00:00
<main class="container-xl">
2020-05-28 08:42:36 +00:00
<div id="diagnostics-block" class="my-3 p-3 bg-white rounded shadow">
<h6 class="border-bottom pb-2 mb-2">Diagnostics</h6>
2021-03-27 23:10:01 +00:00
<h3>Versions</h3>
2020-05-28 08:42:36 +00:00
<div class="row">
<div class="col-md">
<dl class="row">
2020-05-28 18:25:25 +00: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 15:05:17 +00:00
<span class="badge badge-info d-none" id="server-branch" title="This is a branched version.">Branched</span>
2020-05-28 18:25:25 +00:00
</dt>
2020-05-28 08:42:36 +00:00
<dd class="col-sm-7">
<span id="server-installed"> {{ version }} </span>
</dd>
2020-06-03 15:07:32 +00:00
<dt class="col-sm-5">Server Latest
2021-01-19 16:55:21 +00:00
<span class="badge badge-secondary d-none" id="server-failed" title="Unable to determine latest version.">Unknown</span>
2020-06-03 15:07:32 +00:00
</dt>
2020-05-28 18:25:25 +00: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>
2021-04-05 13:09:16 +00:00
{{ # if diagnostics .web_vault_enabled }}
2020-05-28 18:25:25 +00:00
<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 08:42:36 +00:00
<dd class="col-sm-7">
<span id="web-installed"> {{ diagnostics .web_vault_version }} </span>
</dd>
2021-02-03 17:43:54 +00:00
{{ # unless diagnostics .running_within_docker }}
2020-06-03 15:07:32 +00:00
<dt class="col-sm-5">Web Latest
2021-01-19 16:55:21 +00:00
<span class="badge badge-secondary d-none" id="web-failed" title="Unable to determine latest version.">Unknown</span>
2020-06-03 15:07:32 +00:00
</dt>
2020-05-28 18:25:25 +00:00
<dd class="col-sm-7">
<span id="web-latest"> {{ diagnostics .latest_web_build }} </span>
</dd>
2021-02-03 17:43:54 +00:00
{{ / unless }}
2021-04-05 13:09:16 +00:00
{{ / if }}
{{ # unless diagnostics .web_vault_enabled }}
<dt class="col-sm-5">Web Installed</dt>
<dd class="col-sm-7">
<span id="web-installed">Web Vault is disabled</span>
</dd>
{{ / unless }}
2021-03-27 23:10:01 +00:00
<dt class="col-sm-5">Database</dt>
<dd class="col-sm-7">
<span><b> {{ diagnostics .db_type }} :</b> {{ diagnostics .db_version }} </span>
</dd>
2020-05-28 08:42:36 +00:00
</dl>
</div>
</div>
<h3>Checks</h3>
<div class="row">
<div class="col-md">
<dl class="row">
2021-01-19 16:55:21 +00:00
<dt class="col-sm-5">Running within Docker</dt>
<dd class="col-sm-7">
{{ # if diagnostics .running_within_docker }}
2021-03-27 23:10:01 +00:00
<span class="d-block"><b>Yes</b></span>
2021-01-19 16:55:21 +00:00
{{ / if }}
{{ # unless diagnostics .running_within_docker }}
2021-03-27 23:10:01 +00:00
<span class="d-block"><b>No</b></span>
2021-01-19 16:55:21 +00:00
{{ / unless }}
</dd>
2021-03-27 23:10:01 +00:00
<dt class="col-sm-5">Uses a reverse proxy</dt>
2021-01-19 16:55:21 +00:00
<dd class="col-sm-7">
2021-03-27 23:10:01 +00:00
{{ # if diagnostics .ip_header_exists }}
<span class="d-block" title="IP Header found."><b>Yes</b></span>
2021-01-19 16:55:21 +00:00
{{ / if }}
2021-03-27 23:10:01 +00:00
{{ # unless diagnostics .ip_header_exists }}
<span class="d-block" title="No IP Header found."><b>No</b></span>
{{ / unless }}
</dd>
{{!-- Only show this if the IP Header Exists --}}
{{ # if diagnostics .ip_header_exists }}
<dt class="col-sm-5">IP header
{{ # if diagnostics .ip_header_match }}
<span class="badge badge-success" title="IP_HEADER config seems to be valid.">Match</span>
{{ / if }}
{{ # unless diagnostics .ip_header_match }}
<span class="badge badge-danger" title="IP_HEADER config seems to be invalid. IP's in the log could be invalid. Please fix.">No Match</span>
{{ / unless }}
</dt>
<dd class="col-sm-7">
{{ # if diagnostics .ip_header_match }}
<span class="d-block"><b>Config/Server:</b> {{ diagnostics .ip_header_name }} </span>
{{ / if }}
{{ # unless diagnostics .ip_header_match }}
<span class="d-block"><b>Config:</b> {{ diagnostics .ip_header_config }} </span>
<span class="d-block"><b>Server:</b> {{ diagnostics .ip_header_name }} </span>
2021-01-19 16:55:21 +00:00
{{ / unless }}
</dd>
2021-03-27 23:10:01 +00:00
{{ / if }}
{{!-- End if IP Header Exists --}}
2021-01-19 16:55:21 +00:00
<dt class="col-sm-5">Internet access
{{ # if diagnostics .has_http_access }}
2021-03-27 23:10:01 +00:00
<span class="badge badge-success" title="We have internet access!">Ok</span>
2021-01-19 16:55:21 +00:00
{{ / if }}
{{ # unless diagnostics .has_http_access }}
2021-03-27 23:10:01 +00:00
<span class="badge badge-danger" title="There seems to be no internet access. Please fix.">Error</span>
2021-01-19 16:55:21 +00:00
{{ / unless }}
</dt>
<dd class="col-sm-7">
{{ # if diagnostics .has_http_access }}
2021-03-27 23:10:01 +00:00
<span class="d-block"><b>Yes</b></span>
2021-01-19 16:55:21 +00:00
{{ / if }}
{{ # unless diagnostics .has_http_access }}
2021-03-27 23:10:01 +00:00
<span class="d-block"><b>No</b></span>
{{ / unless }}
</dd>
<dt class="col-sm-5">Internet access via a proxy</dt>
<dd class="col-sm-7">
{{ # if diagnostics .uses_proxy }}
<span class="d-block" title="Internet access goes via a proxy (HTTPS_PROXY or HTTP_PROXY is configured)."><b>Yes</b></span>
{{ / if }}
{{ # unless diagnostics .uses_proxy }}
<span class="d-block" title="We have direct internet access, no outgoing proxy configured."><b>No</b></span>
2021-01-19 16:55:21 +00:00
{{ / unless }}
</dd>
2020-05-28 08:42:36 +00:00
<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>
2021-04-05 13:09:16 +00:00
<dt class="col-sm-5">Date & Time (Local)</dt>
<dd class="col-sm-7">
<span><b>Server:</b> {{ diagnostics .server_time_local }} </span>
</dd>
2020-05-28 08:42:36 +00:00
<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>
2021-01-19 16:55:21 +00:00
<dt class="col-sm-5">Domain configuration
2021-02-03 17:43:54 +00:00
<span class="badge badge-success d-none" id="domain-success" title="The domain variable matches the browser location and seems to be configured correctly.">Match</span>
<span class="badge badge-danger d-none" id="domain-warning" title="The domain variable does not matches the browsers location.
The domain variable does not seem to be configured correctly.
Some features may not work as expected!">No Match</span>
<span class="badge badge-success d-none" id="https-success" title="Configurued to use HTTPS">HTTPS</span>
<span class="badge badge-danger d-none" id="https-warning" title="Not configured to use HTTPS.
Some features may not work as expected!">No HTTPS</span>
2021-01-19 16:55:21 +00:00
</dt>
<dd class="col-sm-7">
<span id="domain-server" class="d-block"><b>Server:</b> <span id="domain-server-string"> {{ diagnostics .admin_url }} </span></span>
<span id="domain-browser" class="d-block"><b>Browser:</b> <span id="domain-browser-string"></span></span>
</dd>
</dl>
</div>
</div>
<h3>Support</h3>
<div class="row">
<div class="col-md">
<dl class="row">
<dd class="col-sm-12">
If you need support please check the following links first before you create a new issue:
2021-04-27 21:18:32 +00:00
<a href="https://bitwardenrs.discourse.group/" target="_blank" rel="noreferrer">Vaultwarden Forum</a>
| <a href="https://github.com/dani-garcia/vaultwarden/discussions" target="_blank" rel="noreferrer">Github Discussions</a>
2021-01-19 16:55:21 +00:00
</dd>
</dl>
<dl class="row">
<dd class="col-sm-12">
You can use the button below to pre-generate a string which you can copy/paste on either the Forum or when Creating a new issue at Github.<br>
We try to hide the most sensitive values from the generated support string by default, but please verify if there is nothing in there which you want to hide!<br>
</dd>
</dl>
<dl class="row">
<dt class="col-sm-3">
<button type="button" id="gen-support" class="btn btn-primary" onclick="generateSupportString(); return false;">Generate Support String</button>
<br><br>
<button type="button" id="copy-support" class="btn btn-info d-none" onclick="copyToClipboard(); return false;">Copy To Clipboard</button>
</dt>
<dd class="col-sm-9">
<pre id="support-string" class="pre-scrollable d-none" style="width: 100%; height: 16em; size: 0.6em; border: 1px solid; padding: 4px;"></pre>
</dd>
2020-05-28 08:42:36 +00:00
</dl>
</div>
</div>
</div>
</main>
<script>
2021-01-19 16:55:21 +00:00
dnsCheck = false;
timeCheck = false;
domainCheck = false;
2021-02-03 17:43:54 +00:00
httpsCheck = false;
2020-05-28 18:25:25 +00:00
(() => {
2021-01-19 16:55:21 +00:00
// ================================
// Date & Time Check
2020-05-28 18:25:25 +00:00
const d = new Date();
const year = d.getUTCFullYear();
2020-06-04 15:05:17 +00:00
const month = String(d.getUTCMonth()+1).padStart(2, '0');
2020-05-28 18:25:25 +00: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');
2020-12-12 06:47:54 +00:00
const browserUTC = `$ { year}-$ { month}-$ { day} $ { hour}:$ { minute}:$ { seconds} UTC`;
2020-05-28 18:25:25 +00:00
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');
2021-01-19 16:55:21 +00:00
timeCheck = true;
2020-05-28 18:25:25 +00:00
}
2021-01-19 16:55:21 +00:00
// ================================
2020-05-28 18:25:25 +00:00
// 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');
2021-01-19 16:55:21 +00:00
dnsCheck = true;
2020-05-28 18:25:25 +00:00
} else {
document.getElementById('dns-warning').classList.remove('d-none');
}
2021-01-19 16:55:21 +00:00
// ================================
2021-04-27 21:18:32 +00:00
// Version check for both vaultwarden and web-vault
2020-05-28 18:25:25 +00:00
let serverInstalled = document.getElementById('server-installed').innerText;
let serverLatest = document.getElementById('server-latest').innerText;
2020-06-04 15:05:17 +00:00
let serverLatestCommit = document.getElementById('server-latest-commit').innerText.replace('-', '');
if (serverInstalled.indexOf('-') !== -1 && serverLatest !== '-' && serverLatestCommit !== '-') {
2020-05-28 18:25:25 +00:00
document.getElementById('server-latest-commit').classList.remove('d-none');
}
const webInstalled = document.getElementById('web-installed').innerText;
2020-06-04 15:05:17 +00:00
checkVersions('server', serverInstalled, serverLatest, serverLatestCommit);
2021-02-03 17:43:54 +00:00
{{ # unless diagnostics .running_within_docker }}
const webLatest = document.getElementById('web-latest').innerText;
2020-05-28 18:25:25 +00:00
checkVersions('web', webInstalled, webLatest);
2021-02-03 17:43:54 +00:00
{{ / unless }}
2020-05-28 08:42:36 +00:00
2020-06-04 15:05:17 +00:00
function checkVersions(platform, installed, latest, commit=null) {
2020-05-28 18:25:25 +00:00
if (installed === '-' || latest === '-') {
document.getElementById(platform + '-failed').classList.remove('d-none');
return;
}
2020-05-28 08:42:36 +00:00
2020-06-04 15:05:17 +00: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 18:25:25 +00:00
} else {
2020-06-04 15:05:17 +00: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 18:25:25 +00:00
}
}
2021-01-19 16:55:21 +00:00
// ================================
// Check valid DOMAIN configuration
document.getElementById('domain-browser-string').innerText = location.href.toLowerCase();
if (document.getElementById('domain-server-string').innerText.toLowerCase() == location.href.toLowerCase()) {
document.getElementById('domain-success').classList.remove('d-none');
domainCheck = true;
} else {
document.getElementById('domain-warning').classList.remove('d-none');
}
2021-02-03 17:43:54 +00:00
// Check for HTTPS at domain-server-string
if (document.getElementById('domain-server-string').innerText.toLowerCase().startsWith('https://') ) {
document.getElementById('https-success').classList.remove('d-none');
httpsCheck = true;
} else {
document.getElementById('https-warning').classList.remove('d-none');
}
2020-05-28 18:25:25 +00:00
})();
2021-01-19 16:55:21 +00:00
// ================================
// Generate support string to be pasted on github or the forum
async function generateSupportString() {
supportString = "### Your environment (Generated via diagnostics page)\n";
2021-04-27 21:18:32 +00:00
supportString += "* Vaultwarden version: v {{ version }} \n";
2021-01-19 16:55:21 +00:00
supportString += "* Web-vault version: v {{ diagnostics .web_vault_version }} \n";
supportString += "* Running within Docker: {{ diagnostics .running_within_docker }} \n";
2021-03-27 23:10:01 +00:00
supportString += "* Uses a reverse proxy: {{ diagnostics .ip_header_exists }} \n";
{{ # if diagnostics .ip_header_exists }}
supportString += "* IP Header check: {{ diagnostics .ip_header_match }} ( {{ diagnostics .ip_header_name }} )\n";
{{ / if }}
2021-01-19 16:55:21 +00:00
supportString += "* Internet access: {{ diagnostics .has_http_access }} \n";
2021-03-27 23:10:01 +00:00
supportString += "* Internet access via a proxy: {{ diagnostics .uses_proxy }} \n";
2021-01-19 16:55:21 +00:00
supportString += "* DNS Check: " + dnsCheck + "\n";
supportString += "* Time Check: " + timeCheck + "\n";
supportString += "* Domain Configuration Check: " + domainCheck + "\n";
2021-02-03 17:43:54 +00:00
supportString += "* HTTPS Check: " + httpsCheck + "\n";
2021-01-19 16:55:21 +00:00
supportString += "* Database type: {{ diagnostics .db_type }} \n";
2021-03-27 23:10:01 +00:00
supportString += "* Database version: {{ diagnostics .db_version }} \n";
2021-02-03 17:43:54 +00:00
supportString += "* Clients used: \n";
supportString += "* Reverse proxy and version: \n";
supportString += "* Other relevant information: \n";
2021-01-19 16:55:21 +00:00
jsonResponse = await fetch(' {{ urlpath }} /admin/diagnostics/config');
configJson = await jsonResponse.json();
supportString += "\n### Config (Generated via diagnostics page)\n```json\n" + JSON.stringify(configJson, undefined, 2) + "\n```\n";
document.getElementById('support-string').innerText = supportString;
document.getElementById('support-string').classList.remove('d-none');
document.getElementById('copy-support').classList.remove('d-none');
}
function copyToClipboard() {
const str = document.getElementById('support-string').innerText;
const el = document.createElement('textarea');
el.value = str;
el.setAttribute('readonly', '');
el.style.position = 'absolute';
el.style.left = '-9999px';
document.body.appendChild(el);
el.select();
document.execCommand('copy');
document.body.removeChild(el);
}
2020-12-12 06:47:54 +00:00
</script>