npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

@rededis/dataverse-mcp-server

v0.4.0

Published

MCP server for Microsoft Dataverse API

Readme

dataverse-mcp-server

npm version npm downloads CI Node.js TypeScript License: MIT

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_NAME only scopes list_entities (schema browsing). Data tools (query_records, get_record, create_record, …) keep full access to any table regardless of solution membership — shared tables like account or contact remain 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) | | list_entity_keys | List alternate keys on a table (returns key_attributes, entity_key_index_status, …) | | add_entity_key | Create an alternate key (single or composite) — enables race-safe keyed-PATCH upserts | | delete_entity_key | Delete an alternate key and its supporting unique index (disabled by default, see Safety) |

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, then delete_attribute on 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

  1. Register an app in Azure AD
  2. Add API permission: Dynamics CRM > user_impersonation (or Application permissions)
  3. Create a client secret
  4. 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 four delete tools are gated behind the same DATAVERSE_ALLOW_DELETE=true flag:

  • delete_record — removes a row and all its data
  • delete_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)
  • delete_entity_key — drops an alternate key and its supporting unique index; any keyed-PATCH upsert flows relying on it stop working

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