Genexus MCP

GeneXus 18 MCP server for Claude, Cursor, and AI agents — read, edit, analyze KB objects (transactions, web panels, procedures, SDTs) over the Model Context Protocol.

GeneXus MCP Server — GeneXus 18 for Claude, Cursor, and AI Agents

npm version npm downloads License: MIT SafeSkill 85/100 MCP Badge

¿Hablás español?Guía de inicio en español Stuck?Troubleshooting guide


GeneXus MCP Server lets AI agents — Claude Desktop, Claude Code, Cursor, Antigravity, and any MCP-compatible client — read, edit, analyze, and refactor objects inside a GeneXus 18 Knowledge Base. It talks to the native GeneXus SDK, so the agent works with the real KB, not a copy or a parsed approximation.

In practice: you point the MCP at your KB, then ask your AI assistant things like "list all transactions with attribute CustomerId", "add a rule to the Order transaction that validates the total", or "refactor this procedure to use the new SDT" — and it does it.


Prerequisites

Before you start, make sure you have:

  • Windows (GeneXus is Windows-only — this MCP runs on Windows)
  • GeneXus 18 installed locally (usually C:\Program Files (x86)\GeneXus\GeneXus18)
  • A GeneXus 18 Knowledge Base opened at least once in the IDE (so it has been built/initialized)
  • Node.js 18+ (download)
  • An MCP-compatible AI clientClaude Desktop, Claude Code, Cursor, Antigravity, etc.

You do not need to clone this repo or install anything globally — npx handles it.


Quickstart (3 steps)

Step 1 — Run the installer

Open a terminal and run, replacing the paths with your KB folder and your GeneXus install:

npx genexus-mcp@latest init --kb "C:\KBs\YourKB" --gx "C:\Program Files (x86)\GeneXus\GeneXus18"

Prefer the wizard? Run npx genexus-mcp@latest init --interactive and answer the prompts.

When it finishes you should see 🎉 You are all set! plus a JSON snippet for your AI client.

Step 2 — Register the MCP in your AI client

The installer auto-registers the server with Claude Desktop, Claude Code, Cursor, and Antigravity when it detects them. If yours wasn't detected, copy the JSON snippet from Step 1 into your client's MCP config manually. See the client setup guide if unsure where that file lives.

Step 3 — Restart your AI client and test

Fully close and reopen Claude / Cursor / etc. Then try this prompt:

"Using the GeneXus MCP, list the first 5 transactions in my KB and show their names."

If you get a list back — you're done. Skip to What can I ask the AI? for ideas.

If something didn't work, go straight to Troubleshooting — most issues are covered there.


🤖 Let your AI install it for you

If you'd rather not run anything in the terminal yourself, paste this into your AI chat:

Please configure the GeneXus MCP server. Run npx genexus-mcp@latest init --kb "<MY_KB_PATH>" --gx "<MY_GENEXUS_PATH>" in the terminal. If I haven't told you my GeneXus path and KB path yet, ask me first. Once it succeeds, read the JSON block it printed and add it to my MCP client config. Tell me when I should restart the client to start using GeneXus tools.

Replace the placeholders or let the AI ask you for them.


Corporate install (fixed path, ASR-friendly)

If your machine has Microsoft Defender ASR, SmartScreen, or another endpoint policy blocking unsigned binaries, the default npx flow is painful — npx caches the package under %LOCALAPPDATA%\npm-cache\_npx\<hash>\..., and the <hash> changes per version, so IT can't whitelist a stable path without a wildcard over the whole npm cache (which is too broad).

Use the corporate installer instead. It extracts the binaries to a stable directory and registers the AI clients to launch the gateway directly from there — npx is never on the runtime path.

