Skip to main content
Glama

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 via GmatConsole and 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 (cumulative ElapsedSecs, no parentheses in conditionals, Propagate Synchronized for 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 in data/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@10 per package.json)

  • A local GMAT install (R2025a tested) — for the runGmat and sample tools

  • An OpenAI API key — only if you want to rebuild the docs-search cache from scratch; the repo ships a prebuilt data/embeddings.json and queries are embedded with a local model

Related MCP server: Godot MCP

Quick Start

  1. Clone the repo

git clone https://github.com/ginomoretta-creator/gmat-mcp-server.git
cd gmat-mcp-server
  1. Install dependencies

pnpm install
  1. Configure environment Create a .env.local at the repo root pointing at your GMAT install:

echo "GMAT_BIN=C:\Path\To\GMAT_R2025a\bin" > .env.local

See .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.

  1. Build the project

pnpm build
  1. (Optional) Rebuild the docs cache from the live docs — requires OPENAI_API_KEY in .env.local; skip this to use the prebuilt cache

pnpm run setup
  1. Start the MCP server

pnpm start

The 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-node

  • pnpm 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 -- --force

Environment Variables

  • GMAT_BIN (required for runGmat/samples): GMAT bin folder containing GmatConsole(.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 test to use pages-test.json during setup

  • MCP_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_PORT to decide which port to listen on.

Files read for env values:

  • Setup reads both .env and .env.local

  • Runtime reads .env.local (via pnpm 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 start

Your 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.js

Note: 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 via GmatConsole.exe and returns { ok, stage, errors, reports, raw_tail }. stagecompleted | 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 .script names (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 -- --force

  • To 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) with OPENAI_API_KEY

  • Cache not found at data/embeddings.json. Run setup first.

    • Run pnpm build && pnpm run setup to generate the cache

  • Network timeouts while scraping

    • The scraper retries with exponential backoff; rerun setup or adjust your network

  • MCP client can’t see tools

    • Ensure the server is started from the project directory and connected via stdio

    • Confirm pnpm start logs 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 server

License

ISC

A
license - permissive license
-
quality - not tested
B
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/ginomoretta-creator/gmat-mcp-server'

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