nakama-mcp
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@nakama-mcpList the 10 most recent players whose username contains 'test'."
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
nakama-mcp
An MCP (Model Context Protocol) server for Heroic Labs Nakama. It lets Claude (or any MCP host) talk to a running Nakama instance across both of its HTTP APIs:
Client API (
:7350) — player-facing: authentication, accounts, friends, groups, storage, leaderboards, tournaments, RPCs, …Console API (
:7351) — admin/operations: search players, inspect & edit storage, leaderboards, active matches, server status & metrics, …
Nakama exposes ~180 operations across the two surfaces, so this server uses a search + execute design instead of one tool per endpoint, plus a handful of promoted convenience tools for the most common jobs.
Tools
Tool | Read/Write | What it does |
| read | Find operations by intent → returns action IDs, method/path, params. |
| write | Run any operation by |
| write | Establish a player session (device / custom / email) for client-API calls. |
| write | Call a registered runtime RPC (payload encoded the way the gateway expects). |
| read | List / search player accounts. |
| read | Fetch one player account by user ID. |
| read | List storage objects (filter by collection / key / owner). |
| read | Node status and lightweight service metrics. |
| read | Probe client + console reachability and admin login. |
| write | Write/update a storage object as the authenticated player. |
| write | Submit a score to a leaderboard as the authenticated player. |
| write | Send an in-app notification to a player (console). |
| write | Ban a player account by user ID (console). |
| write | Remove a ban from a player account (console). |
Reliability features
Auto-pagination —
nakama_execute_action,nakama_console_list_accounts, andnakama_console_list_storageacceptauto_paginate: true(+ optionalmax_pages, default 5) to followcursor/next_cursorand merge pages, adding__pages_fetched/__more_availableto the result.Secret redaction — error output is scrubbed of the configured server key / console password, JWTs, and
Basic/Bearerheader values before it reaches the model.Healthcheck —
nakama_healthcheckprobes both surfaces (and verifies admin login); use it first when calls fail.
Typical flow: ask nakama_search_actions for what you want → take the action_id → call nakama_execute_action. The promoted tools are shortcuts for frequent reads.
Related MCP server: Claude-LMStudio Bridge
Install & build
npm install
npm run buildConfiguration
All configuration is via environment variables. Defaults match a stock local Nakama dev setup.
Variable | Default | Notes |
|
| Host for both APIs. |
|
| Client API port. |
|
| Console API port. |
|
| Use |
|
| Server key for client authenticate endpoints. |
|
| Console admin user. |
|
| Console admin password. |
|
| Per-request timeout. |
See .env.example. These are secrets — prefer your MCP host's env config over committing them.
Add to an MCP host
Claude Desktop (claude_desktop_config.json)
{
"mcpServers": {
"nakama": {
"command": "node",
"args": ["/absolute/path/to/nakama-mcp/dist/index.js"],
"env": {
"NAKAMA_HOST": "127.0.0.1",
"NAKAMA_SERVER_KEY": "defaultkey",
"NAKAMA_CONSOLE_USERNAME": "admin",
"NAKAMA_CONSOLE_PASSWORD": "password"
}
}
}
}Claude Code
claude mcp add nakama -- node /absolute/path/to/nakama-mcp/dist/index.jsHow auth works
Console API: the server auto-logs-in with
NAKAMA_CONSOLE_USERNAME/NAKAMA_CONSOLE_PASSWORDon first use, caches the JWT, and refreshes when it expires. You don't call a login tool.Client API: authenticate endpoints use HTTP Basic with
NAKAMA_SERVER_KEY. Every other client endpoint needs a player session — callnakama_authenticatefirst; the session token is held in memory for the rest of the connection.RPCs:
nakama_call_rpcJSON-encodes the payload as Nakama's REST gateway expects. Passhttp_keyto call an RPC without a player session.
Usage examples (what to ask Claude)
"Search Nakama for how to ban an account, then ban user
<uuid>.""List the 10 most recent players whose username contains
test.""Show me server status and current latency."
"Authenticate as device
demo-1, then write a storage object in collectionsaves.""Call the
healthcheckRPC."
Testing against a real Nakama
A docker-compose.yml (Nakama 3.37.0 + CockroachDB) and a live integration test are included.
docker compose up -d # start Nakama + DB (wait until healthy)
npm run build
npm run test:integration # drives the MCP server over stdio against the live server
docker compose down -v # stop and wipeThe test exercises the full path end to end: tools/list, console auto-login + status,
list accounts, player device authentication, GetAccount, and a storage write/read round-trip.
It prints a PASS/FAIL summary and exits non-zero on any failure, so it is CI-friendly.
Set VERBOSE=1 to see server logs. It honors the same NAKAMA_* env vars as the server
(defaults already match the bundled compose).
Continuous integration
.github/workflows/ci.yml runs on every push and PR:
smoke —
npm ci→ build →npm run test:resolve+npm run test:redact+npm run test:smoke(unit + protocol surface; no Nakama). Fast.integration — boots Nakama + CockroachDB with
docker compose up --wait, then runsnpm run test:integration, dumps server logs on failure, and tears down.
Run the same checks locally:
npm test # resolver + smoke, no server needed
npm run test:integration # needs `docker compose up -d`Regenerating the API catalog
The bundled data/catalog.json is generated from Nakama's upstream OpenAPI (Swagger 2.0) specs.
regen-catalog also resolves request-body $refs into inline field schemas, so nakama_search_actions
shows Claude the exact fields (name, type, required, description — including nested objects) each POST/PUT body expects.
Run it on your machine (needs network) to refresh and fully enrich the catalog:
npm run regen-catalog # uses master
npm run regen-catalog -- v3.37.0 # a specific git ref/tagThe resolver is covered by a unit test (npm run test:resolve).
Install as a desktop extension (MCPB)
For zero-prerequisite installs (no Node, no npm, no build), package the server as an
MCPB bundle and install the single file.
npm run mcpb # builds mcpb-build/ and packs dist-mcpb/nakama-mcp.mcpbnpm run mcpb runs two steps you can also run separately:
npm run mcpb:build— type-checks, bundles the server with esbuild intomcpb-build/server/index.mjs, and stagesmanifest.json+data/catalog.json.npm run mcpb:pack— packsmcpb-build/intodist-mcpb/nakama-mcp.mcpb(validates the manifest). A plaincd mcpb-build && zip -r ../dist-mcpb/nakama-mcp.mcpb .also works.
Then drag dist-mcpb/nakama-mcp.mcpb onto Claude Desktop to install. The installer prompts for
the connection settings declared in manifest.json (host, ports, HTTPS, server key, console
username/password); the server key and console password are stored in the OS keychain.
MCPB is the right choice when Nakama runs on the user's own machine/localhost. If you target a shared or cloud Nakama, a remote HTTP server is the better distribution path (see below).
Distribution / upgrade path
This is a local stdio server — the fastest shape to prototype and run against your own Nakama. For wider distribution to people who don't have Node set up, the recommended next steps are:
MCPB bundle — package the server with its Node runtime so it installs without prerequisites (best when it still needs to reach a Nakama the user runs locally).
Remote streamable-HTTP — host it once behind a URL (best if it targets a shared/cloud Nakama); add OAuth there if needed.
The tool layer and Nakama client are transport-agnostic, so moving to either is mostly swapping StdioServerTransport in src/index.ts.
License
Apache-2.0. Nakama is a trademark of Heroic Labs; this is an independent integration.
Maintenance
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/mlger/nakama-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server