| 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: |
| 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: Example queries: "Show me the SALES_ANALYTICS space" "What tables are in FINANCE_DWH?" "Tell me about the HR_ANALYTICS space"
Error handling: |
| 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: |
| 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: 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: |
| 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: |
| 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: |
| 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: Always specify a LIMIT to control result size Use WHERE clauses to filter data efficiently Check table schema first with get_table_schema() 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: Analyzes your query - Detects SQL syntax, aggregations, complexity 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
Falls back gracefully - If primary method fails, tries alternatives 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: 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: 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: 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: List user's current permissions (list_database_users) Verify no applications depend on this user Check if user owns database objects Get management approval for production users 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: 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: 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: When to use this vs get_asset_details: 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: 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: Run task chain: run_task_chain(space_id='SALES', object_id='Daily_ETL') Get logId from response (e.g., 2295172) Check status: get_task_log(space_id='SALES', log_id=2295172) 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: Optional parameters: 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: 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: Get history: get_task_history(space_id='SALES', object_id='Daily_ETL') Find failed run: Look for status='FAILED', note logId Get details: get_task_log(space_id='SALES', log_id=, detail_level='detailed') View error messages in the response
Note: Uses API: GET /api/v1/datasphere/tasks/logs/{space_id}/objects/{object_id} |