GASSAPI MCP Server
Enables AI assistants to manage API endpoints, environments, and testing workflows through the GASSAPI backend. Provides semantic documentation tools for endpoint cataloging and automated flow creation for backend-to-frontend development workflows.
README
GASSAPI MCP v2
Model Context Protocol (MCP) server untuk integrasi GASSAPI dengan AI assistants.
🚀 Quick Start
Prerequisites
- Node.js >= 16.0.0
- npm atau yarn
- Akses ke GASSAPI backend
📦 Installation
Step 1: Install Package
npm install martin-1103/mcp2
Step 2: Installation Method
Method 1: Global Install (Recommended)
npm install -g gassapi-mcp2
claude mcp add gassapi-mcp2
Method 2: Local Install
npm install gassapi-mcp2
claude mcp add gassapi-mcp2
📋 Simple Setup (3 Steps)
Step 1: Login ke GASSAPI Backend
Login ke backend GASSAPI untuk mendapatkan access token:
curl -X POST "http://mapi.gass.web.id/?act=login" \
-H "Content-Type: application/json" \
-d '{"email": "your-email@example.com", "password": "YourPassword"}'
Step 2: Dapatkan Project ID
List projects untuk mendapatkan project ID:
curl -X GET "http://mapi.gass.web.id/?act=projects" \
-H "Authorization: Bearer YOUR_ACCESS_TOKEN"
Step 3: Buat gassapi.json File
Buat file gassapi.json di working directory Anda dengan template:
{
"project": {
"id": "YOUR_PROJECT_ID_HERE",
"name": "Your Project Name",
"description": "Your project description"
},
"mcpClient": {
"token": "YOUR_TOKEN_HERE"
}
}
Ganti dengan:
YOUR_PROJECT_ID_HERE→ Project ID dari Step 2YOUR_TOKEN_HERE→ Token dari Step 1
Note: Base URL sudah hardcoded ke http://mapi.gass.web.id - tidak perlu konfigurasi API URL.
✅ Verification
Test MCP Server
# Test help command
gassapi-mcp2 --help
# Test version
gassapi-mcp2 --version
# Test status
gassapi-mcp2 --status
Claude Code Integration
# List MCP servers
claude mcp list
# Test connection
# Restart Claude Code dan coba gunakan GASSAPI tools
🛠️ Development
Local Development
# Clone repository
git clone <repository-url>
cd gassapi-mcp2
# Install dependencies
npm install
# Build
npm run build
# Development mode
npm run dev
# Type checking
npm run typecheck
🔧 Configuration Format
gassapi.json Structure
{
"project": {
"id": "proj_abc123def456",
"name": "Project Name",
"description": "Project description"
},
"mcpClient": {
"token": "plain_text_mcp_token_here"
}
}
Note: Base URL sudah hardcoded ke http://mapi.gass.web.id - tidak perlu api_base_url configuration.
Auto-Detection
MCP server akan otomatis mencari gassapi.json di:
- Current working directory
- Parent directories (hingga 5 levels up)
🛠️ Available MCP Tools
Authentication & Project Context
get_project_context- Get project info with environments and foldershealth_check- Check MCP server status
Environment Management
list_environments- List all environmentsget_environment_details- Get detailed environment infocreate_environment- Create new environmentupdate_environment_variables- Update environment variablesset_default_environment- Set default environmentdelete_environment- Delete environment
Folder Management
list_folders- List project folderscreate_folder- Create new folderupdate_folder- Update folder detailsmove_folder- Move folder to different parentdelete_folder- Delete folderget_folder_details- Get folder details
Endpoint Management
list_endpoints- List all endpointsget_endpoint_details- Get detailed endpoint configurationcreate_endpoint- Create endpoint with semantic contextupdate_endpoint- Update endpoint configuration
Flow Management
create_flow- Create automation flowexecute_flow- Execute flowget_flow_details- Get flow detailslist_flows- List all flowsdelete_flow- Delete flow
Testing Tools
test_endpoint- Test single endpointtest_multiple_endpoints- Test multiple endpointscreate_test_suite- Create test suitelist_test_suites- List test suites
📝 Endpoint Documentation & Cataloging
Mencatat Endpoint yang Sudah Ada
create_endpoint(
name: "User Registration",
method: "POST",
url: "/api/auth/register",
folder_id: "folder_authentication",
description: "Endpoint untuk registrasi user baru dengan email verification",
purpose: "Public user registration dengan email verification required",
headers: {
"Content-Type": "application/json"
},
body: '{"name": "{{userName}}", "email": "{{userEmail}}", "password": "{{password}}"}',
request_params: {
"name": "Full name untuk display",
"email": "Email address untuk login dan communication",
"password": "User password (min 8 chars, include uppercase, lowercase, numbers)"
},
response_schema: {
"user_id": "Unique user identifier",
"name": "User display name",
"email": "User email address",
"status": "Account status (active|inactive|suspended)",
"verification_required": "Whether email verification needed"
}
)
Workflow: Backend → MCP Documentation → AI Frontend
1. Backend Developer:
// Di PHP code (sudah ada)
public function register() {
// Logic untuk registrasi user
// Return user data atau error
}
2. Documentation Team:
// Gunakan MCP tools untuk catat
create_endpoint(
name: "User Registration",
method: "POST",
url: "/api/auth/register",
// ... semantic context untuk AI understanding
)
3. AI Frontend Team:
// AI dapat endpoint info dan generate UI
get_endpoint_details(endpoint_id: "ep_user_reg")
// AI understands purpose dan generate appropriate React components
Contoh Endpoint User Registration dengan Semantic Context
create_endpoint(
name: "User Registration",
method: "POST",
url: "/api/auth/register",
folder_id: "folder_authentication",
description: "Public user registration endpoint dengan email verification",
purpose: "New user account creation dengan email verification untuk security",
// Request parameters documentation
request_params: {
"name": "User's full name for display purposes",
"email": "User's email address for login and communication",
"password": "Password with security requirements (8+ chars, mixed case, numbers)",
"confirm_password": "Password confirmation untuk prevent typos"
},
// Response schema documentation
response_schema: {
"user_id": "Unique system identifier untuk user record",
"name": "User display name untuk UI",
"email": "User email address untuk authentication",
"status": "Account status: active|inactive|suspended|pending_verification",
"email_verified": "Email verification status flag",
"verification_token": "Email verification token (if required)",
"created_at": "Account creation timestamp"
},
// Important implementation notes
header_docs: {
"Content-Type": "Application/JSON untuk request body",
"Accept": "Application/JSON untuk response format"
}
)
Semantic Fields untuk AI Understanding
| Field | Type | Purpose | Example | AI Benefit |
|---|---|---|---|---|
purpose |
string | Business purpose (max 250 chars) | "User registration with email verification" | AI understands use case and generates appropriate UI flow |
request_params |
object | Parameter documentation | {"name": "User's full name for display"} |
AI generates correct form fields with validation |
response_schema |
object | Response field documentation | {"user_id": "Unique user identifier"} |
AI handles response data correctly in frontend code |
header_docs |
object | Header documentation | {"Content-Type": "Application/JSON"} |
AI includes proper headers in API calls |
🔧 Development
Build & Run
# Build project
npm run build
# Run development server
npm run dev
# Run production server
npm start
# Type checking
npm run typecheck
# Clean build
npm run clean
Testing
# Run basic test
npm test
# Run all tests
node test/runners/run-all-tests.js
# Run specific category
node test/runners/run-category-tests.js endpoints
# Run semantic fields tests
node test/unit/endpoints/semantic-test-runner.js
🔍 Configuration Format
gassapi.json Structure
{
"project": {
"id": "proj_abc123def456",
"name": "Project Name",
"description": "Project description"
},
"mcpClient": {
"token": "plain_text_mcp_token_here"
}
}
Note: Base URL sudah hardcoded ke http://mapi.gass.web.id - tidak perlu api_base_url configuration.
Auto-Detection
MCP server akan otomatis mencari gassapi.json di:
- Current working directory
- Parent directories (hingga 5 levels up)
🚨 Troubleshooting
Common Issues
1. "No configuration found"
- Pastikan
gassapi.jsonada di working directory atau parent directory - Cek format JSON valid
2. "Invalid token"
- Login kembali ke backend untuk dapat token baru
- Pastikan token belum expired
3. "Backend unavailable"
- Pastikan backend server sudah berjalan di
http://mapi.gass.web.id - Check koneksi internet dan firewall settings
4. MCP server not found
- Install globally:
npm install -g gassapi-mcp2 - Atau gunakan npx:
npx gassapi-mcp2
Debug Commands
# Check MCP server status
gassapi-mcp2 --status
# Test help
gassapi-mcp2 --help
# Test version
gassapi-mcp2 --version
# Test backend connectivity
curl "http://mapi.gass.web.id/?act=health"
📞 Usage Examples
Basic Usage in Claude Code
User: "Show my project"
AI: Uses get_project_context tool
User: "Create endpoint for user registration"
AI: create_endpoint dengan semantic fields
User: "Test this endpoint"
AI: test_endpoint dengan environment variables
Advanced Usage
User: "Create flow untuk user registration dengan email verification"
AI: create_flow dengan multiple steps dan validation
User: "List semua endpoints di folder Authentication"
AI: list_endpoints dengan filter folder_id
🤝 Contributing
- Fork repository
- Create feature branch
- Run tests:
npm test - Submit pull request
📄 License
MIT License
🎯 Key Benefits:
- ✅ Semantic context untuk AI understanding
- ✅ Real-time endpoint management
- ✅ Automated flow creation
- ✅ Comprehensive testing tools
- ✅ Easy integration dengan Claude Code/Cursor
推荐服务器
Baidu Map
百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。
Playwright MCP Server
一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。
Magic Component Platform (MCP)
一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。
Audiense Insights MCP Server
通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。
VeyraX
一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。
graphlit-mcp-server
模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。
Kagi MCP Server
一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。
e2b-mcp-server
使用 MCP 通过 e2b 运行代码。
Neon MCP Server
用于与 Neon 管理 API 和数据库交互的 MCP 服务器
Exa MCP Server
模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。