ADT MCP Server
An MCP server for ABAP Development Tools (ADT) that exposes various ABAP repository-read tools over a standardized interface.
ADT MCP Server
This repository provides a Model Context Protocol (MCP) server for ABAP Development Tools (ADT), exposing various ABAP repository-read tools (program, class, function, include, interface, structure, table, where-used, etc.) over a standardized MCP interface.
π Now includes SAP BTP (Business Technology Platform) support with JWT authentication and service key utilities!
π Quick Start: See QUICK_START.md for immediate setup instructions.
π Client Connections: See MCP_CLIENT_CONNECTIONS.md for connecting to Cline, Claude Desktop, and other MCP clients.
π Documentation: Complete documentation is available in the doc/ folder.
Prerequisites
- Python 3.9+
- pip (the Python package installer)
- A running SAP ABAP system with ADT services enabled
- A
.envfile in the project root with your SAP connection settings (see below)
Setup
-
Clone the repository
git clone https://github.com/<your-org>/<your-repo>.git cd <your-repo>Note: The MCP server can now be run from any directory, not just the project directory. See REMOTE_CONNECTION_GUIDE.md for details.
Transport Options: The server supports multiple transport protocols: STDIO (default), SSE, and Streamable HTTP.
-
Create and activate a virtual environment
python -m venv .venv source .venv/bin/activate # Linux/macOS .\.venv\Scripts\activate # Windows -
Install dependencies
pip install mcp "mcp[cli]"Then install:
pip install -r requirements.txt -
Configure environment variables
Copy the example
.env.exampleto.envand fill in your SAP credentials:For On-Premise Systems (Basic Authentication)
SAP_AUTH_TYPE=basic SAP_URL=https://my.sap.system:443 SAP_CLIENT=100 SAP_USER=YOUR_USER SAP_PASS=YOUR_PASS SAP_VERIFY_SSL=true # Optional timeout configuration (in seconds) SAP_TIMEOUT_DEFAULT=45 # Default timeout (45 seconds) SAP_TIMEOUT_CSRF=15 # CSRF token timeout (15 seconds) SAP_TIMEOUT_LONG=60 # Long operations timeout (60 seconds)For BTP Systems (JWT Authentication)
SAP_AUTH_TYPE=jwt SAP_URL=https://your-system.abap.region.hana.ondemand.com SAP_JWT_TOKEN=eyJhbGciOiJSUzI1NiIsImp... SAP_VERIFY_SSL=true # Optional timeout configuration (in seconds) SAP_TIMEOUT_DEFAULT=45 # Default timeout (45 seconds) SAP_TIMEOUT_CSRF=15 # CSRF token timeout (15 seconds) SAP_TIMEOUT_LONG=60 # Long operations timeout (60 seconds)π‘ Tip: Use the included BTP utilities to generate .env files from service keys automatically!
π BTP Integration
This server now includes comprehensive SAP BTP support with:
- JWT Token Authentication for BTP ABAP systems
- Service Key Parsing and analysis
- Automatic .env Generation from BTP service keys
- CLI Utility for easy configuration management
Quick BTP Setup
- Download your service key from BTP cockpit
- Generate .env file using the CLI utility:
python btp_env_generator.py --service-key service-key.json --username [email protected] --prompt-password - Use the generated .env file in your project
For complete BTP integration details, see BTP_INTEGRATION_GUIDE.md.
Available Tools
ABAP Repository Tools
get_program_source_mcpβ Retrieve ABAP program sourceget_class_source_mcpβ Retrieve ABAP class sourceget_function_group_source_mcpβ Retrieve function group sourceget_function_source_mcpβ Retrieve function module sourceget_include_source_mcpβ Retrieve include sourceget_interface_source_mcpβ Retrieve interface sourceget_structure_source_mcpβ Retrieve structure definitionget_table_source_mcpβ Retrieve table definitionget_table_contents_mcpβ Fetch table data (max rows default 100)get_package_structure_mcpβ Retrieve package metadataget_type_info_mcpβ Retrieve type informationget_transaction_properties_mcpβ Retrieve transaction propertiesget_search_objects_mcpβ Quick search for repository objectsget_usage_references_mcpβ Retrieve whereβused references for any objectget_cds_source_mcpβ Retrieve CDS view sourceget_metadata_extension_source_mcpβ Retrieve metadata extension sourceget_sql_query_mcpβ Execute freestyle SQL queriesget_enhancements_mcpβ Discover enhancement implementations
π BTP Tools
generate_env_from_service_key_file_mcpβ Generate .env from service key filegenerate_env_from_service_key_json_mcpβ Generate .env from service key JSONparse_btp_service_key_mcpβ Parse and analyze service keysget_btp_connection_status_mcpβ Check current BTP configuration
Troubleshooting
"MCP error -32000: Connection closed" Error
If you get this error when connecting from another directory:
-
Make sure you use the full path to the server:
python /full/path/to/mcp-adt/mcp_server.py -
Check MCP client configuration:
{ "mcpServers": { "adt-server": { "command": "python", "args": ["/full/path/to/mcp-adt/mcp_server.py"] } } } -
Run connection test:
python /path/to/mcp-adt/test_remote_connection.py -
Check logs:
- Log file is created in project directory:
mcp_server.log - Check for import or configuration errors
- Log file is created in project directory:
Other Common Issues
- ModuleNotFoundError: Make sure all dependencies are installed:
pip install -r requirements.txt - .env file issues: File is automatically searched in project directory
- Permission issues: On Linux/macOS you may need
chmod +x mcp_server.py
For detailed information see REMOTE_CONNECTION_GUIDE.md
License
Related Servers
Scout Monitoring MCP
sponsorPut performance and error data directly in the hands of your AI assistant.
Alpha Vantage MCP Server
sponsorAccess financial market data: realtime & historical stock, ETF, options, forex, crypto, commodities, fundamentals, technical indicators, & more
DevCycle
Turn your favourite AI tool into a feature management assistant. DevCycle's MCP works with your favourite coding assistant so you can create and monitor feature flags using natural language right in your workflow.
Frame0 MCP Server
Create and modify wireframes in the Frame0 app through natural language prompts.
MagicPod
A server for integrating with MagicPod, an AI-powered test automation platform.
Authless Remote MCP Server
An example of a remote MCP server deployable on Cloudflare Workers without authentication.
Azure DevOps
Interact with Azure DevOps Work Items using the Azure DevOps REST API.
Claude Code Buddy (CCB)
Add persistent project memory and smart task routing to Claude Code. Stop repeating context every session - Claude finally remembers your architecture, decisions, and patterns forever. 100% local, 17 MCP tools.
kemdiCode MCP
kemdiCode MCP is a Model Context Protocol server that gives AI agents and IDE assistants access to 124 specialized tools for code analysis, generation, git operations, file management, AST-aware editing, project memory, cognition & self-improvement, multi-board kanban, and multi-agent coordination.
Genetic Algorithm MCP
A server that uses a Genetic Algorithm to solve maximization problems.
Creatify
MCP Server that exposes Creatify AI API capabilities for AI video generation, including avatar videos, URL-to-video conversion, text-to-speech, and AI-powered editing tools.
Second Opinion
Review commits and codebases using external LLMs like OpenAI, Google Gemini, and Mistral.