How to integrate Bunnycdn MCP with Mastra AI

Trusted by
AWS
Glean
Zoom
Airtable

30 min · no commitment · see it on your stack

Bunnycdn logo
Mastra AI logo
divider

Introduction

This guide walks you through connecting Bunnycdn to Mastra AI using the Composio tool router. By the end, you'll have a working Bunnycdn agent that can create a new pull zone for static assets, list all dns zones in your bunnycdn account, delete a storage zone by its id through natural language commands.

This guide will help you understand how to give your Mastra AI agent real control over a Bunnycdn account through Composio's Bunnycdn MCP server.

Before we dive in, let's take a quick look at the key ideas and tools involved.

Also integrate Bunnycdn with

TL;DR

Here's what you'll learn:
  • Set up your environment so Mastra, OpenAI, and Composio work together
  • Create a Tool Router session in Composio that exposes Bunnycdn tools
  • Connect Mastra's MCP client to the Composio generated MCP URL
  • Fetch Bunnycdn tool definitions and attach them as a toolset
  • Build a Mastra agent that can reason, call tools, and return structured results
  • Run an interactive CLI where you can chat with your Bunnycdn agent

What is Mastra AI?

Mastra AI is a TypeScript framework for building AI agents with tool support. It provides a clean API for creating agents that can use external services through MCP.

Key features include:

  • MCP Client: Built-in support for Model Context Protocol servers
  • Toolsets: Organize tools into logical groups
  • Step Callbacks: Monitor and debug agent execution
  • OpenAI Integration: Works with OpenAI models via @ai-sdk/openai

What is the Bunnycdn MCP server, and what's possible with it?

The Bunnycdn MCP server is an implementation of the Model Context Protocol that connects your AI agent and assistants like Claude, Cursor, etc directly to your Bunnycdn account. It provides structured and secure access to your CDN resources, so your agent can perform actions like managing storage zones, configuring DNS records, creating pull zones, and retrieving zone details on your behalf.

  • Effortless storage zone management: Instantly add or delete storage zones in specific regions, letting your agent optimize file storage based on your needs.
  • Automated DNS configuration: Direct your agent to create, update, or remove DNS records and zones, helping you keep your domain setup fast and flexible.
  • Pull zone creation and removal: Have your agent set up new pull zones or clean up unused ones, streamlining your content delivery workflows with minimal manual intervention.
  • Detailed configuration and status retrieval: Ask your agent to fetch comprehensive details for any DNS or pull zone, ensuring you always have up-to-date insights into your CDN setup.
  • Full account overview and auditing: Let the agent list all your DNS zones and pull critical stats, making it easy to audit or review your Bunnycdn resources on demand.

Supported Tools & Triggers

