Skip to content
https://mindmx.org

Infrastructure

· 17 checks — DNS, redirects, IPv6, crawlability, URL variants, and domain intelligence rolled into one auditable list.
SCORE
82
GRADE
B
FIX
1
REVIEW
5
PASS
11
INFO
0
Probed from New York, United Stated
301 Moved Permanently
Checks
17
11 PASS 5 REVIEW 1 FIX
F
Redirect Chain
Action
4 redirect(s), 1184 ms total
FIX
4 redirect(s), 1184 ms total
Warning::
4 redirects before reaching final URL
Each redirect adds latency. Try to minimize the chain to 1 hop.
Info::
Uses 302 (temporary) redirect
If permanent, use 301 instead.
Got: https://desk.mindmx.org/
Warning::
Redirect overhead: 1184 ms total
Got: 1184 ms
Info::
Cross-domain redirect detected

https://mindmx.org

270 ms · HTTP/1.1

301

https://desk.mindmx.org/

112 ms · HTTP/1.1

302

https://auth.mindmx.org/application/o/au...

350 ms · HTTP/1.1

302

https://auth.mindmx.org/flows/-/default/...

303 ms · HTTP/1.1

302

https://auth.mindmx.org/if/flow/default-...

150 ms · HTTP/1.1 FINAL

#URLStatusTimeProtocolServer
1https://mindmx.org301270 msHTTP/1.1cloudflare
2https://desk.mindmx.org/302112 msHTTP/1.1cloudflare
3https://auth.mindmx.org/application/o/au...302350 msHTTP/1.1cloudflare
4https://auth.mindmx.org/flows/-/default/...302303 msHTTP/1.1cloudflare
5https://auth.mindmx.org/if/flow/default-...200150 msHTTP/1.1cloudflare

See the visual redirect chain in the HTTP Probe tab →

Each redirect adds latency. Try to minimize the chain to 1 hop.

Why this matters

Redirect chain — each hop adds latency; combine into one redirect where possible.

Source: Google Search Central / web.dev

If permanent, use 301 instead.

Why this matters

302 (Found) is for genuinely temporary redirects — if this redirect is permanent, switch to 301 to preserve SEO equity.

Learn more

Search engines treat 302 as temporary, keeping the original URL indexed and not transferring full link equity to the destination. Use 301 (Moved Permanently) for permanent redirects (HTTP→HTTPS, www-vs-non-www, URL restructures).

Source: Google Search Central

B
CAA Records
No CAA records (any CA may issue certificates)
REVIEW
No CAA records (any CA may issue certificates)
Info::
No CAA records published
Without CAA records, any publicly-trusted CA can issue certificates for this domain. Adding a CAA record (`yourdomain. IN CAA 0 issue "letsencrypt.org"`) restricts issuance to CAs you authorize. Required by CAB Forum baseline since 2017; the default of 'any CA' is widely supported but is the broader attack surface for issuance fraud.
C
Reverse DNS
Action
0/4 IPs match cert SAN
REVIEW
0/4 IPs match cert SAN
Info::
PTR lookup failed for 172.67.183.52: lookup 172.67.183.52: no such host
No reverse DNS record set for this IP. Common on bare cloud-VM IPs without provider-side PTR; not a security issue.
Info::
PTR lookup failed for 104.21.56.90: lookup 104.21.56.90: no such host
No reverse DNS record set for this IP. Common on bare cloud-VM IPs without provider-side PTR; not a security issue.
Info::
PTR lookup failed for 2606:4700:3030::6815:385a: lookup 2606:4700:3030::6815:385a: no such host
No reverse DNS record set for this IP. Common on bare cloud-VM IPs without provider-side PTR; not a security issue.
Info::
PTR lookup failed for 2606:4700:3032::ac43:b734: lookup 2606:4700:3032::ac43:b734: no such host
No reverse DNS record set for this IP. Common on bare cloud-VM IPs without provider-side PTR; not a security issue.
C
Crawlability
Action
robots.txt present, sitemap with 0 URLs
REVIEW
robots.txt present, sitemap with 0 URLs
Info::
robots.txt is present
Got: 10240 bytes
Info::
sitemap.xml is present
Warning::
sitemap.xml contains invalid XML
Search engines may not be able to parse the sitemap. Fix XML validation errors.
Warning::
sitemap.xml is empty — no URLs found
An empty sitemap provides no value. Add <url> entries for your pages.
Info::
robots.txt does not reference a sitemap
Add a 'Sitemap:' directive to robots.txt so search engines can discover your sitemap.

