// docs / quotas & limits
Kvote i limiti
Svaka quota i rate-limit vrijednost ispod izvedena je iz entitlements module u build time, tako da ova stranica ne može odstupiti od onoga što server stvarno enforce.
Prava po paketu
| Besplatno | Hobi | Pro | Unlimited | |
|---|---|---|---|---|
| Scans / month | 3 | 50 | 200 | Plan Unlimited¹ |
| Projects (verified domains) | 1 | 1 | 5 | 20 |
| API tokens | 0 | 1 | 5 | 20 |
| Webhook endpoints | 0 | 1 | 5 | 20 |
| Active probes | ne | da | da | da |
| GitHub repo scans | ne | ne | da | da |
| Scheduled re-scans | ne | ne | ≥3h cadence | ≥6h cadence |
| Live threat detection | ne | ne | ne | da |
| Sharable reports | ne | ne | da | da |
| Retention | 7 dana | 30 dana | 90 dana | 365 dana |
| Team seats | 1 | 1 | 1 | 5 |
| Support | standardna | standardna | prioritetna | namjenska |
¹ 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
Svaki /api/v1/* i /api/mcp request je keyed on hash bearer token i prolazi kroz dva 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.
Na 429, response uključuje:
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
}Window koji je tripped imenovan je u message (burst (10/s) vs steady (60/min)) da se client backoff može prilagoditi.
Ograničenje brzine skeniranja plana Free (po 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 uspješnih prijava po IP/24 svakih 24 sata, kako bi se spriječilo automatizovano kreiranje računa plana Free. Ograničeni callback-ovi preusmjeravaju na /sign-in?error=rate_limited.
Zadržavanje
Scans + findings auto-purge prema tabeli iznad. Anonymous one-shot scans expire 24h after creation. Audit logs retain for 18 months. Monitor snapshots prune to last 7 days plus latest baseline per (domain, signal). Dismissed alerts purge after 90 days. All retention enforced daily by /api/cron/retention-cleanup.