Tools
Add Allowed RefererAdds a hostname to the allowed referer list for a pull zone.
Add Blocked IPTool to add an IP address to the blocked list of a pull zone.
Add Blocked RefererTool to add a blocked referer to a pull zone.
Add Storage ZoneTool to add a new storage zone.
Add/Update Edge RuleTool to add or update edge rules in a BunnyCDN pull zone for advanced traffic control.
Check DNS Zone AvailabilityTool to check if a DNS zone name is available for registration.
Check Pull Zone AvailabilityTool to check if a pull zone name is available for registration.
Check Storage Zone AvailabilityTool to check if a storage zone name is available.
Create DatabaseCreates a new Bunny Database (SQLite-compatible edge database).
Create DNS RecordTool to create a new DNS record in a specific DNS zone.
Create Live Live 2Tool to retrieve live metrics data for database groups.
Create Pull ZoneCreates a new CDN pull zone in BunnyCDN for content delivery acceleration.
Create Shield Rate LimitTool to create a new Shield rate limit rule for protecting against excessive requests.
Create Shield Zone Access ListTool to create a new custom access list in a Shield Zone.
Delete Container RegistryTool to delete a container registry from Magic Containers.
Delete DatabaseTool to delete a BunnyCDN database by its ID.
Delete DNS RecordTool to delete a specific DNS record by its ID.
Delete DNS ZoneTool to delete a specific DNS zone by its ID.
Delete Edge RuleTool to delete an Edge Rule from a Pull Zone by its ID.
Delete Database GroupTool to delete a specific database group by its ID.
Delete Pull ZoneTool to delete a specific pull zone by its ID.
Delete Shield Zone Access ListTool to delete a custom access list from a Shield Zone.
Delete Storage ZoneTool to delete a storage zone.
Generate 2FA VerificationTool to generate 2FA verification details for account security setup.
Generate Database Auth TokenTool to generate an authentication token for a BunnyCDN database.
Get Billing SummaryTool to retrieve billing summary with data report for each Pull Zone.
Get Container Config SuggestionsTool to get AI-powered configuration suggestions for deploying a container image on BunnyCDN's Magic Containers platform.
Get Container Image DigestTool to retrieve the digest of a container image from a registry.
Get DatabaseTool to retrieve details of a specific database by its ID.
Get Database StatisticsTool to retrieve time-series statistics for a Bunny Database instance.
Get DNS Zone DetailsTool to retrieve details of a specific DNS zone by its ID.
Get DNS Zone ListTool to list all DNS zones in your Bunny CDN account.
Get Database GroupTool to retrieve details of a specific database group by its ID.
Get LanguagesTool to retrieve the list of languages supported by BunnyCDN's video library.
Get Database LimitsTool to retrieve current database limits for the authenticated BunnyCDN account.
Get oEmbedTool to retrieve oEmbed metadata for BunnyCDN video embeds.
Get Optimal Base RegionTool to get the optimal base region for Magic Containers.
Get Optimizer StatisticsRetrieve optimizer statistics for a Pull Zone to understand optimization performance.
Get Origin Shield Queue StatisticsTool to retrieve Origin Shield Queue Statistics for a specific Pull Zone.
Get Pull ZoneTool to retrieve details of a specific Pull Zone.
Get Pull Zone ListRetrieve a paginated list of all Pull Zones in your BunnyCDN account.
Get SafeHop StatisticsTool to retrieve SafeHop statistics for a specific Pull Zone.
Get Shield Bot Detection ConfigurationTool to retrieve bot detection configuration for a specific Shield Zone.
Get Shield DDoS EnumsTool to retrieve available enums for Shield DDoS configuration.
Get Shield Event LogsTool to retrieve Shield Event Logs for a specific Shield Zone and date.
Get Shield Metrics Bot DetectionTool to retrieve bot detection metrics for a specific Shield Zone.
Get Shield Metrics OverviewTool to retrieve comprehensive security metrics overview for a Shield Zone.
Get Shield Metrics Overview DetailedTool to retrieve detailed Shield zone metrics overview including DDoS protection, WAF, bot detection, rate limiting, access lists, and upload scanning statistics.
Get Shield Metrics Rate Limit by IDTool to retrieve shield metrics for a specific rate limit by ID.
Get Shield Metrics Rate LimitsTool to retrieve rate limit metrics for a Shield Zone.
Get Shield Metrics Upload ScanningTool to retrieve upload scanning metrics for a specific Shield Zone.
Get Shield Metrics WAF RuleTool to retrieve shield metrics for a specific WAF rule.
Get Shield Promo StateTool to retrieve a breakdown of Shield promotional data.
Get Shield Rate Limit by IDTool to retrieve a specific rate limit configuration by its ID.
Get Shield Rate LimitsTool to retrieve Shield Rate Limits for a specific Shield Zone.
Get Shield Shield ZonesTool to retrieve a list of all Shield Zones with their configurations.
Get Shield Upload Scanning ConfigurationTool to retrieve upload scanning configuration for a Shield Zone.
Get Shield WAF Custom Rule by IDTool to retrieve details of a specific Shield WAF custom rule by its ID.
Get Shield WAF Custom RulesTool to retrieve custom WAF rules for a specific Shield Zone.
Get Shield WAF Engine ConfigTool to retrieve Shield WAF engine configuration settings.
Get Shield WAF EnumsTool to retrieve available enums for Shield WAF configuration.
Get Shield WAF ProfilesTool to retrieve available WAF profiles for Shield zones.
Get Shield WAF Rules Plan SegmentationTool to retrieve WAF rules organized by subscription plan tiers.
Get Shield WAF Rules Review TriggeredTool to retrieve triggered WAF rules for review in a specific Shield Zone.
Get Shield WAF Rules by Shield Zone IDTool to retrieve Shield WAF Rules for a specific Shield Zone.
Get Shield ZoneTool to retrieve detailed configuration of a specific Shield Zone.
Get Shield Zone Access ListTool to retrieve a specific custom access list from a Shield Zone.
Get Shield Zone Access List EnumsTool to retrieve available enums for Shield Zone Access List configuration.
Get Shield Zone Access ListsTool to retrieve all access lists for a Shield Zone, including both managed threat lists and custom lists.
Get Shield Zone by Pull Zone IDTool to retrieve Shield Zone details by Pull Zone ID.
Get Shield Zones Pull Zone MappingTool to retrieve the mapping between Shield Zones and Pull Zones.
Get StatisticsTool to retrieve CDN statistics data for bandwidth, requests, cache performance, and geographic distribution.
Get Storage Zone DetailsTool to retrieve the full details of a storage zone, including configuration, usage metrics, and credentials.
Get Storage Zone ListTool to list all storage zones in your Bunny CDN account.
Get User Audit LogTool to retrieve user audit log entries for a specific date with optional filtering.
Get User DetailsTool to retrieve complete details of the currently authorized user account.
Get User LimitsTool to retrieve user limits and quotas for Magic Containers.
Get What's New ItemsTool to retrieve What's New items for the current user.
Invalidate Database Auth TokensTool to invalidate all authentication tokens for a BunnyCDN database.
Invalidate Group Auth TokensTool to invalidate authentication tokens for a specific database group.
List API KeysTool to retrieve a paginated list of all API keys in your BunnyCDN account.
List ApplicationsTool to list all Magic Container applications in your Bunny CDN account.
List Container Image TagsTool to list all available tags for a container image in a registry.
List Container RegistriesTool to list all container registries in your BunnyCDN Magic Containers account.
List Country ListTool to retrieve the list of countries supported by BunnyCDN with their tax rates and Points of Presence.
List Database Active UsageTool to retrieve active database usage statistics.
List Database ConfigurationTool to retrieve database configuration including available storage regions, primary regions, and replica regions.
List Databases V2Tool to list databases with pagination support using the v2 API.
List Database UsageTool to retrieve aggregated usage metrics for a Bunny Database instance.
List Database VersionsTool to list all versions of a specific database.
List Edge ScriptsRetrieve a paginated list of all edge scripts in your BunnyCDN account.
List Database GroupsTool to retrieve a list of all database groups in your BunnyCDN account.
List Group StatisticsTool to retrieve time-series statistics for a database group.
List Database Group UsageTool to retrieve aggregated usage statistics for a database group over a specified time period.
List NodesTool to retrieve a list of Magic Container nodes in your BunnyCDN account.
List NotificationsTool to list all notifications for the currently logged in user.
List Region ListTool to retrieve the list of regions supported by BunnyCDN with their geographic coordinates and pricing.
List RegionsTool to list all available regions for Magic Containers.
List Video LibrariesRetrieve a paginated list of all video libraries in your BunnyCDN account.
List VolumesTool to list all volumes for a Magic Container application in your BunnyCDN account.
Post Shield WAF Rules Review TriggeredTool to review and apply actions to triggered WAF rules in a specific Shield Zone.
Purge Pull ZonePurges the entire CDN cache for a specified pull zone.
Purge URLPurge a specific URL from the BunnyCDN cache to force it to be refreshed from the origin.
Remove Allowed RefererRemoves a hostname from the allowed referer list for a pull zone.
Remove Blocked IPTool to remove an IP address from the blocked list of a pull zone.
Remove Blocked RefererTool to remove a blocked referer from a pull zone.
Reset Pull Zone Security KeyTool to reset the security token key for a specific pull zone.
Reset What's NewTool to reset the What's New notification list for the current user.
Restore DatabaseTool to restore a BunnyCDN database to a specific generation/version.
Search Global SearchPerform a global search across all BunnyCDN resources (pull zones, storage zones, DNS zones, scripts, streams).
Search Public Container ImagesTool to search for public container images by prefix in a registry.
Set Edge Rule EnabledTool to enable or disable an edge rule in a BunnyCDN pull zone.
Set Force SSLTool to set Force SSL on a pull zone hostname.
Set Notifications OpenedTool to mark all user notifications as opened.
Update DatabaseTool to update an existing Bunny Database.
Update Database GroupTool to update a database group by its ID.
Update Pull ZoneTool to update settings for a specific pull zone.
Update Shield Bot Detection ConfigurationTool to update bot detection configuration for a specific Shield Zone.
Update Shield Rate Limit by IDTool to update a specific rate limit configuration by its ID.
Update Shield ZoneTool to update configuration settings for a Shield Zone.
Update Shield Zone Access ListTool to update a custom access list in a Shield Zone.
Update Shield Zone Access List ConfigurationTool to update an access list configuration in a Shield Zone.
Update Shield Zone Upload ScanningTool to update upload scanning settings for a shield zone.
Update Storage ZoneTool to update settings for a specific storage zone.
Update User DetailsTool to update the currently authorized user's account details.
Validate Origin URL Pull ZoneTool to validate an origin URL before creating or configuring a pull zone.

