ua-tracer
by Paul Kinlan
ua-tracer
what does a user agent actually fetch, follow & run?
Trace jqagGmoB
First seen: 2026-07-02 18:55:34.757 UTC
User-Agent: Mastodon/4.5.11 (http.rb/5.3.1; +https://kapteinis.lv/) Bot
Bot verification: Not a known bot (no IP-range check applies).
What this user agent did
Directly-referenced assets:
✗ fetched CSS
✗ fetched JS
✗ fetched image
✗ fetched font (HTML)
Document-level link hints:
✗ fetched favicon
✗ fetched apple-touch-icon
✗ fetched web manifest
✗ fetched preload
✗ fetched prefetch
Second-level follows (proves it parsed the linking file):
✗ followed CSS background-image
✗ followed CSS @font-face
✗ followed manifest icon
✗ followed CSS @import
Frames (does it descend into iframes?):
✗ fetched iframe document
✗ descended into iframe (loaded inner image)
Reporting (a report-only CSP is violated by inline styles; reports can arrive via HTTP headers with no JS, or via in-page beacons):
✗ sent a CSP/Reporting report (any path)
✗ delivered via report-uri/Report-To header (no JS)
✗ delivered via in-page beacon (securitypolicyviolation / ReportingObserver)
Social embed (Open Graph / Twitter card images):
✓ fetched og:image
✗ fetched twitter:image
JavaScript execution:
✗ EXECUTED classic JS
✗ EXECUTED ES module
✗ posted client timing
Server-side request waterfall
Every request the server received for this trace, in receive order. +ms is the delta from the
homepage request.
| Received | Δ | Kind | Method | User-Agent |
|---|---|---|---|---|
| 2026-07-02 18:55:34.757 UTC | +0 ms | homepage | GET | Mastodon/4.5.11 (http.rb/5.3.1; +https://kapteinis.lv/) Bot |
request headers (12){
"accept": "text/html",
"accept-encoding": "gzip",
"accept-language": "en, *;q=0.5",
"connection": "close",
"date": "Thu, 02 Jul 2026 18:55:34 GMT",
"host": "uatracer.com",
"traceparent": "00-291084fab89066a143658bcbda51c08e-24c06f7f7478808c-01",
"tracestate": "",
"user-agent": "Mastodon/4.5.11 (http.rb/5.3.1; +https://kapteinis.lv/) Bot",
"via": "HTTP/1.1 ams.vultr.prod.deno-cluster.net",
"x-deno-userspace-traceparent": "00-291084fab89066a143658bcbda51c08e-0a95569f6970cad2-01",
"x-deno-userspace-tracestate": ""
}
|
||||
| 2026-07-02 18:55:36.173 UTC | +1416 ms | Open Graph image | GET | Mastodon/4.5.11 (http.rb/5.3.1; +https://kapteinis.lv/) |
request headers (10){
"accept-encoding": "gzip",
"connection": "close",
"date": "Thu, 02 Jul 2026 18:55:36 GMT",
"host": "uatracer.com",
"traceparent": "00-eeb606b76b24b6b85f95d815e4c24d87-6667eed25455ed50-01",
"tracestate": "",
"user-agent": "Mastodon/4.5.11 (http.rb/5.3.1; +https://kapteinis.lv/)",
"via": "HTTP/1.1 ams.vultr.prod.deno-cluster.net",
"x-deno-userspace-traceparent": "00-eeb606b76b24b6b85f95d815e4c24d87-273c19005f4a6ee8-01",
"x-deno-userspace-tracestate": ""
}
|
||||