Skip to main content
Glama

substack-mcp ๐Ÿ“ฐ

An MCP server for reading Substack โ€” publications, posts, comments, author profiles, recommendations, and your Notes feed โ€” using your own reader session, no official API required.

It's read-only ๐Ÿ”’: nothing it does can post, like, comment, or change your account state.

๐Ÿ› ๏ธ Tools

Tool

Description

list_published_posts

List recent posts from a publication

get_post

Get a post's full content by domain + slug (works on paywalled posts if you're a paid subscriber)

get_post_by_url

Get a post's full content from any post URL, including generic substack.com/@handle/p-<id> links

search_posts

Search posts within a publication

search_all_subscriptions

Search across every publication you're subscribed to

list_subscriptions

List your subscriptions (free and paid)

get_post_comments

Get a post's comments, with nested replies, by domain + slug

get_post_comments_by_url

Same, from any post URL

get_author_profile

Get an author's public profile (bio, social links, publications they write for)

get_recommendations

List publications a given publication recommends to its readers

get_notes_feed

List recent items from your Notes home feed

Related MCP server: Substack MCP Server

โš™๏ธ How it works

Substack doesn't expose a public API for these reads. Instead, this server replays the same /api/v1/* requests your browser makes when you're logged in, authenticated with your substack.sid session cookie. That means:

  • You need an active Substack account and a valid session token.

  • The token expires periodically โ€” when requests start failing with an auth error, re-extract it (see below).

โš ๏ธ This is an unofficial library and is not affiliated with or endorsed by Substack. It only accesses content you're already entitled to (your own subscriptions, public posts, and your own account data) and doesn't bypass paywalls or rate limits. Be mindful of Substack's Terms of Use when using it.

๐Ÿš€ Setup

git clone https://github.com/ryanrodrigues25200525-svg/substack-mcp.git
cd substack-mcp
npm install
npm run build

๐Ÿ”‘ Get your session token

  1. Log into Substack in your browser.

  2. Open DevTools โ†’ Application/Storage โ†’ Cookies โ†’ substack.com.

  3. Copy the value of the substack.sid cookie.

๐Ÿ”Œ Configure your MCP client

Add to your MCP client's config (e.g. Claude Code's ~/.claude.json, under mcpServers):

{
  "mcpServers": {
    "substack": {
      "command": "node",
      "args": ["/absolute/path/to/substack-mcp/dist/index.js"],
      "env": {
        "SUBSTACK_SESSION_TOKEN": "your_token_here"
      }
    }
  }
}

๐Ÿšซ Never commit your token. Keep it in your local MCP client config only, not in this repo or in version control.

๐Ÿงช Development

npm run build               # compile TypeScript
SUBSTACK_SESSION_TOKEN=xxx npm test   # run the integration test suite against live Substack endpoints

The test suite makes real requests against live publications, so it needs a valid SUBSTACK_SESSION_TOKEN and is subject to Substack's rate limits.

๐Ÿ“„ License

MIT

A
license - permissive license
-
quality - not tested
C
maintenance

Maintenance

โ€“Maintainers
โ€“Response time
โ€“Release cycle
โ€“Releases (12mo)
Commit activity

Resources

Unclaimed servers have limited discoverability.

Looking for Admin?

If you are the server author, to access and configure the admin panel.

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/ryanrodrigues25200525-svg/substack-mcp'

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