What is the Composio tool router, and how does it fit here?

What is Composio SDK?

Composio's Composio SDK helps agents find the right tools for a task at runtime. You can plug in multiple toolkits (like Gmail, HubSpot, and GitHub), and the agent will identify the relevant app and action to complete multi-step workflows. This can reduce token usage and improve the reliability of tool calls. Read more here: Getting started with Composio SDK

The tool router generates a secure MCP URL that your agents can access to perform actions.

How the Composio SDK works

The Composio SDK follows a three-phase workflow:

  1. Discovery: Searches for tools matching your task and returns relevant toolkits with their details.
  2. Authentication: Checks for active connections. If missing, creates an auth config and returns a connection URL via Auth Link.
  3. Execution: Executes the action using the authenticated connection.

Step-by-step Guide

Prerequisites

Before starting, make sure you have:
  • Node.js 18 or higher
  • A Composio account with an active API key
  • An OpenAI API key
  • Basic familiarity with TypeScript

Getting API Keys for OpenAI and Composio

OpenAI API Key
  • Go to the OpenAI dashboard and create an API key.
  • You need credits or a connected billing setup to use the models.
  • Store the key somewhere safe.
Composio API Key
  • Log in to the Composio dashboard.
  • Go to Settings and copy your API key.
  • This key lets your Mastra agent talk to Composio and reach Bunnycdn through MCP.