Search engines may not be able to parse the sitemap. Fix XML validation errors.

Why this matters

An unparseable sitemap is silently ignored by Google — the URLs it advertises are never queued for crawl.

Learn more

Google's sitemap parser is strict about XML validity. A single unescaped `&` or unclosed tag invalidates the whole file. Run your sitemap through a validator (Search Console's Sitemaps report flags it) and fix the offending entry. Most generators escape correctly; mistakes usually come from manually-written entries.

Source: sitemaps.org / Google Search Central

An empty sitemap provides no value. Add <url> entries for your pages.

Why this matters

An empty sitemap signals 'no content to index' to Google — actively harmful versus having no sitemap at all.

Learn more

Google compares URLs in the sitemap against URLs it has crawled. An empty sitemap on a site with thousands of pages signals abandonment. Either populate it correctly (most CMSes auto-generate) or delete the file and let Google crawl normally.

Source: Google Search Central / sitemaps.org

Add a 'Sitemap:' directive to robots.txt so search engines can discover your sitemap.

Why this matters

robots.txt omits Sitemap: directive — crawlers must fetch /sitemap.xml by convention; reliable but missing the explicit hint.

Source: sitemaps.org

robots.txt 200 OK
Size 10240 B Sitemaps referenced 0 User-agents Blocking No — crawling allowed
<!DOCTYPE html>
<html lang="fr">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>desk.mindmx</title>
<link rel="icon" type="image/png" href="/favicon/favicon-96x96.png" sizes="96x96" />
<link rel="icon" type="image/svg+xml" href="/favicon/favicon.svg" />
<link rel="shortcut icon" href="/favicon/favicon.ico" />
<link rel="apple-touch-icon" sizes="180x180" href="/favicon/apple-touch-icon.png" />
<meta name="apple-mobile-web-app-title" content="desk.mindmx" />
<link rel="manifest" href="/favicon/site.webmanifest" />
<link href="https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Outfit:wght@300;400;500;600;700;800&display=swap" rel="stylesheet" />
<script src="https://unpkg.com/react@18.3.1/umd/react.development.js" integrity="sha384-hD6/rw4ppMLGNu3tX5cjIb+uRZ7UkRJ6BPkLpg4hAu/6onKUg4lLsHAs9EBPT82L" crossorigin="anonymous"></script>
<script src="https://unpkg.com/react-dom@18.3.1/umd/react-dom.development.js" integrity="sha384-u6aeetuaXnQ38mYT8rp6sbXaQe3NL9t+IBXmnYxwkUI2Hw4bsp2Wvmx4yRQF1uAm" crossorigin="anonymous"></script>
<script src="https://unpkg.com/@babel/standalone@7.29.0/babel.min.js" integrity="sha384-m08KidiNqLdpJqLq95G/LEi8Qvjl/xUYll3QILypMoQ65QorJ9Lvtp2RXYGBFj1y" crossorigin="anonymous"></script>
<link href="https://cdn.jsdelivr.net/npm/quill@2.0.2/dist/quill.snow.css" rel="stylesheet" />
<script src="https://cdn.jsdelivr.net/npm/quill@2.0.2/dist/quill.js"></script>
<style>
* { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg:         #0d0d0f;
  --bg2:        #111114;
  --bg3:        #16161a;
  --bg4:        #1e1e24;
  --bg5:        #26262e;
  --line:       rgba(255,255,255,0.06);
  --line2:      rgba(255,255,255,0.10);
  --text:       #c8c8d0;
  --text-dim:   #666676;
  --text-bright:#f0f0f4;
  --accent:     #00d4ff;
  --accent-dim: rgba(0,212,255,0.12);
  --accent-glow:rgba(0,212,255,0.25);
  --vpn:        #e8922a;
  --vpn-dim:    rgba(232,146,42,0.15);
  --admin-c:    #e05555;
  --admin-dim:  rgba(224,85,85,0.15);
  --mfa:        #5b8dee;
  --mfa-dim:    rgba(91,141,238,0.15);
  --green:      #3dba6e;
  --red:        #e05555;
  --radius:     12px;
  --radius-sm:  6px;
  --header-h:   56px;
  --font:       'Outfit', sans-serif;
  --font-body:  'Inter', sans-serif;
  --header-bg:  rgba(13,13,15,0.85);
  --card-bg:    linear-gradient(135deg,rgba(255,255,255,0.04) 0%,rgba(255,255,255,0.02) 100%);
  --card-shine: rgba(255,255,255,0.06);
  --card-hover-shadow: 0 8px 32px rgba(0,0,0,0.4), 0 0 0 1px rgba(0,212,255,0.18);
  --card-hover-border: rgba(0,212,255,0.22);
  --avatar-text: #fff;
  --scrollbar-thumb: #26262e;
}

