SSE Server with JWT Authentication

Secure middleware server implementing Model Context Protocol (MCP) over SSE with JWT authentication. Enables standardized communication between AI tools and clients with dynamic tool registration, request logging, and session management. Perfect for building production-ready AI systems requiring secure access patterns.

Installation

Installing for Claude Desktop

Option 1: One-Command Installation

npx mcpbar@latest install anisirji/mcp-server-remote-setup-with-jwt-auth -c claude

This command will automatically install and configure the SSE Server with JWT Authentication MCP server for your selected client.

Option 2: Manual Configuration

Run the command below to open your configuration file:

npx mcpbar@latest edit -c claude

After opening your configuration file, copy and paste this configuration:

View JSON configuration
{
  "mcpServers": {
    "SSE Server with JWT Authentication": {
      "command": "npx",
      "args": [
        "-y",
        "server"
      ],
      "env": {
        "JWT_SECRET": "${input:jwt_secret}"
      }
    }
  }
}

MseeP.ai Security Assessment Badge

πŸ” SSE MCP Server with JWT Authentication

This is a Model Context Protocol (MCP) SSE server with JWT-based authentication.
It allows you to expose multiple AI tools over an SSE transport, protected via secure Bearer Token flow.

Built with:

  • πŸš€ Node.js + Express
  • 🧩 @modelcontextprotocol/sdk
  • πŸ”’ JSON Web Tokens (JWT) for authentication
  • βš™οΈ Zod for input validation

βœ… Fully tested with @modelcontextprotocol/inspector

πŸ“‚ Project Structure

server/
β”œβ”€β”€ index.ts          # Main Express + MCP server
β”œβ”€β”€ .env              # Environment variables
β”œβ”€β”€ package.json      # Project metadata & scripts
β”œβ”€β”€ tsconfig.json     # TypeScript config
└── README.md         # You are here!

✨ Features

  • βœ… Secure SSE connection using Bearer JWT token
  • βœ… Dynamic Tool registration (echo, time, random number, etc.)
  • βœ… Tested with MCP Inspector
  • βœ… Logs all request lifecycle events
  • βœ… Session management for /message endpoint
  • πŸš€ Ready to extend for production use

βš™οΈ Setup

1. Clone the repository

git clone https://github.com/anisirji/mcp-server-remote-setup-with-jwt-auth.git
cd mcp-server-remote-setup-with-jwt-auth

2. Install dependencies

npm install

3. Create .env file

echo "JWT_SECRET=your-secret-key" > .env

4. Run the server

npm run dev

βœ… Server will run on:

http://localhost:3001/sse

πŸ§ͺ Testing the server with MCP Inspector

Step 1 β€” Install MCP Inspector

πŸ“– Official Docs: MCP Inspector

npx @modelcontextprotocol/inspector

Step 2 β€” Generate a token

Use cURL to get your JWT token:

curl "http://localhost:3001/auth/token?username=aniket&scope=mcp:access"

βœ… Example response:

{
  "token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9..."
}

Step 3 β€” Connect MCP Inspector

  1. Open Inspector UI
  2. Set Transport Type: SSE
  3. URL:
    http://localhost:3001/sse
    
  4. Add Authorization Header:
    Authorization: Bearer <your-token>
    
  5. Click Connect

πŸŽ‰ Success! Your server is now connected.

Step 4 β€” Test tools

Go to Tools tab in Inspector and click List Tools.

You will see:

  • βœ… test
  • βœ… echo
  • βœ… get-time
  • βœ… random-number

Test them and enjoy!

πŸ“– API Reference

πŸ”‘ Generate Token

GET /auth/token?username=<username>&scope=mcp:access

πŸ”Œ SSE Endpoint (requires token)

GET /sse
Authorization: Bearer <token>

πŸ“© Send Message to active session

POST /message?sessionId=<sessionId>
Authorization: Bearer <token>

🧩 Tools Reference

Tool NameDescription
testTest connection (security check)
echoEcho back provided message
get-timeReturns current server time
random-numberReturns random number (min/max)

πŸ—“οΈ Upcoming Changes

  • Token revocation list (blacklist)
  • Role-based tool access (scope checks)
  • Session heartbeat / keep-alive
  • Rate limiting & logging
  • Dockerization for deployment

πŸ“š Useful Resources

πŸ‘¨β€πŸ’» Maintainer

Aniket

πŸ“„ License

This project is open-source and free to use.

πŸš€ Build. Secure. Empower.

Share:
Details:
  • Stars


    4
  • Forks


    2
  • Last commit


    2 months ago
  • Repository age


    3 months
View Repository

Auto-fetched from GitHub .

MCP servers similar to SSE Server with JWT Authentication:

Β 

Β 
Β 
  • Stars


  • Forks


  • Last commit


Β 

Β 
Β 
  • Stars


  • Forks


  • Last commit


Β 

Β 
Β 
  • Stars


  • Forks


  • Last commit


SSE Server with JWT Authentication: MCP Server – MCP.Bar