Infrastructure
· 9 checks — DNS, redirects, IPv6, crawlability, URL variants, and domain intelligence rolled into one auditable list.CCrawlabilityActionrobots.txt present, sitemap with 0 URLsREVIEW
Search engines may not be able to parse the sitemap. Fix XML validation errors.
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.
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.
robots.txt omits Sitemap: directive — crawlers must fetch /sitemap.xml by convention; reliable but missing the explicit hint.
Source: sitemaps.org
<!DOCTYPE html><html lang="en" data-astro-transition-scope="astro-tyfwoq7n-1"> <head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1"><meta name="astro-view-transitions-enabled" content="true"><meta name="astro-view-transitions-fallback" content="animate"><script type="module" src="/_astro/ClientRouter.astro_astro_type_script_index_0_lang.DX0F14C8.js"></script><style>.astro-loading-indicator {
pointer-events: none;
background-color: #1f98e7;
position: fixed;
z-index: 1031;
top: 0;
left: 0;
width: 100%;
height: 2px;
transition: transform 300ms ease-out, opacity 150ms 150ms ease-in;
transform: translate3d(0, 0, 0) scaleX(var(--progress, 0));
transform-origin: 0;
}
[dir="rtl"] .astro-loading-indicator {
transform-origin: 100% 0;
}
</style><script>(function(){const className = "astro-loading-indicator";
const animationDuration = 300;
const threshold = 200;
(() => {
let progress = 0.25
let opacity = 0
/** @type {number | undefined} */
let trickleInterval = undefined
/** @type {number | undefined} */
let thresholdTimeout = undefined;
const element = document.createElement("div")
element.classList.add(className)
element.ariaHidden = "true"
/** @param {typeof progress} _progress */
const setProgress = (_progress) => {
progress = _progress
element.style.setProperty('--progress', String(progress))
}
/** @param {typeof opacity} _opacity */
const setOpacity = (_opacity) => {
opacity = _opacity
element.style.setProperty('opacity', String(opacity))
}
setOpacity(opacity)
document.addEventListener("DOMContentLoaded", () => {
document.body.prepend(element)
})
document.addEventListener("astro:before-preparation", () => {
thresholdTimeout = setTimeout(() => {
setOpacity(1)
trickleInterval = window.setInterval(() => {
setProgress(progress + Math.random() * 0.03)
}, animationDuration)
}, threshold)
})
document.addEventListener("astro:before-swap", (ev) => {
if (!thresholdTimeout) {
return
}
window.clearTimeout(thresholdTimeout)
ev.newDocument.body.prepend(element)
window.clearInterval(trickleInterval)
trickleInterval = undefined
setProgress(1)
window.setTimeout(() => {
setOpacity(0)
}, animationDuration / 2)
window.setTimeout(() => {
setProgress(0.25)
}, animationDuration * 2)
})
})()
})();</script><meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=5"><link rel="shortcut icon" type="image/x-icon" href="/favicon.ico"><meta name="generator" content="Astro v5.7.14"><link rel="preconnect" href="https://fonts.googleapis.com"><link rel="preconnect" href="https://fonts.gstatic.com" crossorigin><link href="https://fonts.googleapis.com/css2?family=Rubik:wght@300..900&display=swap" rel="stylesheet"><!-- <script src="/src/pwa.ts"></script> --><link rel="manifest" href="/manifest.webmanifest"><link rel="apple-touch-icon" sizes="180x180" href="/png/hexLogo-180.png"><link rel="apple-touch-icon" sizes="167x167" href="/png/hexLogo-167.png"><link rel="apple-touch-icon" sizes="152x152" href="/png/hexLogo-152.png"><link rel="apple-touch-icon" sizes="120x120" href="/png/hexLogo-120.png"><meta name="theme-color" content="#000"><link rel="apple-touch-startup-image" href="/splashscreens/splashscreen-2048-2732.png" media="(device-width: 1024px) and (device-height: 1366px) and (-webkit-device-pixel-ratio: 2) and (orientation: portrait)"><link rel="apple-touch-startup-image" href="/splashscreens/splashscreen-2732-2048.png" media="(device-width: 1024px) and (device-height: 1366px) and (-webkit-device-pixel-ratio: 2) and (orientation: landscape)"><link rel="apple-touch-startup-image" href="/splashscreens/splashscreen-1668-2388.png" media="(device-width: 834px) and (device-height: 1194px) and (-webkit-device-pixel-ratio: 2) and (orientation: portrait)"><link rel="apple-touch-startup-image" href="/splashscreens/splashscreen-2388-1668.png" media="(device-width: 834px) and (device-height: 1194px) and (-webkit-device-pixel-ratio: 2) and (orientation: landscape)"><link rel="apple-touch-startup-image" href="/splashscreens/splashscreen-1668-2224.png" media="(device-width: 834px) and (device-height: 1112px) and (-webkit-device-pixel-ratio: 2) and (orientation: portrait)"><link rel="apple-touch-startup-image" href="/splashscreens/splashscreen-2224-1668.png" media="(device-width: 834px) and (device-height: 1112px) and (-webkit-device-pixel-ratio: 2) and (orientation: landscape)"><link rel="apple-touch-startup-image" href="/splashscreens/splashscreen-1536-2048.png" media="(device-width: 768px) and (device-height: 1024px) and (-webkit-device-pixel-ratio: 2) and (orientation: portrait)"><link rel="apple-touch-startup-image" href="/splashscreens/splashscreen-2048-1536.png" media="(device-width: 768px) and (device-height: 1024px) and (-webkit-device-pixel-ratio: 2) and (orientation: landscape)"><link rel="apple-touch-startup-image" href="/splashscreens/splashscreen-1242-2688.png" media="(device-width: 414px) and (device-height: 896px) and (-webkit-device-pixel-ratio: 3) and (orientation: portrait)"><link rel="apple-touch-startup-image" href="/splashscreens/splashscreen-2688-1242.png" media="(device-width: 414px) and (device-height: 896px) and (-webkit-device-pixel-ratio: 3) and (orientation: landscape)"><link rel="apple-touch-startup-image" href="/splashscreens/splashscreen-1125-2436.png" media="(device-width: 375px) and (device-height: 812px) and (-webkit-device-pixel-ratio: 3) and (orientation: portrait)"><link rel="apple-touch-startup-image" href="/splashscreens/splashscreen-2436-1125.png" media="(device-width: 375px) and (device-height: 812px) and (-webkit-device-pixel-ratio: 3) and (orientation: landscape)"><link rel="apple-touch-startup-image" href="/splashscreens/splashscreen-828-1792.png" media="(device-width: 414px) and (device-height: 896px) and (-webkit-device-pixel-ratio: 2) and (orientation: portrait)"><link rel="apple-touch-startup-image" href="/splashscreens/splashscreen-1792-828.png" media="(device-width: 414px) and (device-height: 896px) and (-webkit-device-pixel-ratio: 2) and (orientation: landscape)"><link rel="apple-touch-startup-image" href="/splashscreens/splashscreen-1242-2208.png" media="(device-width: 414px) and (device-height: 736px) and (-webkit-device-pixel-ratio: 3) and (orientation: portrait)"><link rel="apple-touch-startup-image" href="/splashscreens/splashscreen-2208-1242.png" media="(device-width: 414px) and (device-height: 736px) and (-webkit-device-pixel-ratio: 3) and (orientation: landscape)"><link rel="apple-touch-startup-image" href="/splashscreens/splashscreen-750-1334.png" media="(device-width: 375px) and (device-height: 667px) and (-webkit-device-pixel-ratio: 2) and (orientation: portrait)"><link rel="apple-touch-startup-image" href="/splashscreens/splashscreen-1334-750.png" media="(device-width: 375px) and (device-height: 667px) and (-webkit-device-pixel-ratio: 2) and (orientation: landscape)"><link rel="apple-touch-startup-image" href="/splashscreens/splashscreen-640-1136.png" media="(device-width: 320px) and (device-height: 568px) and (-webkit-device-pixel-ratio: 2) and (orientation: portrait)"><link rel="apple-touch-startup-image" href="/splashscreens/splashscreen-1136-640.png" media="(device-width: 320px) and (device-height: 568px) and (-webkit-device-pixel-ratio: 2) and (orientation: landscape)"><title>Infowars: There's a War on For Your Mind!</title><link rel="canonical" href="https://www.infowars.com/"><meta name="description" content="The #1 Independent news service in the world, battling globalism and promoting a pro-human future worldwide. Infowars is Tomorrow's News Today."><meta name="robots" content="index, follow"><meta property="og:title" content="Infowars: There's a War on For Your Mind!"><meta property="og:type" content="website"><meta property="og:image" content="https://assets.infowarsmedia.com/images/37123e47-0b58-4aa5-a024-60b6fe72f5ef-large.jpg"><meta property="og:url" content="https://www.infowars.com/"><meta name="twitter:creator" content="@jonasmerlins1"><link rel="icon" href="/favicon.ico"><meta name="twitter:image" content="https://assets.infowarsmedia.com/images/37123e47-0b58-4aa5-a024-60b6fe72f5ef-large.jpg"><meta name="twitter:title" content="Infowars: There's a War on For Your Mind!"><meta name="twitter:description" content="The #1 Independent news service in the world, battling globalism and promoting a pro-human future worldwide. Infowars is Tomorrow's News Today."><script type="text/partytown" async src="https://www.googletagmanager.com/gtag/js?id=G-58YVN960S9"></script><script type="text/partytown"> window.dataLayer = window.dataLayer || []; function gtag(){dataLayer.push(arguments);} gtag('js', new Date()); gtag('config', 'G-58YVN960S9');
</script><link rel="stylesheet" href="/_astro/index.BxwEkdLS.css">
<link rel="stylesheet" href="/_astro/about.BbDaAZHH.css">
<link rel="stylesheet" href="/_astro/index.D77BVDmQ.css">
<link rel="stylesheet" href="/_astro/index.C-jKHGLw.css"><script type="module" src="/_astro/page.DlXkxCA4.js"></script>
<script>!(function(w,p,f,c){if(!window.crossOriginIsolated && !navigator.serviceWorker) return;c=w[p]=Object.assign(w[p]||{},{"lib":"/~partytown/","debug":false});c[f]=(c[f]||[]).concat(["dataLayer.push"])})(window,'partytown','forward');/* Partytown 0.11.2 - MIT QwikDev */
const t={preserveBehavior:!1},e=e=>{if("string"==typeof e)return[e,t];const[n,r=t]=e;return[n,{...t,...r}]},n=Object.freeze((t=>{const e=new Set;let n=[];do{Object.getOwnPropertyNames(n).forEach((t=>{"function"==typeof n[t]&&e.add(t)}))}while((n=Object.getPrototypeOf(n))!==Object.prototype);return Array.from(e)})());!function(t,r,o,i,a,s,c,l,d,p,u=t,f){function h(){f||(f=1,"/"==(c=(s.lib||"/~partytown/")+(s.debug?"debug/":""))[0]&&(d=r.querySelectorAll('script[type="text/partytown"]'),i!=t?i.dispatchEvent(new CustomEvent("pt1",{detail:t})):(l=setTimeout(v,(null==s?void 0:s.fallbackTimeout)||1e4),r.addEventListener("pt0",w),a?y(1):o.serviceWorker?o.serviceWorker.register(c+(s.swPath||"partytown-sw.js"),{scope:c}).then((function(t){t.active?y():t.installing&&t.i
BURL Variantswww/non-www, trailing slash, HTTP→HTTPSREVIEW
www / non-www
Inconsistent — duplicate content risk
HTTP → HTTPS
Consistent
BTLS Certificate Expiry & Recommendations32 days until leaf cert expires — 4 issues to addressREVIEW
Certificate validity
Recommended actions
- Prefer TLS 1.3 — TLS 1.2 is acceptable but TLS 1.3 removes RSA key exchange and improves latency
- Enable HSTS: Strict-Transport-Security: max-age=31536000; includeSubDomains
- Enable DNSSEC on your domain for DNS spoofing protection
- Enable OCSP stapling on your TLS server to remove a CA roundtrip and protect user privacy
BCDN & DeliveryCloudflareREVIEW
A+DNS Records2 A records, 7 ms lookupPASS
| A | 104.20.26.96, 172.66.157.39 |
| AAAA | 2606:4700:10::ac42:9d27, 2606:4700:10::6814:1a60 |
| CNAME | — |
| NS | merlin.ns.cloudflare.com, robin.ns.cloudflare.com |
| MX | 0 d239469a.ess.barracudanetworks.com 10 d239469b.ess.barracudanetworks.com |
| TXT | MS=ms36157856 google-site-verification=FDgbAoTCTtNC_D2UODrqQtAoieV9B9CUf3XuUYuZ7Hw google-site-verification=JCbsuh5IbARTR32XHPmVIM8Q9z7U2ovkJXNq7L4odZU google-site-verification=dhjmQhoH7GR4ts2XynUQ8Q8uWGAZtQsApk6PBv7-VdY google-site-verification=eI67r8NFe903degJ3oUyBxqGNil0qF5Ydkyden0UR18 SPF v=spf1 ip4:173.226.180.136 ip4:3.82.6.208 ip4:172.31.37.20 a mx a:email.infowars... |
| CAA | Lookup not available with standard resolver |
CAA record lookup requires a specialized DNS resolver. This check will be available in a future update.
Informational: CAA (Certification Authority Authorization) records weren't checked in this scan.
ARedirect Chain1 redirect(s), 403 ms totalPASS
https://infowars.com
22 ms · HTTP/1.1
https://www.infowars.com
381 ms · HTTP/1.1 FINAL
| # | URL | Status | Time | Protocol | Server |
|---|---|---|---|---|---|
| 1 | https://infowars.com | 301 | 22 ms | HTTP/1.1 | cloudflare |
| 2 | https://www.infowars.com | 200 | 381 ms | HTTP/1.1 | cloudflare |
See the visual redirect chain in the HTTP Probe tab →
A+IPv6 ReadinessIPv6 reachable (1 ms)PASS
A+Domain Intelligenceinfowars.com — via Cloudflare, Inc., 27 years, 6 months oldPASS
2551 days
June 9, 2033
32 days
Issued by Google Trust Services
27 years, 6 months
Registered March 7, 1999
Not enabled
Protects against DNS spoofing
Unknown
2606:4700:10::6814:1a60
Cloudflare, Inc.
Expiry timeline
Recommended actions
- Enable DNSSEC to protect visitors from DNS spoofing
- Enable registrar lock (clientTransferProhibited) to block unauthorized domain transfers
DNSSEC protects against DNS spoofing attacks. While not required, enabling DNSSEC adds an additional layer of security. Contact your DNS provider to enable it.
Without DNSSEC, an attacker who can poison your DNS can hijack your domain — and SSL certs alone don't stop them.
Learn more ▾ ▴
DNSSEC adds cryptographic signatures to DNS records, preventing forged responses from poisoning resolver caches. Without it, an attacker who controls the network path can redirect your domain to a malicious server before any HTTPS handshake happens. Most modern registrars (Cloudflare, Google Domains, Route 53) enable it with one toggle.
Source: ICANN / RFC 4033
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.
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