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

@porkbunllc/mcp-server

v0.11.0

Published

Porkbun MCP server — exposes the Porkbun v3 API as tools for AI agents (Claude Desktop, Cursor, etc.)

Downloads

903

Readme

Porkbun MCP Server

npm version npm downloads License: MIT

A Model Context Protocol server that exposes the Porkbun v3 API as native tools for AI agents — Claude Desktop, Cursor, Cline, and any other MCP-compatible client.

Status: v0.11.0 — covers everything you can do in the Porkbun web UI, plus outbound webhooks. All write operations attach an Idempotency-Key automatically, so retries within 24 hours don't double-charge.

What's included (46 tools)

Read tools (free, no spend, no state changes)

| Tool | Description | |---|---| | ping | Verify API connectivity and credentials | | check_domain | Check availability and pricing for a single domain | | get_registration_requirements | TLD registration requirements as JSON Schema — is it API-registerable, the create payload, and registry eligibility fields (.us nexus, .ca legal type, …) | | get_pricing | Get registration/renewal/transfer pricing for all TLDs (no auth needed) | | list_marketplace | Browse the Porkbun aftermarket — filter by TLD, max price, name substring | | list_domains | Paginate through domains; filter by tld, expiry, auto-renew, API access | | get_domain | Get metadata for a single domain in the account | | get_balance | Get account credit balance | | get_api_settings | Get monthly spend limit, low-balance alert, auto top-up config, MTD spend | | get_nameservers | Get current nameservers for a domain | | list_dns_records | List DNS records for a domain | | list_dnssec_records | List DNSSEC DS records published at the registry | | list_url_forwards | List URL forwarding rules for a domain | | list_glue_records | List glue records (host-to-IP mappings) for a domain | | list_transfers | List in-progress and recent inbound transfers | | get_transfer_status | Get status of a specific inbound transfer | | get_ssl_bundle | Retrieve the free Porkbun-issued SSL bundle for a domain | | get_webhook_event_types | List the event types a webhook endpoint can subscribe to | | list_webhooks | List webhook endpoints (URL, events, status, delivery health, secret) | | get_webhook | Get a single webhook endpoint by id | | list_webhook_deliveries | List recent delivery attempts (status, attempts, HTTP, error); ~30-day history | | get_webhook_delivery | Get a single delivery incl. the full signed payload | | list_doc_topics | List Porkbun API doc topics (the docs index) | | read_doc | Read a doc page as Markdown (dns, webhooks, … or overview/full) | | search_docs | Keyword-search the full reference; returns the most relevant sections |

The list_doc_topics / read_doc / search_docs tools let an agent ground itself in Porkbun's own documentation (the /llms Markdown surface) mid-conversation — no web browsing required, and no API credentials needed. You can add the server purely to research the API, then supply keys when you're ready for live operations.

Domain lifecycle writes (spend account credit)

| Tool | Description | |---|---| | register_domain | Register a new domain — call check_domain first to confirm price | | renew_domain | Renew an existing domain | | transfer_domain | Initiate an inbound transfer (returns transferId; takes 5-7 days) |

Domain settings writes (free)

| Tool | Description | |---|---| | update_auto_renew | Turn auto-renewal on or off | | update_nameservers | Replace the nameserver list for a domain (full replace, not append) |

DNS / DNSSEC / URL-forwarding / glue writes (free)

| Tool | Description | |---|---| | create_dns_record | Create a new DNS record (A, AAAA, CNAME, MX, TXT, etc.) | | update_dns_record | Update an existing DNS record by its ID | | delete_dns_record | Delete a DNS record by its ID | | create_dnssec_record | Submit a DNSSEC DS record to the registry | | delete_dnssec_record | Remove a DNSSEC DS record by key tag | | create_url_forward | Create a URL forwarding rule | | delete_url_forward | Delete a URL forwarding rule by ID | | create_glue_record | Create a glue record (host-to-IP mapping at the registry) | | update_glue_record | Replace the IP list for a glue record | | delete_glue_record | Delete a glue record by host |

Webhook writes (free)

| Tool | Description | |---|---| | create_webhook | Register an HTTPS endpoint to receive signed event payloads; returns the signing secret | | update_webhook | Change an endpoint's URL, events, or status (ACTIVE/DISABLED) | | rotate_webhook_secret | Generate a new signing secret for an endpoint | | test_webhook | Send a webhook.test event to confirm reachability and signature verification | | resend_webhook | Re-queue a past delivery (reuses the original event id) | | delete_webhook | Delete a webhook endpoint |

