MCP Server with Authentication

MCP Server with Authentication

Implements a secure MCP server with API Key and JWT authentication, providing tools like echo, login, secure_action, and admin_action. Includes MCP Inspector integration for testing and debugging.

Category
Visit Server

README

๐Ÿš€ MCP Server with Authentication and Testing with Inspector

This project implements a Model Context Protocol (MCP) server with two authentication mechanisms: API Key Authentication and JWT (JSON Web Token) Authentication. It provides a robust framework for handling authenticated requests with comprehensive error handling and logging, suitable for production environments. The server supports tools like echo, login, secure_action, and admin_action, with authentication enforced where required.

๐Ÿ“š Table of Contents

  1. ๐Ÿš€ Project Overview

  2. ๐ŸŽฏ Purpose

  3. โœจ Features

  4. ๐Ÿ—‚๏ธ Project Structure

  5. โœ… Prerequisites

  6. โš™๏ธ Installation

  7. ๐Ÿงฉ Packages

  8. ๐Ÿšฆ Usage

  9. ๐Ÿ”„ Workflow

  10. ๐Ÿฉต Troubleshooting

๐ŸŽฏ Purpose

The purpose of this project is to demonstrate secure MCP server implementations with two distinct authentication methods:

  • ๐Ÿ”‘ API Key Authentication: Validates requests using predefined API keys.
  • ๐Ÿ›ก๏ธ JWT Authentication: Uses JSON Web Tokens for user authentication and permission-based access control.

This project is designed for developers who need a secure, scalable, and extensible MCP server with robust debugging and logging capabilities.

โœจ Features

  • ๐Ÿ”‘ API Key Authentication:

    • Validates requests using a set of predefined API keys.
    • Supports key extraction from arguments, metadata, or environment variables.
    • Simple echo tool for demonstration.
  • ๐Ÿ›ก๏ธ JWT Authentication:

    • Supports user authentication via username/password to generate JWT tokens.
    • Enforces permission-based access control (read, write, admin).
    • Includes tools: login, echo, secure_action, and admin_action.
    • Configurable token expiry (default: 24 hours).
    • Token extraction from arguments, metadata, or environment variables.
  • โš ๏ธ Robust Error Handling:

    • Custom McpError for consistent error responses.
    • Detailed logging of errors and server events.
  • ๐Ÿ“ Logging:

    • Configurable logging to both console and rotating log files.
    • Log rotation based on file size (5MB, with 5 backups).
    • Automatic cleanup of old log files based on age.
  • ๐Ÿ” MCP Inspector Integration:

    • Compatible with MCP Inspector for testing and debugging.
    • Supports debugging via --debug flag.

๐Ÿ—‚๏ธ Project Structure

/
โ”œโ”€โ”€ src/
โ”‚   โ”œโ”€โ”€ config/
โ”‚   โ”‚   โ”œโ”€โ”€ __init__.py
โ”‚   โ”‚   โ”œโ”€โ”€ app_settings.py                     # Configuration for environment variables and settings
โ”‚   โ”‚   โ””โ”€โ”€ logging_config.py                   # Logging setup with file rotation
โ”‚   โ”œโ”€โ”€ mcp-server-with-stdio-api-key-auth.py   # API Key Authentication server
โ”‚   โ”œโ”€โ”€ mcp-server-with-stdio-auth2-auth.py     # To Do
โ”‚   โ””โ”€โ”€ mcp-server-with-stdio-jwt-key-auth.py   # JWT Authentication server
โ”œโ”€โ”€ pyproject.toml                              # Project documentation
โ””โ”€โ”€ README.md                                   # Python dependencies

โœ… Prerequisites

  • Python: Version 3.13 or higher
  • uv: Used for managing Python virtual environments
  • Node.js: Required for running MCP Inspector
  • NPM: Required to run MCP Inspector
  • Operating System: Windows, macOS, or Linux

โš™๏ธ Installation

  1. ๐Ÿ“ฅ Clone the Repository:

    git clone https://github.com/ahmad-act/MCP-Server-with-Authentication-and-Testing-with-Inspector.git
    cd MCP-Server-with-Authentication-and-Testing-with-Inspector
    
  2. ๐Ÿช„ Set Up a Virtual Environment (recommended):

    uv venv
    source venv/bin/activate  # On Windows: venv\Scripts\activate
    
  3. ๐Ÿ“ฆ Install Dependencies:

    uv sync
    

๐Ÿงฉ Packages

The following Python packages are required:

mcp[cli]>=1.10.1
PyJWT>=2.8.0
python-dotenv>=1.0.0

๐Ÿ‘‰ Install them using:

uv add mcp[cli] PyJWT python-dotenv

๐Ÿšฆ Usage

1๏ธโƒฃ MCP Server with Stdio and API Key (mcp-server-with-stdio-api-key-auth.py)

โ–ถ๏ธ Run the MCP Server:

โš ๏ธ You do not need to manually run the MCP server for stdio transport. MCP Inspector runs the MCP Server for stdio transport.

โ–ถ๏ธ Run the MCP Inspector:

