Skip to main content
Glama

gpt2agent

MCP server for your ChatGPT account: codex login โ†’ ChatGPT Plus/Pro inside any MCP client.

An MCP server that puts your ChatGPT Plus or Pro subscription โ€” every model and the account-tier features below โ€” inside Claude Code, Codex, Cursor, Windsurf, Zed, and any MCP client.

PyPI version CI License: MIT Python 3.10+

๐Ÿ“– Quickstart ยท Client setup ยท Troubleshooting ยท FAQ ยท Docs index


What it does

gpt2agent exposes 25 MCP tools that forward requests directly to ChatGPT's backend API. No proxy process. No separate account. No platform API key. Your codex login, your token, your quota.

If you already have the codex CLI logged in, setup is zero extra steps โ€” gpt2agent reuses the same ~/.codex/auth.json bearer and picks up its background-refreshed token automatically.

Works with Claude Code, Codex CLI, and any client that speaks the MCP protocol over stdio.


Related MCP server: claude-max-mcp

Install โ€” one line

curl -fsSL https://raw.githubusercontent.com/robotlearning123/gpt2agent/main/install.sh | bash

That command:

  1. Installs gpt2agent via pipx (creates an isolated env; falls back to a git install if PyPI is unreachable).

  2. Reuses your existing ~/.codex/auth.json if you've run codex login โ€” no separate ChatGPT token paste needed.

  3. Detects which MCP clients you have (Claude Code, Codex, Cursor, Windsurf, Claude Desktop, Zed) and writes the right config for each.

  4. Drops the Claude Code skills (deep-research + gpt2agent) into ~/.claude/skills/.

Or step-by-step

# 1. Install the package globally (isolated venv)
pipx install gpt2agent

# 2. Register with all detected MCP clients (Claude Code, Codex)
gpt2agent install                          # auto-detect everything

# Want only one client?
gpt2agent install --client claude-code   # or: codex, cursor, windsurf, claude-desktop, zed
# (VS Code & Cline: see docs/clients.md for the manual snippet)

# HTTP transport instead of stdio?
gpt2agent install --transport http --http-port 9000

Or as a Claude Code plugin

/plugin marketplace add robotlearning123/gpt2agent
/plugin install gpt2agent@gpt2agent

This bundles the MCP server registration + both skills in one step. You still need the gpt2agent CLI on PATH (pipx install gpt2agent) โ€” the plugin wires the server (gpt2agent run --stdio) and skills, not the Python package itself.

Per-client config

The install subcommand writes the right thing for each:

Client

File

Section

Claude Code

~/.claude.json

mcpServers.gpt2agent (stdio: gpt2agent run --stdio)

Codex CLI

~/.codex/config.toml

[mcp_servers.gpt2agent]

Both are idempotent and back up the prior file as <name>.bak-gpt2agent.

After running install, restart Claude Code so it re-spawns the subprocess. Codex picks up the new server on its next invocation automatically.

