Os navegadores modernos podem enviar um relatório estruturado sempre que bloqueiam um script, imagem ou estilo que viola a sua CSP. O SiteGuardian fornece-lhe o endpoint para os receber — agregados, desduplicados e com alertas.
Plano gratuito inclui 10 000 relatórios/mês · Privacy-first · Alojado na UE
A misconfigured CSP can flood you with millions of reports from a single browser tab. We bucket by (directive, blocked URI, source file) — one row with a count, three samples, and a browser breakdown.
Client IPs hashed with a daily-rotating salt. Query strings + fragments stripped from document URIs before storage. User-Agent reduced to browser family. No session tokens. No cookies.
Built-in metrics for any alert rule: spike detection (csp_report_volume) and new-violation-type notifications (csp_new_violation_type_count). Catch a broken deploy the moment the first real user hits it.
One click on the monitor's detail page. We generate an HMAC-signed URL and hand you a copy-paste CSP snippet.
Both legacy (report-uri) and modern (Reporting-Endpoints + Report-To) formats are supported in parallel. Works with every current browser.
Within seconds of real traffic the CSP Reports tab lights up with the first buckets. Click a row for raw samples, browser breakdown, and affected pages.
After a week of reports we suggest allowlist additions ranked by how many users each suggestion would unbreak. Apply the diff, redeploy, tighten the next ring.
Sem custo adicional
Os relatórios CSP estão incluídos em todos os planos SiteGuardian. O seu escalão define a quota mensal e o período de retenção.
| Plano | CSP reports / month | Retenção |
|---|---|---|
| Gratuito | 10 000 | 7 days |
| Pro | 1 000 000 | 90 days |
| Business | 10 000 000 | 180 days |
| Compliance | 10 000 000 | 180 days |
| Enterprise | Negociado | 365 dias |
Limite atingido? A ingestão pausa automaticamente com um aviso de atualização — nunca é cobrado por excesso. A proteção anti-abuso por monitor ativa-se aos 10 000 relatórios/minuto.
One monitor, one header, 60 seconds to the first bucket.
Start free