Serversai.com.mcp/hapi-mcp
M

HAPI MCP Server

ai.com.mcp/hapi-mcp · v0.6.0
▦ docker
v0.6.0docker oci: docker.io/hapimcp/hapi-cli:0.6.0🌐 https://{HAPI_FQDN}:{HAPI_PORT}/mcp↗ Website↗ Repository
{}server.json

The full server descriptor as registered with IndusMCP.

{
  "$schema": "https://static.modelcontextprotocol.io/schemas/2025-12-11/server.schema.json",
  "name": "ai.com.mcp/hapi-mcp",
  "description": "HAPI MCP server: Dynamically exposes OpenAPI REST APIs as MCP tools for AI assistants",
  "title": "HAPI MCP Server",
  "repository": {
    "url": "https://github.com/larebelion/hapimcp",
    "source": "github"
  },
  "version": "0.6.0",
  "websiteUrl": "https://docs.mcp.com.ai/components/hapi-server/hapi-cli",
  "packages": [
    {
      "registryType": "oci",
      "identifier": "docker.io/hapimcp/hapi-cli:0.6.0",
      "runtimeHint": "docker",
      "transport": {
        "type": "streamable-http",
        "url": "https://{HAPI_FQDN}:{HAPI_PORT}/mcp",
        "headers": [
          {
            "description": "Authorization token for accessing the MCP server",
            "format": "string",
            "isSecret": true,
            "name": "Authorization"
          }
        ]
      },
      "runtimeArguments": [
        {
          "description": "Port mapping for the host to container (e.g., '3030:3030'). Adjust second port if changing internal container port (HAPI_PORT)",
          "isRequired": true,
          "format": "string",
          "default": "3030:3030",
          "type": "named",
          "name": "-p",
          "valueHint": "port"
        },
        {
          "description": "Volume mapping for HAPI configuration directory",
          "format": "string",
          "default": "~/.hapi:/app/.hapi",
          "type": "named",
          "name": "-v",
          "valueHint": "volume",
          "isRepeated": true
        }
      ],
      "packageArguments": [
        {
          "description": "Command to start the HAPI MCP server",
          "isRequired": true,
          "format": "string",
          "default": "serve",
          "type": "positional",
          "name": "serve",
          "valueHint": "serve"
        },
        {
          "description": "The name of the project/API to serve (e.g., 'petstore'). Optional when using HAPI_OPENAPI environment variable",
          "format": "string",
          "type": "positional",
          "name": "projectName",
          "valueHint": "petstore"
        },
        {
          "description": "The port to listen on inside the container",
          "format": "number",
          "default": "3030",
          "type": "named",
          "name": "--port",
          "valueHint": "port"
        },
        {
          "description": "Run in headless mode (serve MCP-only, no business logic)",
          "format": "boolean",
          "default": "true",
          "type": "named",
          "name": "--headless"
        },
        {
          "description": "The server provides REST API's business logic AND also exposes them as MCP tools",
          "format": "boolean",
          "default": "true",
          "type": "named",
          "name": "--mcp"
        },
        {
          "description": "Enable development mode with verbose logging",
          "format": "boolean",
          "type": "named",
          "name": "--dev"
        },
        {
          "description": "The full URL for the backend API server (overrides OpenAPI spec servers). Uses OAS server URL if not provided",
          "format": "string",
          "type": "named",
          "name": "--url",
          "valueHint": "url"
        },
        {
          "description": "OpenAPI spec file path or URL to use instead of loading from HAPI_HOME",
          "format": "string",
          "type": "named",
          "name": "--openapi",
          "valueHint": "openapi"
        },
        {
          "description": "Comma-separated list of allowed origins for CORS (e.g., 'http://localhost:3000,https://example.com')",
          "format": "string",
          "type": "named",
          "name": "--cors",
          "valueHint": "origins"
        },
        {
          "description": "Comma-separated list of OAS configuration files to apply (can be URLs)",
          "format": "string",
          "type": "named",
          "name": "--filename",
          "valueHint": "files"
        },
        {
          "description": "Path to SSL certificate file for HTTPS. Volume mount required if using Docker. https://docs.mcp.com.ai/components/hapi-server/hapi-cli#running-with-tls-https",
          "format": "string",
          "type": "named",
          "name": "--cert",
          "valueHint": "path"
        },
        {
          "description": "Path to SSL key file for HTTPS. Volume mount required if using Docker",
          "format": "string",
          "type": "named",
          "name": "--key",
          "valueHint": "path"
        }
      ],
      "environmentVariables": [
        {
          "description": "Fully Qualified Domain Name for the HAPI server (used in MCP tool URLs)",
          "format": "string",
          "default": "localhost",
          "name": "HAPI_FQDN"
        },
        {
          "description": "Directory path for HAPI configuration and specs. Should be mounted as a volume in Docker",
          "format": "string",
          "default": "/app/.hapi",
          "name": "HAPI_HOME"
        },
        {
          "description": "The name of the project/API (alternative to positional argument)",
          "format": "string",
          "name": "PROJECT_NAME"
        },
        {
          "description": "OpenAPI spec URL or path (alternative to --openapi flag)",
          "format": "string",
          "name": "HAPI_OPENAPI"
        },
        {
          "description": "Backend API base URL (alternative to --url flag)",
          "format": "string",
          "name": "HAPI_URL"
        },
        {
          "description": "Server port (alternative to --port flag) - this is the internal container port",
          "format": "number",
          "default": "3030",
          "name": "HAPI_PORT"
        },
        {
          "description": "Enable headless mode (alternative to --headless flag)",
          "format": "boolean",
          "default": "true",
          "name": "HAPI_HEADLESS"
        },
        {
          "description": "Enable MCP mode (alternative to --mcp flag)",
          "format": "boolean",
          "default": "true",
          "name": "HAPI_MCP"
        },
        {
          "description": "Enable development mode (alternative to --dev flag)",
          "format": "boolean",
          "name": "HAPI_DEV"
        },
        {
          "description": "Comma-separated allowed CORS origins (alternative to --cors flag)",
          "format": "string",
          "name": "HAPI_CORS"
        },
        {
          "description": "Comma-separated configuration files (alternative to --filename flag)",
          "format": "string",
          "name": "HAPI_CONFIG_FILES"
        },
        {
          "description": "Node environment (development, production). 'development' enables verbose logging and debugging features.",
          "format": "string",
          "default": "production",
          "name": "NODE_ENV"
        }
      ]
    }
  ],
  "remotes": [
    {
      "type": "streamable-http",
      "url": "https://{HAPI_FQDN}:{HAPI_PORT}/mcp",
      "variables": {
        "HAPI_FQDN": {
          "description": "Fully Qualified Domain Name for the HAPI server",
          "format": "string",
          "default": "localhost"
        },
        "HAPI_PORT": {
          "description": "Port for the HAPI server",
          "format": "number",
          "default": "3030"
        }
      }
    }
  ],
  "_meta": {
    "io.modelcontextprotocol.registry/publisher-provided": {
      "documentation": "https://docs.mcp.com.ai/deployment/docker",
      "examples": [
        {
          "command": "docker run -p 3030:3030 -v ~/.hapi:/app/.hapi hapimcp/hapi-cli:0.6.0 serve petstore --port 3030 --headless --url https://petstore3.swagger.io/api/v3",
          "description": "Save specs in ~/.hapi/specs. Download example if not present: https://petstore3.swagger.io/api/v3/swagger.json",
          "name": "Quick Start with a local API spec"
        },
        {
          "command": "docker run -p 3030:3030 -e HAPI_OPENAPI=https://api.example.com/openapi.json -e HAPI_URL=https://api.example.com hapimcp/hapi-cli:0.6.0 serve my-api --headless",
          "description": "Serve a custom API using environment variables",
          "name": "Custom OpenAPI with Environment Variables"
        },
        {
          "config": "See https://docs.mcp.com.ai/deployment/docker#docker-compose-example",
          "description": "Run with persistent volumes and custom specs",
          "name": "Docker Compose Setup"
        }
      ],
      "keywords": [
        "openapi",
        "rest-api",
        "api-first",
        "headless",
        "docker"
      ],
      "license": "MIT",
      "publisher": "La Rebelion Labs"
    },
    "dev.indusmcp/source": "official-registry-mirror",
    "dev.indusmcp/synced": "2026-05-12"
  }
}