Manual config (if you'd rather not run install)

Claude Code โ€” add to ~/.claude.json:

{
  "mcpServers": {
    "gpt2agent": {
      "type": "stdio",
      "command": "gpt2agent",
      "args": ["run", "--stdio"]
    }
  }
}

Codex CLI โ€” add to ~/.codex/config.toml:

[mcp_servers.gpt2agent]
command = "gpt2agent"
args = ["run", "--stdio"]

Setup (manual token paste โ€” only if codex isn't available)

gpt2agent setup

Prompts for a ChatGPT session token (saved to ~/.gpt2agent/token.json, mode 600), detects your plan, and registers gpt2agent with your detected MCP clients over stdio โ€” the same wiring as gpt2agent install. The codex login flow is preferred when available because codex auto-refreshes its token; gpt2agent reloads ~/.codex/auth.json on mtime change so long calls don't 401 mid-flight.


Tools (25)

Chat & reasoning

Tool

What it does

chat

Talk to any model on your account (gpt-5-3 default, override via model=). Pass gpt-5-5-pro, o3-pro, gpt-5-4-thinking, โ€ฆ

agent

Agent Mode โ€” 262K context with autonomous browsing, code execution, tool use

deep_research

Web-augmented research with citations (~30โ€“120 s). Auto-confirms by default

deep_research_heavy

Long-form DR via gpt-5-5-pro + connector (5โ€“30 min, monthly quota). Configurable via [models].heavy_dr

gpt_chat

Talk through one of your private Custom GPTs (g-p-*) โ€” experimental

Image & file management

Tool

What it does

generate_image

Generate images via ChatGPT's built-in DALL-E. Returns download URLs + metadata

get_file_info

Metadata for any ChatGPT file (images, uploads)

get_file_download_url

Temporary download URL for a ChatGPT file (~1h expiry)

Code execution

Tool

What it does

code_interpreter

Run Python in ChatGPT's sandbox. Returns output + any generated charts/images

canvas_execute

Execute code via ChatGPT's Canvas feature (live editing environment)

Account introspection

Tool

What it does

account_status

Plan, country, groups, feature count, subscription expiry

list_models

All models on your account (slug, max_tokens, reasoning_type, capabilities, enabled_tools)

list_conversations

Recent ChatGPT conversations (titles: emails/phones redacted)

get_conversation

Full message history for a specific conversation (multimodal, code, images)

list_tasks

Scheduled / completed ChatGPT tasks

list_apps

Connected apps + connectors

list_custom_gpts

Your private g-p-* GPTs

Memory & instructions

Tool

What it does

memory_list

List all ChatGPT memory entries (emails/phones redacted)

memory_search

Keyword filter over memories

memory_create_via_chat

Add a memory (model-initiated workaround โ€” POST /memories is 405)

custom_instructions_get

Read your current about_user / about_model

custom_instructions_set

Update them (read-modify-write, preserves unspecified fields)

Codex (cloud agent)

Tool

What it does

list_codex_envs

Codex environments (label, repos, network policy)

list_codex_tasks

Recent Codex tasks + status

codex_task_create

Kick off a new Codex task (resolves env from repo_label)


Architecture

Native Python implementation โ€” no proxy. The server calls /backend-api/conversation (SSE) directly using curl_cffi for TLS impersonation. Vendored POW and Turnstile solvers handle the OpenAI Sentinel challenge. Token is reloaded from disk on each request, so codex's background refresh propagates transparently. See NOTICES for attribution.

~/.codex/auth.json  (or ~/.gpt2agent/token.json)  โ† auto-refreshed by codex
        |
   gpt2agent  (stdio MCP server, token reloaded on each call)
        |
   curl_cffi  โ†’  chatgpt.com /backend-api/{conversation,f/conversation,me,
                                          models, memories, codex, gizmos, ...}
        |
   25 MCP tools  (chat, agent, DR ร—2, GPT chat, image gen,
                  code interpreter, canvas, memory r/w,
                  instructions r/w, codex r/w, account introspect)

Configuration

Optional, searched in order: ~/.gpt2agent/config.toml, ./config.toml, ~/.config/gpt2agent/config.toml. Full reference: docs/configuration.md.

[server]
host = "127.0.0.1"   # loopback only; the HTTP transport is UNAUTHENTICATED
port = 9000

[models]
chat     = "gpt-5-3"        # default for chat tool
agent    = "agent-mode"     # default for agent tool
heavy_dr = "gpt-5-5-pro"    # override slug for deep_research_heavy

Limitations

  • Deep Research quota: roughly ~248 heavy requests / monthly cycle on Pro, lower on Plus โ€” approximate and account/region-dependent, not a guaranteed number.

  • Account-tier features not yet supported: Sora video, Operator/CUA, voice sessions. These use HTTP endpoints that return 404 or haven't yet been reverse-engineered out of the chatgpt.com web bundle.

  • gpt_chat is experimental โ€” gizmo_id payload field verified against web traffic but not load-tested across all g-p-* types.

  • Requires an active ChatGPT Plus or Pro subscription.


Security & risk โ€” read before you run this

gpt2agent talks to ChatGPT's private backend the way the web app does. That has real consequences; please understand them before pointing it at your account.

  • It impersonates the chatgpt.com web client. It uses curl_cffi TLS fingerprint impersonation and vendored Proof-of-Work + Cloudflare Turnstile solvers to pass the OpenAI Sentinel challenge. This is very likely against the OpenAI Terms of Service, and automated/abnormal traffic can get your account rate-limited, challenged, suspended, or banned. Use an account you can afford to lose, keep volume human-scale, and don't rely on it for anything critical. This is a reverse-engineering / research tool, not an official API.

  • The HTTP transport is UNAUTHENTICATED. It proxies your entire account โ€” read all conversations, spend Deep Research quota, overwrite custom instructions, launch Codex cloud tasks. Anyone who can reach the port controls your account. Therefore:

    • Use stdio (the default for gpt2agent install) for local clients like Claude Code and Codex. It is not network-exposed.

    • The server binds 127.0.0.1 by default and refuses to start the HTTP transport on a non-loopback host unless you explicitly set GPT2AGENT_ALLOW_REMOTE=1. Only do that behind your own auth proxy / firewall.

  • Your token stays local. It is read from ~/.codex/auth.json (or ~/.gpt2agent/token.json, chmod 600) and sent only to chatgpt.com. gpt2agent never transmits it anywhere else. Token/secret values are redacted from error messages and logs (best-effort).

  • PII redaction is limited. Tools that return conversation/memory data strip only emails and phone numbers from text โ€” names, addresses, IDs, and the full message bodies of get_conversation are returned verbatim. Don't treat the output as anonymized.

  • GPT2AGENT_RAW_DUMP (debug) writes raw, unredacted SSE/poll traffic โ€” including prompts, responses, and resume tokens โ€” to the path you give it. Use only for debugging and delete the dumps after.

Found a security issue? See SECURITY.md.


Development

python -m venv .venv
source .venv/bin/activate
pip install -e ".[dev]"
pytest

Release

Tagged releases are configured to publish to PyPI and create a GitHub Release with the matching CHANGELOG section:

# bump version
$EDITOR pyproject.toml             # e.g. "0.0.3" โ†’ "0.0.4"
$EDITOR CHANGELOG.md               # add ## [0.0.4] - YYYY-MM-DD ...
git commit -am "release: 0.0.4"
git tag v0.0.4
git push origin main --tags        # release workflow fires on the tag

The release workflow (.github/workflows/release.yml) verifies the tag matches pyproject.toml, runs the test matrix, builds wheel + sdist, publishes to PyPI via OIDC trusted publishing, and posts a GitHub Release with that version's CHANGELOG body.

One-time PyPI setup required before the first publish succeeds. PyPI's OIDC exchange needs a Trusted Publisher registered for this repo (project gpt2agent, owner robotlearning123, workflow release.yml, environment pypi) at pypi.org โ†’ Publishing โ€” or a first manual twine upload to create the project. Until that is done the release job fails with invalid-publisher and the package is not on PyPI; the install.sh one-liner falls back to a git+https install in the meantime.


License

MIT. See NOTICES for third-party attributions.


Acknowledgments

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

Maintenance

โ€“Maintainers
โ€“Response time
5dRelease cycle
4Releases (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/robotlearning123/gpt2agent'

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