Install dependencies

bash
npm install @composio/core @mastra/core @mastra/mcp @ai-sdk/openai dotenv

Install the required packages.

What's happening:

  • @composio/core is the Composio SDK for creating MCP sessions
  • @mastra/core provides the Agent class
  • @mastra/mcp is Mastra's MCP client
  • @ai-sdk/openai is the model wrapper for OpenAI
  • dotenv loads environment variables from .env

Set up environment variables

bash
COMPOSIO_API_KEY=your_composio_api_key_here
COMPOSIO_USER_ID=your_user_id_here
OPENAI_API_KEY=your_openai_api_key_here

Create a .env file in your project root.

What's happening:

  • COMPOSIO_API_KEY authenticates your requests to Composio
  • COMPOSIO_USER_ID tells Composio which user this session belongs to
  • OPENAI_API_KEY lets the Mastra agent call OpenAI models

Import libraries and validate environment

typescript
import "dotenv/config";
import { openai } from "@ai-sdk/openai";
import { Agent } from "@mastra/core/agent";
import { MCPClient } from "@mastra/mcp";
import { Composio } from "@composio/core";
import * as readline from "readline";

import type { AiMessageType } from "@mastra/core/agent";

const openaiAPIKey = process.env.OPENAI_API_KEY;
const composioAPIKey = process.env.COMPOSIO_API_KEY;
const composioUserID = process.env.COMPOSIO_USER_ID;

