Dataverse MCP Server
No description available
Ask AI about Dataverse MCP Server
Powered by Claude Β· Grounded in docs
I know everything about Dataverse MCP Server. Ask me about installation, configuration, usage, or troubleshooting.
0/500
Reviews
Documentation
dataverse-mcp-server
MCP (Model Context Protocol) server for Microsoft Dataverse API with safe-by-default configuration. Works with any Dataverse / Dynamics 365 environment.
Tools
Data operations
| Tool | Description |
|---|---|
list_entities | List Dataverse tables with optional prefix and solution filters |
list_solutions | List Dataverse solutions (use uniquename to filter list_entities) |
get_entity_schema | Get attributes of a specific table |
query_records | Query records with OData $filter, $select, $top, $orderby, $expand |
get_record | Get a single record by ID |
create_record | Create a record |
update_record | Update a record |
delete_record | Delete a record (disabled by default, see Safety) |
Note:
solution/DATAVERSE_SOLUTION_NAMEonly scopeslist_entities(schema browsing). Data tools (query_records,get_record,create_record, β¦) keep full access to any table regardless of solution membership β shared tables likeaccountorcontactremain reachable.
Schema operations
| Tool | Description |
|---|---|
create_entity | Create a new table with attributes |
add_attribute | Add a column to an existing table |
update_attribute | Update column metadata (display name, required level, bounds, β¦) |
delete_attribute | Delete a column (disabled by default, see Safety) |
get_attribute_dependencies | List CRM components (forms, views, workflows, β¦) that reference a column β use after delete_attribute fails with 0x8004f01f |
create_relationship | Create relationships between tables (1:N, N:N) |
Dataverse does not allow changing a column's logical name or type. To "rename" or change type: create a new column, migrate data via
update_record, thendelete_attributeon the old one.
Picklist option management
| Tool | Description |
|---|---|
get_picklist_options | Read options of a Local or Global OptionSet as [{ value, label }] |
add_picklist_option | Add an option to an existing OptionSet (InsertOptionValue) |
update_picklist_option | Rename an option on an OptionSet (UpdateOptionValue) |
delete_picklist_option | Remove an option from an OptionSet (DeleteOptionValue) |
Picklist tools accept either entity_logical_name + attribute_logical_name (Local OptionSet) or option_set_name (Global OptionSet) β the two modes are mutually exclusive. Write operations require Customizer or System Administrator role on the connected service principal. Deleting an option does not update existing records that hold its numeric value β they are left with an orphan integer.
Quick start (no clone)
Add to .mcp.json in your project root:
{
"mcpServers": {
"dataverse": {
"command": "npx",
"args": ["-y", "@rededis/dataverse-mcp-server"]
}
}
}
Create a .env file next to it with the four required variables (see Environment variables below) and restart your MCP client. The -y flag tells npx to auto-confirm the package install.
Setup
Environment variables
DATAVERSE_TENANT_ID=your-azure-tenant-id
DATAVERSE_CLIENT_ID=your-app-registration-client-id
DATAVERSE_CLIENT_SECRET=your-client-secret
DATAVERSE_RESOURCE_URL=https://your-org.crm.dynamics.com
DATAVERSE_ENTITY_PREFIX=contoso_ # optional, default prefix filter for list_entities
DATAVERSE_SOLUTION_NAME=MySolution # optional, default solution unique name for list_entities
DATAVERSE_ALLOW_DELETE=true # optional, enable delete operations (disabled by default)
Azure App Registration
- Register an app in Azure AD
- Add API permission: Dynamics CRM > user_impersonation (or Application permissions)
- Create a client secret
- Grant the app a security role in Dataverse (e.g. System Administrator for full access)
Build
npm install
npm run build
Claude Code configuration (local build)
If you cloned the repo instead of using npx:
{
"mcpServers": {
"dataverse": {
"command": "node",
"args": ["./dist/index.js"]
}
}
}
Create a .env file with your credentials (see .env.example).
Safety
Destructive operations are disabled by default to prevent accidental data loss. All three delete tools are gated behind the same DATAVERSE_ALLOW_DELETE=true flag:
delete_recordβ removes a row and all its datadelete_attributeβ removes a column along with ALL values across every record (no recovery short of a full environment restore)delete_picklist_optionβ removes an option from an OptionSet; records that hold the option's integer value are left with an orphan number (no label in UI, broken reports)
When the flag is off, each tool registers as a stub that returns an instructional error instead of performing the delete. To enable, add DATAVERSE_ALLOW_DELETE=true to your .env file and restart the MCP server.
License
MIT