Porkbun POSTs a signed JSON payload to your endpoint when subscribed events occur (domain.registered, domain.renewed, domain.transfer.completed, domain.expiring, dns.record.created|updated|deleted). Verify the X-Porkbun-Signature header — it's sha256= + HMAC-SHA256 of {timestamp}.{rawBody} keyed by the endpoint secret, where {timestamp} is the X-Porkbun-Webhook-Timestamp header.

Install

You'll need Node.js 18 or newer.

npx -y @porkbunllc/mcp-server

This downloads and runs the latest version on demand. No global install needed.

Configure your MCP client

Claude Desktop

Add this to ~/Library/Application Support/Claude/claude_desktop_config.json (macOS) or %APPDATA%\Claude\claude_desktop_config.json (Windows):

{
  "mcpServers": {
    "porkbun": {
      "command": "npx",
      "args": ["-y", "@porkbunllc/mcp-server"],
      "env": {
        "PORKBUN_API_KEY": "pk1_your_public_key_here",
        "PORKBUN_SECRET_API_KEY": "sk1_your_secret_key_here"
      }
    }
  }
}

Restart Claude Desktop. Porkbun tools should appear in the tool picker.

Docs-only, no keys: the documentation tools (search_docs, read_doc, list_doc_topics) work without credentials, so you can omit the env block entirely to use the server just for API research. The authenticated tools return a clear "set PORKBUN_API_KEY" message until you add keys.

Cursor / Cline / Continue

Most MCP-aware editors use a similar mcpServers config block. See your client's documentation for the exact location.

Get API keys

Create API keys at porkbun.com/account/api. You'll need both the public key (pk1_…) and the secret key (sk1_…).

By default, API access is opt-in per domain. To use the API to manage all your domains, enable the "Opt In All Domains" toggle in the same settings page. Otherwise you'll need to enable API access for each domain individually under Domain Management.

Recommended: scope the key to your agent

Each API key supports two optional restrictions, set via the gear icon next to the key in porkbun.com/account/api:

  • Allowed IPs — one entry per line; supports bare IPv4/IPv6 plus CIDR ranges (198.51.100.0/24, 2001:db8::/32). Requests from other IPs fail with HTTP 403 IP_NOT_ALLOWED before any other check runs.
  • Allowed domains — one entry per line, exact match. Operations against domains not in the list fail with HTTP 403 DOMAIN_NOT_ALLOWED.

Empty fields = no restriction (matches current behavior). When you give an MCP server a key, the recommended pattern is:

  1. Create a fresh key dedicated to the agent (not your master key).
  2. List the specific domains the agent should manage.
  3. If you know the agent's egress IP, list it too.

The blast radius of an accidentally-leaked key drops to "operations on these domains from this IP" instead of "anything on the account."

Environment variables

| Variable | Required | Purpose | |---|---|---| | PORKBUN_API_KEY | for live ops | Your Porkbun public API key. Omit to use only the credential-free documentation tools. | | PORKBUN_SECRET_API_KEY | for live ops | Your Porkbun secret API key. Omit to use only the credential-free documentation tools. | | PORKBUN_BASE_URL | no | Override the API base URL (e.g. for testing against api-betamax.porkbun.com/api/json/v3) | | PORKBUN_DOCS_BASE | no | Override the docs host used by the *_doc(s) tools (default https://porkbun.com) |

Local development

git clone https://github.com/oborseth/Porkbun-MCP.git
cd Porkbun-MCP
npm install
npm run build
npm start          # or: node dist/index.js

The server speaks JSON-RPC 2.0 over stdio. Smoke test from a shell:

(printf '%s\n' \
  '{"jsonrpc":"2.0","id":1,"method":"initialize","params":{"protocolVersion":"2024-11-05","capabilities":{},"clientInfo":{"name":"test","version":"1.0"}}}' \
  '{"jsonrpc":"2.0","method":"notifications/initialized"}' \
  '{"jsonrpc":"2.0","id":2,"method":"tools/list"}') \
  | PORKBUN_API_KEY=pk1_… PORKBUN_SECRET_API_KEY=sk1_… node dist/index.js

Reliability

All write operations (when added in future releases) will automatically attach a per-call Idempotency-Key header. Retried calls within 24 hours return the cached response — your agent can safely retry on network errors without double-charging.

License

MIT

Links