Fire in da houseTop Tip:Paying $100+ per month for Perplexity, MidJourney, Runway, ChatGPT and other tools is crazy - get all your AI tools in one site starting at $15 per month with Galaxy AI Fire in da houseCheck it out free

mcp-stytch-consumer-todo-list

MCP.Pizza Chef: stytchauth

The mcp-stytch-consumer-todo-list is an MCP server that combines a React/Vite static website, a REST API using Hono and Workers KV, and a Model Context Protocol server built on Workers Durable Objects. It manages user and client identity with Stytch Consumer, demonstrating how to extend a full-stack app for AI agent interaction with secure authentication and real-time context management.

Use This MCP server To

Authenticate users in TODO apps with Stytch Consumer integration Serve static React/Vite frontend via Cloudflare Workers Manage TODO items with REST API backed by Workers KV Provide real-time context to AI agents via MCP server Demonstrate full-stack app extension for AI agent workflows Use Durable Objects for stateful MCP server operations Combine authentication, API, and AI context in one server

README

Workers + Stytch TODO App MCP Server

This is a Workers server that composes three functions:

User and client identity is managed using Stytch. Put together, these three features show how to extend a traditional full-stack application for use by an AI agent.

This demo uses the Stytch Consumer product, which is purpose-built for Consumer SaaS authentication requirements. If you are more interested in Stytch's B2B product, see this demo instead.

Set up

Follow the steps below to get this application fully functional and running using your own Stytch credentials.

In the Stytch Dashboard

  1. Create a Stytch account. Within the sign up flow select Consumer Authentication as the authentication type you are interested in. Once your account is set up a Project called "My first project" will be automatically created for you.

  2. Navigate to Frontend SDKs to enable the Frontend SDK in Test

  3. Navigate to Connected Apps to enable Dynamic Client Registration

  4. Navigate to Project Settings to view your Project ID and API keys. You will need these values later.

On your machine

In your terminal clone the project and install dependencies:

git clone https://github.com/stytchauth/mcp-stytch-consumer-todo-list.git
cd mcp-stytch-consumer-todo-list
npm i

Next, create an .env.local file by running the command below which copies the contents of .env.template.

cp .env.template .env.local

Open .env.local in the text editor of your choice, and set the environment variables using the public_token found on Project Settings.

# This is what a completed .env.local file will look like
VITE_STYTCH_PUBLIC_TOKEN=public-token-test-abc123-abcde-1234-0987-0000-abcd1234

Create a .dev.vars file by running the command below which copies the contents of .dev.vars.template

cp .dev.vars.template .dev.vars

Open .dev.vars in the text editor of your choice, and set the environment variables using the Project ID and Secret found on Project Settings.

// This is what a completed .dev.vars file will look like
STYTCH_PROJECT_ID=project-test-6c20cd16-73d5-44f7-852c-9a7e7b2ccf62
STYTCH_SECRET=your-stytch-secret-key

Running locally

After completing all the setup steps above the application can be run with the command:

npm run dev

The application will be available at http://localhost:3000 and the MCP server will be available at http://localhost:3000/sse.

Test your MCP server using the MCP Inspector

npx @modelcontextprotocol/inspector@latest

Deploy to Cloudflare Workers

Click the button - you'll need to configure environment variables after the initial deployment.

Deploy to Cloudflare

Or, if you want to follow the steps by hand:

  1. Create a KV namespace for the TODO app to use
wrangler kv namespace create TODOS
  1. Update the KV namespace ID in wrangler.jsonc with the ID you received:
"kv_namespaces": [
   {
      "binding": "TODOS",
      "id": "your-kv-namespace-id"
   }
]
  1. Upload your Stytch Env Vars for use by the worker
npx wrangler secret bulk .dev.vars
  1. Deploy the worker
npm run deploy
  1. Grant your deployment access to your Stytch project. Assuming your Stytch project was deployed at https://mcp-stytch-consumer-todo-list.$YOUR_ACCOUNT_NAME.workers.dev:
    1. Add https://mcp-stytch-consumer-todo-list.$YOUR_ACCOUNT_NAME.workers.dev/authenticate as an allowed Redirect URL
    2. Add https://mcp-stytch-consumer-todo-list.$YOUR_ACCOUNT_NAME.workers.dev as an allowed Authorized Application in the Frontend SDKs configuration

Get help and join the community

💬 Stytch community Slack

Join the discussion, ask questions, and suggest new features in our Slack community!

mcp-stytch-consumer-todo-list FAQ

How does this MCP server handle user authentication?
It uses Stytch Consumer for secure user and client identity management.
What technologies power the static website in this MCP server?
The frontend is built with React and Vite, served via Cloudflare Workers Assets.
How is the TODO data stored and accessed?
TODO items are managed through a REST API built with Hono and stored in Workers KV.
What role do Durable Objects play in this MCP server?
Durable Objects host the MCP server component, enabling stateful, real-time context management.
Can this MCP server be adapted for B2B authentication?
Yes, there is a related demo using Stytch B2B for business authentication scenarios.
How does this server demonstrate extending full-stack apps for AI agents?
By integrating authentication, API, and MCP context serving in one cohesive app.
Is this MCP server limited to TODO apps?
No, the architecture can be adapted for other full-stack applications requiring AI context and auth.
What is the benefit of using Workers for this MCP server?
Workers provide scalable, edge-deployed hosting for frontend, API, and MCP server components.