html, body { width:100%; height:100%; background:var(--bg); color:var(--text); font-family:var(--font-body); overflow:hidden; transition: background 0.3s, color 0.3s; }
#root { width:100%; height:100%; }

::-webkit-scrollbar { width:5px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:var(--scrollbar-thumb); border-radius:3px; }

@keyframes fadeUp { from{opacity:0;transform:translateY(14px)} to{opacity:1;transform:translateY(0)} }
@keyframes fadeIn { from{opacity:0} to{opacity:1} }
@keyframes pulse  { 0%,100%{opacity:1} 50%{opacity:0.4} }
@keyframes slideRight { from{transform:translateX(100%);opacity:0} to{transform:translateX(0);opacity:1} }
@keyframes slideLeft  { from{transform:translateX(0);opacity:1}   to{transform:translateX(100%);opacity:0} }

.fade-up  { animation: fadeUp  0.45s cubic-bezier(0.16,1,0.3,1) both; }
.fade-in  { animation: fadeIn  0.3s ease both; }
.slide-in { animation: slideRight 0.35s cubic-bezier(0.16,1,0.3,1) both; }

.app-card {
  transition: transform 0.2s cubic-bezier(0.16,1,0.3,1), box-shadow 0.2s ease, border-color 0.2s ease;
}
.app-card:hover {
  transform: translateY(-3px) scale(1.01);
  box-shadow: var(--card-hover-shadow);
  border-color: var(--card-hover-border) !important;
}
.app-card:active { transform:translateY(0) scale(0.99); }
.status-online { animation: pulse 2.5s ease-in-out infinite; }
.dropdown-enter { animation: fadeUp 0.2s cubic-bezier(0.16,1,0.3,1) both; }
.header-blur { backdrop-filter:blur(20px) saturate(1.4); -webkit-backdrop-filter:blur(20px) saturate(1.4); }

.menu-item {
  display:flex; align-items:center; gap:10px;
  padding:9px 14px; text-decoration:none;
  color:var(--text); font-size:13px; font-family:var(--font);
  border-bottom:1px solid var(--line); transition:background 0.1s; cursor:pointer;
  background:transparent; border-left:0; border-right:0; border-top:0; width:100%; text-align:left;
}
.menu-item:hover { background:var(--bg4); }
.menu-item:last-child { border-bottom:none; }

.pref-overlay {
  position:fixed; inset:0; background:rgba(0,0,0,0.5); z-index:200;
  animation: fadeIn 0.2s ease both;
}
.pref-panel {
  position:fixed; top:0; right:0; bottom:0; width:360px;
  background:var(--bg3); border-left:1px solid var(--line2);
  display:flex; flex-direction:column; z-index:201;
  box-shadow:-24px 0 64px rgba(0,0,0,0.5);
}
.pref-panel.open  { animation: slideRight 0.35s cubic-bezier(0.16,1,0.3,1) both; }

/* Quill editor overrides for dark theme */
.ql-toolbar.ql-snow { border-color: var(--line2) !important; background: var(--bg4); border-radius: 8px 8px 0 0; }
.ql-container.ql-snow { border-color: var(--line2) !important; background: var(--bg2); border-radius: 0 0 8px 8px; font-family: var(--font-body); font-size: 13px; color: var(--text); min-height: 150px; }
.ql-editor { color: var(--text); min-height: 150px; }
.ql-editor.ql-blank::before { color: var(--text-dim); font-style: normal; }
.ql-snow .ql-stroke { stroke: var(--text-dim) !important; }
.ql-snow .ql-fill { fill: var(--text-dim) !important; }
.ql-snow .ql-picker-label { color: var(--text-dim) !important; }
.ql-snow .ql-picker-options { background: var(--bg3) !important; border-color: var(--line2) !important; }
.ql-snow .ql-picker-item { color: var(--text) !important; }
.ql-snow button:hover .ql-stroke, .ql-snow button.ql-active .ql-stroke { stroke: var(--accent) !important; }
.ql-snow button:hover .ql-fill, .ql-snow button.ql-active .ql-fill { fill: var(--accent) !important; }

