Voltar ao índice
Design e UI

Padrões de autenticação e autorização

Orienta autenticação e controle de acesso com sessões, JWT, OAuth2, OpenID Connect e RBAC para aplicações e APIs.

Ver código no GitHub Instala diretamente do repositório-fonte.

O que esta skill faz

Esta skill separa verificação de identidade e autorização de ações, oferecendo padrões para login, sessões, tokens e políticas. Ela também cobre OAuth2, OpenID Connect, SSO, RBAC, propriedade de recursos e ambientes multi-tenant.

Quando usar

  • Implementar autenticação em uma aplicação
  • Proteger APIs REST ou GraphQL
  • Adicionar login social ou SSO
  • Criar permissões baseadas em funções
  • Investigar falhas de sessão ou autorização

Como usar

  1. Revise o repositório e mapeie usuários, recursos, papéis e fronteiras de confiança
  2. Separe requisitos de autenticação dos de autorização
  3. Escolha entre sessões, JWT ou OAuth2/OpenID Connect conforme o fluxo
  4. Implemente hash de senhas, HTTPS e verificações de permissão
  5. Teste expiração, logout, acesso negado e isolamento entre usuários

O que revisar antes de instalar

  • A escolha entre sessão e token depende da arquitetura e das ameaças
  • JWT não resolve sozinho revogação, armazenamento ou autorização
  • A documentação detalhada adicional precisa ser consultada quando necessária

SKILL.md

---
name: auth-implementation-patterns
description: Master authentication and authorization patterns including JWT, OAuth2, session management, and RBAC to build secure, scalable access control systems. Use when implementing auth systems, securing APIs, or debugging security issues.
---

# Authentication & Authorization Implementation Patterns

Build secure, scalable authentication and authorization systems using industry-standard patterns and modern best practices.

## When to Use This Skill

- Implementing user authentication systems
- Securing REST or GraphQL APIs
- Adding OAuth2/social login
- Implementing role-based access control (RBAC)
- Designing session management
- Migrating authentication systems
- Debugging auth issues
- Implementing SSO or multi-tenancy

## Core Concepts

### 1. Authentication vs Authorization

**Authentication (AuthN)**: Who are you?

- Verifying identity (username/password, OAuth, biometrics)
- Issuing credentials (sessions, tokens)
- Managing login/logout

**Authorization (AuthZ)**: What can you do?

- Permission checking
- Role-based access control (RBAC)
- Resource ownership validation
- Policy enforcement

### 2. Authentication Strategies

**Session-Based:**

- Server stores session state
- Session ID in cookie
- Traditional, simple, stateful

**Token-Based (JWT):**

- Stateless, self-contained
- Scales horizontally
- Can store claims

**OAuth2/OpenID Connect:**

- Delegate authentication
- Social login (Google, GitHub)
- Enterprise SSO

## Detailed patterns and worked examples

Detailed pattern documentation lives in `references/details.md`. Read that file when the navigation tier above is insufficient.

## Best Practices

1. **Never Store Plain Passwords**: Always hash with bcrypt/argon2
2. **Use HTTPS**: Encrypt data in transit
3. **Short-Lived Access Tokens**: 15-30 minutes max
4. **Secure Cookies**: httpOnly, secure, sameSite flags
5. **Validate All Input**: Email format, password strength
6. **Rate Limit Auth Endpoints**: Prevent brute force attacks
7. **Implement CSRF Protection**: For session-based auth
8. **Rotate Secrets Regularly**: JWT secrets, session secrets
9. **Log Security Events**: Login attempts, failed auth
10. **Use MFA When Possible**: Extra security layer

## Common Pitfalls

- **Weak Passwords**: Enforce strong password policies
- **JWT in localStorage**: Vulnerable to XSS, use httpOnly cookies
- **No Token Expiration**: Tokens should expire
- **Client-Side Auth Checks Only**: Always validate server-side
- **Insecure Password Reset**: Use secure tokens with expiration
- **No Rate Limiting**: Vulnerable to brute force
- **Trusting Client Data**: Always validate on server