if (!openaiAPIKey) throw new Error("OPENAI_API_KEY is not set");
if (!composioAPIKey) throw new Error("COMPOSIO_API_KEY is not set");
if (!composioUserID) throw new Error("COMPOSIO_USER_ID is not set");

const composio = new Composio({
  apiKey: composioAPIKey as string,
});
What's happening:
  • dotenv/config auto loads your .env so process.env.* is available
  • openai gives you a Mastra compatible model wrapper
  • Agent is the Mastra agent that will call tools and produce answers
  • MCPClient connects Mastra to your Composio MCP server
  • Composio is used to create a Tool Router session

Create a Tool Router session for Bunnycdn

typescript
async function main() {
  const session = await composio.create(
    composioUserID as string,
    {
      toolkits: ["bunnycdn"],
    },
  );

  const composioMCPUrl = session.mcp.url;
  console.log("Bunnycdn MCP URL:", composioMCPUrl);
What's happening:
  • create spins up a short-lived MCP HTTP endpoint for this user
  • The toolkits array contains "bunnycdn" for Bunnycdn access
  • session.mcp.url is the MCP URL that Mastra's MCPClient will connect to

Configure Mastra MCP client and fetch tools

typescript
const mcpClient = new MCPClient({
    id: composioUserID as string,
    servers: {
      nasdaq: {
        url: new URL(composioMCPUrl),
        requestInit: {
          headers: session.mcp.headers,
        },
      },
    },
    timeout: 30_000,
  });

console.log("Fetching MCP tools from Composio...");
const composioTools = await mcpClient.getTools();
console.log("Number of tools:", Object.keys(composioTools).length);
What's happening:
  • MCPClient takes an id for this client and a list of MCP servers
  • The headers property includes the x-api-key for authentication
  • getTools fetches the tool definitions exposed by the Bunnycdn toolkit

Create the Mastra agent

typescript
const agent = new Agent({
    name: "bunnycdn-mastra-agent",
    instructions: "You are an AI agent with Bunnycdn tools via Composio.",
    model: "openai/gpt-5",
  });
What's happening:
  • Agent is the core Mastra agent
  • name is just an identifier for logging and debugging
  • instructions guide the agent to use tools instead of only answering in natural language
  • model uses openai("gpt-5") to configure the underlying LLM

Set up interactive chat interface

typescript
let messages: AiMessageType[] = [];

console.log("Chat started! Type 'exit' or 'quit' to end.\n");

const rl = readline.createInterface({
  input: process.stdin,
  output: process.stdout,
  prompt: "> ",
});

rl.prompt();

rl.on("line", async (userInput: string) => {
  const trimmedInput = userInput.trim();

  if (["exit", "quit", "bye"].includes(trimmedInput.toLowerCase())) {
    console.log("\nGoodbye!");
    rl.close();
    process.exit(0);
  }

  if (!trimmedInput) {
    rl.prompt();
    return;
  }

  messages.push({
    id: crypto.randomUUID(),
    role: "user",
    content: trimmedInput,
  });

  console.log("\nAgent is thinking...\n");

  try {
    const response = await agent.generate(messages, {
      toolsets: {
        bunnycdn: composioTools,
      },
      maxSteps: 8,
    });

    const { text } = response;

    if (text && text.trim().length > 0) {
      console.log(`Agent: ${text}\n`);
        messages.push({
          id: crypto.randomUUID(),
          role: "assistant",
          content: text,
        });
      }
    } catch (error) {
      console.error("\nError:", error);
    }

    rl.prompt();
  });

  rl.on("close", async () => {
    console.log("\nSession ended.");
    await mcpClient.disconnect();
    process.exit(0);
  });
}

main().catch((err) => {
  console.error("Fatal error:", err);
  process.exit(1);
});
What's happening:
  • messages keeps the full conversation history in Mastra's expected format
  • agent.generate runs the agent with conversation history and Bunnycdn toolsets
  • maxSteps limits how many tool calls the agent can take in a single run
  • onStepFinish is a hook that prints intermediate steps for debugging

Complete Code

Here's the complete code to get you started with Bunnycdn and Mastra AI:

typescript
import "dotenv/config";
import { openai } from "@ai-sdk/openai";
import { Agent } from "@mastra/core/agent";
import { MCPClient } from "@mastra/mcp";
import { Composio } from "@composio/core";
import * as readline from "readline";

