Skip to content
https://openwrt.org

Infrastructure

· 9 checks — DNS, redirects, IPv6, crawlability, URL variants, and domain intelligence rolled into one auditable list.
SCORE
94
GRADE
A
FIX
1
REVIEW
2
PASS
6
INFO
0
Probed from Madrid, Spain
200 OK
Checks
9
6 PASS 2 REVIEW 1 FIX
D
CDN & Delivery
Action
No CDN detected
FIX
No CDN detected
Warning::
No CDN detected
A CDN can significantly improve load times for users around the world by caching content at edge nodes closer to them.
No CDN detected

Consider using a CDN to improve global delivery speed and reduce origin load.

B
Crawlability
robots.txt present, sitemap with 0 URLs
REVIEW
robots.txt present, sitemap with 0 URLs
Info::
robots.txt is present
Got: 5882 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 references 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

robots.txt 200 OK
Size 5882 B Sitemaps referenced 1 User-agents Baiduspider, SemrushBot, Gigabot, *, Go-http-client, Sogou, SEOkicks, Scrapy, Baiduspider-render, MauiBot, HTTrack, Yeti, yacybot, Wget, YisouSpider Blocking No — crawling allowed
User-agent: Baiduspider
User-agent: Baiduspider-render
Disallow: /feed.php?mode=list&ns=
Disallow: /lib/plugins/datatables/
Disallow: /*id=*
Disallow: /*datasrt=*
Disallow: /*dataflt*

User-agent: Go-http-client
Disallow: /*datasrt=*
Disallow: /*dataflt*
Disallow: /*do=diff*
Disallow: /*do=media*

User-agent: MauiBot
Disallow: /toh/views/toh_admin*
Disallow: /toh/views/toh_available_864*
Disallow: /toh/views/toh_discontinued_864*
Disallow: /toh/views/toh_modem_supported*
Disallow: /*datasrt=*
Disallow: /*dataflt*

User-agent: Sogou
Disallow: /
Disallow: /toh/views/toh_admin_modem_wlan*
Disallow: /toh/views/toh_admin_serial*
Disallow: /zh/toh/views/toh_available_864
Disallow: /*datasrt=*
Disallow: /*dataflt*

User-agent: SemrushBot
Disallow: /feed.php?*
Disallow: /*idx=*
Disallow: /*rev=*
Disallow: /*do=diff*
Disallow: /*do=edit$
Disallow: /*do=index$
Disallow: /*do=login*
Disallow: /*do=media*
Disallow: /*do=recent$
Disallow: /*do=register$
Disallow: /*do=resendpwd*
Disallow: /*do=revisions$
Disallow: /*tab_details=edit*
Disallow: /*tab_details=history*
Disallow: /*tab_details=view*
Disallow: /*tab_files=files*
Disallow: /*tab_files=search*
Disallow: /*tab_files=upload*
Disallow: /*datasrt=*
Disallow: /*dataflt*
Disallow: /de/en/
Disallow: /de/kr/
Disallow: /en/kr/
Disallow: /es/en/
Disallow: /es/kr/
Disallow: /fr/kr/
Disallow: /hu/kr/
Disallow: /ja/en/
Disallow: /ja/kr/
Disallow: /jp/en/
Disallow: /ko/cz/
Disallow: /ko/en/
Disallow: /ko/kr/
Disallow: /pl/cz/
Disallow: /pl/ko/
Disallow: /pl/kr/
Disallow: /pt/en/
Disallow: /pt/kr/
Disallow: /ru/en/
Disallow: /ru/kr/
Disallow: /tr/en/
Disallow: /zh/en/
Disallow: /zh/kr/
Disallow: /playground/
Disallow: /*/playground/
Disallow: /*/packages/pkgdata/
Disallow: /*/toh/hwdata/

