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
¿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 client — Claude 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 --interactiveand 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 shell →
C:\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."
WorkWithPlus pattern editing (full structural + theming control)
- "In WorkWithPlusOrder, add a 'Duplicate' button to the transaction view alongside Save/Cancel/Delete."
- "Group the Customer transaction attributes into a 'Contact Info' section with theme class GroupTelaResp."
- "On the WorkWithPlusInvoice list, add a new ordering by InvoiceDate descending."
- "Style the Save button on WorkWithPlusOrder with buttonClass='btn ButtonGreen' and apply BigTitle to the form header."
- "Remove the Export action from the Selection grid of WorkWithPlusReport."
- "Read the Documentation part of the transaction Customer and rewrite it in markdown."
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:
| Client | Auto-config | Notes |
|---|---|---|
| Claude Desktop | ✅ | Restart required after install |
| Claude Code (CLI) | ✅ | Reload session |
| Cursor | ✅ | Restart required |
| Antigravity | ✅ | Restart required |
| Any MCP client | Manual | Use 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 & Discovery —
genexus_query,genexus_read,genexus_inspect,genexus_list_objects,genexus_properties - Editing & Architecture —
genexus_edit,genexus_create_object,genexus_delete_object,genexus_refactor,genexus_forge,genexus_add_variable - Analysis —
genexus_analyze(modes:linter,navigation,hierarchy,impact,data_context,ui_context,pattern_metadata,summary,explain),genexus_inject_context,genexus_doc,genexus_search_source - File System & Assets —
genexus_asset,genexus_export_object,genexus_import_object - History & DB —
genexus_history,genexus_sql(action=ddloraction=navigation),genexus_structure - Lifecycle & Build —
genexus_lifecycle,genexus_test,genexus_format - Native Layout SDK —
genexus_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 - WorkWithPlus pattern editing — full read/write of
PatternInstanceandPatternVirtualparts viagenexus_read/genexus_edit. Supports the entire pattern XML surface: containers (<table>, groups), controls (<textBlock>,<errorViewer>,<attribute>,<gridAttribute>,<filterAttribute>), actions (<standardAction>,<userAction>), grids, orders, rules, and event blocks. Both Transaction and Selection views are addressable independently (XPath/instance/transaction/...vs/instance/level/selection/...). - Documentation & Help parts —
Documentation(rich text / markdown) andHelp(HTML) are now first-class write targets viagenexus_edit(fixed in v2.4.4 — both parts had a silent no-op bug previously). - Theme classes & styling — apply real ThemeClass values (
themeClass,buttonClass,groupThemeClass,cellThemeClass, etc) so generated screens use the KB's design system. Discover the available classes withgenexus_list_objects --typeFilter ThemeClass --nameFilter <Button|TextBlock|Title>and apply them in the pattern XML.
Multi-KB (v2.3.0+): every non-meta tool takes an optional
kbargument (alias or absolute path). The gateway can hold up toServer.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 theKBs[]schema.
Edit modes (genexus_edit): full (whole-part replacement, default), patch (Replace/Insert_After/Append over a context anchor — works on source code AND pattern XML), ops (typed semantic ops like set_attribute, add_rule for source-bearing parts).
Pattern XML auto-reconcile: WorkWithPlus encodes IDE rendering order in a per-parent childrenOrderedList attribute. The MCP now rebuilds (and creates if missing) every list from the actual XML child order on each write — callers only describe where an element goes in the tree and the MCP makes the IDE render it there. The response includes a childrenOrderedListReconciliation block listing each (re)written parent plus any structural elements that couldn't be inferred safely.
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).
WorkWithPlus pattern editing — what you can actually do
WorkWithPlus patterns are XML documents that drive Transaction-and-Selection screens. The MCP exposes the entire surface so an agent can design or restructure a screen without opening the IDE:
| Capability | Tool / pattern | Status |
|---|---|---|
Read PatternInstance / PatternVirtual XML | genexus_read --part PatternInstance | ✅ |
Replace whole pattern (mode: full) | genexus_edit --mode full --part PatternInstance | ✅ verified live |
Find/replace text-style patches (mode: patch) | genexus_edit --mode patch --part PatternInstance --operation Replace | ✅ verified live |
| Add / remove / reorder structural elements (textBlock, attribute, standardAction, table-as-group, order, filterAttribute, gridAttribute, eventBlock…) | XML edit + auto-reconcile | ✅ verified live |
Theme classes (themeClass, buttonClass, groupThemeClass, cellThemeClass, format="HTML") | XML attribute on the element | ✅ verified live |
| Reorganize Transaction view (form layout, action row) | edit under /instance/transaction/... | ✅ verified live |
| Reorganize Selection view (list/grid, filters, orders) | edit under /instance/level/selection/... | ✅ verified live |
Auto-rebuild childrenOrderedList from XML order | done implicitly on every write; report under childrenOrderedListReconciliation | ✅ verified live |
Recommended workflow for a screen redesign:
genexus_list_objects --typeFilter ThemeClass --nameFilter Button— discover the actual button classes available in this KB (ButtonGreen,ButtonBlue,ButtonRed, etc — names vary per KB).genexus_read --name WorkWithPlus<Object> --part PatternInstance— get the current XML.- Edit the XML in memory (LLM): wrap attributes in a
<table isGroup="True" title="…" groupThemeClass="GroupTelaResp">, reorder buttons, add a new<standardAction>, attachbuttonClass="btn ButtonGreen", etc. genexus_edit --mode full --part PatternInstance --content "<new xml>"— the MCP rewrites the part, reconcileschildrenOrderedListon every container, and verifies the round-trip.- Read back to confirm; refresh the GeneXus IDE to see the result.
Custom buttons use <userAction>, not <standardAction>. Trn_Enter / Trn_Cancel / Trn_Delete are the only registered standard actions on a WorkWithPlus transaction; any custom button (Duplicate, Audit, Export, etc.) must be a <userAction caption="…" name="…" buttonClass="btn ButtonGreen" confirm="False" />. The MCP's reconciler treats <userAction> as a peer of <standardAction> (same typeCode 17/18 by context), so they coexist in the same TableActions row and the IDE renders them side-by-side.
Things to know (orientation, not gotchas):
- WorkWithPlus normalizes some attributes after every save. Certain fields are bound to the underlying transaction (e.g.,
titleon top-level groups derives from the transaction's friendly name). When"Apply this pattern on save"is enabled on the WorkWithPlus object, the engine recomputes those fields — same behavior whether you edit in the IDE or via MCP. To make a hard override stick, toggle that flag via MCP:
Accepts{ "tool": "genexus_properties", "arguments": { "action": "set", "name": "WorkWithPlus<Object>", "propertyName": "SDPlus_Editor_Apply_On_Save", "value": "False" } }"True" | "False" | "Default"(Default inherits the KB-level setting). Set back to"Default"to re-enable engine recomputation. Validated live in this repo. - Structural safety is enforced by the SDK. If you submit XML that violates pattern invariants (e.g., a
<transaction>without a<level>, or a<standardAction>whosenameisn't a registered action), the SDK rejects the save and the MCP returns the exact error so you can fix the input. The KB never ends up half-written. - The IDE Pattern preview is a structural mockup, not a styled render. Theme CSS (
buttonClass,themeClass, fonts, colors) is resolved at runtime, not in the preview canvas — so even after a successful MCP write the preview pane will look generic. To verify styling: open the element in the IDE tree and check the right-hand Properties panel (the applied classes show there), or hit Run / Live Editing to see the real CSS. This is GeneXus IDE behavior, independent of how the pattern was edited.
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.KBPathkeep working — the gateway auto-migrates them toKBs[]+DefaultKbat 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 +
DefaultKbset → opensDefaultKblazily - 2+ KBs open → server returns
KB_AMBIGUOUSand you must passkbexplicitly
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 byWorkerIdleTimeoutMinutes, 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/mcpwith SSE. Header:MCP-Protocol-Version: 2025-11-25.
Development & building from source
Want to contribute or run a local dev build?
- Clone this repo on Windows.
- Run
.\setup.bat— checks prerequisites, builds the C# components, and auto-registers the local build with detected AI clients. - 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:
| Skill | What it gives the agent |
|---|---|
genexus-mastery | This repository's preferred MCP workflow + multi-KB usage |
genexus18-guidelines | Local engineering rules layered on top of Nexa |
nexa | Full GeneXus 18 reference set: every object type, command, type, property — imported from the official genexuslabs/genexus-skills |
frontend/chameleon-controls-library | 58 Chameleon UI component specs |
frontend/mercury-design-system | Mercury tokens, bundles, theming |
frontend/design-system-builder | Authoring custom design systems |
frontend/ui-creator | Panel/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
mainwith apackage.jsonversion 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
相關伺服器
Alpha Vantage MCP Server
贊助Access financial market data: realtime & historical stock, ETF, options, forex, crypto, commodities, fundamentals, technical indicators, & more
secretctl
AI-safe secrets manager - inject credentials as env vars, AI never sees plaintext
mistaike.ai
MCP security gateway with DLP scanning (PII, secrets, API keys), prompt injection protection, Memory Vault, Bug Vault (295k+ patterns), and unified audit logging. Two endpoints: free bug search at /mcp and authenticated hub at /hub_mcp.
Angreal
An MCP server providing AI assistants with discovery capabilities for angreal projects.
Web3 MCP Server
An MCP server for interacting with Web3 and EVM-compatible chains.
Python Interpreter MCP
An MCP server that provides Python code execution capabilities through a REST API interface.
ZEN University Syllabus
An MCP server to access and utilize content from the ZEN University syllabus.
cellrank-MCP
A natural language interface for single-cell RNA sequencing (scRNA-Seq) analysis using the CellRank toolkit.
Xcode-Studio-MCP
Unified MCP server for Xcode + iOS Simulator — build, deploy, screenshot, and interact with your iOS app from Claude Code, Cursor, or any MCP client. Built in Swift. Single binary. No Node/Python runtime required.
Tickerr — Live AI Tool Status & API Pricing
Real-time status monitoring, uptime tracking, incident history, and API pricing for 42+ AI tools including ChatGPT, Claude, Gemini, Cursor, GitHub Copilot, Perplexity, DeepSeek, and Groq. No API key required. Data updated every 5 minutes from independent monitoring infrastructure.
Dart MCP
An example MCP server built with Dart and deployed on Cloudflare Workers.