Skip to content
https://migrationpolicy.org

Infrastructure

· 9 checks — DNS, redirects, IPv6, crawlability, URL variants, and domain intelligence rolled into one auditable list.
SCORE
94
GRADE
A
FIX
0
REVIEW
2
PASS
7
INFO
0
Probed from Madrid, Spain
301 Moved Permanently
Checks
9
7 PASS 2 REVIEW
B
URL Variants
www/non-www, trailing slash, HTTP→HTTPS
REVIEW
www/non-www, trailing slash, HTTP→HTTPS
Critical::
Both www and non-www versions serve content
Got: Both variants return 200 Expected: One variant 301-redirects to the other
Info::
HTTP correctly 301-redirects to HTTPS

www / non-www

200https://www.migrationpolicy.org/
200https://migrationpolicy.org/

Inconsistent — duplicate content risk

HTTP → HTTPS

301http://migrationpolicy.org/ https://migrationpolicy.org/

Consistent

B
TLS Certificate Expiry & Recommendations
77 days until leaf cert expires — 2 issues to address
REVIEW

Certificate validity

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

Recommended actions

  • Enable HSTS: Strict-Transport-Security: max-age=31536000; includeSubDomains
  • Enable OCSP stapling on your TLS server to remove a CA roundtrip and protect user privacy
A+
DNS Records
3 A records, 61 ms lookup
PASS
3 A records, 61 ms lookup
Info::
Resolves to 3 IPv4 address(es)
Got: 172.67.71.206, 104.26.8.60, 104.26.9.60
Info::
Has 3 IPv6 (AAAA) record(s)
Got: 2606:4700:20::681a:93c, 2606:4700:20::ac43:47ce, 2606:4700:20::681a:83c
Info::
2 nameserver(s) configured
Got: lady.ns.cloudflare.com, mark.ns.cloudflare.com
Info::
1 mail exchanger(s) configured
Info::
CAA records not checked
CAA record lookup requires a specialized DNS resolver. This check will be available in a future update.
Info::
SPF record present in TXT
Info::
DNS resolution time: 61 ms
Got: 61 ms
A172.67.71.206, 104.26.8.60, 104.26.9.60
AAAA2606:4700:20::681a:93c, 2606:4700:20::ac43:47ce, 2606:4700:20::681a:83c
CNAME
NSlady.ns.cloudflare.com, mark.ns.cloudflare.com
MX
1 migrationpolicy-org.mail.protection.outlook.com
TXT
perplexity-ai-domain-verification-ew5tnx=mJuT51qKnSg1NVzbvqw8FiOh4
apple-domain-verification=DzoXJp8djNHKn7ul
google-site-verification=AsoO-KPPwtXH6W5ED_Kvsj1nYdv1TKvOi1j09rZbWcs
SPF v=spf1 mx a:s06148.databank.host include:spf.protection.outlook.com include:us._...
MS=ms69984386
CAALookup not available with standard resolver
Resolved in 61 ms

CAA record lookup requires a specialized DNS resolver. This check will be available in a future update.

Why this matters

Informational: CAA (Certification Authority Authorization) records weren't checked in this scan.

A
Redirect Chain
1 redirect(s), 579 ms total
PASS
1 redirect(s), 579 ms total
Info::
Single redirect
Got: https://migrationpolicy.org → https://www.migrationpolicy.org/ (301)
Info::
WWW normalization redirect
Info::
Redirect overhead: 579 ms total
Got: 579 ms

https://migrationpolicy.org

467 ms · HTTP/1.1

301

https://www.migrationpolicy.org/

112 ms · HTTP/1.1 FINAL

#URLStatusTimeProtocolServer
1https://migrationpolicy.org301467 msHTTP/1.1cloudflare
2https://www.migrationpolicy.org/200112 msHTTP/1.1cloudflare

See the visual redirect chain in the HTTP Probe tab →

A+
IPv6 Readiness
IPv6 reachable (17 ms)
PASS
IPv6 reachable (17 ms)
Info::
IPv6 is configured and reachable at 2606:4700:20::681a:93c, 2606:4700:20::ac43:47ce, 2606:4700:20::681a:83c
Got: 17 ms connect
IPv6 Ready
AAAA Records 2606:4700:20::681a:93c, 2606:4700:20::ac43:47ce, 2606:4700:20::681a:83c Connection Reachable (17 ms)
A+
Crawlability
robots.txt present, sitemap with 4173 URLs
PASS
robots.txt present, sitemap with 4173 URLs
Info::
robots.txt is present
Got: 1925 bytes
Info::
sitemap.xml is present
Info::
sitemap.xml is valid XML
Info::
sitemap.xml contains 4173 entries
Info::
robots.txt references sitemap
robots.txt 200 OK
Size 1925 B Sitemaps referenced 1 User-agents GPTBot, ChatGPT-User, * Blocking No — crawling allowed
#
# robots.txt
#

User-agent: *
Crawl-delay: 10

