Enables natural language interactions with SAP S/4HANA and ECC systems by automatically discovering OData services and generating dynamic CRUD tools for all entities, allowing users to query, create, update, and delete business data through conversational AI.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@SAP OData to MCP Servershow me the last 5 purchase orders created this week"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
SAP OData to MCP Server for BTPπ
π― Project Goal
Transform your SAP S/4HANA or ECC system into a conversational AI interface by exposing all OData services as dynamic MCP tools. This enables natural language interactions with your ERP data:
"Show me 10 banks" β Automatically queries the Bank entity with $top=10
"Update bank with ID 1 to have street number 5" β Executes PATCH operation on Bank entity
"Create a new customer with name John Doe" β Performs POST to Customer entity
"List all purchase orders from this week" β Applies $filter for date range on PurchaseOrder entity
ποΈ Architecture Overview - 3-Level Progressive Discovery
graph TB
A[AI Agent/LLM] --> B[MCP Client]
B --> C[SAP MCP Server]
C --> D[SAP BTP Destination]
D --> E[SAP System]
C --> F[Level 1: Lightweight Discovery]
F --> G[Minimal Service/Entity List]
C --> H[Level 2: Full Metadata]
H --> I[Complete Entity Schemas]
C --> J[Level 3: CRUD Execution]
J --> K[Authenticated Operations]
style A fill:#e1f5fe
style C fill:#f3e5f5
style E fill:#e8f5e8
style F fill:#fff3e0
style H fill:#e8eaf6
style J fill:#e0f2f1Core Components:
π Level 1 - Discovery: Lightweight search returning minimal service/entity lists (token-optimized)
π Level 2 - Metadata: Full schema details on-demand for selected entities
β‘ Level 3 - Execution: Authenticated CRUD operations using metadata from Level 2
π MCP Protocol Layer: Full compliance with MCP 2025-06-18 specification
π HTTP Transport: Session-based Streamable HTTP for web applications
π BTP Integration: Seamless authentication via SAP BTP Destination service
3-Level Approach Benefits:
Token Efficient: Level 1 returns 90% less data than full schemas
Progressive Detail: Fetch full schemas only when needed
Better LLM Experience: Smaller responses, clearer workflow
Reduced Context: From 200+ tools down to just 3
β¨ Key Features
π¨ Natural Language to OData
Smart Query Translation: Converts natural language to proper OData queries
Context-Aware Operations: Understands entity relationships and constraints
Parameter Inference: Automatically maps user intent to tool parameters
π Dynamic CRUD Operations
Read Operations: Entity sets with filtering, sorting, pagination
Create Operations: New entity creation with validation
Update Operations: Partial and full entity updates
Delete Operations: Safe entity deletion with confirmation
π Production-Ready
Session Management: Automatic session creation and cleanup
Error Handling: Comprehensive error handling with user-friendly messages
Logging: Detailed logging for debugging and monitoring
Security: DNS rebinding protection, CORS, Helmet security
π Real-Time Metadata
Service Catalog: Live discovery of available services
Entity Schemas: Dynamic schema generation from OData metadata
Capability Detection: Automatic detection of CRUD capabilities per entity
ποΈ System Architecture
βββββββββββββββββββββββ βββββββββββββββββββββββββββββ βββββββββββββββββββββββ
β β β β β β
β π€ AI Agent β β π₯οΈ SAP MCP Server β β π’ SAP β
β - Claude βββββΊβ - Service Discovery βββββΊβ - OData Services β
β - GPT-4 β β - CRUD Tool Registry β β - Business Logic β
β - Local LLMs β β - Session Management β β - Master Data β
β β β - BTP Authentication β β β
βββββββββββββββββββββββ βββββββββββββββββββββββββββββ βββββββββββββββββββββββ
β
βΌ
βββββββββββββββββββββββββββββ
β β
β βοΈ SAP BTP Platform β
β - Destination Service β
β - Connectivity Service β
β - XSUAA Security β
β β
βββββββββββββββββββββββββββββ π― Use Cases
π Business Intelligence Queries
User: "Show me top 10 customers by revenue this quarter"
β Tool: r-CustomerService-Customer
β Parameters: $filter, $orderby, $topπ Data Maintenance
User: "Update supplier ABC123 to have status 'Active'"
β Tool: u-SupplierService-Supplier
β Parameters: SupplierId="ABC123", Status="Active"π Analytical Insights
User: "How many open purchase orders are there?"
β Tool: r-PurchaseOrderService-PurchaseOrder
β Parameters: $filter=Status eq 'Open'&$count=trueπ§ System Administration
User: "List all inactive users in the system"
β Tool: r-UserService-User
β Parameters: $filter=Status eq 'Inactive'π οΈ Installation & Setup
Prerequisites
Node.js 18.x or higher
SAP S/4HANA or ECC system with OData services enabled
SAP BTP account with Destination and Connectivity services
TypeScript knowledge for customization
π Usage Examples
Natural Language Queries
The MCP server automatically translates these natural language commands to the appropriate tool calls:
Natural Language | Generated Tool Call | OData Query |
"Show me 10 banks" |
|
|
"Find banks in Germany" |
|
|
"Update bank 123 name to ABC Corp" |
|
|
"Create a new customer John Doe" |
|
|
"Delete order 456" |
|
|
π Available Tools - 3-Level Architecture
The server exposes 3 progressive discovery tools instead of hundreds of individual CRUD tools:
Level 1: discover-sap-data
Purpose: Lightweight search for services and entities
Returns: Minimal data (serviceId, serviceName, entityName, entityCount)
Usage:
// Search for customer entities
discover-sap-data({ query: "customer" })
// Get all available services
discover-sap-data({ query: "" })
// Search in specific category
discover-sap-data({ query: "sales", category: "sales" })Fallback: If no matches found, returns ALL services with entity lists
Level 2: get-entity-metadata
Purpose: Get complete schema for a specific entity
Returns: Full schema with properties, types, keys, capabilities
Usage:
// Get full schema for Customer entity
get-entity-metadata({
serviceId: "API_BUSINESS_PARTNER",
entityName: "Customer"
})Output: All properties, types, nullable flags, maxLength, keys, capabilities
Level 3: execute-sap-operation
Purpose: Perform authenticated CRUD operations
Operations: read, read-single, create, update, delete
Usage:
// Read customers
execute-sap-operation({
serviceId: "API_BUSINESS_PARTNER",
entityName: "Customer",
operation: "read",
filterString: "CustomerName eq 'ACME'"
})
// Update customer
execute-sap-operation({
serviceId: "API_BUSINESS_PARTNER",
entityName: "Customer",
operation: "update",
parameters: { CustomerID: "123", CustomerName: "New Name" }
})Workflow Example
1. discover-sap-data β "customer"
β Returns: List of customer-related entities
2. get-entity-metadata β "API_BUSINESS_PARTNER", "Customer"
β Returns: Full schema with all properties
3. execute-sap-operation β read/create/update/delete
β Executes operation with proper parametersProtocol Version: 2025-06-18
Supported Capabilities:
β Tools with
listChangednotificationsβ Resources with
listChangednotificationsβ Logging with level control
β Session Management for HTTP transport
β Error Handling with proper error codes
Transport Support
β Streamable HTTP (recommended)
β Stdio for command line usage
β Session-based with automatic cleanup
β DNS Rebinding Protection
π Security & Authentication
SAP BTP Integration
Uses BTP Destination service for S/4HANA or ECC authentication
Supports Principal Propagation and OAuth2
Automatic token refresh and session management
Secure credential storage in BTP
HTTP Security
Helmet.js security headers
CORS protection with configurable origins
DNS rebinding attack prevention
Request rate limiting (configurable)
Session Security
Automatic session expiration (24h default)
Secure session ID generation
Session cleanup on server restart
Memory leak prevention
π API Reference
Health Check
GET /health
{
"status": "healthy",
"activeSessions": 3,
"discoveredServices": 25,
"version": "2.0.0"
}Server Info
GET /mcp
{
"name": "btp-sap-odata-to-mcp-server",
"protocol": { "version": "2025-06-18" },
"capabilities": { "tools": {}, "resources": {} },
"features": ["Dynamic service discovery", "CRUD operations"],
"activeSessions": 3
}Documentation
GET /docs
{
"title": "SAP MCP Server API",
"endpoints": {...},
"mcpCapabilities": {...},
"usage": {...}
}π¬ Demo
See the MCP server in action:

βοΈ Environment Variable: Disable ReadEntity Tool Registration
To disable registration of the ReadEntity tool for all entities in all services, set the following in your .env file:
DISABLE_READ_ENTITY_TOOL=trueThis will prevent registration of the ReadEntity tool for all entities and services.
β‘ Quick Start
For local development and testing, see LOCAL_RUN.md
For deployment to SAP BTP, see DEPLOYMENT.md