Skip to main content
Glama
MarioDeFelipe

SAP Datasphere MCP Server

Server Configuration

Describes the environment variables required to run the server.

NameRequiredDescriptionDefault
MCP_HTTP_HOSTNoBind address in HTTP mode127.0.0.1
MCP_HTTP_PATHNoURL path for the MCP endpoint in HTTP mode/mcp
MCP_HTTP_PORTNoBind port in HTTP mode8080
MCP_TRANSPORTNoTransport mode: stdio or httpstdio
USE_MOCK_DATANoEnable mock data mode for testing without real credentialsfalse
DATASPHERE_BASE_URLYesSAP Datasphere tenant base URL (e.g., https://your-tenant.eu10.hcs.cloud.sap)
MCP_HTTP_AUTH_TOKENNoBearer token for HTTP mode authentication (optional)
DATASPHERE_CLIENT_IDYesOAuth 2.0 client ID (technical user)
DATASPHERE_TENANT_IDYesSAP Datasphere tenant ID
DATASPHERE_TOKEN_URLYesOAuth 2.0 token endpoint URL (e.g., https://your-tenant.authentication.eu10.hana.ondemand.com/oauth/token)
DATASPHERE_CLIENT_SECRETYesOAuth 2.0 client secret

Capabilities

Features and capabilities supported by this server

CapabilityDetails
tools
{
  "listChanged": false
}
prompts
{
  "listChanged": false
}
resources
{
  "subscribe": false,
  "listChanged": false
}
experimental
{}

Tools

Functions exposed to the LLM to take actions

NameDescription
list_spacesA

List all SAP Datasphere spaces with their status and metadata.

Use this tool when:

  • User asks "What spaces are available?" or "Show me all spaces"

  • You need to discover available Datasphere environments

  • Starting data exploration workflow

  • Checking space status and availability

What you'll get:

  • Space IDs and names

  • Space status (ACTIVE, DEVELOPMENT, etc.)

  • Table/view counts per space

  • Owner information (with include_details=True)

Example queries:

  • "What Datasphere spaces exist?"

  • "Show me all data spaces"

  • "Which spaces are active?"

Next steps after using this tool:

  • Use get_space_info() to explore a specific space

  • Use search_tables() to find tables across spaces

get_space_infoA

Get comprehensive information about a specific SAP Datasphere space.

Use this tool when:

  • User asks about a specific space (e.g., "Tell me about SALES_ANALYTICS")

  • You need to see what tables/views exist in a space

  • Checking space configuration and metadata

  • Following up from list_spaces() results

What you'll get:

  • Complete space metadata (status, owner, created date)

  • List of all tables and views in the space

  • Table schemas and row counts

  • Connection information

Required parameter:

  • space_id: Must be uppercase (e.g., 'SALES_ANALYTICS', 'FINANCE_DWH')

Example queries:

  • "Show me the SALES_ANALYTICS space"

  • "What tables are in FINANCE_DWH?"

  • "Tell me about the HR_ANALYTICS space"

Error handling:

  • If space not found, list_spaces() will show available spaces

search_tablesA

Search for tables and views across all Datasphere spaces by name or description.

Use this tool when:

  • User asks "Find tables with customer data"

  • Looking for tables containing specific keywords

  • Don't know exact table name but know the domain

  • Searching across multiple spaces

Search behavior:

  • Searches both table names and descriptions

  • Case-insensitive matching

  • Returns results from all spaces (or specific space if filtered)

  • Includes table metadata (type, columns, row counts)

Search tips:

  • Use domain keywords: "customer", "sales", "order", "finance"

  • Partial matches work: "cust" finds "CUSTOMER_DATA"

  • Filter by space_id to narrow results

Example queries:

  • "Find all tables related to customers"

  • "Search for sales order tables"

  • "Show me all tables with 'finance' in the name"

Next steps:

  • Use get_table_schema() for detailed column information

  • Use execute_query() to retrieve actual data

get_table_schemaA

Get detailed schema information for a specific table or view.

Use this tool when:

  • User asks "What columns are in CUSTOMER_DATA?"

  • Need to understand table structure before querying

  • Planning JOIN operations (need to see key columns)

  • Checking data types for analysis

What you'll get:

  • Complete column list with data types

  • Primary key indicators

  • Column descriptions

  • Table metadata (row count, last updated)

Required parameters:

  • space_id: The space containing the table (uppercase)

  • table_name: Exact table name (case-sensitive, usually uppercase)

Example queries:

  • "Show me the schema of CUSTOMER_DATA in SALES_ANALYTICS"

  • "What columns does SALES_ORDERS have?"

  • "Describe the GL_ACCOUNTS table structure"

Best practices:

  • Use search_tables() first if you don't know the exact table name

  • Check column types before writing queries

  • Identify key columns for JOINs

Next steps:

  • Use execute_query() with proper column names and types

list_connectionsA

List all external data source connections and their current status.

Use this tool when:

  • User asks "What data sources are connected?"

  • Checking connection health and availability

  • Understanding data lineage and sources

  • Troubleshooting data refresh issues

What you'll get:

  • Connection IDs and names

  • Connection types (SAP_ERP, SALESFORCE, EXTERNAL, etc.)

  • Connection status (CONNECTED, DISCONNECTED, ERROR)

  • Host information and last tested timestamp

Supported connection types:

  • SAP_ERP, SAP_S4HANA, SAP_BW

  • SALESFORCE, EXTERNAL

  • SNOWFLAKE, DATABRICKS

  • POSTGRESQL, MYSQL, ORACLE, SQLSERVER, HANA

Example queries:

  • "What external connections exist?"

  • "Show me all SAP ERP connections"

  • "Check if Salesforce connection is active"

Use cases:

  • Data integration monitoring

  • Connection health checks

  • Understanding data sources

get_task_statusA

Get status and execution details of data integration and ETL tasks.

Use this tool when:

  • User asks "What tasks are running?"

  • Monitoring data pipeline execution

  • Checking when data was last refreshed

  • Troubleshooting failed tasks

What you'll get:

  • Task IDs and names

  • Execution status (COMPLETED, RUNNING, FAILED, SCHEDULED)

  • Last run timestamp and next scheduled run

  • Execution duration and records processed

  • Associated space information

Filtering options:

  • No parameters: Show all tasks

  • task_id: Get specific task details

  • space_id: Show all tasks for a space

Example queries:

  • "What tasks are currently running?"

  • "Show me all tasks in SALES_ANALYTICS"

  • "When did DAILY_SALES_ETL last run?"

  • "Check status of task FINANCE_RECONCILIATION"

Task types:

  • ETL/data loading tasks

  • Transformation workflows

  • Scheduled data refreshes

  • Data replication jobs

browse_marketplaceA

Browse and search available data packages in the SAP Datasphere marketplace.

Use this tool when:

  • User asks "What data packages are available?"

  • Looking for external reference data (benchmarks, currency rates, etc.)

  • Exploring marketplace offerings

  • Planning to enrich internal data with external sources

What you'll get:

  • Package IDs and names

  • Package descriptions and categories

  • Provider information

  • Package versions and sizes

  • Pricing information (Free or paid)

Categories:

  • Reference Data (industry benchmarks, standards)

  • Financial Data (currency rates, market data)

  • Geospatial Data

  • Industry-specific datasets

Example queries:

  • "What marketplace packages are available?"

  • "Find financial data packages"

  • "Show me industry benchmarks"

  • "Search for currency rate data"

Use cases:

  • Data enrichment planning

  • Finding external reference data

  • Competitive benchmarking

  • Currency conversion support

find_assets_by_columnA

Find all assets (tables/views) containing a specific column name across SAP Datasphere spaces.

Use this tool when:

  • User asks "Which tables contain CUSTOMER_ID?"

  • Performing data lineage analysis

  • Impact analysis before schema changes

  • Finding datasets for specific use cases

  • Locating related data across spaces

What you'll get:

  • Asset names and types (View, Table, etc.)

  • Space IDs where assets are located

  • Column information (name, type, position)

  • Total column count per asset

  • Consumption URLs for data access

Use cases:

  • Data lineage discovery (find all uses of a column)

  • Impact analysis (before renaming/removing columns)

  • Dataset discovery (find tables with specific fields)

  • Cross-space data exploration

  • Schema relationship mapping

Example queries:

  • "Find all tables with CUSTOMER_ID column"

  • "Which views contain SALES_AMOUNT?"

  • "Show me assets with COUNTRY_CODE in SAP_CONTENT space"

  • "List tables that have ORDER_DATE column"

Performance notes:

  • Searches across multiple spaces by default

  • Uses intelligent caching for better performance

  • Results limited to 50 assets by default (configurable)

  • Case-insensitive search by default

analyze_column_distributionA

Perform advanced statistical analysis of a column's data distribution including nulls, distinct values, percentiles, and outlier detection.

Use this tool when:

  • User asks "What's the data quality of AMOUNT column?"

  • Performing data profiling before analytics

  • Assessing column completeness and distribution

  • Detecting outliers and data anomalies

  • Understanding data patterns for ML/AI

What you'll get:

  • Basic statistics (count, nulls, distinct values, completeness)

  • Numeric statistics (min, max, mean, percentiles)

  • Distribution analysis (top values, frequency)

  • Outlier detection (IQR method)

  • Data quality assessment

Use cases:

  • Data quality assessment

  • Pre-analytics data profiling

  • Outlier and anomaly detection

  • Understanding value distributions

  • ML feature engineering preparation

  • Data cleansing planning

Example queries:

  • "Analyze the distribution of SALES_AMOUNT column"

  • "What's the data quality of CUSTOMER_AGE?"

  • "Profile the ORDER_STATUS column"

  • "Detect outliers in PRICE column"

  • "Show me statistics for QUANTITY field"

Analysis includes:

  • Null percentage and completeness rate

  • Distinct value count and cardinality

  • For numeric columns: min, max, mean, percentiles (p25, p50, p75)

  • Top value frequencies

  • Outlier detection using IQR method

  • Data quality recommendations

Performance notes:

  • Analyzes up to 10,000 records (configurable)

  • Default sample size: 1,000 records

  • Works with numeric, string, and date columns

  • Automatic type detection and appropriate statistics

execute_queryA

Execute read-only SQL queries against SAP Datasphere tables to retrieve and analyze data.

IMPORTANT: This is a HIGH-RISK tool that requires user consent before execution.

Use this tool when:

  • User explicitly requests data retrieval (e.g., "Show me customers from USA")

  • Need to perform data analysis with aggregations

  • Joining multiple tables for insights

  • Filtering and sorting data

Capabilities:

  • SELECT queries with full SQL syntax (WHERE, JOIN, GROUP BY, ORDER BY, LIMIT)

  • Read-only access - NO write operations allowed

  • Results limited to 100 rows by default (configurable via limit parameter)

  • Automatic query sanitization and injection prevention

Security & Restrictions:

  • Only SELECT statements allowed

  • Blocked operations: INSERT, UPDATE, DELETE, DROP, CREATE, ALTER, etc.

  • No SQL comments allowed (security risk)

  • Queries sanitized to prevent injection attacks

  • User consent required before execution (high-risk operation)

Query best practices:

  1. Always specify a LIMIT to control result size

  2. Use WHERE clauses to filter data efficiently

  3. Check table schema first with get_table_schema()

  4. Use qualified table names when joining

Example queries:

  • "SELECT * FROM CUSTOMER_DATA WHERE country = 'USA' LIMIT 10"

  • "SELECT customer_id, SUM(amount) as total FROM SALES_ORDERS GROUP BY customer_id ORDER BY total DESC LIMIT 20"

  • "SELECT c.customer_name, o.order_date, o.amount FROM CUSTOMER_DATA c JOIN SALES_ORDERS o ON c.customer_id = o.customer_id WHERE o.status = 'COMPLETED' LIMIT 50"

Error handling:

  • Invalid SQL syntax: Returns syntax error with guidance

  • Forbidden operations: Blocked with explanation

  • Missing tables: Suggests using search_tables() to find correct name

  • Permission denied: Explains consent requirement

Note: This tool uses mock data in development. Real query execution requires OAuth authentication.

smart_queryA

🚀 SMART QUERY - Intelligent query router that automatically selects the best execution method for your query.

NEW in v1.0.5 - This is a composite tool combining execute_query, query_relational_entity, and query_analytical_data with intelligent routing and fallback logic.

Why use smart_query instead of individual query tools?

  • ✅ Automatic routing to the most reliable method

  • ✅ Fallback handling if primary method fails

  • ✅ No need to understand different query methods

  • ✅ Better error recovery and diagnostics

  • ✅ Performance optimization based on query type

How it works:

  1. Analyzes your query - Detects SQL syntax, aggregations, complexity

  2. Routes intelligently - Chooses the best execution method:

    • Aggregations (SUM, COUNT, GROUP BY) → Analytical endpoint

    • Simple SELECT → Relational endpoint (most reliable)

    • Complex SQL → SQL parsing with OData conversion

  3. Falls back gracefully - If primary method fails, tries alternatives

  4. Returns detailed logs - Shows routing decisions and execution path

Query Modes:

  • auto (default) - Intelligent routing based on query analysis

  • relational - Force use of relational endpoint (most reliable)

  • analytical - Force use of analytical endpoint (for aggregations)

  • sql - Force use of SQL parsing method

Use this tool when:

  • You want reliable query execution without worrying about method selection

  • You're unsure which query method to use

  • You need fallback handling for production reliability

  • You want to see execution diagnostics

Supported query patterns:

  • Simple SELECT: SELECT * FROM SAP_SC_FI_V_ProductsDim LIMIT 10

  • Filtering: SELECT * FROM table WHERE PRICE > 1000

  • Column selection: SELECT PRODUCTID, PRICE FROM table

  • Aggregations: SELECT COMPANYNAME, SUM(GROSSAMOUNT) FROM table GROUP BY COMPANYNAME

  • Sorting: SELECT * FROM table ORDER BY PRICE DESC LIMIT 5

Parameters:

  • space_id - Space ID (e.g., "SAP_CONTENT")

  • query - SQL query or natural language request

  • mode - Routing mode: "auto", "relational", "analytical", "sql" (default: "auto")

  • limit - Max rows to return (default: 1000)

  • include_metadata - Include routing logs and decisions (default: true)

  • fallback - Enable fallback to alternative methods (default: true)

Example queries:

# Auto-routing - simple SELECT
smart_query(space_id="SAP_CONTENT", query="SELECT * FROM SAP_SC_FI_V_ProductsDim LIMIT 5")

# Auto-routing - aggregation
smart_query(space_id="SAP_CONTENT", query="SELECT COMPANYNAME, SUM(GROSSAMOUNT) FROM SAP_SC_SALES_V_SalesOrders GROUP BY COMPANYNAME")

# Force relational mode
smart_query(space_id="SAP_CONTENT", query="SELECT * FROM SAP_SC_FI_V_ProductsDim", mode="relational")

# Disable fallback (fail fast)
smart_query(space_id="SAP_CONTENT", query="SELECT * FROM table", fallback=False)

Response includes:

  • Query results (data)

  • Method used (relational, analytical, sql, or fallback)

  • Execution time

  • Rows returned

  • Routing decision log (if include_metadata=true)

  • Detected query characteristics

Error handling:

  • If primary method fails, automatically tries fallbacks

  • Returns detailed error log showing all attempted methods

  • Provides suggestions for fixing query issues

  • Shows routing decisions for debugging

Performance:

  • Relational: 1-5 seconds, up to 50K records

  • Analytical: Fast for aggregations

  • SQL: 1-5 seconds, up to 1K records

When to use individual tools instead:

  • Use query_relational_entity when you need specific entity_name control

  • Use query_analytical_data when you know you need analytical consumption

  • Use execute_query when you need exact SQL syntax control

  • Use smart_query for everything else (recommended for most use cases)

Note: This tool provides the same functionality as the individual query tools but with better reliability through intelligent routing and fallback handling.

list_database_usersA

List all database users in a specific SAP Datasphere space.

Use this tool when:

  • User asks "What database users exist in SALES space?"

  • Auditing user access and permissions

  • Checking who has database access to a space

  • Before creating a new database user (avoid duplicates)

What you'll get:

  • Database user IDs and full names

  • User status (ACTIVE, INACTIVE)

  • Access permissions and privileges

  • Last login information

  • Audit policy settings

Required parameter:

  • space_id: The space ID (uppercase, e.g., 'SALES', 'FINANCE')

Example queries:

  • "List all database users in SALES space"

  • "Show me who has database access to FINANCE"

  • "What database users are configured?"

Database user access types:

  • Consumption: Read data with/without grant privileges

  • Ingestion: Write/load data into space

  • Schema access: Local and space schema access

  • Script server: Execute advanced analytics

Note: This corresponds to the CLI command: datasphere dbusers list --space

create_database_userA

Create a new database user in a SAP Datasphere space with specified permissions.

IMPORTANT: This is a HIGH-RISK tool that requires user consent before execution.

Use this tool when:

  • User requests "Create a database user named JEFF in SALES"

  • Setting up new user access for applications or analysts

  • Configuring data ingestion users

  • Establishing read-only consumption users

Required parameters:

  • space_id: The space where user will be created

  • database_user_id: User name suffix (e.g., 'JEFF', 'REPORTING_USER')

  • user_definition: JSON object defining permissions and settings

User definition structure:

{
  "consumption": {
    "consumptionWithGrant": false,
    "spaceSchemaAccess": false,
    "scriptServerAccess": false,
    "enablePasswordPolicy": false,
    "localSchemaAccess": false,
    "hdiGrantorForCupsAccess": false
  },
  "ingestion": {
    "auditing": {
      "dppRead": {
        "isAuditPolicyActive": false,
        "retentionPeriod": 7
      },
      "dppChange": {
        "isAuditPolicyActive": false,
        "retentionPeriod": 7
      }
    }
  }
}

Permission types:

  • Consumption: Read access to space data

    • consumptionWithGrant: Allow granting privileges to others

    • spaceSchemaAccess: Access to space schema objects

    • scriptServerAccess: Execute stored procedures/UDFs

  • Ingestion: Write access for data loading

    • Audit policies for compliance (DPP read/change tracking)

Security notes:

  • New password is auto-generated and returned (store securely!)

  • Audit retention period: 1-365 days

  • Minimum privilege principle recommended

  • Password must be changed on first login

Example queries:

  • "Create a read-only database user named ANALYST in SALES"

  • "Set up a database user for data loading in FINANCE"

  • "Create user REPORTING with consumption access"

Note: Corresponds to CLI: datasphere dbusers create --space --databaseuser --file-path <def.json>

reset_database_user_passwordA

Reset the password for an existing database user in SAP Datasphere.

IMPORTANT: This is a HIGH-RISK tool that requires user consent before execution.

Use this tool when:

  • User requests "Reset password for database user JEFF"

  • Password forgotten or compromised

  • Regular password rotation policy

  • Account locked due to failed login attempts

What happens:

  • Old password is invalidated immediately

  • New password is auto-generated securely

  • User must change password on next login

  • Action is logged for security audit

Required parameters:

  • space_id: The space containing the database user

  • database_user_id: The user whose password needs reset

Security considerations:

  • New password shown only once - save securely!

  • Recommend using output_file to save credentials

  • Notify user through secure channel

  • Enforce password change on first login

  • All active sessions are terminated

Example queries:

  • "Reset password for JEFF in SALES space"

  • "Generate new password for database user ANALYST"

  • "REPORTING_USER password expired, reset it"

Best practices:

  • Always save output to secure file

  • Communicate new password via secure channel (not email!)

  • Verify user identity before resetting

  • Document password reset in change log

Note: Corresponds to CLI: datasphere dbusers password reset --space --databaseuser

update_database_userA

Update permissions and configuration for an existing database user.

IMPORTANT: This is a HIGH-RISK tool that requires user consent before execution.

Use this tool when:

  • User requests "Grant schema access to JEFF in SALES"

  • Modifying user permissions or access levels

  • Enabling/disabling audit policies

  • Changing retention periods

  • Updating user privileges

What you can update:

  • Consumption permissions (read access, grants)

  • Schema access (space, local, HDI)

  • Script server access

  • Audit policies and retention periods

  • Password policies

Required parameters:

  • space_id: The space containing the database user

  • database_user_id: The user to update

  • updated_definition: JSON with new configuration (full definition required)

Update examples:

Grant schema access:

{
  "consumption": {
    "spaceSchemaAccess": true,
    "consumptionWithGrant": false,
    ...
  },
  "ingestion": {...}
}

Enable audit logging:

{
  "consumption": {...},
  "ingestion": {
    "auditing": {
      "dppRead": {
        "isAuditPolicyActive": true,
        "retentionPeriod": 90
      }
    }
  }
}

Important notes:

  • Must provide complete user definition (not partial updates)

  • Changes take effect immediately

  • Active sessions may need reconnection

  • All changes are logged for audit

Example queries:

  • "Grant space schema access to JEFF"

  • "Enable audit logging for ANALYST with 90 day retention"

  • "Update REPORTING_USER to have consumption with grant"

Note: Corresponds to CLI: datasphere dbusers update --space --databaseuser --file-path <def.json>

delete_database_userA

Delete a database user from a SAP Datasphere space.

IMPORTANT: This is a HIGH-RISK tool that requires user consent before execution. WARNING: This action is IRREVERSIBLE. User and all associated permissions are permanently deleted.

Use this tool when:

  • User explicitly requests "Delete database user JEFF from SALES"

  • Decommissioning user accounts

  • Removing unauthorized access

  • Cleaning up test/temporary users

  • User left organization

What happens:

  • User account is permanently deleted

  • All active sessions terminated immediately

  • All granted privileges revoked

  • Cannot be undone - must recreate if needed

  • Deletion is logged for audit

Required parameters:

  • space_id: The space containing the database user

  • database_user_id: The user to delete

  • force: Optional flag to skip confirmation dialog

Safety considerations:

  • PERMANENT deletion - no recovery possible

  • Verify user identity and authorization

  • Check if user owns any objects (may cause errors)

  • Document reason for deletion

  • Consider deactivating instead of deleting

Before deleting:

  1. List user's current permissions (list_database_users)

  2. Verify no applications depend on this user

  3. Check if user owns database objects

  4. Get management approval for production users

  5. Document deletion in change log

Example queries:

  • "Delete database user JEFF from SALES space"

  • "Remove TEMP_USER from FINANCE"

  • "Delete TEST_ANALYST - no longer needed"

Best practices:

  • Always confirm with user before deleting

  • Use force=false for interactive confirmation

  • Keep audit trail of deletions

  • For temporary removal, consider update instead

Note: Corresponds to CLI: datasphere dbusers delete --space --databaseuser [--force]

list_catalog_assetsA

Browse all data assets across all SAP Datasphere spaces.

Use this tool when:

  • User asks "What assets are available in Datasphere?"

  • Building a complete data catalog or asset inventory

  • Discovering available data assets across all spaces

  • Searching for specific asset types across the system

  • Understanding the overall data landscape

What you'll get:

  • Asset IDs and names across all spaces

  • Asset types (AnalyticalModel, View, Table)

  • Space information for each asset

  • Consumption URLs (analytical and relational)

  • Exposure status and metadata URLs

  • Creation and modification timestamps

Available parameters:

  • select_fields: Specific fields to return (e.g., ['name', 'description', 'spaceId'])

  • filter_expression: OData filter (e.g., "spaceId eq 'SAP_CONTENT'")

  • top: Maximum results (default 50, max 1000)

  • skip: Results to skip for pagination

  • include_count: Include total count of assets

Example queries:

  • "List all available assets in Datasphere"

  • "Show me all analytical models across all spaces"

  • "Find assets in the SAP_CONTENT space"

  • "List the first 20 assets with their consumption URLs"

Common filters:

  • By space: filter_expression="spaceId eq 'SAP_CONTENT'"

  • By type: filter_expression="assetType eq 'AnalyticalModel'"

  • Exposed only: filter_expression="exposedForConsumption eq true"

  • Combined: filter_expression="spaceId eq 'SALES' and assetType eq 'View'"

Asset types you'll see:

  • AnalyticalModel: Multi-dimensional models for analytics

  • View: SQL views combining multiple data sources

  • Table: Physical tables with business data

  • Fact: Fact tables in analytical models

  • Dimension: Dimension tables in analytical models

Note: This uses the Catalog API: GET /api/v1/datasphere/consumption/catalog/assets

get_asset_detailsA

Get comprehensive metadata for a specific SAP Datasphere asset.

Use this tool when:

  • User asks "Show me details about the Financial Transactions asset"

  • Need complete asset documentation and structure

  • Want to understand asset dimensions, measures, and relationships

  • Looking for consumption URLs to access the data

  • Checking asset business purpose and technical details

  • Validating asset availability before integration

What you'll get:

  • Complete asset metadata (name, description, business purpose)

  • Space information and ownership details

  • Asset type and consumption type (analytical/relational)

  • Consumption URLs for data access

  • Metadata URLs for schema information

  • Dimensions and measures (for analytical models)

  • Relationships to other assets

  • Technical details (row count, size, refresh info)

  • Business context (domain, classification, retention)

  • Version and status information

  • Tags and categorization

Required parameters:

  • space_id: The space containing the asset (e.g., 'SAP_CONTENT')

  • asset_id: The asset identifier (e.g., 'SAP_SC_FI_AM_FINTRANSACTIONS')

Optional parameters:

  • expand_fields: Related entities to expand (e.g., ['columns', 'relationships'])

Example queries:

  • "Get details for SAP_SC_FI_AM_FINTRANSACTIONS in SAP_CONTENT"

  • "Show me the structure of the Financial Transactions asset"

  • "What are the dimensions and measures of this analytical model?"

  • "Give me the consumption URL for the Sales Data View"

Use cases:

  • Understand asset structure before querying

  • Get consumption URLs for data access

  • Review asset business purpose and classification

  • Check asset relationships and dependencies

  • Validate data freshness (last refresh time)

  • Generate asset documentation

Note: This uses the Catalog API: GET /api/v1/datasphere/consumption/catalog/spaces('{spaceId}')/assets('{assetId}')

get_asset_by_compound_keyA

Retrieve asset using OData compound key identifier (alternative access method).

Use this tool when:

  • You have both space ID and asset ID ready

  • Want direct access without knowing the exact endpoint structure

  • Working with bookmarked or favorited assets

  • Have pre-known asset identifiers from other systems

  • Need to resolve cross-references quickly

What you'll get:

  • Same comprehensive metadata as get_asset_details

  • Complete asset information with consumption URLs

  • All dimensions, measures, and relationships

  • Technical and business context

Required parameters:

  • space_id: The space identifier

  • asset_id: The asset identifier

How it works: This tool combines space_id and asset_id into an OData compound key format: spaceId='SAP_CONTENT',assetId='SAP_SC_FI_AM_FINTRANSACTIONS'

Example queries:

  • "Get asset SAP_SC_FI_AM_FINTRANSACTIONS from SAP_CONTENT using compound key"

  • "Retrieve CUSTOMER_VIEW in SALES_SPACE"

When to use this vs get_asset_details:

  • Use this: When you want simplified parameter passing

  • Use get_asset_details: When you need expand options or prefer explicit endpoint

Note: This uses the Catalog API: GET /api/v1/datasphere/consumption/catalog/assets({compoundKey})

get_space_assetsA

List all data assets within a specific SAP Datasphere space.

Use this tool when:

  • User asks "What assets are in the SAP_CONTENT space?"

  • Browsing assets within a specific space

  • Creating a space-specific asset inventory

  • Filtering assets by type within a space

  • Validating space contents and available data

  • Understanding what data is available in a space

What you'll get:

  • All assets within the specified space

  • Asset names, descriptions, and types

  • Exposure status for each asset

  • Consumption URLs (analytical and relational)

  • Creation and modification timestamps

  • Asset counts and pagination info

Required parameters:

  • space_id: The space to browse (e.g., 'SAP_CONTENT')

Optional parameters:

  • filter_expression: Filter by asset type or other criteria

  • top: Maximum results (default 50, max 1000)

  • skip: Results to skip for pagination

Example queries:

  • "List all assets in the SAP_CONTENT space"

  • "Show me analytical models in SALES_ANALYTICS"

  • "What tables are available in FINANCE_SPACE?"

  • "List exposed assets in SAP_CONTENT"

Common filters:

  • By type: filter_expression="assetType eq 'AnalyticalModel'"

  • Exposed only: filter_expression="exposedForConsumption eq true"

  • By name pattern: filter_expression="contains(name, 'Financial')"

  • Combined: filter_expression="assetType eq 'View' and exposedForConsumption eq true"

Asset types:

  • AnalyticalModel: Multi-dimensional models with dimensions and measures

  • View: SQL views combining data from multiple sources

  • Table: Physical tables with business data

  • Fact: Fact tables in dimensional models

  • Dimension: Dimension tables for analysis

Use cases:

  • Space content discovery

  • Asset inventory generation

  • Data availability validation

  • Finding specific asset types

  • Understanding space data landscape

Note: This uses the Catalog API: GET /api/v1/datasphere/consumption/catalog/spaces('{spaceId}')/assets

test_connectionA

Test the connection to SAP Datasphere and verify OAuth authentication status. Use this tool to check if the MCP server can successfully connect to SAP Datasphere.

get_current_userA

Get authenticated user information including user ID, email, display name, roles, permissions, and account status. Use this to understand the current user's identity and access rights in SAP Datasphere.

get_tenant_infoA

Retrieve SAP Datasphere tenant configuration and system information including tenant ID, region, version, license type, storage quota/usage, user count, space count, enabled features, and maintenance windows. Use this for system administration and capacity planning.

get_available_scopesA

List available OAuth2 scopes for the current user, showing which scopes are granted and which are available but not granted. Includes scope descriptions and the token's current scopes. Use this to understand API access capabilities and troubleshoot permission issues.

search_catalogA

Universal search across all catalog items in SAP Datasphere using advanced search syntax. Supports searching across KPIs, assets, spaces, models, views, and tables. Use SCOPE: prefix for targeted searches. Boolean operators (AND, OR, NOT) supported.

get_analytical_metadataB

Retrieve CSDL metadata for analytical consumption of a specific asset. Returns analytical schema with dimensions, measures, hierarchies, and aggregation information for BI and analytics integration. Automatically identifies analytical elements based on SAP annotations.

get_relational_metadataA

Retrieve CSDL metadata for relational consumption of a specific asset. Returns complete schema information including tables, columns, data types, primary/foreign keys, and relationships for relational data access and ETL planning. Includes SQL type mapping.

get_asset_variablesA

Retrieve input parameters/variables and filter-capability annotations declared in the OData $metadata of a SAP Datasphere asset (wave 2026.10). Use this when the asset is parameterised (e.g., a view or analytic model with input variables) and you need to know what variables to bind and which fields are filterable/sortable before querying. Returns variables (name, type, default, nullable, multi_value), filter annotations, and the column list.

list_relational_entitiesA

List all available relational entities (tables/views) within a specific SAP Datasphere asset for row-level data access and ETL operations. Returns OData entity sets that can be queried for detailed data extraction.

get_relational_entity_metadataA

Get detailed metadata for a specific relational entity including column definitions, data types, SQL type mappings, and ETL extraction capabilities. Optimized for data warehouse loading and transformation workflows.

query_relational_entityA

Execute OData queries on relational entities for ETL data extraction. Supports large batch processing (up to 50,000 records), advanced filtering, column selection, and pagination. Optimized for data warehouse loading and analytics pipelines. Use list_relational_entities to discover available entity names first.

list_analytical_datasetsA

List all available analytical datasets within a specific asset. Discovers analytical models that can be queried for business intelligence and reporting. Returns entity sets with their names, types, and URLs for data access.

get_analytical_modelA

Get the OData service document and metadata for a specific analytical model. Returns entity sets, dimensions, measures, and query capabilities. Parses CSDL metadata to identify analytical properties (dimensions with sap:aggregation-role='dimension', measures with sap:aggregation-role='measure').

query_analytical_dataA

Execute OData queries on analytical models to retrieve aggregated data with dimensions and measures. Supports full OData query syntax: $select (column selection), $filter (WHERE conditions), $orderby (sorting), $top/$skip (pagination), $apply (aggregations with sum/average/min/max/count/groupby). Perfect for business intelligence, reporting, and data analysis.

get_object_definitionA

Get complete design-time object definition from SAP Datasphere repository. Retrieves detailed structure, logic, transformations, and metadata for tables (with columns, keys, indexes), views (with SQL definitions), analytical models (with dimensions/measures), and data flows (with transformation steps). Use this for understanding object implementation details, extracting schema information, or planning migrations.

get_deployed_objectsA

List runtime/deployed objects that are actively running in SAP Datasphere. Returns deployment status, runtime metrics, execution history for data flows, and performance statistics. Use this for monitoring deployed assets, tracking execution status, analyzing runtime performance, and identifying active vs inactive objects.

run_task_chainA

Execute a task chain in SAP Datasphere and get a log ID for tracking.

Use this tool when:

  • User asks to "Run the ETL pipeline" or "Execute task chain X"

  • Triggering scheduled data loads or transformations

  • Starting data replication or synchronization jobs

  • Automating data refresh workflows

  • Executing orchestrated data pipelines

What happens:

  • Task chain execution is initiated immediately

  • Returns a logId to track the execution status

  • Task runs asynchronously (use get_task_log to check status)

  • All child tasks in the chain are executed in order

Required parameters:

  • space_id: The space containing the task chain (e.g., 'SALES_SPACE')

  • object_id: The task chain name/ID (e.g., 'Daily_ETL_Pipeline')

What you'll get:

  • logId: Unique identifier to track this execution

  • Use get_task_log(space_id, logId) to monitor progress

  • Use get_task_history(space_id, object_id) to see all runs

Example queries:

  • "Run the Daily_ETL_Pipeline in SALES_SPACE"

  • "Execute task chain Customer_Sync in FINANCE_SPACE"

  • "Trigger the data refresh pipeline in ANALYTICS"

  • "Start the nightly batch job in DWH_SPACE"

Important notes:

  • Task chains run asynchronously - tool returns immediately

  • Check status with get_task_log using the returned logId

  • Requires appropriate permissions to run task chains

  • Failed runs can be investigated with detailed logs

Workflow example:

  1. Run task chain: run_task_chain(space_id='SALES', object_id='Daily_ETL')

  2. Get logId from response (e.g., 2295172)

  3. Check status: get_task_log(space_id='SALES', log_id=2295172)

  4. View details: get_task_log(space_id='SALES', log_id=2295172, detail_level='detailed')

Note: Uses API: POST /api/v1/datasphere/tasks/chains/{space_id}/run/{object_id}

get_task_logA

Get detailed information about a specific task execution in SAP Datasphere.

Use this tool when:

  • Checking status of a running task (after run_task_chain)

  • Investigating why a task failed

  • Viewing detailed execution logs and messages

  • Monitoring task chain progress

  • Debugging data pipeline issues

What you'll get (depends on detail_level):

  • status (default): Simple status object {"status": "COMPLETED"}

  • status_only: Just the status string "COMPLETED"

  • detailed: Full details including messages and child nodes

  • extended: Extended logs with complete message details

Required parameters:

  • space_id: The space where the task ran

  • log_id: The log ID from run_task_chain or get_task_history

Optional parameters:

  • detail_level: Amount of detail to return

    • 'status' (default): Status object only

    • 'status_only': Status string only

    • 'detailed': Full logs with messages and children

    • 'extended': Extended logs with message details

Status values:

  • RUNNING: Task is currently executing

  • COMPLETED: Task finished successfully

  • FAILED: Task encountered an error

  • CANCELLED: Task was manually stopped

Example queries:

  • "Check status of task log 2295172 in SALES_SPACE"

  • "Get detailed logs for log ID 2295172"

  • "Show me why task 2326060 failed in FINANCE"

  • "Get extended execution details for log 2295172"

Detailed response includes:

  • logId, status, startTime, endTime, runTime

  • objectId (task chain name)

  • user who ran the task

  • children: Array of child task executions

  • messages: Array of log messages with severity and timestamps

Use cases:

  • Monitor long-running ETL jobs

  • Debug failed data pipelines

  • Audit task execution history

  • Track data refresh timing

  • Investigate error messages

Note: Uses API: GET /api/v1/datasphere/tasks/logs/{space_id}/{log_id}

get_task_historyA

Get the execution history for a specific task chain or object in SAP Datasphere.

Use this tool when:

  • Viewing all previous runs of a task chain

  • Analyzing task execution patterns

  • Finding failed runs to investigate

  • Checking historical performance

  • Auditing task chain executions

  • Understanding run frequency and duration

What you'll get:

  • Array of all historical task runs for the specified object

  • Each entry includes: logId, status, startTime, endTime, runTime

  • Sorted by most recent first

  • Shows RUNNING, COMPLETED, FAILED, CANCELLED runs

Required parameters:

  • space_id: The space containing the task chain

  • object_id: The task chain name to get history for

Response includes for each run:

  • logId: Unique identifier for this execution

  • status: RUNNING, COMPLETED, FAILED, or CANCELLED

  • startTime: When the task started (ISO format)

  • endTime: When the task finished (if completed)

  • runTime: Duration in milliseconds

  • objectId: The task chain name

  • applicationId: Always 'TASK_CHAINS' for task chains

  • activity: The activity type (e.g., 'RUN_CHAIN')

  • user: Who initiated the run

Example queries:

  • "Show me the run history for Daily_ETL_Pipeline in SALES_SPACE"

  • "List all executions of Customer_Sync in FINANCE"

  • "Get historical runs for Nested_Chain_1 in DWH_SPACE"

  • "How many times has Data_Refresh run this week?"

Use cases:

  • Identify recurring failures

  • Analyze execution duration trends

  • Find specific failed runs to debug

  • Audit who ran tasks and when

  • Plan maintenance windows

  • Monitor SLA compliance

Workflow example:

  1. Get history: get_task_history(space_id='SALES', object_id='Daily_ETL')

  2. Find failed run: Look for status='FAILED', note logId

  3. Get details: get_task_log(space_id='SALES', log_id=, detail_level='detailed')

  4. View error messages in the response

Note: Uses API: GET /api/v1/datasphere/tasks/logs/{space_id}/objects/{object_id}

Prompts

Interactive templates invoked by user choice

NameDescription
explore_datasphereGuided workflow to explore SAP Datasphere resources and understand available data
analyze_sales_dataTemplate for analyzing sales data with common queries and insights
check_data_pipelineMonitor data pipeline health, task status, and connection status
query_builder_assistantInteractive assistant to help build SQL queries for Datasphere tables

Resources

Contextual data attached and managed by the client

NameDescription
Datasphere SpacesList of all Datasphere spaces and their configurations
Data ConnectionsAvailable data source connections
Integration TasksData integration and ETL tasks
Data MarketplaceAvailable data packages in the marketplace
Sales Analytics - TablesTables and views in the Sales Analytics space
Finance Data Warehouse - TablesTables and views in the Finance Data Warehouse space
HR Analytics - TablesTables and views in the HR Analytics space

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/MarioDeFelipe/sap-datasphere-mcp'

If you have feedback or need assistance with the MCP directory API, please join our Discord server