/* Editor modal */
.editor-overlay { position:fixed; inset:0; background:rgba(0,0,0,0.6); z-index:300; animation: fadeIn 0.2s ease both; display:flex; align-items:center; justify-content:center; }
.editor-modal { width:700px; max-width:95vw; max-height:90vh; background:var(--bg3); border:1px solid var(--line2); border-radius:16px; display:flex; flex-direction:column; box-shadow:0 32px 80px rgba(0,0,0,0.5); animation: fadeUp 0.3s cubic-bezier(0.16,1,0.3,1) both; overflow:hidden; }
.editor-field { display:flex; flex-direction:column; gap:6px; }
.editor-field label { font-size:11px; font-weight:600; color:var(--text-dim); text-transform:uppercase; letter-spacing:0.08em; font-family:var(--font); }
.editor-input { padding:8px 12px; border-radius:8px; border:1px solid var(--line2); background:var(--bg2); color:var(--text); font-size:13px; font-family:var(--font-body); outline:none; transition:border-color 0.15s; }
.editor-input:focus { border-color:var(--accent); }
.editor-input::placeholder { color:var(--text-dim); }
select.editor-input { cursor:pointer; }
.editor-btn { padding:8px 18px; border-radius:8px; border:none; font-size:12px; font-weight:600; font-family:var(--font); cursor:pointer; transition:all 0.15s; }
.editor-btn-primary { background:var(--accent); color:#000; }
.editor-btn-primary:hover { filter:brightness(1.1); }
.editor-btn-danger { background:var(--admin-dim); color:var(--admin-c); border:1px solid rgba(224,85,85,0.3); }
.editor-btn-danger:hover { background:rgba(224,85,85,0.25); }
.editor-btn-ghost { background:transparent; color:var(--text-dim); border:1px solid var(--line2); }
.editor-btn-ghost:hover { background:var(--bg4); color:var(--text); }

/* Confirm dialog */
.confirm-overlay { position:fixed; inset:0; background:rgba(0,0,0,0.6); z-index:400; animation: fadeIn 0.15s ease both; display:flex; align-items:center; justify-content:center; }
.confirm-dialog { width:400px; max-width:90vw; background:var(--bg3); border:1px solid var(--line2); border-radius:14px; padding:28px; box-shadow:0 24px 64px rgba(0,0,0,0.5); animation: fadeUp 0.25s cubic-bezier(0.16,1,0.3,1) both; }

/* Tag input */
.tag-chip { display:inline-flex; align-items:center; gap:4px; padding:3px 8px; border-radius:4px; background:var(--bg4); border:1px solid var(--line2); font-size:11px; color:var(--text); font-family:var(--font); }
.tag-chip button { background:none; border:none; color:var(--text-dim); cursor:pointer; font-size:12px; padding:0; line-height:1; }
.tag-chip button:hover { color:var(--admin-c); }

/* Ann action buttons */
.ann-action { background:transparent; border:1px solid var(--line2); border-radius:6px; padding:4px 8px; cursor:pointer; font-size:11px; color:var(--text-dim); transition:all 0.15s; }
.ann-action:hover { background:var(--bg4); color:var(--text); }
</style>
<meta name="x-authentik-groups" content="" /><meta name="x-authentik-username" content="" /><meta name="x-authentik-name" content="" /><meta name="x-authentik-email" content="" /></head>
<body>
<div id="root"></div>
<script type="text/babel">
const { useState, useEffect, useRef, useCallback, useMemo } = React;

// ── AUTHENTIK USER FROM META TAGS ────────────────────────────────────────────

function getAuthentikUser() {
  const getMeta = (name) => {
    const el = document.querySelector(`meta[name="${name}"]`);
    if (!el) return '';
    const val = el.getAttribute('content') || '';
    // nginx sub_filter injects $http_x_authentik_* which is empty string if header absent
    if (val.startsWith('$http_') || val === '') return '';
    return val;
  };

  const rawGroups = getMeta('x-authentik-groups');
  const username  = getMeta('x-authentik-username');
  const fullName  = getMeta('x-authentik-name');
  const email     = getMeta('x-authentik-email');

  // Parse groups: Authentik sends pipe-separated or comma-separated list
  const groups = rawGroups
    ? rawGroups.split(/[|,]/).map(g => g.trim().toLowerCase()).filte
sitemap.xml 200 OK
Type URL Set URLs 0 entries Valid XML No
B
TLS Certificate Expiry & Recommendations
75 days until leaf cert expires — 2 issues to address
REVIEW

Certificate validity

75
days left
0d 30d 60d 90d+

Recommended actions

  • Submit your domain to hstspreload.org to be added to the Chrome preload list
  • Enable OCSP stapling on your TLS server to remove a CA roundtrip and protect user privacy
B
Operational Status Page
No status page link detected
REVIEW
No status page link detected
Info::
No operational status page link detected
Status pages communicate planned maintenance and incidents to users -- a hallmark of operationally-mature services. Most SaaS teams publish one via Atlassian Statuspage, Instatus, BetterUptime, or a self-hosted Cachet. Smaller sites legitimately don't need one; flagged as Info, not a failure.
A+
DNS Records
2 A records, 41 ms lookup
PASS
2 A records, 41 ms lookup
Info::
Resolves to 2 IPv4 address(es)
Got: 172.67.183.52, 104.21.56.90
Info::
Has 2 IPv6 (AAAA) record(s)
Got: 2606:4700:3030::6815:385a, 2606:4700:3032::ac43:b734
Info::
2 nameserver(s) configured
Got: harlan.ns.cloudflare.com, anastasia.ns.cloudflare.com
Info::
1 mail exchanger(s) configured
Info::
No SPF record found in TXT records
SPF helps prevent email spoofing. Add a TXT record starting with 'v=spf1'.
Info::
DNS resolution time: 41 ms
Got: 41 ms
A172.67.183.52, 104.21.56.90
AAAA2606:4700:3030::6815:385a, 2606:4700:3032::ac43:b734
CNAME
NSharlan.ns.cloudflare.com, anastasia.ns.cloudflare.com
MX
10 inbound-smtp.eu-west-1.amazonaws.com
TXT
CAALookup not available with standard resolver
Resolved in 41 ms

SPF helps prevent email spoofing. Add a TXT record starting with 'v=spf1'.

Why this matters

Without SPF, receiving servers can't validate sending IPs — your domain is easier to spoof in phishing.

Learn more

SPF complements DMARC. Both should be published. SPF records list authorized sending IPs (e.g., `v=spf1 include:_spf.google.com ~all` for Google Workspace). After publishing, verify in Google Postmaster Tools or mxtoolbox.

Source: RFC 7208 (SPF)

A+
Subdomain Takeover
No subdomain takeover risk detected
PASS
No subdomain takeover risk detected
Info::
No CNAME record present
A+
DNSSEC
Signed and validating
PASS
Signed and validating
Info::
DNSSEC fully signed and chain validates (ECDSAP256SHA256)
A+
Multi-Resolver DNS Speed
Mean 22ms across 3 resolvers (spread 13ms)
PASS
Mean 22ms across 3 resolvers (spread 13ms)
Info::
Cloudflare: 18ms
Got: 18ms via 1.1.1.1:53
Info::
Google: 19ms
Got: 19ms via 8.8.8.8:53
Info::
Quad9: 31ms
Got: 31ms via 9.9.9.9:53
A+
IPv6 Readiness
IPv6 reachable (3 ms)
PASS
IPv6 reachable (3 ms)
Info::
IPv6 is configured and reachable at 2606:4700:3030::6815:385a, 2606:4700:3032::ac43:b734
Got: 3 ms connect
IPv6 Ready
AAAA Records 2606:4700:3030::6815:385a, 2606:4700:3032::ac43:b734 Connection Reachable (3 ms)
A+
URL Variants
www/non-www, trailing slash, HTTP→HTTPS
PASS
www/non-www, trailing slash, HTTP→HTTPS
Info::
HTTP correctly 301-redirects to HTTPS

www / non-www

https://www.mindmx.org/
200https://mindmx.org/

HTTP → HTTPS

301http://mindmx.org/ https://mindmx.org/

Consistent

A+
Domain Intelligence
mindmx.org — via Cloudflare, Inc., 2 months old
PASS
mindmx.org — via Cloudflare, Inc., 2 months old
Info::
Domain registered until Mar 7, 2027 (9 months remaining)
Info::
Domain is only 2 months old
Newly registered domains may face SEO trust challenges. Search engines generally give more authority to older domains. This is informational — not a problem to fix.
Got: Registered Mar 7, 2026
Info::
DNSSEC is enabled
Info::
Registrar: Cloudflare, Inc.
Warning::
Registrar lock is NOT enabled
The domain can be transferred without an unlock step. Enable registrar lock (clientTransferProhibited) in your registrar's control panel to protect against unauthorized or accidental transfers.
Domain expiry

284 days

March 7, 2027

SSL certificate

75 days

Issued by Let's Encrypt

Domain age

2 months

Registered March 7, 2026

DNSSEC

Enabled

Protects against DNS spoofing

Hosting

Unknown

2606:4700:3030::6815:385a

Registrar

Cloudflare, Inc.

Unlocked 2 NS records
Expiry timeline
Today
+1 year
Domain expiry SSL expiry Danger zone (≤30 days)
Recommended actions
  • Newly registered domain — build backlinks and content to establish SEO trust
  • Enable registrar lock (clientTransferProhibited) to block unauthorized domain transfers
Registrar Cloudflare, Inc.
Created March 7, 2026 (2 months ago)
Expires March 7, 2027 (9 months)
Last Updated March 12, 2026
Name Servers anastasia.ns.cloudflare.com, harlan.ns.cloudflare.com
DNSSEC Enabled
Hosting
IP Address 2606:4700:3030::6815:385a
Data source: rdap (0.2s)

Newly registered domains may face SEO trust challenges. Search engines generally give more authority to older domains. This is informational — not a problem to fix.

Why this matters

Informational: domain age. Newer domains may have lower trust signals in spam/security filters.

The domain can be transferred without an unlock step. Enable registrar lock (clientTransferProhibited) in your registrar's control panel to protect against unauthorized or accidental transfers.

Why this matters

Without registrar lock, an attacker who phishes your registrar credentials can transfer the domain in minutes — total brand hijack.

Learn more

Registrar lock (clientTransferProhibited, clientUpdateProhibited, clientDeleteProhibited) requires extra verification before any transfer/update/delete. Every major registrar offers it free. Combined with 2FA on your registrar account, it's the strongest defense against domain hijacking.

Source: ICANN / domain-security best practice

A+
HTTP Probe Timing
Total 329 ms — DNS, TCP, TLS, TTFB, content transfer breakdown
PASS
DNS Lookup DNS Lookup — time to resolve the domain name to an IP address.
40 ms
TCP Connect TCP Connect — time to establish a TCP connection to the server.
2 ms
TLS Handshake TLS Handshake — time to complete the HTTPS encryption handshake.
10 ms
Time to First Byte Time to First Byte — how long the server takes to respond with the first byte of data.
329 ms
Total Time Total request time from DNS lookup through full response.
330 ms

Connection waterfall

DNS Lookup 40 ms TCP Connect 2 ms TLS Handshake 10 ms Server Processing 277 ms Content Transfer 0 ms
A
CDN & Delivery
Cloudflare (DYNAMIC)
PASS
Cloudflare (DYNAMIC)
Info::
Site is served via Cloudflare CDN (edge: EWR)
Got: cf-ray: 9fe95de35fc25e76-EWR
Info::
CDN cache status: DYNAMIC
CDN Detected: Cloudflare
Provider Cloudflare Cache Status DYNAMIC Evidence cf-ray: 9fe95de35fc25e76-EWR
A+
CDN Cache Observability
Cache state: DYNAMIC
PASS
Cache state: DYNAMIC
Info::
CDN cache state observable via 1 header(s)
Got: cf-cache-status=DYNAMIC
A+
Health Check Endpoint
Health endpoint at https://mindmx.org/health (HTTP 200)
PASS
Health endpoint at https://mindmx.org/health (HTTP 200)
Info::
Public health endpoint at https://mindmx.org/health
Got: https://mindmx.org/health
All checks on this page are automated. Results are estimates - run targeted manual reviews when the score affects a release decision.

Send Feedback