// docs / quotas & limits
Quote è limiti
Every quota è rate-limit value below hè derived da u entitlements module at build time, so this page pò never drift da what u server actually enforces.
Diritti per pianu
| Gratisi | Passatempu | Pro | Illimité | |
|---|---|---|---|---|
| Scansioni / mese | 3 | 50 | 200 | Pianu Unlimited¹ |
| Prughjetti (verified duminii) | 1 | 1 | 5 | 20 |
| API tokens | 0 | 1 | 5 | 20 |
| Webhook endpoints | 0 | 1 | 5 | 20 |
| Active probes | nò | sì | sì | sì |
| GitHub repo scansioni | nò | nò | sì | sì |
| Scheduled re-scansioni | nò | nò | ≥3h cadence | ≥6h cadence |
| Live threat detection | nò | nò | nò | sì |
| Sharable reports | nò | nò | sì | sì |
| Ritenzione | 7 days | 30 days | 90 days | 365 days |
| Team seats | 1 | 1 | 1 | 5 |
| Supportu | standard | standard | priorità | dedicatu |
¹ The Unlimited plan's scan quota is subject to fair use — see Terms. ² The project cap defaults to 20 active-monitoring domains at ≥6h cadence. Contact support@fixvibe.app to raise it in exchange for a longer scheduled cadence.
API rate limits
Every /api/v1/* è /api/mcp dumanda hè keyed on a hash of u bearer token è runs through two windows:
- Burst: 10 requests per second.
- Steady: 60 requests per minute.
- Per signed-in user: 30 scan submissions per 10 minutes — a soft cap above the per-plan monthly quota that absorbs bursts without exhausting the daily budget.
On 429, u response includes:
HTTP/1.1 429 Too Many Requests
content-type: application/json
retry-after: 47
x-ratelimit-limit: 60
x-ratelimit-remaining: 0
x-ratelimit-reset: 1715116200
{
"error": "rate_limited",
"message": "Token rate limit exceeded — steady (60/min). Retry in 47s.",
"retry_after_seconds": 47
}The window which tripped hè named in u message (burst (10/s) vs steady (60/min)) so a client backoff pò adapt.
Limita di velocità di scansione di u pianu Free (per IP/24)
On top of the per-org 3-scans-per-month cap, Free plan users face an additional per-IP/24 rate limit: 3 scans per rolling 24 hours per IP /24 block. The same limiter covers anonymous instant scans, which prevents farming Free quota through throwaway accounts on one IP. Requests exceeding the limit return HTTP 429 Too Many Requests with a Retry-After header.
Signup throttle (per IP/24)
5 registrazioni successive per IP/24 ogni 24 ore, per impedisce a creazione automatica di conti di u pianu Free. I callbacks limitati riportanu à /sign-in?error=rate_limited.
Ritenzione
Scans + risultati auto-purge per u table above. Anonymous one-shot scansioni expire 24h after creation. Audit logs retain per 18 months. Monitor snapshots prune à last 7 days plus u latest baseline per (duminiu, signal). Dismissed allarmi purge after 90 days. All retention enforced daily by /api/cron/retention-cleanup.