The stdio server is typically launched by the MCP Inspector, not manually. Run the Inspector with the following command, add -e environment variable and adjusting the --directory path to your src/ directory:

npx @modelcontextprotocol/inspector uv -e MCP_API_KEY=sk-1234567890abcdef --directory '<your-src-directory>/src' run mcp-server-with-stdio-api-key-auth.py --debug

MCP Inspector Run

๐ŸŒ Open the MCP Inspector:

Open the link http://localhost:6274/?MCP_PROXY_AUTH_TOKEN=XXXXXXXXXXXXXXXXXX with its token in your browser:

MCP Inspector Use

๐Ÿงช Using the MCP Inspector

  1. After running the above command, the Inspector will start and automatically connect to the stdio-based server.

  2. In the Inspector UI (http://127.0.0.1:6274), inspect the available tools (e.g., echo).

  3. Test the echo tool:

    • Input:
    {
      "method": "call_tool",
      "params": {
        "name": "echo",
        "arguments": {
          "message": "test",
          "_api_key": "sk-1234567890abcdef"
        }
      }
    }
    

    Expected Response:

    {
      "result": [
        {
          "type": "text",
          "text": "Echo: test"
        }
      ]
    }
    

    MCP Inspector Use MCP Inspector Use MCP Inspector Use

2๏ธโƒฃ MCP Server with Stdio and API Key (mcp-server-with-stdio-jwt-key-auth.py)

โ–ถ๏ธ Run the MCP Server:

โš ๏ธ You do not need to manually run the MCP server for stdio transport. MCP Inspector will launch the server automatically.

โ–ถ๏ธ Run the MCP Inspector:

The stdio server is typically launched by the MCP Inspector, not manually. Run the Inspector with the following command, adjusting the --directory path to your src/ directory:

npx @modelcontextprotocol/inspector uv --directory '<your-src-directory>\src' run mcp-server-with-stdio-jwt-key-auth.py --debug

MCP Inspector Run

๐ŸŒ Open the MCP Inspector:

Open the link http://localhost:6274/?MCP_PROXY_AUTH_TOKEN=XXXXXXXXXXXXXXXXXX with its token in your browser:

MCP Inspector Use

๐Ÿงช Using the MCP Inspector

  1. After running the above command, the Inspector will start and automatically connect to the stdio-based server.

  2. Usage Flow:

    • Step 1: Login to Get JWT Token:

      {
        "method": "call_tool",
        "params": {
          "name": "login",
          "arguments": {
            "username": "user1",
            "password": "password123"
          }
        }
      }
      

      Response:

      {
        "result": [
          {
            "type": "text",
            "text": "Login successful! JWT Token: eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9..."
          }
        ]
      }
      
    • Step 2: Use JWT Token for Authenticated Requests:

      {
        "method": "call_tool",
        "params": {
          "name": "echo",
          "arguments": {
            "message": "test",
            "_jwt_token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9..."
          }
        }
      }
      

      Response:

      {
        "result": [
          {
            "type": "text",
            "text": "Echo (authenticated as user1): test"
          }
        ]
      }
      

    MCP Inspector Use MCP Inspector Use MCP Inspector Use MCP Inspector Use

3๏ธโƒฃ MCP Server with Stdio and Auth2 (mcp-server-with-stdio-auth2-auth.py)

๐Ÿšง To Do


๐Ÿ”„ Workflow

  1. ๐Ÿ”‘ API Key Authentication:

    • The server checks for a valid API key in the request arguments, metadata, or environment variables.
    • If valid, the request is processed; otherwise, an error is returned.
    • The echo tool demonstrates basic functionality.
  2. ๐Ÿ›ก๏ธ JWT Authentication:

    • Users first call the login tool with valid credentials to obtain a JWT token.
    • The token is used in subsequent requests for tools like echo, secure_action, or admin_action.
    • Permissions (read, write, admin) are checked for each tool.
    • Tokens expire after 24 hours (configurable).
  3. ๐Ÿ“ Logging:

    • Logs are written to both the console and a rotating log file in the logs directory.
    • Old log files are cleaned up based on a specified retention period.
  4. ๐Ÿ” Testing with MCP Inspector:

    • Use MCP Inspector to interact with the server via a web interface.
    • Debug mode (--debug) provides detailed output for troubleshooting.

๐Ÿฉต Troubleshooting

  • ๐Ÿšซ Invalid API Key:

    • Ensure the API key is one of: sk-1234567890abcdef, sk-abcdef1234567890, sk-test123456789.
    • Check environment variable MCP_API_KEY or request arguments.
  • โš ๏ธ Invalid JWT Token:

    • Verify the token is not expired (valid for 24 hours).
    • Ensure the correct JWT_SECRET is set.
    • Check username/password for login tool.
  • ๐Ÿ”’ Permission Errors:

    • Ensure the user has the required permissions (read, write, or admin) for the requested tool.
  • ๐Ÿ“ Log Files:

    • Check the logs directory for detailed error messages.
    • Logs are named in the format YYYYMM.log.

Recommended Servers

playwright-mcp

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured