MCP ERPNext Plugin
Integrates Claude with ERPNext v16, enabling CRUD operations, queries, and method calls through a secure MCP interface.
README
MCP ERPNext Plugin
Plugin MCP (Model Context Protocol) para integração entre Claude e ERPNext v16. Permite que Claude se conecte e interaja com instâncias do ERPNext através de uma interface simples e segura.
Características
- ✅ Configuração segura de credenciais (URL, API Key, API Secret)
- ✅ Testes de conexão com ERPNext
- ✅ CRUD completo (Create, Read, Update, Delete) de documentos
- ✅ Suporte para filtros e consultas avançadas
- ✅ Chamadas de métodos Frappe/ERPNext
- ✅ Recuperação de metadados de documentos
- ✅ Interface CLI para configuração
- ✅ Armazenamento seguro de credenciais
📦 Instalação
Guia Rápido
Para instalação completa e detalhada, veja INSTALL.md (recomendado para primeira instalação).
Resumo
- Instale Python 3.8+
- Baixe o repositório
- Execute
pip install -r requirements.txt - Configure com
python src/cli.py configure --interactive - Adicione ao Claude Desktop via
claude_desktop_config.json - Reinicie Claude Desktop
Pré-requisitos
- Python 3.8+
- Claude Desktop
- Acesso ao ERPNext v16 (https://erpnext.glsoltec.com.br)
Configuração
Obter Credenciais do ERPNext
- Acesse sua instância do ERPNext
- Vá para: Menu → Usuário (seu usuário) → Configurações
- Gere uma nova chave de API:
- Clique em "Gerar Chave API"
- Copie a API Key e API Secret
Configurar o Plugin
# Modo interativo (recomendado)
python src/cli.py configure --interactive
# Exemplo de resposta:
# Enter ERPNext URL: https://seu-instance.erpnext.com
# Enter API Key: sua_api_key
# Enter API Secret: seu_api_secret
Verificar Configuração
# Ver status
python src/cli.py status
# Testar conexão
python src/cli.py test
Uso
Iniciar o Servidor MCP
python src/server.py
O servidor será iniciado e estará pronto para receber comandos do Claude.
Ferramentas Disponíveis para Claude
1. configure_erpnext
Configura a conexão com ERPNext.
{
"url": "https://seu-instance.erpnext.com",
"api_key": "sua_chave_api",
"api_secret": "seu_secret"
}
2. test_connection
Testa a conexão com o servidor ERPNext.
{}
3. get_document
Obtém um documento específico.
{
"doctype": "Customer",
"name": "CUST-001"
}
4. get_list
Obtém uma lista de documentos com filtros opcionais.
{
"doctype": "Invoice",
"filters": {"status": "Draft"},
"fields": ["name", "customer", "total"],
"limit": 10
}
5. create_document
Cria um novo documento.
{
"doctype": "Customer",
"data": {
"customer_name": "Novo Cliente",
"customer_type": "Individual",
"country": "Brazil"
}
}
6. update_document
Atualiza um documento existente.
{
"doctype": "Customer",
"name": "CUST-001",
"data": {
"customer_name": "Nome Atualizado"
}
}
7. delete_document
Deleta um documento.
{
"doctype": "Customer",
"name": "CUST-001"
}
8. call_method
Chama um método Frappe/ERPNext.
{
"method": "frappe.client.get_list",
"params": {
"doctype": "Customer",
"limit_page_length": 5
}
}
9. get_config
Mostra o status da configuração atual.
{}
Exemplos de Uso com Claude
Exemplo 1: Consultar Clientes
Claude: "Liste os 5 primeiros clientes da minha instância ERPNext"
Claude usará:
- get_list(doctype="Customer", limit=5)
Exemplo 2: Criar Nota Fiscal
Claude: "Crie uma nota fiscal para o cliente CUST-001 com total de R$ 1.000"
Claude usará:
- create_document(doctype="Invoice", data={...})
Exemplo 3: Atualizar Pedido
Claude: "Atualize o pedido SO-001 para status de processamento"
Claude usará:
- update_document(doctype="Sales Order", name="SO-001", data={...})
Estrutura de Diretórios
mcp-erpnext/
├── src/
│ ├── __init__.py # Inicializador do pacote
│ ├── config.py # Gerenciamento de configuração
│ ├── erpnext_client.py # Cliente ERPNext
│ ├── server.py # Servidor MCP
│ └── cli.py # Interface de linha de comando
├── requirements.txt # Dependências Python
└── README.md # Este arquivo
Armazenamento de Credenciais
As credenciais são armazenadas de forma segura em:
- Linux/Mac:
~/.mcp-erpnext/config.json - Windows:
C:\Users\seu_usuario\.mcp-erpnext\config.json
⚠️ Segurança: O arquivo contém credenciais sensíveis. Nunca compartilhe ou faça commit deste arquivo no git.
Segurança
Boas Práticas
- Use API Keys específicas para cada integração
- Defina permissões apropriadas na chave de API no ERPNext
- Nunca compartilhe credenciais em repositórios públicos
- Considere usar variáveis de ambiente em produção
Permissões Recomendadas no ERPNext
- Leitura (Read) para documentos que Claude pode consultar
- Criação (Create) apenas se necessário
- Edição (Write) apenas se necessário
- Exclusão (Delete) restrita ao necessário
📚 Documentação
🚀 Comece Aqui
- INSTALL.md - Guia passo a passo de instalação (⭐ Comece aqui!)
- QUICKSTART.md - Instalação em 5 minutos
💡 Usando o Plugin
- .claude/README.md - Como usar com Claude Desktop
- API.md - Referência técnica de todas as ferramentas
- CLAUDE_INTEGRATION.md - Integração avançada com Claude
🛠️ Desenvolvimento
- DEVELOPMENT.md - Guia para desenvolvedores
- CONTRIBUTING.md - Como contribuir
📖 Referências Externas
Troubleshooting
Erro: "ERPNext not configured"
Execute o comando de configuração:
python src/cli.py configure --interactive
Erro: "Connection refused"
Verifique:
- A URL do ERPNext está correta
- O servidor ERPNext está rodando
- Sua rede permite acesso à instância
Erro: "Unauthorized (401)"
Verifique:
- API Key e API Secret estão corretos
- A chave de API ainda é válida
- O usuário tem permissões necessárias
Erro: "Forbidden (403)"
A chave de API não tem permissões para a ação. Configure permissões apropriadas no ERPNext.
Suporte
Para problemas, sugestões ou contribuições:
- Abra uma issue no repositório
- Envie um pull request com melhorias
- Consulte a documentação do Frappe/ERPNext
Licença
Este projeto está sob licença MIT. Veja LICENSE para detalhes.
Changelog
v1.0.0
- Lançamento inicial
- Suporte completo para CRUD de documentos
- Configuração interativa via CLI
- Suporte a filtros e consultas avançadas
- Integração com MCP para Claude
Recommended Servers
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.
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.
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.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
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.
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.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
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.