# Authentication Mission Control supports two auth modes via `AUTH_MODE`: - `local`: shared bearer token auth for self-hosted deployments - `clerk`: Clerk JWT auth ## Local mode Backend: - `AUTH_MODE=local` - `LOCAL_AUTH_TOKEN=` Frontend: - `NEXT_PUBLIC_AUTH_MODE=local` - Provide the token via the login UI. ## Clerk mode Backend: - `AUTH_MODE=clerk` - `CLERK_SECRET_KEY=` Frontend: - `NEXT_PUBLIC_AUTH_MODE=clerk` - `NEXT_PUBLIC_CLERK_PUBLISHABLE_KEY=` ## Agent authentication Autonomous agents primarily authenticate via an `X-Agent-Token` header. On shared user/agent routes, the backend also accepts `Authorization: Bearer ` after user auth does not resolve. See [API reference](api.md) for details. Security notes: - Agent auth is rate-limited to **20 requests per 60 seconds per IP**. Exceeding this returns `429 Too Many Requests`. - Authentication failure logs may include a short token prefix for debugging, but never the full token.