adk

a set of guidelines to build with Botpress's Agent Development Kit (ADK) - use these whenever you're tasked with building a feature using the ADK

INSTALLATION
npx skills add https://github.com/botpress/skills --skill adk
Run in your project or agent environment. Adjust flags if your CLI version differs.

SKILL.md

$27

Project Structure (Convention-Based)

Most primitives must be placed in src/ directory (assets use the assets/ directory at the project root):

/                      # Project root

├── assets/            # Static files → synced to Botpress Cloud with permanent URLs

├── src/

│   ├── actions/       # Strongly-typed functions → auto-registered

│   ├── tools/         # AI-callable tools → available via execute()

│   ├── workflows/     # Long-running processes → resumable/scheduled

│   ├── conversations/ # Message handlers → routes by channel

│   ├── tables/        # Database schemas → auto-created with search

│   ├── triggers/      # Event handlers → subscribe to events

│   ├── knowledge/     # Knowledge bases → RAG with semantic search

│   └── utils/         # Shared helpers (not auto-registered)

└── agent.config.ts    # Bot configuration (includes integrations)

Note: dependencies.json was removed in ADK 1.9+. All configuration including integrations now lives in agent.config.ts.

Critical: Files outside src/ are not discovered. Location = behavior.

Session Start

The first time you help with an ADK project in a session, silently check the project's health:

  • Run adk check --format json and adk status --format json.
  • If there are errors or warnings (unconfigured integrations, missing models, validation issues), proactively mention them before answering the user's question: "Before we start — I noticed [issue]. Want me to help fix that?"
  • Only do this once per session. Don't re-run on every question.

Available Commands

