Skip to main content
Glama
JoaoA1egre

Star Wars Explorer

by JoaoA1egre

🚀 Star Wars Explorer - MCP Server

Um servidor Model Context Protocol (MCP) desenvolvido com Laravel que fornece acesso a dados da franquia Star Wars através de uma API externa e banco de dados local.

📋 Sobre o Projeto

Este projeto implementa um servidor MCP usando Laravel que permite:

  • 🔍 Buscar personagens de Star Wars no banco de dados local

  • đŸ“„ Importar personagens da API externa (SWAPI) para o banco local

  • đŸ’Ÿ Armazenar dados localmente para consultas rĂĄpidas

  • đŸ€– Integração com IAs atravĂ©s do protocolo MCP

đŸ› ïž Tecnologias

  • PHP 8.5+

  • Laravel 12

  • Laravel MCP - Protocolo Model Context Protocol

  • Laravel Sail - Ambiente Docker

  • MySQL 8.4 - Banco de dados

  • Redis - Cache

📩 PrĂ©-requisitos

Antes de começar, certifique-se de ter instalado:

Nota: Como utilizamos Laravel Sail, nĂŁo Ă© necessĂĄrio ter PHP instalado localmente. Tudo roda dentro do Docker.

🚀 Instalação

Passo 1: Clonar o RepositĂłrio

git clone <url-do-repositorio>
cd mcp-app

Passo 2: Configurar o Ambiente

# Copiar o arquivo de configuração de ambiente
cp .env.example .env

Passo 3: Instalar DependĂȘncias

# Instalar dependĂȘncias do Composer via Sail
./vendor/bin/sail composer install

Dica: Se vocĂȘ nĂŁo tiver o vendor/bin/sail, execute primeiro:

composer install

Passo 4: Configurar a Aplicação

# Gerar a chave da aplicação
./vendor/bin/sail artisan key:generate

# Executar as migrations do banco de dados
./vendor/bin/sail artisan migrate

Passo 5: Iniciar os Containers

# Iniciar os containers em background
./vendor/bin/sail up -d

# Ou iniciar e ver os logs em tempo real
./vendor/bin/sail up

▶ Executando o Servidor MCP

ApĂłs a instalação, vocĂȘ tem duas formas de executar o servidor:

Opção 1: Modo STDIO (Produção)

Execute o servidor MCP diretamente:

./vendor/bin/sail artisan mcp:start star-wars-explorer

Este comando inicia o servidor no modo STDIO, pronto para comunicação via protocolo MCP.

Opção 2: Inspector (Desenvolvimento/Testes) ⭐ Recomendado

Use o Inspector para testar o servidor com uma interface visual:

./vendor/bin/sail artisan mcp:inspector star-wars-explorer

O Inspector:

  • 🌐 Abre uma interface web interativa

  • đŸ§Ș Permite testar todas as tools disponĂ­veis

  • 📊 Mostra as respostas do servidor em tempo real

  • 🔍 Facilita o debug e desenvolvimento

đŸ§Ș Testando as Funcionalidades

O servidor MCP expÔe uma tool chamada star-wars-tool com as seguintes funcionalidades:

1. Buscar Todos os Personagens

Chame a tool sem parĂąmetros para listar todos os personagens salvos localmente:

{}

2. Buscar por Nome

Busque personagens pelo nome no banco de dados local:

{
  "search": "Luke"
}

3. Importar da API Externa

Importe um personagem da API SWAPI usando o ID:

{
  "id": 1
}

IDs disponíveis na API: 1, 2, 3, 4, 5... (consulte a documentação da SWAPI)

📁 Estrutura do Projeto

mcp-app/
├── app/
│   ├── Mcp/
│   │   ├── Servers/
│   │   │   ├── StarWarsServer.php    # Servidor MCP principal
│   │   │   └── MyAssistantServer.php # Servidor exemplo
│   │   └── Tools/
│   │       ├── StarWarsTool.php      # Tool principal
│   │       └── GetProjectStats.php   # Tool exemplo
│   ├── Models/
│   │   └── Character.php             # Model do personagem
│   └── Services/
│       ├── External/
│       │   └── SwapiService.php      # Serviço de integração com API
│       └── Models/
│           └── CharacterService.php  # Lógica de negócio
├── routes/
│   └── ai.php                        # Registro dos servidores MCP
├── database/
│   └── migrations/                   # Migrations do banco
└── compose.yaml                       # Configuração Docker

🔧 Comandos Úteis

Gerenciamento do Docker

# Iniciar containers
./vendor/bin/sail up -d

# Parar containers
./vendor/bin/sail down

# Ver logs
./vendor/bin/sail logs

# Acessar shell do container
./vendor/bin/sail shell

Comandos Artisan

# Ver logs do Laravel
./vendor/bin/sail artisan pail

# Limpar cache
./vendor/bin/sail artisan config:clear
./vendor/bin/sail artisan cache:clear

# Executar migrations
./vendor/bin/sail artisan migrate

# Rollback migrations
./vendor/bin/sail artisan migrate:rollback

Comandos MCP

# Listar servidores MCP disponĂ­veis
./vendor/bin/sail artisan mcp:inspector

# Iniciar servidor especĂ­fico
./vendor/bin/sail artisan mcp:start star-wars-explorer

# Abrir inspector para testes
./vendor/bin/sail artisan mcp:inspector star-wars-explorer

🎯 Funcionalidades da Tool

A StarWarsTool oferece trĂȘs modos de operação:

ParĂąmetro

Tipo

Descrição

id

integer (opcional)

ID do personagem na API SWAPI para importar

search

string (opcional)

Nome do personagem para buscar localmente

Comportamento:

  • Se id for fornecido: importa da API e salva no banco local

  • Se search for fornecido: busca no banco local por nome

  • Se nenhum parĂąmetro: retorna todos os personagens do banco local

🔌 Integração com Clientes MCP

Para integrar este servidor MCP com um cliente (como Claude Desktop, Cursor, etc.), configure:

Handle: star-wars-explorer

Comando:

php artisan mcp:start star-wars-explorer

Transport: STDIO

📝 PadrĂ”es de CĂłdigo

Este projeto segue as melhores prĂĄticas do Laravel:

  • ✅ declare(strict_types=1); em todos os arquivos PHP

  • ✅ Tipagem estrita em propriedades, parĂąmetros e retornos

  • ✅ Services como final readonly class

  • ✅ Controllers magros (Thin Controllers)

  • ✅ LĂłgica de negĂłcio em Services

  • ✅ Dependency Injection via construtor

🐛 Troubleshooting

Erro: "MCP Server with name [star-wars-explorer] not found"

Verifique se o servidor estĂĄ registrado em routes/ai.php:

Mcp::local('star-wars-explorer', StarWarsServer::class);

Erro: "Connection refused" ao iniciar Sail

Certifique-se de que o Docker estĂĄ rodando:

docker ps

Erro ao executar migrations

Verifique se o banco de dados estĂĄ configurado corretamente no .env:

DB_CONNECTION=mysql
DB_HOST=mysql
DB_PORT=3306
DB_DATABASE=laravel
DB_USERNAME=sail
DB_PASSWORD=password

📚 Recursos Adicionais

📄 Licença

Este projeto estå sob a licença MIT.


Desenvolvido com ❀ usando Laravel e MCP

-
security - not tested
F
license - not found
-
quality - not tested

Resources

Unclaimed servers have limited discoverability.

Looking for Admin?

If you are the server author, to access and configure the admin panel.

Appeared in Searches

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/JoaoA1egre/mcp-app'

If you have feedback or need assistance with the MCP directory API, please join our Discord server