# One-liner — installs latest release, registers AI clients
iex (irm https://raw.githubusercontent.com/lennix1337/Genexus18MCP/main/scripts/install.ps1)

# With explicit KB and GeneXus paths
$s = irm https://raw.githubusercontent.com/lennix1337/Genexus18MCP/main/scripts/install.ps1
& ([scriptblock]::Create($s)) -Kb "C:\KBs\MyKB" -Gx "C:\Program Files (x86)\GeneXus\GeneXus18"

Install location:

  • Admin shellC:\Tools\GenexusMCP\
  • Non-admin shell%LOCALAPPDATA%\Programs\GenexusMCP\

Paths to give to IT for the ASR / Defender exclusion list:

<InstallDir>\GxMcp.Gateway.exe
<InstallDir>\worker\GxMcp.Worker.exe

Re-run the same one-liner later to upgrade — it detects the installed version (version.txt in the install dir) and downloads only if a newer release is available. Use -Force to reinstall the same version, -Version v2.3.0 to pin a specific tag, -NoClient to skip AI client registration. Node.js 18+ must be installed for client registration; without it the script still extracts the binaries but you'll need to edit the client config (claude_desktop_config.json etc.) manually.


What can I ask the AI?

Once installed, here's what unlocks. Try these as your first prompts:

Exploration

  • "List all objects of type Procedure in the KB."
  • "Show me the source of the procedure CalculateInvoiceTotal."
  • "Find all transactions that reference the attribute CustomerId."

Editing

  • "Add a rule to the Order transaction: error('Total must be positive') if Total < 0."
  • "Add a new attribute CreatedAt of type DateTime to the Customer transaction."
  • "Rename the variable &qty to &quantity in procedure CreateOrder."

Analysis

  • "Explain what the procedure ProcessShipment does, step by step."
  • "What SQL does the query in WebPanel CustomerList generate?"
  • "Summarize the structure of the Sales module."

Build & lifecycle

  • "Build the KB and report any errors."
  • "Run the unit tests and show me which failed."

The agent picks the right tool from the 30+ tools the MCP exposes (read, edit, refactor, analyze, build, layout automation, history, SQL preview, etc.). The full tool list is in Tool Surface below.


Supported AI clients

Auto-detected and auto-configured by the installer:

ClientAuto-configNotes
Claude DesktopRestart required after install
Claude Code (CLI)Reload session
CursorRestart required
AntigravityRestart required
Any MCP clientManualUse the JSON snippet printed by init

Troubleshooting

Most install issues fall into a handful of buckets — see TROUBLESHOOTING.md for fixes:

  • Installer can't find GeneXus or the KB
  • AI client doesn't see the GeneXus tools after restart
  • "Worker failed to start" / .NET 4.8 errors
  • KB build errors / locked artifacts
  • Port 5000 already in use
  • Permissions on %LOCALAPPDATA%\GenexusMCP\

Still stuck? Open an issue with the output of npx genexus-mcp doctor --mcp-smoke.


Tool Surface

The worker exposes these tool families to the MCP router. (Detailed schemas in GEMINI.md.)

  • Search & Discoverygenexus_query, genexus_read, genexus_inspect, genexus_list_objects, genexus_properties
  • Editing & Architecturegenexus_edit, genexus_create_object, genexus_delete_object, genexus_refactor, genexus_forge, genexus_add_variable
  • Analysisgenexus_analyze (modes: linter, navigation, hierarchy, impact, data_context, ui_context, pattern_metadata, summary, explain), genexus_inject_context, genexus_doc, genexus_search_source
  • File System & Assetsgenexus_asset, genexus_export_object, genexus_import_object
  • History & DBgenexus_history, genexus_sql (action=ddl or action=navigation), genexus_structure
  • Lifecycle & Buildgenexus_lifecycle, genexus_test, genexus_format
  • Native Layout SDKgenexus_layout (get_tree, find_controls, set_property, rename_printblock, add_printblock, get_preview, …)
  • KB pool (v2.3.0+)genexus_kb (list, open, close, set_default) for multi-KB parallel work
  • Patterns — Smart XML generation/interpretation (e.g., WorkWithPlus PatternInstance).

Multi-KB (v2.3.0+): every non-meta tool takes an optional kb argument (alias or absolute path). The gateway can hold up to Server.MaxOpenKbs (default 3) KBs open at once, each in its own Worker process — calls to different KBs run truly in parallel. See Advanced Configuration for the KBs[] schema.

Edit modes (genexus_edit): xml (full replacement, default), ops (typed semantic ops like set_attribute, add_rule), patch (JSON-Patch RFC 6902).

Safe by default: all write tools accept dryRun: true (returns a preview without mutating the KB) and idempotencyKey (safe retries; concurrent calls coalesce, results cached 15 min).


AXI CLI (for agents and automation)

The genexus-mcp command itself is also an agent-facing CLI with token-optimized output:

genexus-mcp status               # gateway/worker state
genexus-mcp doctor --mcp-smoke   # health check + protocol probe
genexus-mcp tools list           # list available tools
genexus-mcp config show          # current resolved config
genexus-mcp layout status        # native layout automation state

Global flags: --format toon|json|text · --fields f1,f2,... · --limit N · --query <text> · --quiet · --no-color.

Full contract: docs/axi_cli_contract.md. Best-practices playbook: docs/llm_cli_mcp_playbook.md.


Advanced Configuration

The installer writes a config.json for you. To customize networking, timeouts, or shadow paths:

{
  "Server": {
    "HttpPort": 5000,
    "BindAddress": "127.0.0.1",
    "SessionIdleTimeoutMinutes": 10,
    "WorkerIdleTimeoutMinutes": 5,
    "MaxOpenKbs": 3
  },
  "GeneXus": {
    "InstallationPath": "C:\\Program Files (x86)\\GeneXus\\GeneXus18",
    "WorkerExecutable": "worker\\GxMcp.Worker.exe"
  },
  "Environment": {
    "DefaultKb": "main",
    "KBs": [
      { "alias": "main",   "path": "C:\\KBs\\YourKB" },
      { "alias": "legacy", "path": "C:\\KBs\\OtherKB" }
    ]
  }
}

Backward compatibility: old configs with a single Environment.KBPath keep working — the gateway auto-migrates them to KBs[] + DefaultKb at load time.

Working with multiple KBs

Once you declare more than one KB in Environment.KBs[], every tool accepts an optional kb argument:

// LLM example: list procedures in two KBs in parallel
{ "tool": "genexus_list_objects", "arguments": { "kb": "main",   "type": "Procedure" } }
{ "tool": "genexus_list_objects", "arguments": { "kb": "legacy", "type": "Transaction" } }

Resolution rules when kb is omitted:

  • exactly 1 KB open → uses that KB
  • 0 KBs open + DefaultKb set → opens DefaultKb lazily
  • 2+ KBs open → server returns KB_AMBIGUOUS and you must pass kb explicitly

Manage the pool at runtime:

{ "tool": "genexus_kb", "arguments": { "action": "list" } }
// → { openKbs: [{alias, path, pid, workingSetMB, idleSeconds}], maxOpenKbs, defaultKb, declaredKbs }

{ "tool": "genexus_kb", "arguments": { "action": "open", "alias": "adhoc", "path": "C:/KBs/ScratchKB" } }
{ "tool": "genexus_kb", "arguments": { "action": "close", "alias": "legacy" } }
{ "tool": "genexus_kb", "arguments": { "action": "set_default", "alias": "main" } }   // persists to config.json

When the pool is full and no Worker is idle, the server returns KB_POOL_FULL — close one explicitly or raise Server.MaxOpenKbs. Each Worker carries the SDK in its own process (~200–400 MB idle, up to 1–2 GB on heavy KBs), so size the pool against available RAM.

Architecture

graph LR
    A[AI Client / Nexus-IDE] -->|MCP stdio or HTTP /mcp| B[Gateway .NET 8]
    B -->|JSON-RPC over process boundary| C[Worker .NET Framework 4.8]
    C -->|Native SDK| D[GeneXus KB]
  • Worker pool (v2.3.0+): one .NET 4.8 Worker process per open KB, capped by MaxOpenKbs (default 3). Workers are spawned lazily, recycled by WorkerIdleTimeoutMinutes, and evicted LRU when the pool is full.
  • Cross-KB parallelism: tool calls to different KBs run on different Worker processes and never block each other. Calls to the same KB are still serialized by the GeneXus SDK's STA requirement.
  • Gateway reuse: multiple IDE instances share one gateway via lease files at %LOCALAPPDATA%\GenexusMCP\gateway-leases.
  • HTTP mode: also available at http://127.0.0.1:5000/mcp with SSE. Header: MCP-Protocol-Version: 2025-11-25.

Development & building from source

Want to contribute or run a local dev build?

  1. Clone this repo on Windows.
  2. Run .\setup.bat — checks prerequisites, builds the C# components, and auto-registers the local build with detected AI clients.
  3. If GeneXus or your KB aren't auto-detected, follow the prompts.

Bundled AI skills (.gemini/skills/)

This repo ships a set of agent skills under .gemini/skills/ that any MCP-compatible client with skill support (Gemini CLI, Claude Code via plugin, etc.) can load to ground its GeneXus reasoning:

SkillWhat it gives the agent
genexus-masteryThis repository's preferred MCP workflow + multi-KB usage
genexus18-guidelinesLocal engineering rules layered on top of Nexa
nexaFull GeneXus 18 reference set: every object type, command, type, property — imported from the official genexuslabs/genexus-skills
frontend/chameleon-controls-library58 Chameleon UI component specs
frontend/mercury-design-systemMercury tokens, bundles, theming
frontend/design-system-builderAuthoring custom design systems
frontend/ui-creatorPanel/screen generation templates

Third-party skills are Apache 2.0 (see .gemini/skills/NOTICE.md). To refresh against upstream, follow the steps in NOTICE.md.

Nexus-IDE (VS Code extension)

src/nexus-ide is a lightweight VS Code extension that ships with the repo:

  • Virtual filesystem using the genexus:// scheme
  • Dynamic KB explorer with multi-part editing (Source, Rules, Events, Variables)
  • Built-in MCP discovery commands (tools, resources, prompts)

Automated release

  • Workflow: .github/workflows/release.yml
  • Trigger: push to main with a package.json version bump
  • Behavior: publishes to npm if version is new + creates a GitHub Release tagged v<version>
  • Required secret: NPM_TOKEN

License

MIT — see LICENSE.

Search keywords: GeneXus MCP · GeneXus 18 MCP · GeneXus AI · GeneXus Claude · Model Context Protocol GeneXus · GeneXus low-code AI agent · GeneXus Cursor · GeneXus Antigravity

İlgili Sunucular

NotebookLM Web Importer

Web sayfalarını ve YouTube videolarını tek tıkla NotebookLM'e aktarın. 200.000'den fazla kullanıcı tarafından güveniliyor.

Chrome Eklentisini Yükle