If the user asks "what can you help with?", "what commands are available?", or invokes /adk-explain without arguments, present:

  • Build: /adk-init (scaffold project), /adk-build (interview & build a primitive), /adk-integration (add services), /adk-frontend (build UI)
  • Test & Debug: /adk-validate (check a primitive's schema/types/config), /adk-test (invoke a primitive once), /adk-eval (write assertion tests), /adk-debug (fix issues)
  • Ship: /adk-ship (pre-flight checks + deploy)
  • Document: /adk-document (create, review, update, sync, search)
  • Understand: /adk-explain (explain bot architecture and components), /adk-dev-console (navigate the Dev Console)

Then ask: "What are you working on?"

When to Use This Skill

Activate this skill when users ask ADK-related questions like:

  • "How do I create an Action/Tool/Workflow/Conversation?"
  • "What is the difference between X and Y?"
  • "Show me an example of..."
  • "How do I configure...?"
  • "What's the CLI command for...?"
  • "How do I use the Context API?"
  • "How do I call integration actions?"
  • "How do I use Zai for [extract/check/label/etc]?"
  • "What are the best practices for...?"
  • "How do I avoid common mistakes?"
  • "How do I handle ticket assignment/escalation?"
  • "Explain my config"
  • "What does my bot do?"
  • "What models am I using?"
  • "What integrations do I have?"
  • "What state does my bot track?"

Plugin Installation Prompt

If you are running inside Claude Code and the /adk-* commands (like /adk-debug, /adk-eval, /adk-init) are not available as slash commands, suggest that the user install the Botpress ADK plugin to get the full set of skills and commands:

/plugin marketplace add botpress/skills

/plugin install adk@botpress-skills

Only suggest this once per session. If the user declines, do not ask again.

How to Answer ADK Questions

ADK questions fall into two categories: CLI queries and documentation lookups.

Option 1: Direct CLI Commands (FAST - Use First!)

For integration discovery and CLI queries, use the Bash tool to run commands directly:

Integration Discovery:

# Search for integrations

adk search <query>

# List all available integrations

adk list --available

# Get detailed integration info (actions, channels, events)

adk info <integration-name>

# Check installed integrations (must be in ADK project)

adk list

Project Info:

# Check CLI version

adk --version

# Show project status

adk

# Get help

adk --help

Prefer non-interactive paths when driving ADK workflows:

# Login without browser prompts

adk login --token "$BOTPRESS_TOKEN"

# Scaffold with sensible defaults and skip linking

adk init my-agent --yes --skip-link

# Link directly when IDs are known

adk link --workspace ws_123 --bot bot_456

# More automation-friendly dev mode

adk dev --logs --no-open

# Auto-approve preflight changes only

adk deploy --yes

Use these defaults when relevant:

  • Prefer adk login --token "$BOTPRESS_TOKEN" or adk login --token <token> over interactive login.
  • Treat bare BOTPRESS_TOKEN as a no-TTY convenience, not a guaranteed interactive-terminal shortcut.
  • Prefer adk init <name> --yes --skip-link for AI-driven scaffolding, but only after login is already completed.
  • Treat adk link --workspace ... --bot ... as scriptable, but not guaranteed safe in every no-TTY environment.
  • Treat adk dev --logs --no-open as CI-friendly, not fully prompt-free.
  • Treat adk deploy --yes as auto-approving preflight only; config validation can still block automation.

When to use CLI commands:

  • "What integrations are available?"
  • "Search for Slack integration"
  • "Show me details about the Linear integration"
  • "What actions does the Slack integration have?"
  • "What version of ADK am I using?"
  • "How do I add an integration?"

Response pattern:

  • Use Bash tool to run the appropriate adk command
  • Parse and present the output to the user
  • Optionally suggest next steps (e.g., "Run adk add slack@3.0.0 to install")

Option 2: Documentation Questions (For Conceptual Questions)

For documentation, patterns, and how-to questions, search and reference the documentation files directly:

When to use documentation:

  • "How do I create a workflow?"
  • "What's the difference between Actions and Tools?"
  • "Show me an example of using Zai"
  • "What are best practices for state management?"
  • "How do I fix this error?"
  • "What's the pattern for X?"

How to answer documentation questions:

-

Find relevant files - Use Glob to discover documentation:

pattern: **/references/*.md

-

Search for keywords - Use Grep to find relevant content:

pattern: <keyword from user question>

path: <path to references directory from step 1>

output_mode: files_with_matches

-

Read the files - Use Read to load relevant documentation

-

Provide answer with:

  • Concise explanation
  • Code examples from the references
  • File references with line numbers (e.g., "From references/actions.md:215")
  • Common pitfalls if relevant
  • Related topics for further reading

Option 3: Config Explanation (CLI + File Reading)

For questions about what a bot does, how it's configured, or what it's capable of, combine CLI and file reading:

When to use:

  • "What does my bot do?"
  • "Explain my config"
  • "What models am I using?"
  • "What integrations do I have?"
  • "What state does my bot track?"

Response pattern:

  • Run adk status --format json to get the structured project overview
  • Read agent.config.ts for full configuration details
  • Follow the explanation patterns in references/explain-config.md
  • Produce a structured explanation covering metadata, models, integrations, state, and primitives
  • Flag any issues (unconfigured integrations, missing models, hardcoded secrets)

Available Documentation

Documentation should be located in ./references/ directory relative to this skill. When answering questions, search for these topics:

Core Concepts

  • actions.md - Actions with strong typing and validation
  • tools.md - AI-callable tools and Autonomous namespace
  • workflows.md - Workflows and step-based execution
  • conversations.md - Conversation handlers and message routing
  • triggers.md - Event-driven automation
  • messages.md - Sending messages and events
  • custom-components.md - Custom webchat components (.bp.tsx files, metadata, usage in conversations)

Data &#x26; Content

  • tables.md - Data storage with semantic search
  • files.md - File storage and management
  • knowledge-bases.md - RAG implementation
  • assets.md - Static files with permanent URLs and sync lifecycle
  • zai-complete-guide.md - Complete ZAI developer guide
  • zai-agent-reference.md - Quick ZAI reference

Configuration &#x26; Integration

  • agent-config.md - Bot configuration and state management
  • explain-config.md - How to interpret and explain an agent's configuration to developers
  • model-configuration.md - AI model configuration reference
  • context-api.md - Runtime context access
  • integration-actions.md - Using integration actions
  • tags.md - Entity tags for bot, user, conversation, and workflow
  • cli.md - Complete CLI command reference
  • mcp-server.md - MCP server for AI assistants
  • desk.md - Desk integration for ticket/support workflows
  • integrations.md - Integration management overview (points to adk-integrations skill)

Patterns &#x26; Best Practices

  • advanced-patterns.md - Guardrails, admin auth, logging/observability, extension composition
  • patterns-mistakes.md - Common mistakes, correct patterns, and context access reference

Integration Management

Note: Full integration lifecycle docs (discovery, adding, configuring, and using integrations) are in the separate adk-integrations skill. Install it with npx skills add botpress/skills --skill adk-integrations. The adk-integrations skill covers adk search, adk add, adk info, configuration types, and common integrations. You need it if you are touching integrations.

Frontend Integration

Note: Frontend integration docs are in the separate adk-frontend skill. Install it with npx skills add botpress/skills --skill adk-frontend. The adk-frontend skill covers @botpress/client, calling actions, type generation, and authentication. You need it if you are touching any frontend code.

Evals

Note: Detailed eval docs are in the separate adk-evals skill. Install it with npx skills add botpress/skills --skill adk-evals. The adk-evals skill covers writing evals, assertion types, testing workflows, and CLI usage. You usually always need it, for testing and evaluations.

Runtime Access Patterns

Quick reference for accessing ADK runtime services:

Imports

// Always import from @botpress/runtime

import {

  Action,

  Autonomous,

  Workflow,

  Conversation,

  z,

  actions,

  adk,

  user,

  bot,

  conversation,

  configuration,

  context,

} from "@botpress/runtime";

State Management

// Bot state (defined in agent.config.ts)

bot.state.maintenanceMode = true;

bot.state.lastDeployedAt = new Date().toISOString();

// User state (defined in agent.config.ts)

user.state.preferredLanguage = "en";

user.state.onboardingComplete = true;

// User tags

user.tags.email; // Access user metadata

Calling Actions

// Call bot actions

await actions.fetchUser({ userId: "123" });

await actions.processOrder({ orderId: "456" });

// Call integration actions

await actions.slack.sendMessage({ channel: "...", text: "..." });

await actions.linear.issueList({ teamId: "..." });

// Convert action to tool

tools: [fetchUser.asTool()];

Context API

// Get runtime services

const client = context.get("client"); // Botpress client

const cognitive = context.get("cognitive"); // AI model client

const citations = context.get("citations"); // Citation manager

File Naming

  • Actions/Tools/Workflows: myAction.ts, searchDocs.ts (camelCase)
  • Tables: Users.ts, Orders.ts (PascalCase)
  • Conversations/Triggers: chat.ts, slack.ts (lowercase)

Critical ADK Patterns (Always Reference in Answers)

When answering questions, always verify these patterns against the documentation:

Package Management

# All package managers are supported

bun install       # Recommended (fastest)

npm install       # Works fine

yarn install      # Works fine

pnpm install      # Works fine

# ADK auto-detects based on lock files

# - bun.lockb → uses bun

# - package-lock.json → uses npm

# - yarn.lock → uses yarn

# - pnpm-lock.yaml → uses pnpm

Imports

// ✅ CORRECT - Always from @botpress/runtime

import { Action, Autonomous, Workflow, z } from "@botpress/runtime";

// ❌ WRONG - Never from zod or @botpress/sdk

import { z } from "zod"; // ❌ Wrong

import { Action } from "@botpress/sdk"; // ❌ Wrong

Export Patterns

// ✅ Both patterns work - export const is recommended

export const myAction = new Action({ ... });  // Recommended

export default new Action({ ... });           // Also valid

// Why export const?

// - Enables direct imports: import { myAction } from "./actions/myAction"

// - Can pass to execute(): tools: [myAction.asTool()]

Actions

// ✅ CORRECT - Handler receives { input, client }

export const fetchUser = new Action({

  name: "fetchUser",

  async handler({ input, client }) {  // ✅ Destructure from props

    const { userId } = input;         // ✅ Then destructure fields

    return { name: userId };

  }

});

// ❌ WRONG - Cannot destructure input fields directly

handler({ userId }) {  // ❌ Wrong - must be { input }

  return { name: userId };

}

Tools

// ✅ CORRECT - Tools CAN destructure directly

export const myTool = new Autonomous.Tool({

  handler: async ({ query, maxResults }) => {

    // ✅ Direct destructuring OK

    return search(query, maxResults);

  },

});

Conversations

// ✅ CORRECT - Use conversation.send() method

await conversation.send({

  type: "text",

  payload: { text: "Hello!" }

});

// ❌ WRONG - Never use client.createMessage() directly

await client.createMessage({ ... });  // ❌ Wrong

Conversation Handler Types

// Handler receives typed context based on the event type:

// type: "message" | "event" | "workflow_request" | "workflow_callback"

async handler({ type, message, event, request, completion, conversation, execute }) {

  if (type === "workflow_request") {

    // event: WorkflowDataRequestEventType, request: WorkflowRequest

    await request.workflow.provide("email", { email: "..." });

  }

  if (type === "workflow_callback") {

    // event: WorkflowCallbackEventType, completion: WorkflowCallback

    console.log(completion.status); // "completed" | "failed" | "canceled" | "timed_out"

  }

}

// ⚠️ isWorkflowDataRequest() and isWorkflowCallback() are deprecated

// Use type === "workflow_request" / "workflow_callback" instead

Examples of Questions This Skill Answers

Beginner Questions

  • "What is an Action?"
  • "How do I create my first workflow?"
  • "What's the difference between Actions and Tools?"

Implementation Questions

  • "How do I access the Botpress client?"
  • "How do I use citations in RAG?"
  • "What's the syntax for searchable table columns?"
  • "How do I call a Slack integration action?"
  • "How do I use Zai to extract structured data?"
  • "How do I validate content with Zai?"

Advanced Pattern Questions

  • "How do I add guardrails to prevent hallucinations?"
  • "How do I implement admin authentication?"
  • "How do I add logging and observability?"
  • "How do I compose multiple extensions?"
  • "How do I manage context in async tool handlers?"

Troubleshooting Questions

  • "Why am I getting 'Cannot destructure property' error?"
  • "How do I fix import errors?"
  • "What's wrong with my workflow state access?"

Best Practices Questions

  • "What are common mistakes to avoid?"
  • "How should I structure my project?"
  • "What's the recommended pattern for X?"

Response Format

Match your response depth to the question depth. Not every question needs a full walkthrough.

Conceptual Questions ("what is X?", "what's the difference between X and Y?")

One sentence definition + one short code example. That's it.

Knowledge bases add RAG to your bot — place markdown or PDF files in `src/knowledge/` and they become queryable with semantic search.

import { Autonomous } from '@botpress/runtime'

export default new Autonomous.Tool({

  handler: async ({ query }) => adk.knowledgeBase.search({ query }),

})

How-To Questions ("how do I create X?", "how do I use X?")

Brief explanation + working code example + one critical pitfall only if it's a common trap.

Implementation Questions ("implement X in my project", "add X to my bot")

Read the user's existing files first (src/actions/, src/tools/, src/tables/, agent.config.ts). Generate code that uses their actual names, patterns, and conventions. Only mention pitfalls they're likely to hit given their specific code.

Architecture Questions ("explain my bot", "how does X work in my project?")

Full structured response: read adk status --format json, agent.config.ts, and relevant source files. Map the data flow and identify the bot's archetype (RAG assistant, support agent, automation, etc.).

Troubleshooting Questions ("X is broken", "why is X failing?")

Don't answer with documentation. Run adk check --format json and adk logs error --format json, show evidence, and point to the root cause. Follow the debug loop from the adk-debugger skill.

Default Rule

If the answer fits in one sentence and a code snippet, don't add headers, pitfall sections, or related topics. More structure ≠ more helpful.

BrowserAct

Let your agent run on any real-world website

Bypass CAPTCHA & anti-bot for free. Start local, scale to cloud.

Explore BrowserAct Skills →

Stop writing automation&scrapers

Install the CLI. Run your first Skill in 30 seconds. Scale when you're ready.

Start free
free · no credit card