ARC-1
Deployable as a Cloud Foundry app on SAP BTP with full platform integration including Destination Service, Cloud Connector, Principal Propagation, XSUAA OAuth proxy, and BTP Audit Log Service.
Available as a Docker image for containerized deployment, supporting various authentication methods and enterprise security configurations.
Connects AI assistants including GitHub Copilot to SAP systems via the ADT REST API, enabling AI-assisted SAP development with enterprise security controls and guardrails.
Supports OIDC/JWT authentication via Keycloak or any OpenID Connect provider for secure enterprise authentication to SAP systems.
Supports OIDC/JWT authentication via Entra ID, Keycloak, or any OpenID Connect provider for secure enterprise authentication to SAP systems.
Enterprise-ready MCP server for SAP ABAP systems connecting to SAP via the ADT REST API, providing 11 intent-based tools for reading/writing ABAP source, table data, CDS views, executing SQL, managing transports, and performing code analysis with enterprise security controls.
Uses SQLite for object caching in http-streamable deployments, enabling automatic source caching and dependency graph caching for improved performance.
ARC-1 — SAP ADT MCP Server
ARC-1 (pronounced arc one [ɑːrk wʌn]) — Enterprise-ready MCP server for SAP ABAP systems. Secure by default, deployable to BTP or on-premise, and hardened with large unit/integration/E2E test coverage.
ARC-1 connects AI assistants (Claude, GitHub Copilot, Copilot Studio, and any MCP client) to SAP systems via the ADT REST API. It ships as an npm package and Docker image.
Full Documentation | Setup Guide | Tool Reference
Why ARC-1?
Built for organizations that need AI-assisted SAP development with guardrails. Inspired by the pioneering work of abap-adt-api, mcp-abap-adt, and vibing-steampunk — ARC-1 adds what's needed to run in production:
Security & Admin Controls
Safe by default — read-only, no free SQL, no table preview, no transports out of the box. Use
--profile developeror explicit flags to enable capabilitiesOperation allowlists/denylists — control exactly which operation types (read, write, search, query, activate, transport) are permitted
Package restrictions — limit AI write operations (create, update, delete) to specific packages with wildcards (
--allowed-packages "Z*,$TMP"). Read operations are not restricted by package — use SAP's native authorization for read-level access controlData access control — enable table data preview (
--block-data=false) or free-form SQL (--block-free-sql=false)Transport safety — require transport assignments, restrict to specific transports, or make transports read-only. Update/delete operations auto-use the lock correction number when no explicit transport is provided
Safety profiles — preconfigured roles:
viewer,viewer-data,viewer-sql,developer,developer-data,developer-sqlWrites restricted to
$TMPwhen enabled — only local/throwaway objects; writing to transportable packages requires explicit--allowed-packages
Authentication
API key — simple Bearer token for internal deployments
OIDC / JWT — Entra ID, Keycloak, or any OpenID Connect provider
OAuth 2.0 — browser-based login for BTP ABAP Environment
XSUAA — SAP BTP native auth with automatic token proxy for MCP clients
Principal Propagation — per-user identity forwarded through Cloud Connector (every SAP action runs as the actual user, not a technical account)
BTP Cloud Foundry Deployment
Deploy ARC-1 as a Cloud Foundry app on SAP BTP with full platform integration:
Destination Service — connect to SAP systems via managed destinations
Cloud Connector — reach on-premise systems through the connectivity proxy
Principal Propagation — user identity forwarded end-to-end via X.509 certificates
XSUAA OAuth proxy — MCP clients authenticate via standard OAuth, ARC-1 handles the BTP token exchange
Audit logging — structured events to stderr, file, or BTP Audit Log Service
Token Efficiency
11 intent-based tools (~5K schema tokens) instead of 200+ individual tools — keeps the LLM's context window small
Method-level read/edit — read or update a single class method, not the whole source (up to 20x fewer tokens)
Context compression —
SAPContextreturns public API contracts of all dependencies in one call (7-30x compression)
Built-in Object Caching
Automatic source caching — every SAP object read is cached in memory (stdio) or SQLite (http-streamable). Repeated reads return instantly without calling SAP.
Dependency graph caching —
SAPContextdep resolution keyed by source hash; unchanged objects skip all ADT calls on subsequent runs.Pre-warmer — start with
ARC1_CACHE_WARMUP=trueto pre-index all custom objects at startup, enabling reverse dependency lookup (SAPContext(action="usages")).Write invalidation — when
SAPWritemodifies an object, its cache entry is automatically dropped; next read fetches fresh source.
See docs/caching.md for full documentation.
Testing
1,367+ unit tests (
53unit test files, mocked HTTP)~160 integration tests against live SAP systems, with explicit skip reasons when credentials or fixtures are missing
~70 E2E tests that execute real MCP tool calls against a running ARC-1 server and live SAP system
CRUD lifecycle and BTP smoke lanes included (
test:integration:crud,test:integration:btp:smoke)CI matrix on Node
22and24; integration + E2E run onpushtomainand internal PRsReliability telemetry + coverage published as informational CI signals (non-blocking)
Tools Refined for Real-World Usage
The 11 tools are designed from real LLM interaction feedback:
Tool | What it does |
SAPRead | Read ABAP source, table data, CDS views, metadata extensions (DDLX), service bindings (SRVB), message classes, BOR objects, deployed UI5/Fiori apps (BSP, BSP_DEPLOY). Structured format for classes returns metadata + decomposed includes as JSON |
SAPSearch | Object search + full-text source code search across the system |
SAPWrite | Create/update/delete ABAP source and DDIC metadata with automatic lock/unlock (PROG, CLAS, INTF, FUNC, INCL, DDLS, DDLX, BDEF, SRVD, DOMA, DTEL). Batch creation for multi-object workflows (e.g., RAP stack or domain+data element in one call) |
SAPActivate | Activate ABAP objects — single or batch (essential for RAP stacks). Publish/unpublish OData service bindings (SRVB) |
SAPNavigate | Go-to-definition, find references, code completion |
SAPQuery | Execute ABAP SQL with table-not-found suggestions |
SAPTransport | CTS transport management (list, create, release) |
SAPContext | Compressed dependency context — one call replaces N SAPRead calls |
SAPLint | Local ABAP lint (system-aware presets, auto-fix, pre-write validation) |
SAPDiagnose | Syntax check, ABAP Unit tests, ATC code quality, short dumps, profiler traces |
SAPManage | Feature probing — detect what the system supports before acting |
Tool definitions automatically adapt to the target system (BTP vs on-premise), removing unavailable types and adjusting descriptions so the LLM never attempts unsupported operations.
Feature Detection
ARC-1 probes the SAP system at startup and adapts its behavior:
Detects HANA, abapGit, RAP/CDS, AMDP, UI5, and transport availability
Auto-detects BTP vs on-premise systems
Maps SAP_BASIS release to the correct ABAP language version
Each feature can be forced on/off or left on auto-detect
Quick Start
npx arc-1@latest --url https://your-sap-host:44300 --user YOUR_USERFor Docker, BTP deployment, client configuration (Claude Desktop, Claude Code, VS Code, Copilot Studio), and all authentication methods, see the Setup Guide.
Documentation
Full documentation is available at marianfoo.github.io/arc-1.
Guide | Description |
Deployment options, auth methods, client configuration | |
Complete reference for all 11 tools | |
System architecture with diagrams | |
Docker deployment reference | |
All authentication methods | |
Cloud Foundry deployment on SAP BTP | |
Agent workflow patterns and best practices |
Development
npm ci && npm run build && npm testSee CLAUDE.md for codebase structure, testing commands, and contribution guidelines.
Credits
Project | Author | Contribution |
oisee | Original Go MCP server — ARC-1's starting point | |
Marcello Urbani | TypeScript ADT library, definitive API reference | |
Mario Andreschak | First MCP server for ABAP ADT | |
Lars Hvam | ABAP parser/linter (used via @abaplint/core) |
License
MIT
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/marianfoo/arc-1'
If you have feedback or need assistance with the MCP directory API, please join our Discord server