import type { AiMessageType } from "@mastra/core/agent";

const openaiAPIKey = process.env.OPENAI_API_KEY;
const composioAPIKey = process.env.COMPOSIO_API_KEY;
const composioUserID = process.env.COMPOSIO_USER_ID;

if (!openaiAPIKey) throw new Error("OPENAI_API_KEY is not set");
if (!composioAPIKey) throw new Error("COMPOSIO_API_KEY is not set");
if (!composioUserID) throw new Error("COMPOSIO_USER_ID is not set");

const composio = new Composio({ apiKey: composioAPIKey as string });

async function main() {
  const session = await composio.create(composioUserID as string, {
    toolkits: ["bunnycdn"],
  });

  const composioMCPUrl = session.mcp.url;

  const mcpClient = new MCPClient({
    id: composioUserID as string,
    servers: {
      bunnycdn: {
        url: new URL(composioMCPUrl),
        requestInit: {
          headers: session.mcp.headers,
        },
      },
    },
    timeout: 30_000,
  });

  const composioTools = await mcpClient.getTools();

  const agent = new Agent({
    name: "bunnycdn-mastra-agent",
    instructions: "You are an AI agent with Bunnycdn tools via Composio.",
    model: "openai/gpt-5",
  });

  let messages: AiMessageType[] = [];

  const rl = readline.createInterface({
    input: process.stdin,
    output: process.stdout,
    prompt: "> ",
  });

  rl.prompt();

  rl.on("line", async (input: string) => {
    const trimmed = input.trim();
    if (["exit", "quit"].includes(trimmed.toLowerCase())) {
      rl.close();
      return;
    }

    messages.push({ id: crypto.randomUUID(), role: "user", content: trimmed });

    const { text } = await agent.generate(messages, {
      toolsets: { bunnycdn: composioTools },
      maxSteps: 8,
    });

    if (text) {
      console.log(`Agent: ${text}\n`);
      messages.push({ id: crypto.randomUUID(), role: "assistant", content: text });
    }

    rl.prompt();
  });

  rl.on("close", async () => {
    await mcpClient.disconnect();
    process.exit(0);
  });
}

main();

Conclusion

You've built a Mastra AI agent that can interact with Bunnycdn through Composio's Tool Router. You can extend this further by:
  • Adding other toolkits like Gmail, Slack, or GitHub
  • Building a web-based chat interface around this agent
  • Using multiple MCP endpoints to enable cross-app workflows

How to build Bunnycdn MCP Agent with another framework

FAQ

What are the differences in Tool Router MCP and Bunnycdn MCP?

With a standalone Bunnycdn MCP server, the agents and LLMs can only access a fixed set of Bunnycdn tools tied to that server. However, with the Composio Tool Router, agents can dynamically load tools from Bunnycdn and many other apps based on the task at hand, all through a single MCP endpoint.

Can I use Tool Router MCP with Mastra AI?

Yes, you can. Mastra AI fully supports MCP integration. You get structured tool calling, message history handling, and model orchestration while Tool Router takes care of discovering and serving the right Bunnycdn tools.

Can I manage the permissions and scopes for Bunnycdn while using Tool Router?

Yes, absolutely. You can configure which Bunnycdn scopes and actions are allowed when connecting your account to Composio. You can also bring your own OAuth credentials or API configuration so you keep full control over what the agent can do.

How safe is my data with Composio Tool Router?

All sensitive data such as tokens, keys, and configuration is fully encrypted at rest and in transit. Composio is SOC 2 Type 2 compliant and follows strict security practices so your Bunnycdn data and credentials are handled as safely as possible.

Used by agents from

Context
Letta
glean
HubSpot
Agent.ai
Altera
DataStax
Entelligence
Rolai
Context
Letta
glean
HubSpot
Agent.ai
Altera
DataStax
Entelligence
Rolai
Context
Letta
glean
HubSpot
Agent.ai
Altera
DataStax
Entelligence
Rolai

Never worry about agent reliability

We handle tool reliability, observability, and security so you never have to second-guess an agent action.