# Block crawling of query-string URLs to reduce crawl waste/load.
Disallow: /*?*=*

# CSS, JS, Images
Allow: /misc/*.css$
Allow: /misc/*.css?
Allow: /misc/*.js$
Allow: /misc/*.js?
Allow: /misc/*.gif
Allow: /misc/*.jpg
Allow: /misc/*.jpeg
Allow: /misc/*.png
Allow: /modules/*.css$
Allow: /modules/*.css?
Allow: /modules/*.js$
Allow: /modules/*.js?
Allow: /modules/*.gif
Allow: /modules/*.jpg
Allow: /modules/*.jpeg
Allow: /modules/*.png
Allow: /profiles/*.css$
Allow: /profiles/*.css?
Allow: /profiles/*.js$
Allow: /profiles/*.js?
Allow: /profiles/*.gif
Allow: /profiles/*.jpg
Allow: /profiles/*.jpeg
Allow: /profiles/*.png
Allow: /themes/*.css$
Allow: /themes/*.css?
Allow: /themes/*.js$
Allow: /themes/*.js?
Allow: /themes/*.gif
Allow: /themes/*.jpg
Allow: /themes/*.jpeg
Allow: /themes/*.png

# Directories
Disallow: /includes/
Disallow: /misc/
Disallow: /modules/
Disallow: /profiles/
Disallow: /scripts/
Disallow: /themes/

# Files
Disallow: /CHANGELOG.txt
Disallow: /cron.php
Disallow: /INSTALL.mysql.txt
Disallow: /INSTALL.pgsql.txt
Disallow: /INSTALL.sqlite.txt
Disallow: /install.php
Disallow: /INSTALL.txt
Disallow: /LICENSE.txt
Disallow: /MAINTAINERS.txt
Disallow: /update.php
Disallow: /UPGRADE.txt
Disallow: /xmlrpc.php

# Paths (clean URLs)
Disallow: /admin/
Disallow: /comment/reply/
Disallow: /filter/tips/
Disallow: /node/add/
Disallow: /search/
Disallow: /search
Disallow: /user/register/
Disallow: /user/password/
Disallow: /user/login/
Disallow: /user/logout/

# Paths (no clean URLs)
Disallow: /?q=admin/
Disallow: /?q=comment/reply/
Disallow: /?q=filter/tips/
Disallow: /?q=node/add/
Disallow: /?q=search/
Disallow: /?q=user/password/
Disallow: /?q=user/register/
Disallow: /?q=user/login/
Disallow: /?q=user/logout/

# AI crawlers
User-agent: GPTBot
Disallow: /

User-agent: ChatGPT-User
Disallow: /

Sitemap: https://www.migrationpolicy.org/sitemap.xml

A+
Domain Intelligence
migrationpolicy.org — via GoDaddy.com, LLC, 25 years, 11 months old
PASS
migrationpolicy.org — via GoDaddy.com, LLC, 25 years, 11 months old
Info::
Domain registered until Oct 5, 2026 (5 months remaining)
Info::
DNSSEC is enabled
Info::
Registrar: GoDaddy.com, LLC
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

112 days

October 5, 2026

SSL certificate

77 days

Issued by Google Trust Services

Domain age

25 years, 11 months

Registered October 5, 2000

DNSSEC

Enabled

Protects against DNS spoofing

Hosting

Unknown

2606:4700:20::ac43:47ce

Registrar

GoDaddy.com, LLC

Unlocked 2 NS records
Expiry timeline
Today
+1 year
Domain expiry SSL expiry Danger zone (≤30 days)
Recommended actions
  • Enable registrar lock (clientTransferProhibited) to block unauthorized domain transfers
Registrar GoDaddy.com, LLC
Created October 5, 2000 (25 years, 11 months ago)
Expires October 5, 2026 (5 months)
Last Updated November 19, 2025
Name Servers lady.ns.cloudflare.com, mark.ns.cloudflare.com
DNSSEC Enabled
Hosting
IP Address 2606:4700:20::ac43:47ce
Data source: rdap (0.3s)

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 539 ms — DNS, TCP, TLS, TTFB, content transfer breakdown
PASS
DNS Lookup DNS Lookup — time to resolve the domain name to an IP address.
57 ms
TCP Connect TCP Connect — time to establish a TCP connection to the server.
17 ms
TLS Handshake TLS Handshake — time to complete the HTTPS encryption handshake.
21 ms
Time to First Byte Time to First Byte — how long the server takes to respond with the first byte of data.
540 ms
Total Time Total request time from DNS lookup through full response.
540 ms

Connection waterfall

DNS Lookup 57 ms TCP Connect 17 ms TLS Handshake 21 ms Server Processing 445 ms Content Transfer 0 ms
A
CDN & Delivery
Cloudflare (DYNAMIC)
PASS
Cloudflare (DYNAMIC)
Info::
Site is served via Cloudflare CDN (edge: CDG)
Got: cf-ray: 9f0887b0ebd6d10c-CDG
Info::
CDN cache status: DYNAMIC
CDN Detected: Cloudflare
Provider Cloudflare Cache Status DYNAMIC Evidence cf-ray: 9f0887b0ebd6d10c-CDG
All checks on this page are automated. Results are estimates - run targeted manual reviews when the score affects a release decision.

Send Feedback