Skip to main content
Glama

woocommerce-mcp

A small, read-only Model Context Protocol server for WordPress + WooCommerce. It lets Claude (or any MCP client) answer questions about a live store — products, orders, sales, and blog posts — over the official REST APIs. No writes, no plugins to install on the store: it talks to the existing WordPress/WooCommerce REST endpoints.

Built and maintained by WPPoland — senior WordPress & WooCommerce engineering.

Tools

Tool

What it does

Needs WooCommerce keys

list_products

List / search products (name, sku, price, stock, permalink)

yes

get_product

Full details for one product by id

yes

list_orders

Recent orders, newest first, optional status filter

yes

sales_report

Sales totals for a period (week / month / last_month / year)

yes

search_posts

Search published blog posts (public WP REST API)

no

Everything is read-only. The server never creates, edits, or deletes anything in the store.

Related MCP server: WooCommerce MCP Server by CData

Install & build

git clone https://github.com/wppoland/woocommerce-mcp.git
cd woocommerce-mcp
npm install
npm run build

Configure

Set three environment variables:

Var

Required

Example

WP_URL

yes

https://shop.example.com

WC_CONSUMER_KEY

for wc_* tools

ck_xxx

WC_CONSUMER_SECRET

for wc_* tools

cs_xxx

Create the WooCommerce keys in WooCommerce → Settings → Advanced → REST API → Add key with Read permission. search_posts works without keys against any public WordPress site.

The keys are sent to your own store over HTTPS as REST query auth. Use HTTPS, and give the key Read access only.

Use with Claude Desktop / Claude Code

Add to your MCP client config (e.g. claude_desktop_config.json):

{
  "mcpServers": {
    "woocommerce": {
      "command": "node",
      "args": ["/absolute/path/to/woocommerce-mcp/dist/index.js"],
      "env": {
        "WP_URL": "https://shop.example.com",
        "WC_CONSUMER_KEY": "ck_xxx",
        "WC_CONSUMER_SECRET": "cs_xxx"
      }
    }
  }
}

Then ask things like "What were last month's WooCommerce sales?" or "List the 5 most recent orders that are on hold."

Verify

npm run check   # builds, then asserts all five tools register (no network/credentials needed)

Notes

  • Node 18+ (uses the built-in fetch).

  • Logs go to stderr so they never corrupt the stdio MCP protocol on stdout.

  • API errors are surfaced with the store's message; credentials are never echoed.

License

MIT © WPPoland

Install Server
A
license - permissive license
A
quality
C
maintenance

Maintenance

Maintainers
Response time
Release cycle
Releases (12mo)
Commit activity

Resources

Unclaimed servers have limited discoverability.

Looking for Admin?

If you are the server author, to access and configure the admin panel.

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/wppoland/woocommerce-mcp'

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