Argo RPG Platform MCP
OfficialIntegrates with Argo campaigns, providing tools to manage campaigns, mnemons (NPCs, locations, quests, lore, etc.), sessions, guilds, friends, invites, and community forum interactions.
Argo MCP Server
Connects AI assistants to your Argo campaigns via the Model Context Protocol. Once configured, your AI assistant can read and write campaign lore, look up character details, and interact with Argo data directly from the chat interface.
Supported clients: Claude Code, Claude Desktop, OpenAI Codex, VS Code (1.103+), and any MCP-compatible host.
One-click install
Clicking either button hands a vscode:mcp/install URL to your editor with this config:
{ "type": "http", "url": "https://mcp.argo.games/mcp" }VS Code stores the entry in your user-level mcp.json, then negotiates OAuth on first connect via Dynamic Client Registration against the Argo authorization server. No tokens are embedded in the URL — VS Code stores the resulting access and refresh tokens in your OS keychain.
Linux / Flatpak / Snap note: If clicking the button doesn't open VS Code, the vscode: URL handler isn't registered. This is common on:
Flatpak / Snap VS Code — the sandbox isolates the install from the host, so the host browser can't find the protocol handler.
Tarball / manual installs — no postinst hook runs
update-desktop-database. Either runxdg-mime default code.desktop x-scheme-handler/vscodeonce, or use the manual fallback below.
Manual fallback: copy the JSON from the VS Code (one-click, recommended) section below into your VS Code mcp.json config.
The same install button is rendered on the Argo install page at https://app.argo.games/docs/mcp/install.
Prerequisites
Node.js 20 or later
An Argo account with at least one campaign
A Game Master must authorize the AI assistant via the OAuth2 consent flow (see Getting a token)
Quick start
There are three supported ways to use the Argo MCP server. Pick the one that matches your client.
ChatGPT (remote)
Use the hosted endpoint — do not install the npx package. Add this MCP server URL to ChatGPT:
https://mcp.argo.games/mcpChatGPT will walk you through OAuth on first connect via dynamic client registration.
Local MCP clients (Claude Code, Claude Desktop, Codex, etc.) — recommended
Sign in once on the machine that runs the MCP client:
npx -y argo-mcp auth loginThe command prints the consent URL, opens nothing, and asks you to paste the access token (and optionally the refresh token) from the consent page. Tokens are saved locally:
Windows:
%APPDATA%\argo-mcp\tokens.jsonmacOS:
~/Library/Application Support/argo-mcp/tokens.jsonLinux:
${XDG_CONFIG_HOME:-~/.config}/argo-mcp/tokens.json
Then configure the MCP server with no env vars:
{
"mcpServers": {
"argo": { "command": "npx", "args": ["-y", "argo-mcp"] }
}
}Other auth commands:
npx -y argo-mcp auth status # show whether you are signed in
npx -y argo-mcp auth logout # forget locally stored tokensLocal stdio mode does not use OAuth Dynamic Client Registration. DCR is only used by the hosted HTTP server at
https://mcp.argo.games.
Advanced — environment variables
For CI, Docker, or anyone who prefers explicit env config, you can skip auth login and pass tokens directly. OAUTH_TOKEN always wins over the local token store.
{
"mcpServers": {
"argo": {
"command": "npx",
"args": ["-y", "argo-mcp"],
"env": {
"OAUTH_TOKEN": "<your-access-token>",
"REFRESH_TOKEN": "<your-refresh-token>"
}
}
}
}Build from source (contributors)
git clone https://github.com/Argo-RPG-Platform/MCP.git argo-mcp
cd argo-mcp
npm install
npm run buildGetting a token
The MCP server authenticates with Argo using an OAuth2 access token tied to a specific set of campaigns. Tokens are obtained through the Argo consent flow:
Open https://app.argo.games/oauth2/mcp-connect in your browser.
Select the campaigns you want the AI assistant to access and the permission level (read or read+write).
Click Authorize. You will be redirected to a page showing two tokens:
Access token — set this as
OAUTH_TOKENRefresh token — set this as
REFRESH_TOKEN(recommended; enables automatic renewal when the access token expires after ~1 hour)
Treat both tokens like passwords. Revoke them at any time from the campaign's integrations page.
Configuration
VS Code (one-click, recommended)
Use the install buttons at the top of this README, or paste the following into a .vscode/mcp.json (per-workspace) or your user-level MCP config:
{
"servers": {
"argo": {
"type": "http",
"url": "https://mcp.argo.games/mcp"
}
}
}VS Code handles OAuth automatically via Dynamic Client Registration on first connect. There is no need to set OAUTH_TOKEN or REFRESH_TOKEN — VS Code stores tokens in the OS keychain.
Claude Code
Add the server with the CLI:
claude mcp add argo \
--command node \
--args /absolute/path/to/argo-mcp/dist/index.js \
--env OAUTH_TOKEN=<your-access-token> \
--env REFRESH_TOKEN=<your-refresh-token>Or add it manually to your project's .claude/settings.json:
{
"mcpServers": {
"argo": {
"command": "node",
"args": ["/absolute/path/to/argo-mcp/dist/index.js"],
"env": {
"OAUTH_TOKEN": "<your-access-token>",
"REFRESH_TOKEN": "<your-refresh-token>"
}
}
}
}Claude Desktop
Edit your Claude Desktop config file:
macOS:
~/Library/Application Support/Claude/claude_desktop_config.jsonWindows:
%APPDATA%\Claude\claude_desktop_config.json
{
"mcpServers": {
"argo": {
"command": "node",
"args": ["/absolute/path/to/argo-mcp/dist/index.js"],
"env": {
"OAUTH_TOKEN": "<your-access-token>",
"REFRESH_TOKEN": "<your-refresh-token>"
}
}
}
}Restart Claude Desktop after saving.
OpenAI Codex
Add the server to your Codex MCP configuration:
{
"mcpServers": {
"argo": {
"command": "node",
"args": ["/absolute/path/to/argo-mcp/dist/index.js"],
"env": {
"OAUTH_TOKEN": "<your-access-token>",
"REFRESH_TOKEN": "<your-refresh-token>"
}
}
}
}ChatGPT App Submission
For the hosted ChatGPT app surface, this repo exposes OAuth discovery, dynamic client registration, and domain verification endpoints on the MCP domain. The submission checklist and required env vars are in CHATGPT_APP_SUBMISSION.md.
Using a .env file (local dev)
Create a .env file in the argo-mcp directory:
OAUTH_TOKEN=<your-access-token>
REFRESH_TOKEN=<your-refresh-token>Then run directly:
npm run dev # hot-reload via tsx
# or
npm start # compiled dist/Pre-built Agent Skills
Once the MCP is connected, you can install the argo-agent-skills plugin to get ready-made Game Master workflows that orchestrate the tools below — session prep, post-session recap, NPC generation, and a guided MCP setup walkthrough. The same skill source ships parallel packaging for Claude (Code + Claude.ai) and OpenAI-compatible clients (Codex, ChatGPT).
Claude Code:
/plugin marketplace add Argo-RPG-Platform/argo-agent-skills
/plugin install argo-gm-pack@argoClaude.ai / Codex / ChatGPT: download the per-target zip from the latest release and follow the upload steps in that repo's README.
See the Argo Skills docs for the full list of skills, examples, and authoring guidance for your own.
Available tools
This server exposes tools across campaigns, mnemons, sessions, guilds, friends, invites, and the Argo community forum.
Campaigns
list_campaigns(campaign.read) lists accessible campaigns and their access levelget_campaign(campaign.read) retrieves campaign detailscreate_campaign(campaign.create) creates a new campaignupdate_campaign(campaign.write) updates campaign name or descriptionlist_co_gms(campaign.read) lists assistant GMsadd_co_gm(campaign.write) adds an assistant GMremove_co_gm(campaign.write) removes an assistant GM
Mnemons
describe_mnemon_typeslists supported mnemon types, relationship labels, and content-block ruleslist_mnemons(campaign.read) lists mnemon entries for a campaignget_mnemon(campaign.read) retrieves a mnemon entry in fulllist_mnemon_relationships(campaign.read) lists linked entries and relationship edgescreate_*_mnemons(campaign.write) creates typed mnemon entries for NPC, Location, Quest, Lore, Archive, Journal, SessionSummary, Player, and Custom entriesupdate_*_mnemons(campaign.write) updates typed/meta fields for those mnemon entry typesupdate_mnemons_content(campaign.write) edits mnemon content blockscreate_mnemon_relationship(campaign.write) creates a relationship between entriesdelete_mnemon_relationship(campaign.write) deletes a relationship by ID
Sessions
create_session(campaign.write) schedules a campaign sessionlist_sessions(campaign.read) lists sessions for a campaign and monthget_session(campaign.read) retrieves a single sessionupdate_session(campaign.write) updates a session's schedule or text
Guilds
list_guilds(guild.read) lists guilds the current user belongs toget_guild(guild.read) retrieves guild detailslist_guild_members(guild.read) lists guild membersadd_campaign_to_guild(guild.write) links a campaign to a guildinvite_guild_member(guild.admin) invites a guild memberremove_guild_member(guild.admin) removes a guild memberset_guild_member_role(guild.admin) changes a guild member's roleadd_guild_calendar_event(guild.admin) adds a guild calendar event
Friends and invites
list_friends(friends.read) lists accepted friendslist_sent_friend_requests(friends.read) lists outgoing pending requestslist_received_friend_requests(friends.read) lists incoming pending requestssend_friend_request(friends.write) sends a friend requestaccept_friend_request(friends.write) accepts a requestreject_friend_request(friends.write) rejects a requestcancel_friend_request(friends.write) cancels a sent requestinvite_user_by_email(invite.write) sends Argo invitation emails
Forum
forum_list_categories(forum.read) lists forum categoriesforum_list_topics(forum.read) lists topics in a categoryforum_get_latest_topics(forum.read) lists recent forum activityforum_read_topic(forum.read) reads a topic threadforum_search(forum.read) searches forum contentforum_get_user_posts(forum.read) lists the current user's topicsforum_get_notifications(forum.read) lists the current user's notificationsforum_create_topic(forum.write) creates a new topic oncommunity.argo.gamesforum_reply(forum.write) replies to an existing topic oncommunity.argo.games
Many campaign-scoped tools accept campaignId. You can find a campaign's ID from the Argo campaign URL or by asking the GM.
Token renewal
The access token expires after approximately one hour. If REFRESH_TOKEN is configured, the server automatically fetches a new access token on the first request that returns a 401 and retries transparently — no action required.
If no refresh token is set and the access token expires, the tool will return:
Token expired — re-consent at https://app.argo.games/oauth2/mcp-connect
Re-run the consent flow at that URL to get fresh tokens.
Revoking access
To disconnect the AI assistant from a campaign, revoke the grant from the campaign's integrations page in the Argo WebApp. The access token and refresh token will both become invalid immediately.
Environment variables
Variable | Required | Description |
| If not signed in via | OAuth2 access token from the consent flow |
| Recommended | OAuth2 refresh token; enables automatic renewal |
| No | Override the API base URL (default: |
| No | Override the local token file path used by |
Privacy Policy
Full policy: https://argo.games/policies/privacy-policy
What the Argo MCP server handles:
Data collected. OAuth access and refresh tokens issued by the Argo authorization server (
oauth.argo.games); the campaign, mnemon, guild, forum, and friends payloads that pass through tool calls; standard HTTP metadata (IP, user agent) for rate limiting and abuse mitigation.Usage. Tool calls are proxied to the Argo WebAPI (
api.argo.games) on behalf of the authenticated user. Tokens are cached in-process for the lifetime of an MCP session so clients that omitAuthorizationon subsequent requests (a known Claude Code behaviour) keep working.Storage & retention. Session token cache is in-memory only and is evicted after 30 minutes of inactivity. No user content (mnemons, campaigns, forum posts) is persisted by the MCP server — it is forwarded to the WebAPI and discarded. Logs retain only request metadata, not payload contents.
Third-party sharing. Requests are forwarded only to the Argo WebAPI and (during the OAuth flow) the Argo authorization server. No other third parties receive request data from this server.
Contact. Privacy questions:
support@argo.games. Security disclosures: see the SECURITY policy on the Argo GitHub organization.
The hosted privacy policy at the link above is the authoritative version and covers the full Argo platform including the WebAPI and WebApp.
License
MIT — see LICENSE.
This server cannot be installed
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/Argo-RPG-Platform/MCP'
If you have feedback or need assistance with the MCP directory API, please join our Discord server