Skip to content

sec(auth): comparação constant-time do BEARER_TOKEN#148

Merged
BrunooMoniz merged 1 commit into
mainfrom
sec/constant-time-bearer
Jun 18, 2026
Merged

sec(auth): comparação constant-time do BEARER_TOKEN#148
BrunooMoniz merged 1 commit into
mainfrom
sec/constant-time-bearer

Conversation

@BrunooMoniz

Copy link
Copy Markdown
Owner

Bloco D do plano pós-diagnóstico (segurança)

O BEARER_TOKEN mestre era comparado com === (não constant-time) em /mcp e /status, vazando timing que poderia ajudar a recuperar o token byte a byte.

  • Troca as duas comparações por safeEqual (timingSafeEqual + length-guard) — o helper já usado em oauth.ts. Comportamento idêntico (verdadeiro sse igual), agora sem o canal de timing.

npm run build + npm test verdes (1265/1265).

Itens do Bloco D que ficam para seu OK explícito (risco/escopo)

  • Cifrar o oauth-store (oauth.ts): muda persistência de credencial e depende de SECRETS_KEY na VPS — faço backward-compatible, mas merece confirmação.
  • Remover o double-cast as unknown as no gate de auth (index.ts): exige redefinir TokenScopes (Workspace[] vs strings de friend) num caminho de segurança — decisão de modelagem deliberada.
  • Logger central e nonce na CSP do admin: maiores/espalhados, baixo risco de correção mas fora do cirúrgico.

🤖 Generated with Claude Code

Bloco D do plano pós-diagnóstico (segurança). O token mestre era comparado com
=== (não constant-time): vazava timing que poderia ajudar a recuperar o token.
Troca pelas duas comparações por safeEqual (timingSafeEqual + length-guard),
o mesmo helper já usado em oauth.ts. Comportamento idêntico (verdadeiro sse igual).

build+test verdes (1265/1265).

Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
@BrunooMoniz BrunooMoniz merged commit 3d32709 into main Jun 18, 2026
3 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant