Skip to main content
Glama

MCP Shipping Control Center

by bischoff99

MCP Shipping Control Center

A comprehensive shipping and order management platform built with the Model Context Protocol (MCP), integrating EasyPost shipping services and Veeqo order management.

๐Ÿš€ Features

Core Functionality

  • Order Management: Create, update, and track orders through Veeqo integration

  • Shipping Management: Generate labels, track shipments, and manage rates via EasyPost

  • Unified Workflows: Cross-platform operations combining order and shipping data

  • Real-time Dashboard: Web-based interface for monitoring operations

  • Authentication: JWT-based security with role-based access control

Technical Features

  • MCP Protocol: JSON-RPC 2.0 compliant API

  • TypeScript: Full type safety throughout the application

  • Error Handling: Comprehensive error management with retry logic

  • Logging: Structured logging with correlation IDs

  • Testing: Complete test coverage for all components

  • Docker: Containerized deployment ready

  • Kubernetes: Production-ready orchestration

๐Ÿ“ Project Structure

mcp-server/ โ”œโ”€โ”€ src/ โ”‚ โ”œโ”€โ”€ clients/ # API client implementations โ”‚ โ”‚ โ”œโ”€โ”€ easypostClient.ts โ”‚ โ”‚ โ””โ”€โ”€ veeqoClient.ts โ”‚ โ”œโ”€โ”€ methods/ # MCP method implementations โ”‚ โ”‚ โ”œโ”€โ”€ easypost.ts โ”‚ โ”‚ โ”œโ”€โ”€ veeqo.ts โ”‚ โ”‚ โ”œโ”€โ”€ unified.ts โ”‚ โ”‚ โ””โ”€โ”€ web.ts โ”‚ โ”œโ”€โ”€ utils/ # Utility functions โ”‚ โ”‚ โ”œโ”€โ”€ auth.ts โ”‚ โ”‚ โ”œโ”€โ”€ errors.ts โ”‚ โ”‚ โ”œโ”€โ”€ logger.ts โ”‚ โ”‚ โ”œโ”€โ”€ middleware.ts โ”‚ โ”‚ โ””โ”€โ”€ retry.ts โ”‚ โ”œโ”€โ”€ web/ # Web interface components โ”‚ โ”‚ โ”œโ”€โ”€ components/ โ”‚ โ”‚ โ”œโ”€โ”€ pages/ โ”‚ โ”‚ โ”œโ”€โ”€ services/ โ”‚ โ”‚ โ””โ”€โ”€ types/ โ”‚ โ”œโ”€โ”€ server.ts # Main server implementation โ”‚ โ””โ”€โ”€ schema.ts # JSON-RPC schemas โ”œโ”€โ”€ tests/ # Test suites โ”œโ”€โ”€ k8s/ # Kubernetes manifests โ”œโ”€โ”€ Dockerfile โ”œโ”€โ”€ docker-compose.yml โ”œโ”€โ”€ package.json โ””โ”€โ”€ README.md

๐Ÿ› ๏ธ Installation

Prerequisites

  • Node.js 18+

  • npm or pnpm

  • Docker (optional)

  • Kubernetes cluster (optional)

Setup

  1. Clone and install dependencies:

cd mcp-server npm install # or pnpm install
  1. Environment configuration:

cp .env.example .env # Edit .env with your API keys and configuration
  1. Required environment variables:

# API Keys EASYPOST_API_KEY=your_easypost_api_key VEEQO_API_KEY=your_veeqo_api_key # JWT Configuration JWT_SECRET=your_jwt_secret JWT_EXPIRES_IN=24h # Default Admin User DEFAULT_ADMIN_PASSWORD=admin123 # Logging LOG_LEVEL=info

๐Ÿš€ Usage

Development

# Start the development server npm run dev # Run tests npm test # Build for production npm run build

Production

# Using Docker docker build -t mcp-server . docker run -p 3000:3000 mcp-server # Using Docker Compose docker-compose up -d # Using Kubernetes kubectl apply -f k8s/

๐Ÿ“ก API Reference

MCP Methods

Veeqo Methods

  • veeqo.createOrder - Create a new order

  • veeqo.getOrder - Retrieve order details

  • veeqo.listOrders - List orders with pagination

  • veeqo.updateOrder - Update existing order

  • veeqo.deleteOrder - Delete an order

  • veeqo.syncInventory - Sync inventory data

EasyPost Methods

  • easypost.createShipment - Create a new shipment

  • easypost.getRates - Get shipping rates

  • easypost.buyLabel - Purchase shipping label

  • easypost.trackShipment - Track shipment status

Unified Methods

  • unified.createOrderWithShipping - Create order and shipping in one operation

  • unified.processReturn - Handle return processing

  • unified.bulkOperations - Batch operations

Web Methods

  • web.login - User authentication

  • web.getDashboardStats - Dashboard statistics

  • web.searchOrders - Search orders

Example Request

{ "jsonrpc": "2.0", "method": "veeqo.createOrder", "params": { "order": { "line_items_attributes": [ { "product_id": "123", "quantity": 2 } ], "deliver_to": { "first_name": "John", "last_name": "Doe", "address1": "123 Main St", "city": "New York", "state": "NY", "zip": "10001", "country": "US" } } }, "id": 1 }

๐Ÿ”ง Configuration

Docker Configuration

The application includes Docker and Docker Compose configurations for easy deployment:

  • Dockerfile: Multi-stage build for production optimization

  • docker-compose.yml: Complete stack with all services

  • k8s/: Kubernetes manifests for production deployment

Monitoring

  • Prometheus: Metrics collection and monitoring

  • Structured Logging: JSON-formatted logs with correlation IDs

  • Health Checks: Built-in health check endpoints

๐Ÿงช Testing

# Run all tests npm test # Run specific test suites npm test -- --testNamePattern="EasyPost" npm test -- --testNamePattern="Veeqo" npm test -- --testNamePattern="Unified" # Run with coverage npm run test:coverage

๐Ÿ“Š Monitoring

The application includes comprehensive monitoring:

  • Metrics: Prometheus metrics for all operations

  • Logging: Structured logging with correlation IDs

  • Health Checks: Built-in health check endpoints

  • Error Tracking: Comprehensive error handling and reporting

๐Ÿ”’ Security

  • JWT Authentication: Secure token-based authentication

  • Role-based Access: Admin and user role permissions

  • Input Validation: Comprehensive input validation

  • Rate Limiting: Built-in rate limiting protection

  • CORS: Configurable CORS policies

๐Ÿค Contributing

  1. Fork the repository

  2. Create a feature branch

  3. Make your changes

  4. Add tests for new functionality

  5. Submit a pull request

๐Ÿ“„ License

This project is licensed under the MIT License - see the LICENSE file for details.

๐Ÿ†˜ Support

For support and questions:

  • Create an issue in the repository

  • Check the documentation

  • Review the test examples

๐Ÿ”„ Version History

  • v1.0.0 - Initial release with core functionality

  • Complete MCP server implementation

  • EasyPost and Veeqo integrations

  • Web dashboard interface

  • Docker and Kubernetes deployment ready

-
security - not tested
-
license - not tested
-
quality - not tested

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/bischoff99/mcp-server'

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