cep-tools

cep-tools

An MCP server that provides a tool to query Brazilian postal codes (CEPs) via the ViaCEP API, returning address details such as street, neighborhood, city, and state.

Category
Visit Server

README

Assistente de CEP com OpenAI + MCP

Mini-laboratorio para o seminario de Servicos Web sobre Model Context Protocol (MCP).

O projeto demonstra uma aplicacao de IA que conversa com a OpenAI e usa um servidor MCP para consultar CEPs brasileiros na API publica ViaCEP.

Ideia

Quando o usuario pergunta por um CEP, a aplicacao envia a conversa para o modelo da OpenAI com uma ferramenta disponivel. Se o modelo decidir que precisa consultar dados externos, a aplicacao roteia a chamada para o servidor MCP cep-tools, que por sua vez consulta a API REST do ViaCEP.

flowchart LR
  U["Usuario"]
  APP["Chat CLI Node.js"]
  OAI["OpenAI"]
  MCP["MCP Server cep-tools"]
  VIA["API REST ViaCEP"]

  U --> APP
  APP --> OAI
  OAI --> APP
  APP --> MCP
  MCP --> VIA
  VIA --> MCP
  MCP --> APP
  APP --> OAI
  OAI --> APP
  APP --> U

O que o MCP Server expoe

  • Tool consultar_cep: recebe um CEP com ou sem hifen e retorna endereco, bairro, cidade, UF, DDD, codigo IBGE e outros campos.
  • Resource cep://exemplos: retorna uma lista de CEPs prontos para usar na demonstracao.

Requisitos

  • Node.js 20 ou superior
  • NPM
  • Chave da OpenAI para usar o chat

Instalacao

npm install

Copie o arquivo de ambiente:

copy .env.example .env

Edite .env:

OPENAI_API_KEY=sua_chave
OPENAI_MODEL=gpt-4.1-mini

Voce pode trocar OPENAI_MODEL por outro modelo disponivel na sua conta.

Rodando a demo MCP sem OpenAI

Este comando prova que o servidor MCP esta funcionando:

npm run demo:cep

Ele deve listar a tool consultar_cep, o resource cep://exemplos e consultar um CEP de Passo Fundo.

Rodando o chat com OpenAI

npm run chat

Exemplos de perguntas:

Consulta o CEP 01001-000
Qual cidade e bairro do CEP 99010-000?
Me explica o endereco do CEP 20040-020

Durante a execucao, o chat imprime uma linha como:

[MCP] Chamando tool consultar_cep com argumentos {"cep":"99010-000"}

Essa linha e util para a apresentacao, porque mostra o momento exato em que a IA aciona a ferramenta externa via MCP.

Scripts

  • npm run build: valida o TypeScript.
  • npm run mcp:cep: sobe apenas o servidor MCP em stdio.
  • npm run demo:cep: conecta em um cliente MCP local e testa tools/resources.
  • npm run chat: inicia o assistente com OpenAI + MCP.

Estrutura

src/
  cep.ts              Regras de validacao e chamada ao ViaCEP
  mcp-server.ts       Servidor MCP com tool e resource
  mcp-client.ts       Cliente MCP usado pela aplicacao
  demo-mcp-client.ts  Teste isolado do MCP
  chat.ts             Chat CLI com OpenAI e tool calling
docs/
  roteiro-apresentacao.md
  slides.md
  referencias.md

Relacao com Servicos Web

O projeto usa uma API REST tradicional, o ViaCEP, mas a disponibiliza para uma aplicacao de IA por meio de MCP. Assim, a demo mostra duas camadas importantes:

  1. REST continua sendo usado para integrar sistemas web.
  2. MCP padroniza como agentes de IA descobrem e executam capacidades externas.

Pontos para comentar na apresentacao

  • MCP resolve o problema de integracoes N x M entre apps de IA e ferramentas externas.
  • O host cria um client MCP para conversar com cada server.
  • O server MCP expoe primitives como tools, resources e prompts.
  • O transporte local usado aqui e stdio.
  • A comunicacao logica do protocolo e baseada em JSON-RPC.
  • A aplicacao ainda precisa controlar seguranca, validacao, logs e limites de uso.

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured