Definition
Assembly: Microsoft.OData.Mcp.Core.dll Namespace: Microsoft.OData.Mcp.Core.ToolsSyntax
Summary
Factory for creating MCP tools dynamically from OData metadata.Remarks
This factory generates MCP tools based on the parsed OData model, creating tools for CRUD operations, queries, and navigation between entities. The tools are generated dynamically to match the structure and capabilities of the OData service.Methods
FilterToolsForUser Abstract
Filters tools based on user authorization context.Syntax
Parameters
| Name | Type | Description |
|---|---|---|
tools | System.Collections.Generic.IEnumerable<Microsoft.OData.Mcp.Core.Tools.McpToolDefinition> | The tools to filter. |
userScopes | System.Collections.Generic.IEnumerable<string> | The user’s OAuth2 scopes. |
userRoles | System.Collections.Generic.IEnumerable<string> | The user’s roles. |
options | Microsoft.OData.Mcp.Core.Tools.McpToolGenerationOptions? | Options for authorization filtering. |
Returns
Type:System.Collections.Generic.IEnumerable<Microsoft.OData.Mcp.Core.Tools.McpToolDefinition>
A collection of tools the user is authorized to access.
Exceptions
| Exception | Description |
|---|---|
ArgumentNullException | Thrown when tools is null. |
GenerateCrudToolsAsync Abstract
Generates CRUD operation tools for a specific entity type.Syntax
Parameters
| Name | Type | Description |
|---|---|---|
entityType | Microsoft.OData.Mcp.Core.Models.EdmEntityType | The entity type to generate CRUD tools for. |
model | Microsoft.OData.Mcp.Core.Models.EdmModel | The complete OData model for context. |
options | Microsoft.OData.Mcp.Core.Tools.McpToolGenerationOptions? | Options for tool generation. |
Returns
Type:System.Threading.Tasks.Task<System.Collections.Generic.IEnumerable<Microsoft.OData.Mcp.Core.Tools.McpToolDefinition>>
A collection of CRUD tool definitions.
Exceptions
| Exception | Description |
|---|---|
ArgumentNullException | Thrown when entityType or model is null. |
GenerateEntitySetToolsAsync Abstract
Generates tools for entity set operations (collection-level operations).Syntax
Parameters
| Name | Type | Description |
|---|---|---|
entitySet | Microsoft.OData.Mcp.Core.Models.EdmEntitySet | The entity set to generate tools for. |
model | Microsoft.OData.Mcp.Core.Models.EdmModel | The complete OData model for context. |
options | Microsoft.OData.Mcp.Core.Tools.McpToolGenerationOptions? | Options for tool generation. |
Returns
Type:System.Threading.Tasks.Task<System.Collections.Generic.IEnumerable<Microsoft.OData.Mcp.Core.Tools.McpToolDefinition>>
A collection of entity set tool definitions.
Exceptions
| Exception | Description |
|---|---|
ArgumentNullException | Thrown when entitySet or model is null. |
GenerateEntityToolsAsync Abstract
Generates MCP tools for a specific entity type.Syntax
Parameters
| Name | Type | Description |
|---|---|---|
entityType | Microsoft.OData.Mcp.Core.Models.EdmEntityType | The entity type to generate tools for. |
model | Microsoft.OData.Mcp.Core.Models.EdmModel | The complete OData model for context. |
options | Microsoft.OData.Mcp.Core.Tools.McpToolGenerationOptions? | Options for tool generation. |
Returns
Type:System.Threading.Tasks.Task<System.Collections.Generic.IEnumerable<Microsoft.OData.Mcp.Core.Tools.McpToolDefinition>>
A collection of generated MCP tool definitions for the entity type.
Exceptions
| Exception | Description |
|---|---|
ArgumentNullException | Thrown when entityType or model is null. |
GenerateNavigationToolsAsync Abstract
Generates navigation tools for entity relationships.Syntax
Parameters
| Name | Type | Description |
|---|---|---|
entityType | Microsoft.OData.Mcp.Core.Models.EdmEntityType | The entity type to generate navigation tools for. |
model | Microsoft.OData.Mcp.Core.Models.EdmModel | The complete OData model for context. |
options | Microsoft.OData.Mcp.Core.Tools.McpToolGenerationOptions? | Options for tool generation. |
Returns
Type:System.Threading.Tasks.Task<System.Collections.Generic.IEnumerable<Microsoft.OData.Mcp.Core.Tools.McpToolDefinition>>
A collection of navigation tool definitions.
Exceptions
| Exception | Description |
|---|---|
ArgumentNullException | Thrown when entityType or model is null. |
GenerateQueryToolsAsync Abstract
Generates query tools for the OData model.Syntax
Parameters
| Name | Type | Description |
|---|---|---|
model | Microsoft.OData.Mcp.Core.Models.EdmModel | The OData model to generate query tools for. |
options | Microsoft.OData.Mcp.Core.Tools.McpToolGenerationOptions? | Options for tool generation. |
Returns
Type:System.Threading.Tasks.Task<System.Collections.Generic.IEnumerable<Microsoft.OData.Mcp.Core.Tools.McpToolDefinition>>
A collection of query tool definitions.
Exceptions
| Exception | Description |
|---|---|
ArgumentNullException | Thrown when model is null. |
GenerateToolsAsync Abstract
Generates all MCP tools for the specified OData model.Syntax
Parameters
| Name | Type | Description |
|---|---|---|
model | Microsoft.OData.Mcp.Core.Models.EdmModel | The OData model to generate tools for. |
options | Microsoft.OData.Mcp.Core.Tools.McpToolGenerationOptions? | Options for tool generation. |
Returns
Type:System.Threading.Tasks.Task<System.Collections.Generic.IEnumerable<Microsoft.OData.Mcp.Core.Tools.McpToolDefinition>>
A collection of generated MCP tool definitions.
Exceptions
| Exception | Description |
|---|---|
ArgumentNullException | Thrown when model is null. |
GetAvailableToolNames Abstract
Gets all available tool names.Syntax
Returns
Type:System.Collections.Generic.IEnumerable<string>
A collection of all tool names that have been generated.
GetTool Abstract
Gets the tool definition by name.Syntax
Parameters
| Name | Type | Description |
|---|---|---|
toolName | string | The name of the tool to retrieve. |
Returns
Type:Microsoft.OData.Mcp.Core.Tools.McpToolDefinition?
The tool definition if found; otherwise, null.
ValidateTools Abstract
Validates that the generated tools are compatible with the MCP specification.Syntax
Parameters
| Name | Type | Description |
|---|---|---|
tools | System.Collections.Generic.IEnumerable<Microsoft.OData.Mcp.Core.Tools.McpToolDefinition> | The tools to validate. |
Returns
Type:System.Collections.Generic.IEnumerable<string>
A collection of validation errors, or empty if all tools are valid.
Exceptions
| Exception | Description |
|---|---|
ArgumentNullException | Thrown when tools is null. |