cpf-validador
Health Uyari
- License — License: MIT
- Description — Repository has a description
- Active repo — Last push 0 days ago
- Low visibility — Only 5 GitHub stars
Code Basarisiz
- eval() — Dynamic code execution via eval() in app/captcha/predictor.py
Permissions Gecti
- Permissions — No dangerous permissions requested
This tool validates Brazilian CPF (tax ID) numbers, looks up who they belong to by querying a public labor court (TRT3), and automatically solves CAPTCHAs using a locally trained neural network. It provides these features via a REST API, a web interface, and MCP tools for AI agents.
Security Assessment
The tool processes highly sensitive personal data (national ID numbers and names) and makes external network requests to government websites. A critical security concern is the use of `eval()` for dynamic code execution in the CAPTCHA prediction module, which introduces a severe risk of arbitrary code execution if exploited. No dangerous system-level permissions or hardcoded secrets were found, but the combination of handling sensitive personal identifiers, a shared global history log, and unsafe code execution practices raises significant privacy and security concerns. Overall risk: High.
Quality Assessment
The project is licensed under the permissive and standard MIT license, and the repository appears active with very recent updates. However, it suffers from extremely low community visibility (only 5 GitHub stars), meaning the codebase lacks the broader peer review necessary to validate the safety of its neural network and CAPTCHA bypassing mechanisms.
Verdict
Not recommended — use with extreme caution due to the combination of handling highly sensitive PII, a critical `eval()` vulnerability, and the legal/ethical implications of automating CAPTCHA bypasses on government systems.
🔍 Valide CPFs e descubra a quem pertencem — MCP tools + REST API + interface web com CAPTCHA solver via CRNN
🔍 CPF Validador
Valide CPFs, descubra a quem pertencem e encontre o CPF correto a partir de dígitos parciais ou ilegíveis — com resolução automática de CAPTCHA via rede neural treinada localmente.
Expõe as mesmas operações como MCP tools (para agentes AI) e REST API (para integrações diretas), com interface web incluída.
💡 O que este projeto faz
| ✅ | Valida se um CPF é matematicamente correto |
| 👤 | Confirma a quem um CPF pertence pelo nome |
| 🔎 | Descobre o CPF completo a partir de dígitos parciais ou ilegíveis |
| 👥 | Processa dezenas de CPFs em paralelo |
| 🤖 | Integra com qualquer agente AI via protocolo MCP |
Para confirmar a titularidade de um CPF, o sistema consulta o TRT3 — que emite certidões públicas associando CPF e nome. A resolução de CAPTCHA é feita por uma CRNN (Convolutional Recurrent Neural Network) treinada especificamente para isso, atingindo ~99% de acurácia sem depender de nenhum serviço externo.
🤖 MCP Tools
| Tool | Descrição |
|---|---|
validate_cpf |
Valida matematicamente um CPF pelo algoritmo módulo-11 |
generate_valid_variations |
Gera todas as variações válidas de um CPF com dígitos errados ou ilegíveis |
check_feitos_trabalhistas |
Confirma titularidade de um CPF consultando o TRT3 |
find_cpf_by_mask |
Descobre o CPF completo a partir de uma máscara com * nos dígitos desconhecidos |
find_cpf_by_variations |
Dado um CPF parcial ou errado, encontra o correto filtrando pelo nome |
check_multiple_cpfs |
Valida e confirma titularidade de uma lista de CPFs em paralelo |
🌐 REST API
| Método | Rota | Rate limit | Descrição |
|---|---|---|---|
GET |
/ |
— | Interface web |
POST |
/cpf/validate |
— | Valida um CPF matematicamente |
POST |
/cpf/variations |
— | Gera variações válidas de um CPF |
POST |
/trt3/feitos |
10/min por IP | Confirma titularidade de um CPF via TRT3 |
POST |
/trt3/feitos-multiplos |
5/min por IP | Confirma lista de CPFs em paralelo |
POST |
/trt3/buscar-por-mascara |
3/min por IP | Descobre CPF por máscara com * |
POST |
/trt3/buscar-por-variacoes |
3/min por IP | Descobre CPF correto a partir de variações |
GET |
/history/ |
— | Lista o histórico de consultas realizadas |
POST |
/history/save |
— | Salva ou atualiza uma entrada no histórico |
DELETE |
/history/ |
— | Limpa todo o histórico |
DELETE |
/history/{cpf} |
— | Remove a entrada de um CPF específico |
GET |
/health |
— | Health check — retorna {"status": "ok"} |
Documentação interativa: http://localhost:8000/docs (disponível apenas em ENV=development).
📂 Histórico de consultas
O histórico é global e compartilhado — todas as consultas feitas pela interface web, pela REST API ou via MCP gravam no mesmo arquivo de histórico do servidor.
- Interface web: o usuário pode ativar ou desativar o salvamento automático individualmente, através do toggle na aba Histórico. A preferência é salva no
localStoragedo navegador e não afeta outras interfaces. - REST API / MCP: toda consulta bem-sucedida é registrada no histórico global, independente do token utilizado.
Roadmap: no futuro está prevista a opção de múltiplos históricos isolados por token — permitindo que cada integração (web, API, MCP) mantenha seu próprio registro separado.
🏗️ Arquitetura
FastAPI com FastMCP 3.0 montado em /mcp (streamable-http). A camada services/ não tem dependência de framework — a mesma lógica é consumida pelos routers REST e pelo MCP server.
app/
├── main.py # FastAPI — routers + mcp.http_app() em /mcp + rate limiter
├── config.py # Lê todas as variáveis de ambiente com defaults
├── mcp_server.py # FastMCP("cpf-validador") — 6 tools
├── auth.py # TokenMiddleware — autenticação via API_TOKEN + controle prod/dev
├── services/
│ ├── cpf.py # Validação, variações e geração por máscara (zero deps de framework)
│ └── trt3.py # Consulta TRT3: curl_cffi + CAPTCHA solver + pypdf
├── routers/
│ ├── cpf.py # POST /cpf/validate, POST /cpf/variations
│ ├── trt3.py # POST /trt3/feitos, /feitos-multiplos, /buscar-por-mascara, /buscar-por-variacoes
│ ├── history.py # GET/POST/DELETE /history/ — histórico de consultas
│ └── ui.py # GET / — interface web
└── captcha/
├── model.py # Arquitetura CRNN (CNN + BiLSTM + CTC Loss)
├── predictor.py # Inferência: carrega captcha_model.pt e prediz
├── dataset.py # CaptchaDataset com data augmentation
├── train.py # Loop de treino com early stopping + AMP + registry
├── collector.py # Coleta amostras rotuladas direto do TRT3
├── registry.py # Versionamento de modelos (models/vN/model.pt + meta.json)
└── models/ # Histórico de versões treinadas
Regras de camada:
services/— zero imports de FastAPI ou FastMCProuters/emcp_server.py— importam apenas deservices/- I/O bloqueante em
services/trt3.pyé sempre executado viarun_in_threadpool
⚙️ Configuração
Todas as opções são lidas de variáveis de ambiente ou do arquivo .env na raiz do projeto.
Referência completa de variáveis
| Variável | Padrão | Descrição |
|---|---|---|
API_TOKEN |
(vazio — sem auth) | Token Bearer. Se vazio, todos os endpoints ficam abertos |
ENV |
development |
development ou production — controla quais rotas ficam abertas sem token |
TRT3_BASE_URL |
https://certidao.trt3.jus.br |
URL base do site do TRT3 |
TRT3_FORM_PATH |
/certidao/feitosTrabalhistas/aba1.emissao.htm |
Path do formulário de consulta |
HTTP_TIMEOUT |
30 |
Timeout (segundos) para requisições HTTP ao TRT3 |
CAPTCHA_TIMEOUT |
15 |
Timeout (segundos) para download da imagem CAPTCHA |
MAX_CAPTCHA_ATTEMPTS |
20 |
Tentativas máximas de resolver o CAPTCHA antes de desistir |
RETRY_DELAY |
1.0 |
Segundos de espera entre tentativas de CAPTCHA |
DEFAULT_WORKERS |
8 |
Threads paralelas padrão nas consultas em lote |
MAX_WORKERS |
20 |
Limite máximo de workers que o cliente pode solicitar |
TASK_TIMEOUT |
60 |
Timeout (segundos) por CPF individual em consultas paralelas |
MAX_WILDCARDS_IN_MASK |
5 |
Máximo de * na parte base da máscara (evita explosão combinatória) |
RATE_LIMIT_FEITOS |
10/minute |
Rate limit de /trt3/feitos por IP |
RATE_LIMIT_MULTIPLOS |
5/minute |
Rate limit de /trt3/feitos-multiplos por IP |
RATE_LIMIT_MASK |
3/minute |
Rate limit de /trt3/buscar-por-mascara por IP |
RATE_LIMIT_VARIACOES |
3/minute |
Rate limit de /trt3/buscar-por-variacoes por IP |
CAPTCHA_MODEL_PATH |
(vazio — usa app/captcha/captcha_model.pt) |
Path absoluto para o modelo .pt (útil para montar modelo externo) |
HISTORY_RETENTION_DAYS |
90 |
Dias de retenção do histórico (LGPD). 0 = sem limite |
APP_TIMEZONE |
America/Sao_Paulo |
Timezone para timestamps do histórico |
🔒 Rotas abertas por ambiente
| Rota | development |
production |
|---|---|---|
/ |
✅ aberta | ✅ aberta |
/health |
✅ aberta | ✅ aberta |
/docs |
✅ aberta | 🔒 token |
/redoc |
✅ aberta | 🔒 token |
/openapi.json |
✅ aberta | 🔒 token |
/mcp |
🔒 token | 🔒 token |
| demais | 🔒 token | 🔒 token |
Se
API_TOKENestiver vazio, o middleware ignora autenticação em qualquer ambiente.
🔐 Autenticação
Com API_TOKEN configurado, todas as requisições protegidas precisam enviar:
Authorization: Bearer meu-token-secreto
REST:
curl -X POST http://localhost:8000/trt3/feitos \
-H "Authorization: Bearer meu-token-secreto" \
-H "Content-Type: application/json" \
-d '{"cpf": "529.982.247-25"}'
Claude Desktop / Claude Code (claude_desktop_config.json):
{
"mcpServers": {
"cpf-validador": {
"command": "npx",
"args": ["mcp-remote", "http://localhost:8000/mcp", "--allow-http"],
"env": {
"MCP_REMOTE_HEADER_AUTHORIZATION": "Bearer meu-token-secreto"
}
}
}
}
A interface web (/) exibe um gate de autenticação quando API_TOKEN está definido — o token é validado contra o servidor e salvo no navegador.
🚀 Instalação
Docker (recomendado)
git clone https://github.com/opastorello/cpf-validador.git
cd cpf-validador
cp .env.example .env # edite se quiser definir API_TOKEN
docker compose up --build -d
Local
pip install -r requirements.txt
cp .env.example .env
uvicorn app.main:app --host 0.0.0.0 --port 8000 --reload
Após iniciar:
- Interface web:
http://localhost:8000/ - REST docs:
http://localhost:8000/docs(apenas emENV=development) - MCP endpoint:
http://localhost:8000/mcp
📋 Exemplos de uso
Validar um CPF
curl -X POST http://localhost:8000/cpf/validate \
-H "Content-Type: application/json" \
-d '{"cpf": "529.982.247-25"}'
Confirmar titularidade
curl -X POST http://localhost:8000/trt3/feitos \
-H "Content-Type: application/json" \
-d '{"cpf": "529.982.247-25"}'
{
"cpf": "529.982.247-25",
"encontrado": true,
"nome_certidao": "JOAO DA SILVA",
"valida_ate": "18/04/2026",
"numero_certidao": "2026/123456"
}
Descobrir CPF por máscara
Quando você conhece apenas parte dos dígitos — substitua os desconhecidos por *:
curl -X POST http://localhost:8000/trt3/buscar-por-mascara \
-H "Content-Type: application/json" \
-d '{"mascara": "***.123.456-**", "nome": "João Silva"}'
O servidor gera todas as combinações válidas para as posições com *, consulta em paralelo e retorna apenas os matches com o nome informado.
Máximo de 5 wildcards na parte base (posições 0–8) = até 100.000 combinações. Configurável via
MAX_WILDCARDS_IN_MASK.
Recuperar CPF com erros ou dígito faltando
curl -X POST http://localhost:8000/trt3/buscar-por-variacoes \
-H "Content-Type: application/json" \
-d '{"cpf_parcial": "5299824725", "nome": "joao"}'
Consulta em lote
curl -X POST http://localhost:8000/trt3/feitos-multiplos \
-H "Content-Type: application/json" \
-d '{"cpfs": ["529.982.247-25", "111.444.777-35"], "workers": 4}'
🧠 Modelo de CAPTCHA
Arquitetura CRNN
Input (1×60×160)
→ Conv2D ×4 + BatchNorm + ReLU + MaxPool (extração de features visuais)
→ BiLSTM ×2 (128 hidden, bidirectional) (modelagem de sequência)
→ Linear → CTC Loss (decode sem segmentação)
Output: string de 5 caracteres [0-9a-z]
Bootstrapping em 3 rodadas
| Rodada | Amostras | Rotulador | Acurácia dos labels | Acurácia do modelo |
|---|---|---|---|---|
| 1 | 15.000 | ddddocr (OCR genérico) | ~43% | 98.70% |
| 2 | 20.000 | Modelo R1 | ~96% | 98.80% |
| 3 | 20.000 | Modelo R2 | ~99.3% | 98.55% |
Total: 55.000 amostras. O modelo final (v1) convergiu na época 106/120 com val_loss=0.0072.
Hiperparâmetros
- Optimizer: AdamW | LR: 1e-3 com CosineAnnealingLR
- Epochs: 120 com early stopping (patience: 20)
- Batch size: 128 | Treino: GPU com AMP float16 via
torch.amp.autocast - Inferência: CPU-only (Docker)
- Augmentation: rotação, shear, translate, color jitter, gaussian blur, random erasing
Treinar o modelo
1. Coletar amostras
python -m app.captcha.collector --cpf 000.000.000-00 --target 15000 --workers 4
2. Treinar
python -m app.captcha.train --epochs 120 --batch 128 --lr 1e-3
O melhor modelo (menor val_loss) é salvo em app/captcha/captcha_model.pt.
3. Bootstrap (melhora qualidade dos labels)
rm -rf app/captcha/data/
python -m app.captcha.collector --cpf 000.000.000-00 --target 20000 --workers 4
python -m app.captcha.train --epochs 120 --batch 128 --lr 1e-3
Repita 2–3 rodadas até a acurácia estabilizar. Para consultar o histórico de versões:
python -m app.captcha.registry
📦 Dependências principais
| Pacote | Uso |
|---|---|
| FastMCP | Framework MCP server |
| FastAPI | REST API |
| slowapi | Rate limiting por IP |
| curl-cffi | HTTP com impersonação TLS Chrome-124 |
| PyTorch | Rede neural CRNN para CAPTCHA |
| torchvision | Transforms e augmentation de imagem |
| pypdf | Extração de dados do PDF de certidão |
| Pillow | Processamento de imagem |
| python-dotenv | Carregamento de variáveis do .env |
📄 Licença
MIT © 2026 Nícolas Pastorello
Yorumlar (0)
Yorum birakmak icin giris yap.
Yorum birakSonuc bulunamadi