MCP Platform Service
A minimal Model Context Protocol (MCP) service for integration with external platforms. Provides CRUD operations, reference data fetching, and authentication capabilities.
README
MCP Platform Service
A minimal Model Context Protocol (MCP) service for integration with external platforms. This service provides CRUD operations, reference data fetching, and authentication capabilities.
Features
- ✅ CRUD operations (Create, Read, Update, Delete) for entities
- ✅ Reference data fetching (statuses, priorities, categories, etc.)
- ✅ Authentication via API token (environment variable) or login tool
- ✅ Token refresh support
- ✅ MCP-compatible server implementation
- ✅ Ready to run via
npxfrom GitHub
Prerequisites
- Node.js 18.0.0 or higher
- npm or yarn
Installation
Option 1: Run via npx (from GitHub)
npx github:Artemida1609/mcp-service
Option 2: Install locally
git clone https://github.com/Artemida1609/mcp-service.git
cd mcp-service
npm install
Environment Variables
The service supports the following environment variables:
| Variable | Description | Required | Default |
|---|---|---|---|
API_TOKEN |
API token for authentication | No* | - |
API_BASE_URL |
Base URL of the external platform API | No | https://api.example.com/v1 |
API_TIMEOUT |
Request timeout in milliseconds | No | 30000 |
ALLOW_LOGIN |
Enable login tool (true/false) | No | true |
* API_TOKEN is required unless you use the login tool to authenticate.
Usage
Setting Environment Variables
Linux/macOS:
export API_TOKEN="your-api-token-here"
export API_BASE_URL="https://api.yourplatform.com/v1"
Windows (PowerShell):
$env:API_TOKEN="your-api-token-here"
$env:API_BASE_URL="https://api.yourplatform.com/v1"
Windows (CMD):
set API_TOKEN=your-api-token-here
set API_BASE_URL=https://api.yourplatform.com/v1
Running the Service
Via npx:
npx github:your-username/mcp-service
Locally:
npm start
# or
node index.js
The service runs as an MCP server on stdio and communicates via the Model Context Protocol.
MCP Server Integration
Claude Desktop Configuration
Add this to your Claude Desktop configuration file (claude_desktop_config.json):
macOS:
{
"mcpServers": {
"platform-service": {
"command": "npx",
"args": ["github:Artemida1609/mcp-service"],
"env": {
"API_TOKEN": "your-api-token-here",
"API_BASE_URL": "https://api.yourplatform.com/v1"
}
}
}
}
Windows:
{
"mcpServers": {
"platform-service": {
"command": "npx.cmd",
"args": ["github:Artemida1609/mcp-service"],
"env": {
"API_TOKEN": "your-api-token-here",
"API_BASE_URL": "https://api.yourplatform.com/v1"
}
}
}
}
Other MCP Clients
The service communicates via stdio using the MCP protocol. Configure your MCP client to:
- Command:
npx(ornpx.cmdon Windows) - Args:
["github:Artemida1609/mcp-service"] - Environment variables as needed
Available Tools
CRUD Operations
get_entity
Retrieve a specific entity by ID and type.
Parameters:
entityId(string, required): The unique identifier of the entityentityType(string, required): Type of entity (user,project,task,document)
Example:
{
"entityId": "123",
"entityType": "project"
}
create_entity
Create a new entity in the platform.
Parameters:
entityType(string, required): Type of entity to createdata(object, required): Entity data
Example:
{
"entityType": "task",
"data": {
"title": "New Task",
"description": "Task description",
"status": "open"
}
}
update_entity
Update an existing entity.
Parameters:
entityId(string, required): The unique identifierentityType(string, required): Type of entitydata(object, required): Fields to update
Example:
{
"entityId": "123",
"entityType": "task",
"data": {
"status": "completed"
}
}
delete_entity
Delete an entity from the platform.
Parameters:
entityId(string, required): The unique identifierentityType(string, required): Type of entity
Example:
{
"entityId": "123",
"entityType": "task"
}
Reference Data
get_reference
Fetch reference data (statuses, priorities, categories, etc.).
Parameters:
referenceType(string, required): Type of reference (statuses,priorities,categories,tags,users)filters(object, optional): Optional filters
Example:
{
"referenceType": "statuses",
"filters": {
"active": true
}
}
Authentication
login
Authenticate with username and password. Stores the token for subsequent requests.
Parameters:
username(string, required): Usernamepassword(string, required): Password
Example:
{
"username": "user@example.com",
"password": "password123"
}
refresh_token
Refresh an expired access token.
Parameters:
refreshToken(string, required): The refresh token
Example:
{
"refreshToken": "your-refresh-token-here"
}
API Endpoints
The service expects the external platform API to follow these conventions:
GET /entities/{entityType}/{entityId}- Get entityPOST /entities/{entityType}- Create entityPUT /entities/{entityType}/{entityId}- Update entityDELETE /entities/{entityType}/{entityId}- Delete entityGET /reference/{referenceType}- Get reference dataPOST /auth/login- LoginPOST /auth/refresh- Refresh token
All requests require Bearer token authentication in the Authorization header.
Project Structure
mcp-service/
├── index.js # Main MCP server entry point
├── config.js # Configuration and environment variables
├── auth.js # Authentication token management
├── api-client.js # HTTP client for API requests
├── handlers.js # Tool handler implementations
├── tools.js # Tool definitions and descriptions
├── schemas.js # Input schemas for tools
├── package.json # Dependencies and metadata
├── .gitignore # Git ignore rules
└── README.md # This file
Development
Local Development
- Clone the repository
- Install dependencies:
npm install - Set environment variables
- Run:
npm start
Testing
To test the service manually, you can use an MCP client or test the handlers directly:
import { handleGetEntity } from './handlers.js';
const result = await handleGetEntity({
entityId: '123',
entityType: 'project'
});
console.log(result);
Troubleshooting
"No authentication token available" Error
- Ensure
API_TOKENis set in your environment, or - Use the
logintool to authenticate first
"Request timeout" Error
- Increase
API_TIMEOUTenvironment variable - Check network connectivity
- Verify
API_BASE_URLis correct
Login Tool Disabled
- Set
ALLOW_LOGIN=truein your environment variables
Module Not Found Errors
- Run
npm installto install dependencies - Ensure Node.js version is 18.0.0 or higher
Customization
To adapt this service for your specific platform:
- Update
API_BASE_URLto your platform's API endpoint - Modify endpoint paths in
handlers.jsif your API uses different routes - Adjust entity types in
schemas.jsto match your platform's entities - Update reference types in
get_referencehandler - Modify authentication flow in
handleLoginif your platform uses different auth mechanisms
License
MIT
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
Support
For issues and questions, please open an issue on GitHub.
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.
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.
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.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
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.