# 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**
```mermaid
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:#e0f2f1
```
### **Core Components:**
1. **π Level 1 - Discovery**: Lightweight search returning minimal service/entity lists (token-optimized)
2. **π Level 2 - Metadata**: Full schema details on-demand for selected entities
3. **β‘ Level 3 - Execution**: Authenticated CRUD operations using metadata from Level 2
4. **π MCP Protocol Layer**: Full compliance with MCP 2025-06-18 specification
5. **π HTTP Transport**: Session-based Streamable HTTP for web applications
6. **π 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" | `r-BankService-Bank` | `GET /BankSet?$top=10` |
| "Find banks in Germany" | `r-BankService-Bank` | `GET /BankSet?$filter=Country eq 'DE'` |
| "Update bank 123 name to ABC Corp" | `u-BankService-Bank` | `PATCH /BankSet('123')` |
| "Create a new customer John Doe" | `c-CustomerService-Customer` | `POST /CustomerSet` |
| "Delete order 456" | `d-OrderService-Order` | `DELETE /OrderSet('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**:
```javascript
// 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**:
```javascript
// 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**:
```javascript
// 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 parameters
```
### **Protocol Version**: 2025-06-18
### **Supported Capabilities**:
- β
**Tools** with `listChanged` notifications
- β
**Resources** with `listChanged` notifications
- β
**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**
```http
GET /health
{
"status": "healthy",
"activeSessions": 3,
"discoveredServices": 25,
"version": "2.0.0"
}
```
### **Server Info**
```http
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**
```http
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:
```env
DISABLE_READ_ENTITY_TOOL=true
```
This will prevent registration of the ReadEntity tool for all entities and services.
## β‘ Quick Start
- For local development and testing, see [LOCAL_RUN.md](./docs/LOCAL_RUN.md)
- For deployment to SAP BTP, see [DEPLOYMENT.md](./docs/DEPLOYMENT.md)