NALU/src/Nalu.Web/Pages/Docs/Mcp.cshtml
Ricardo Carneiro ea6cdb5395 Initial commit — NALU AI web platform
- ASP.NET Core 9 Razor Pages + Minimal API hybrid
- 14 validators (CPF, CEP, CNPJ, email, phone, name, yes-no, birthdate, handoff, cancel-intent, company-name, plate-br, postal-code, validate_reply)
- OAuth login (Google, Microsoft, GitHub) + cookie auth
- MongoDB usage tracking + CEP cache collection
- Stripe checkout with inline PriceData (no Price IDs)
- MCP server for Claude Code / Cursor integration
- Playground (10 calls/IP/day, no auth)
- Docs: Quickstart, API Reference, N8N, MCP, Créditos, Erros, Fluxos
- Credit system: 3 cr standard validators, 5 cr validate_reply
- SmartSuggestion: contextual re-ask via IA when obtained=false
- Per-IP rate limiting + daily cap + shared-IP abuse detection
- Lightbox for comic images
- Validadores page split: Brasileiros / Universais + Em breve

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-05-10 16:39:04 -03:00

134 lines
6.6 KiB
Plaintext

@page "/docs/mcp"
@model Nalu.Web.Pages.Docs.McpModel
@{
ViewData["Title"] = "MCP Server — NALU AI Docs";
ViewData["Description"] = "Integre NALU AI com Claude Code, Cursor e qualquer cliente MCP via JSON-RPC 2.0.";
}
<section class="bg-gradient-to-b from-slate-50 to-white pt-16 pb-8">
<div class="max-w-3xl mx-auto px-4 sm:px-6">
<div class="text-xs font-semibold text-nalu-600 uppercase tracking-wide mb-3">
<a href="/docs" class="hover:underline">Docs</a> / MCP Server
</div>
<h1 class="text-3xl font-extrabold text-gray-900 mb-2">MCP Server</h1>
<p class="text-gray-500">Use os validadores NALU como ferramentas nativas no Claude Code, Cursor e qualquer cliente MCP.</p>
</div>
</section>
<section class="py-10 bg-white">
<div class="max-w-3xl mx-auto px-4 sm:px-6 space-y-10">
<!-- O que é MCP -->
<div>
<h2 class="text-lg font-bold text-gray-900 mb-2">O que é MCP?</h2>
<p class="text-sm text-gray-600">
Model Context Protocol (MCP) é um protocolo aberto que permite agentes de IA chamarem ferramentas externas de forma padronizada.
O NALU AI expõe todos os validadores como ferramentas MCP via <code class="bg-slate-100 px-1 rounded text-xs">JSON-RPC 2.0</code> sobre <code class="bg-slate-100 px-1 rounded text-xs">stdio</code> ou <code class="bg-slate-100 px-1 rounded text-xs">HTTP/SSE</code>.
</p>
</div>
<!-- Claude Code -->
<div>
<h2 class="text-lg font-bold text-gray-900 mb-3">Configurar no Claude Code</h2>
<p class="text-sm text-gray-600 mb-3">Adicione ao seu <code class="bg-slate-100 px-1 rounded text-xs">~/.claude/settings.json</code>:</p>
<div class="bg-slate-900 rounded-xl p-5 font-mono text-sm text-slate-300 overflow-x-auto leading-relaxed">
<pre>{
"mcpServers": {
"nalu": {
"command": "npx",
"args": ["-y", "@@naluai/mcp-server"],
"env": {
"NALU_API_KEY": "SUA_API_KEY"
}
}
}
}</pre>
</div>
<p class="text-xs text-gray-500 mt-2">Ou via HTTP (se preferir não usar npx):</p>
<div class="bg-slate-900 rounded-xl p-5 font-mono text-sm text-slate-300 overflow-x-auto leading-relaxed mt-2">
<pre>{
"mcpServers": {
"nalu": {
"url": "https://api.naluai.com/mcp",
"headers": {
"Authorization": "Bearer SUA_API_KEY"
}
}
}
}</pre>
</div>
</div>
<!-- Cursor -->
<div>
<h2 class="text-lg font-bold text-gray-900 mb-3">Configurar no Cursor</h2>
<p class="text-sm text-gray-600 mb-3">Acesse <strong>Settings → MCP → Add Server</strong> e adicione:</p>
<div class="bg-slate-900 rounded-xl p-5 font-mono text-sm text-slate-300 overflow-x-auto leading-relaxed">
<pre>Name: NALU AI
URL: https://api.naluai.com/mcp
Headers:
Authorization: Bearer SUA_API_KEY</pre>
</div>
</div>
<!-- Ferramentas disponíveis -->
<div>
<h2 class="text-lg font-bold text-gray-900 mb-3">Ferramentas disponíveis</h2>
<p class="text-sm text-gray-600 mb-3">Após conectar, o agente de IA enxerga estas ferramentas:</p>
<div class="bg-white border border-gray-100 rounded-xl overflow-hidden">
<table class="w-full text-sm">
<thead class="bg-gray-50 border-b border-gray-100">
<tr>
<th class="px-4 py-2 text-left font-semibold text-gray-700">Ferramenta</th>
<th class="px-4 py-2 text-left font-semibold text-gray-700">Descrição</th>
</tr>
</thead>
<tbody class="divide-y divide-gray-50 text-xs">
@foreach (var t in new[] {
("validate_cpf", "Extrai e valida CPF de texto em linguagem natural"),
("validate_cep", "Extrai CEP e retorna endereço completo"),
("validate_cnpj", "Extrai e valida CNPJ"),
("validate_email", "Extrai email com correção de typos"),
("validate_phone_br", "Extrai telefone brasileiro com DDD"),
("validate_plate_br", "Extrai placa Mercosul ou formato antigo"),
("validate_postal_code", "Código postal internacional"),
("validate_full_name", "Extrai nome completo, ignora saudações"),
("validate_yes_no", "Detecta sim/não em linguagem natural"),
("validate_birthdate", "Extrai data de nascimento"),
("validate_handoff", "Detecta intenção de falar com humano"),
("validate_cancel_intent", "Classifica intenção de cancelamento"),
("validate_company_name", "Extrai nome de empresa"),
("validate_reply", "Analisa contexto conversacional completo"),
})
{
<tr class="hover:bg-gray-50">
<td class="px-4 py-2 font-mono text-nalu-600">@t.Item1</td>
<td class="px-4 py-2 text-gray-600">@t.Item2</td>
</tr>
}
</tbody>
</table>
</div>
</div>
<!-- Exemplo de uso -->
<div>
<h2 class="text-lg font-bold text-gray-900 mb-3">Exemplo de uso no Claude Code</h2>
<div class="bg-slate-50 rounded-xl p-5 text-sm text-gray-700 leading-relaxed border border-gray-100">
<p class="text-gray-500 text-xs mb-3">Prompt para o Claude:</p>
<p class="italic">"O usuário disse 'meu cpf é 111.444.777-35'. Use validate_cpf para extrair e validar."</p>
<p class="text-gray-500 text-xs mt-4 mb-1">Claude chama automaticamente:</p>
<pre class="font-mono text-xs bg-white rounded p-3 border border-gray-100">validate_cpf({
"agent_input": "Qual o seu CPF?",
"user_input": "meu cpf é 111.444.777-35"
})</pre>
</div>
</div>
<div class="border-t border-gray-100 pt-6 flex gap-4">
<a href="/docs" class="text-nalu-600 text-sm hover:underline">← Voltar para Docs</a>
<a href="/docs/api-reference" class="text-nalu-600 text-sm hover:underline">API Reference →</a>
</div>
</div>
</section>