User-agent: SEOkicks
User-agent: Scrapy
User-agent: Gigabot
User-agent: HTTrack
User-agent: Wget
User-agent: Yeti
Disallow: /*datasrt=*
Disallow: /*dataflt*
Disallow: /*do=backlink$
Disallow: /*do=edit$
Disallow: /*do=index$
Disallow: /*do=login*
Disallow: /*do=media$
Disallow: /*do=register$
Disallow: /*do=recent$
Disallow: /*do=revisions$
Disallow: /*id=*
Disallow: /_export/


User-agent: yacybot
Disallow: /*datasrt=*
Disallow: /*dataflt*
Disallow: /*do=backlink$
Disallow: /*do=edit$
Disallow: /*do=index$
Disallow: /*do=login*
Disallow: /*do=media$
Disallow: /*do=register$
Disallow: /*do=recent$
Disallow: /*do=revisions$
Disallow: /*id=*


User-agent: YisouSpider
Disallow: /lib/*
Disallow: /lib/plugins/datatables/
Disallow: /lib/plugins/datatables/*
Disallow: *jquery.dataTables.min.js$
Disallow: *buttons.dataTables.min.css$
Disallow: *buttons.html5.min.js$
Disallow: *dataTables.buttons.min.js$
Disallow: *dataTables.fixedColumns.min.js$
Disallow: *dataTables.responsive.min.js$
Disallow: /*idx=*
Disallow: /*datasrt=*
Disallow: /*dataflt*
Disallow: /*do=diff*
Disallow: /*do=edit$
Disallow: /*do=login*
Disallow: /*do=media*
Disallow: /*do=recent$
Disallow: /*do=register$
Disallow: /*do=revisions$
Disallow: /*rev=*


User-agent: *
Disallow: //*
Disallow: /doku.php?id=*
Disallow: /feed.php?*
Disallow: /feed.php?mode=list&ns=
Disallow: /start?id=*
Disallow: /*idx=*
Disallow: /*rev=*
Disallow: /*do=diff*
Disallow: /*do=edit$
Disallow: /*do=index$
Disallow: /*do=login*
Disallow: /*do=media$
Disallow: /*do=profile$
Disallow: /*do=recent$
Disallow: /*do=register$
Disallow: /*do=resendpwd*
Disallow: /*do=revisions$
Disallow: /*tab_details=edit*
Disallow: /*tab_details=history*
Disallow: /*tab_details=view*
Disallow: /*tab_files=files*
Disallow: /*tab_files=search*
Disallow: /*tab_files=upload*
Disallow: /*datasrt=*
Disallow: /*dataflt*
Disallow: /*tseed=018d61fc1fa2f9abdf54c6f201c65c0b
Disallow: /*tseed=ceddb583a0a603952a527c2bb95e91be
Disallow: /*tseed=93ef14dc4babe4f518a0f1af6cd6be73
Disallow: /meta/fwfiles*
Disallow: /*/meta/fwfiles*
Disallow: /_export/raw/*
Disallow: /toh/views/dataclouds
Disallow: /toh/views/toh_admin_modem_wlan*
Disallow: /toh/views/toh_admin_serial*
Disallow: /toh/views/toh_dev_arch-target-cpu*
Disallow: /toh/views/toh_performance_details*
Disallow: /toh/views/toh_available_864*
Disallow: /es/toh/views/toh_available_864*
Disallow: /zh/toh/views/toh_available_864*
Disallow: /zh/toh/views/toh_fwdownload*
Disallow: /zh/toh_fwdownload*
Disallow: /zh/toh/views/toh_packagedownload*
Disallow: /zh/toh_packagedownload*
Disallow: /es/packages/start
Disallow: /ko/packages/start
Disallow: */oldwiki/*
Disallow: /packages/logfile
Disallow: /packages/maintainer-view
Disallow: /packages/table/start
Disallow: /zh/packages/table/start
Disallow: /packages/table_lede17_1/start
Disallow: /playground/
Disallow: /*/playground/
Disallow: /cs/cz/
Disallow: /cs/de/
Disallow: /cs/en/
Disallow: /cs/kr/
Disallow: /cs/cs/
Disallow: /de/cz/
Disallow: /de/en/
Disallow: /de/kr/
Disallow: /en/jp/
Disallow: /en/kr/
Disallow: /es/cz/
Disallow: /es/en/
Disallow: /es/kr/
Disallow: /fr/cz/
Disallow: /fr/en/
Disallow: /fr/kr/
Disallow: /hu/cz/
Disallow: /hu/en/
Disallow: /hu/kr/
Disallow: /it/cz/
Disallow: /it/en/
Disallow: /ja/en/
Disallow: /ja/kr/
Disallow: /jp/cz/
Disallow: /jp/en/
Disallow: /jp/kr/
Disallow: /ko/cz/
Disallow: /ko/en/
Disallow: /ko/kr/
Disallow: /pl/cz/
Disallow: /pl/ko/
Disallow: /pl/kr/
Disallow: /pt/cz/
Disallow: /pt/en/
Disallow: /pt/kr/
Disallow: /ru/cz/
Disallow: /ru/en/
Disallow: /ru/kr/
Disallow: /ru/ru/
Disallow: /ru/tr/
Disallow: /ru/zh/
Disallow: /tr/cs/
Disallow: /tr/cz/
Disallow: /tr/de/
Disallow: /tr/en/
Disallow: /tr/es/
Disallow: /tr/fr/
Disallow: /tr/hu/
Disallow: /tr/it/
Disallow: /tr/ja/
Disallow: /tr/ko/
Disallow: /tr/kr/
Disallow: /tr/pl/
Disallow: /tr/pt/
Disallow: /zh/cz/
Disallow: /zh/en/
Disallow: /zh/kr/
Disallow: /zh-tw/cz/
Disallow: /docs/user-guide/
Disallow: /*/docs/user-guide/
Disallow: /*/hwdata_lede/
Disallow: /*/packages/pkgdata/
Disallow: /*/toh/hwdata/
Disallow: /*/toh/views/

Sitemap: https://openwrt.org/doku.php?do=sitemap

sitemap.xml 200 OK
Type URL Set URLs 0 entries Valid XML No
B
TLS Certificate Expiry & Recommendations
72 days until leaf cert expires — 5 issues to address
REVIEW

Certificate validity

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

Recommended actions

  • Prefer TLS 1.3 — TLS 1.2 is acceptable but TLS 1.3 removes RSA key exchange and improves latency
  • Add includeSubDomains to the HSTS directive
  • Add the preload directive and submit to hstspreload.org once max-age + includeSubDomains are in place
  • 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
A+
DNS Records
1 A records, 47 ms lookup
PASS
1 A records, 47 ms lookup
Info::
Resolves to 1 IPv4 address(es)
Got: 64.226.122.113
Info::
Single A record — no DNS redundancy
Multiple A records provide failover if one server goes down.
Info::
Has 1 IPv6 (AAAA) record(s)
Got: 2a03:b0c0:3:d0::1a51:c001
Info::
3 nameserver(s) configured
Got: ns3.digitalocean.com, ns1.digitalocean.com, ns2.digitalocean.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: 47 ms
Got: 47 ms
A64.226.122.113
AAAA2a03:b0c0:3:d0::1a51:c001
CNAME
NSns3.digitalocean.com, ns1.digitalocean.com, ns2.digitalocean.com
MX
10 util-01.infra.openwrt.org
TXT
google-site-verification=97QkAokBcj-8YxpRIxK87XUcn9N1kvq7w9_0UuvGjMg
SPF v=spf1 ip4:46.101.232.90 ip6:2001:470:1f0b:a42::1 -all
CAALookup not available with standard resolver
Resolved in 47 ms

Multiple A records provide failover if one server goes down.

Why this matters

Single A record means a single point of failure — if that IP goes down, your site is unreachable until DNS TTL expires.

Learn more

Add multiple A records for round-robin failover, or use a managed DNS provider with health-checked failover (Route 53, Cloudflare, NS1). Short TTL (60-300s) lets clients recover faster on outages.

Source: SRE practice / DNS architecture

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
No redirects — direct access
PASS
No redirects — direct access
Info::
No redirects — direct access
Got: https://openwrt.org

https://openwrt.org

133 ms · HTTP/1.1 FINAL

#URLStatusTimeProtocolServer
1https://openwrt.org200133 msHTTP/1.1nginx
A+
IPv6 Readiness
IPv6 reachable (34 ms)
PASS
IPv6 reachable (34 ms)
Info::
IPv6 is configured and reachable at 2a03:b0c0:3:d0::1a51:c001
Got: 34 ms connect
IPv6 Ready
AAAA Records 2a03:b0c0:3:d0::1a51:c001 Connection Reachable (34 ms)
A+
URL Variants
www/non-www, trailing slash, HTTP→HTTPS
PASS
www/non-www, trailing slash, HTTP→HTTPS
Info::
www/non-www redirect configured correctly (preferred: non-www)
Info::
HTTP correctly 301-redirects to HTTPS

www / non-www

301https://www.openwrt.org/
200https://openwrt.org/

Preferred variant: non-www

HTTP → HTTPS

301http://openwrt.org/ https://openwrt.org/

Consistent

A+
Domain Intelligence
openwrt.org — via Gandi SAS, 22 years, 4 months old
PASS
openwrt.org — via Gandi SAS, 22 years, 4 months old
Info::
Domain registered until Apr 2, 2027 (11 months remaining)
Info::
DNSSEC is not enabled
DNSSEC protects against DNS spoofing attacks. While not required, enabling DNSSEC adds an additional layer of security. Contact your DNS provider to enable it.
Info::
Registrar: Gandi SAS
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

291 days

April 2, 2027

SSL certificate

72 days

Issued by Let's Encrypt

Domain age

22 years, 4 months

Registered April 2, 2004

DNSSEC

Not enabled

Protects against DNS spoofing

Hosting

Unknown

2a03:b0c0:3:d0::1a51:c001

Registrar

Gandi SAS

Unlocked 3 NS records
Expiry timeline
Today
+1 year
Domain expiry SSL expiry Danger zone (≤30 days)
Recommended actions
  • Enable DNSSEC to protect visitors from DNS spoofing
  • Enable registrar lock (clientTransferProhibited) to block unauthorized domain transfers
Registrar Gandi SAS
Created April 2, 2004 (22 years, 4 months ago)
Expires April 2, 2027 (11 months)
Last Updated February 6, 2026
Name Servers ns1.digitalocean.com, ns2.digitalocean.com, ns3.digitalocean.com
DNSSEC Not enabled
Hosting
IP Address 2a03:b0c0:3:d0::1a51:c001
Data source: rdap (0.4s)

DNSSEC protects against DNS spoofing attacks. While not required, enabling DNSSEC adds an additional layer of security. Contact your DNS provider to enable it.

Why this matters

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.

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

Connection waterfall

DNS Lookup 48 ms TCP Connect 31 ms TLS Handshake 65 ms Server Processing 37 ms Content Transfer 0 ms
All checks on this page are automated. Results are estimates - run targeted manual reviews when the score affects a release decision.

Send Feedback