tarefas-mcp
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@tarefas-mcplist my tasks"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Exercício 4.2 — MCP server local que consome a sua API (4.1)
Módulo 3 — Construindo interfaces (Aula 6: MCP). Você vai pôr um MCP server na frente da API que construiu no 4.1, expondo tools que um agente de IA pode chamar. O autograder executa o seu MCP server de verdade: ele sobe o server, lista as tools, chama uma delas e confere que o resultado veio da sua API.
Total: 100 pontos — 35 de estrutura no GitHub + 65 de execução real do MCP.
1. Objetivo
No 4.1 você construiu a API REST de uma aplicação de TODO list. Mas um LLM não fala HTTP — ele fala MCP (Model Context Protocol). Neste exercício você cria a camada do meio: um MCP server que expõe duas tools da TODO list e as implementa chamando a sua API REST.
Agente / LLM ──MCP──▶ seu MCP server ──HTTP──▶ sua API 4.1 (localhost:8000)É o conceito da Aula 6: o MCP padroniza como o agente pede coisas; a sua API continua sendo a fonte do dado. O MCP é o adaptador entre os dois mundos.
Related MCP server: task-orchestrator-mcp
2. Pré-requisitos
Ter o Exercício 4.1 concluído (a API roda em
http://localhost:8000).Python ≥ 3.10 e
pip.SDK oficial de MCP para Python:
mcp(incluiFastMCPe o cliente stdio).autogradeinstalado e logado.
Durante a validação do 4.2, a API do 4.1 precisa estar no ar em
localhost:8000, porque as tools do MCP chamam ela.
3. O que construir
4.1 servidor_mcp.py — o MCP server
Um server MCP (stdio) que expõe duas tools, ambas chamando a sua API:
Tool | Assinatura | O que faz |
|
| faz |
|
| faz |
Esqueleto com FastMCP (você completa a listar_tarefas):
# servidor_mcp.py
import httpx
from mcp.server.fastmcp import FastMCP
API = "http://localhost:8000"
mcp = FastMCP("tarefas-mcp")
@mcp.tool()
def criar_tarefa(titulo: str) -> dict:
"""Cria uma tarefa na API e devolve o objeto criado."""
resp = httpx.post(f"{API}/tarefas", json={"titulo": titulo}, timeout=10)
resp.raise_for_status()
return resp.json()
# TODO: implemente a tool listar_tarefas() -> list que faz GET /tarefas
if __name__ == "__main__":
mcp.run() # transporte stdio por padrão4.2 cliente_teste.py — o teste que o autograder roda
Um script que sobe o servidor_mcp.py via stdio, exercita as tools e
imprime no stdout um único envelope JSON (e nada mais):
{
"tools": ["criar_tarefa", "listar_tarefas"],
"criar_resultado": {"id": 1, "titulo": "tarefa via mcp", "concluida": false},
"listar_resultado": [ {"id": 1, "titulo": "tarefa via mcp", "concluida": false} ]
}Esqueleto com o cliente stdio do SDK:
# cliente_teste.py
import asyncio
import json
from mcp import ClientSession, StdioServerParameters
from mcp.client.stdio import stdio_client
async def main() -> dict:
params = StdioServerParameters(command="python", args=["servidor_mcp.py"])
async with stdio_client(params) as (read, write):
async with ClientSession(read, write) as session:
await session.initialize()
tools = await session.list_tools()
nomes = [t.name for t in tools.tools]
criar = await session.call_tool("criar_tarefa", {"titulo": "tarefa via mcp"})
listar = await session.call_tool("listar_tarefas", {})
return {
"tools": nomes,
"criar_resultado": json.loads(criar.content[0].text),
"listar_resultado": json.loads(listar.content[0].text),
}
if __name__ == "__main__":
print(json.dumps(asyncio.run(main())))O formato exato do
call_tool(...).contentpode variar com a versão do SDK — ajuste o parsing para que o envelope final tenhacriar_resultadocomo um objeto comid/titulo/concluida, elistar_resultadocomo uma lista. É isso que o autograder confere.
4. Estrutura do repositório
seu-repo/
├── servidor_mcp.py # MCP server (tools que chamam a API 4.1)
├── cliente_teste.py # imprime o envelope JSON que o autograder lê
├── requirements.txt # mcp, httpx
├── README.md
└── .autograde-exercise # conteúdo: 4.2requirements.txt:
mcp
httpx5. Como rodar localmente
Terminal A — suba a API do 4.1 (reinicie para o store ficar limpo):
uvicorn app.main:app --port 8000 # no repo do 4.1Terminal B — no repo do 4.2:
pip install -r requirements.txt python cliente_teste.pyDeve imprimir o envelope JSON com
tools,criar_resultadoelistar_resultado.
6. Como o autograder avalia (execução real)
Com a API do 4.1 no ar, no repo do 4.2:
autograde validar 4.2O CLI roda python cliente_teste.py (rótulo extract: mcp_test), captura o
envelope JSON e o backend confere:
Critério | O que verifica |
|
|
|
|
|
|
Como o id/concluida só poderiam vir da sua API REST, passar nesses critérios
prova que a tool realmente chamou a API — não devolveu um valor fixo.
7. Rubrica (100 pts)
Estrutura no GitHub — 35 pts
Critério | Pts | Como passa |
| 5 | repositório existe e é público |
| 8 |
|
| 7 |
|
| 5 |
|
| 2 |
|
| 4 | ≥ 3 commits |
| 4 | ≥ 1 PR com título descritivo |
Execução real do MCP — 65 pts
Critério | Pts | Como passa |
| 20 | server expõe |
| 30 |
|
| 15 |
|
8. Troubleshooting
Sintoma | Causa provável | Correção |
| API 4.1 não está no ar | suba |
| logs/prints antes do JSON | imprima só |
| nome de tool diferente | as tools precisam se chamar exatamente |
| tool não chamou a API (devolveu stub) | a tool tem que fazer o POST de verdade e devolver o JSON da API |
timeout na validação | server demora a subir | mantenha o |
9. Reflexão (para o seu README)
No 4.1 o cliente precisava falar HTTP. No 4.2, o agente só precisa saber que
existe uma tool criar_tarefa(titulo). O que o MCP escondeu? Em uma frase:
qual detalhe da sua API o MCP tornou irrelevante para quem chama? (Esse é o
ganho de abstração da Aula 6.)
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/primodeckers/exercicio-4.2-mcp-server'
If you have feedback or need assistance with the MCP directory API, please join our Discord server