gmat-mcp-server
Provides tools to interact with NASA's General Mission Analysis Tool (GMAT), enabling AI agents to run mission scripts, retrieve curated knowledge of GMAT idioms, list and fetch sample scripts, and search GMAT documentation for autonomous mission design and validation.
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., "@gmat-mcp-serverwrite a GMAT script for a two-burn phasing rendezvous and run it"
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.
GMAT MCP Server
An MCP (Model Context Protocol) server that turns NASA's GMAT (General Mission Analysis Tool) into a tool an AI agent can actually use — not just talk about. Any MCP client (Claude Code, Claude Desktop, Cursor, custom apps) gets:
runGmat— the validation loop. Runs a GMAT mission script headless viaGmatConsoleand returns a classified outcome (completed | parse | convergence | run) with extracted errors and report-file contents. The agent writes a script, runs it, reads what broke, and fixes it — the same loop a mission designer uses.getGmatIdioms— curated knowledge. A hand-built knowledge base of GMAT gotchas discovered through that loop (cumulativeElapsedSecs, no parentheses in conditionals,Propagate Synchronizedfor two-spacecraft burns, …), so the agent stops making the classic mistakes.listGmatSamples/getGmatSample— known-good templates. The NASA sample-script corpus as a retrieval source for vetted mission patterns.searchDocs— semantic search over the GMAT documentation, embedded locally and cached indata/embeddings.json.
Example of what this enables: asked for a two-burn phasing rendezvous (700 km circular orbit, 30° separation), the agent derived the textbook solution, verified it exactly under two-body dynamics, discovered it misses by 47 km under J2 gravity by actually running it, and re-targeted the burns with GMAT's differential corrector to converge at 2.96 km — autonomously, in a handful of tool calls.
Requirements
Node.js 18+ (ESM)
pnpm (project uses
pnpm@10perpackage.json)A local GMAT install (R2025a tested) — for the
runGmatand sample toolsAn OpenAI API key — only if you want to rebuild the docs-search cache from scratch; the repo ships a prebuilt
data/embeddings.jsonand queries are embedded with a local model
Related MCP server: Godot MCP
Quick Start
Clone the repo
git clone https://github.com/ginomoretta-creator/gmat-mcp-server.git
cd gmat-mcp-serverInstall dependencies
pnpm installConfigure environment Create a
.env.localat the repo root pointing at your GMAT install:
echo "GMAT_BIN=C:\Path\To\GMAT_R2025a\bin" > .env.localSee .env.example for all variables. The server loads .env.local / .env from the repo root automatically, so it works even when an MCP client spawns it with an empty environment.
Build the project
pnpm build(Optional) Rebuild the docs cache from the live docs — requires
OPENAI_API_KEYin.env.local; skip this to use the prebuilt cache
pnpm run setupStart the MCP server
pnpm startThe server runs over stdio and exposes the searchDocs tool to your MCP client.
Scripts
pnpm build: compile TypeScript to
dist/pnpm start: run server from
dist/index.js(loads.env.local)pnpm dev: run server in watch mode with
ts-nodepnpm run setup: build cache from live docs (requires OpenAI API key)
pnpm run setup:test: build a smaller test cache using
pages-test.json
Pass --force to setup to rebuild the cache from scratch:
pnpm run setup -- --forceEnvironment Variables
GMAT_BIN (required for
runGmat/samples): GMATbinfolder containingGmatConsole(.exe)GMAT_SAMPLES (optional): samples dir (default:
<GMAT_BIN>\..\samples)GMAT_IDIOMS (optional): idioms file (default:
./data/gmat_idioms.md)OPENAI_API_KEY (setup only): used to rebuild the docs-embedding cache
CACHE_DIR (optional): directory for
embeddings.json(default:./data)BASE_URL (optional): docs base URL (default:
https://documentation.help/gmat/)NODE_ENV (optional): set to
testto usepages-test.jsonduring setupMCP_PORT (optional): for wrappers/adapters that expose this stdio server via TCP/SSE. This server itself communicates over stdio and does not bind to a port; some clients or adapters may read
MCP_PORTto decide which port to listen on.
Files read for env values:
Setup reads both
.envand.env.localRuntime reads
.env.local(viapnpm start) or your shell env
Using with MCP Clients
Claude Code
claude mcp add gmat -- node C:\path\to\gmat-docs-mcp-server\dist\index.js(.env.local at the repo root is picked up automatically.)
Other stdio clients
This server communicates via stdio. Point your MCP client to execute the server in your project directory. Two common approaches:
Option A: Use the start script
pnpm startYour MCP client should spawn this command in the repo root (ensures .env.local is picked up).
Option B: Use the wrapper
There is a convenience wrapper that ensures env loading, then starts the compiled server:
node start-mcp.jsNote: If you run the server behind an adapter that serves MCP over SSE/TCP, you can set MCP_PORT to guide that adapter. The server code here still talks over stdio.
Tool: searchDocs
Inputs:
query(string, required)topK(number, default 10, 1–50)minScore(number, default 0.1, 0–1)
Output: formatted text with page name, source URL, similarity score, and extracted content.
GMAT copilot tools (execution + knowledge)
Beyond doc search, the server exposes the GMAT validation loop and curated knowledge so an MCP client (Claude) can write → run → diagnose → fix GMAT missions autonomously:
runGmat— runs a GMAT.script(passed as text) headless viaGmatConsole.exeand returns{ ok, stage, errors, reports, raw_tail }.stage∈completed | parse | convergence | run. Inputs:script(string, required),timeoutSec(number, default 600 — raise for multi-day low-thrust propagations). This is the closed validation loop.getGmatIdioms— returns the curated GMAT idioms/gotchas knowledge base (data/gmat_idioms.md). Read it before generating scripts to avoid common pitfalls.listGmatSamples— lists the bundled NASA sample.scriptnames (a retrieval corpus of known-good patterns).getGmatSample— returns one sample's full text by name, to seed a phase from a vetted template.
These require a local GMAT install; see GMAT_BIN / GMAT_SAMPLES / GMAT_IDIOMS in
.env.example (defaults match a standard GMAT R2025a install).
Data and Cache
Cache file:
data/embeddings.json(or${CACHE_DIR}/embeddings.json)To rebuild:
pnpm run setup -- --forceTo use a smaller test set:
pnpm run setup:test
Customizing Pages
The list of pages to scrape is defined in:
pages.json(full set)pages-test.json(smaller set for tests)
You can edit these files to change the crawl scope. The parser attempts to extract meaningful sections by headings and convert them to Markdown for embedding.
Troubleshooting
Error: OPENAI_API_KEY environment variable is required
Create
.env.local(and optionally.env) withOPENAI_API_KEY
Cache not found at data/embeddings.json. Run setup first.
Run
pnpm build && pnpm run setupto generate the cache
Network timeouts while scraping
The scraper retries with exponential backoff; rerun
setupor adjust your network
MCP client can’t see tools
Ensure the server is started from the project directory and connected via stdio
Confirm
pnpm startlogs show the server is running and the cache is loaded
Project Structure
src/
index.ts # MCP server entry (stdio)
setup.ts # Setup pipeline: scrape → parse/chunk → embed → cache
tools/ # MCP tool definitions and handlers
utils/ # scraper, parser, embedder, cache, search
data/ # Default cache directory (embeddings.json)
pages.json # Full list of pages to scrape
pages-test.json # Smaller list for testing
dist/ # Compiled JavaScript (after pnpm build)
start-mcp.js # Wrapper to load env and run the serverLicense
ISC
This server cannot be installed
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/ginomoretta-creator/gmat-mcp-server'
If you have feedback or need assistance with the MCP directory API, please join our Discord server