Rook is a standalone, autonomous security agent for vulnerability research, bug hunting and source-code auditing. It is a single Go executable built on the ChatBotKit Go SDK, with a library of security skills embedded directly into the binary - no external files, no setup beyond an API key.
Give Rook a target and a scope, and it works through the problem the way a researcher would: reconnaissance, analysis, hypothesis, verification, and a written report.
⚠️ Authorized use only. Rook is an offensive-security tool. Only run it against systems, code and services you own or are explicitly authorized to test. Always pass an explicit--scope.
A single binary, a plain-English task, and an explicit scope. Each example below is backed by Rook's built-in skills:
# Source-code audit - injection, IDOR and broken access control
rook --scope "repo: ./api, read-only, no network" \
"Audit ./api for SQL injection, IDOR and auth bypass"
# Web app / API - SSRF in a URL-fetching feature (authorized target)
rook --scope-file scope.txt \
"Test the link-preview endpoint on staging.example.com for SSRF to cloud metadata"
# External recon & OSINT - map an organisation's attack surface
rook --scope "domain: example.com + subdomains, passive recon only" \
"Map example.com's external surface: subdomains, exposed services and leaked secrets"
# Cloud misconfiguration - read-only review
rook --scope "AWS, describe/list only, no mutations" \
"Check for public S3 buckets, over-permissive IAM roles and IMDS exposure"
# Smart-contract audit
rook --scope "repo: ./contracts" \
"Audit the Solidity contracts for reentrancy, access-control and oracle bugs"
# Supply chain - dependencies and CI exposure
rook --scope "repo: ., read-only" \
"Review dependencies for known CVEs and flag supply-chain risks"Rook also covers OAuth/SAML/JWT flaws, file-upload and SSTI/RCE chains, business-logic and race conditions, HTTP request smuggling, and enterprise identity/infrastructure attack surfaces (M365/Entra, Okta, VPN appliances, vCenter, SharePoint) - see the full skill library.
Security work happens in awkward places - a hardened bastion, an air-gapped network, a throwaway cloud VM, a CI runner, someone else's laptop during an engagement. Rook is built for exactly those:
- One single executable. Everything - the agent loop, the tools, and the
entire skill library - is compiled into one binary via Go's
embed. There is no runtime to install, no interpreter, nonode_modules, no virtualenv, no config files to ship alongside it. Download one file,chmod +x, run. - Portable everywhere. Statically linked (
CGO_ENABLED=0) and cross-compiled for Linux, macOS and Windows on both amd64 and arm64. The same tool drops onto an Apple-silicon laptop, an x86 server, or an ARM box with no changes. Nothing to match against the host's libraries or OS version. - Nothing to fetch at runtime. Because the skills are baked in, Rook works
in locked-down or offline environments where you can't
pip installor pull containers. Its only external dependency is the ChatBotKit API (and your key). - The hard parts run as a service. This is the real reason Rook feels so light. The AI agent harness - model orchestration, the reasoning and tool-execution loop, skill handling, scaling and reliability - runs as a managed service on ChatBotKit, built and maintained by a dedicated team of engineers who do only this. The binary doesn't reimplement any of that complexity; it embeds the skills and streams the conversation. So the agent itself stays small and focused on the task at hand, and you inherit harness improvements without shipping a new build.
- Trivial to distribute and audit. A single artifact with a published checksum is easy to vet, copy onto a target box, version-pin, and remove cleanly afterwards - important when you're operating inside someone else's scope.
- Purpose-built, not a general chatbot. Rook ships as a focused vulnerability-research and bug-hunting agent: it knows the methodology, the bug classes, and the reporting discipline out of the box, and stays within the authorization boundary you give it.
In short: the value isn't just "an AI security agent" - it's an AI security agent you can carry anywhere as one file and run with zero setup.
- Single self-contained binary. The skill library is compiled into the
executable via Go's
embed, so it ships and runs as one file. - Autonomous agent loop. Built on the Go SDK's
agent.ExecuteWithTools- the agent plans, acts, tracks progress and exits on its own, bounded by--max-iterations. - Built-in tools. File read/write/edit and sandboxed shell execution via
the SDK's
DefaultTools. - Embedded skill library. Phase-by-phase security playbooks (see below) surfaced to the model through the SDK skills feature.
- Cross-platform releases. GitHub Actions builds binaries for Linux, macOS and Windows (amd64/arm64) on every tag.
Prebuilt, self-contained binaries are published for every release on the
releases page, for Linux, macOS
and Windows on both amd64 and arm64. Each archive contains a single rook
binary (plus README and LICENSE), and a checksums.txt is published alongside.
Pick the archive for your platform - e.g. rook-v0.1.0-linux-amd64.tar.gz - then
download, (optionally) verify, extract and put rook on your PATH:
VERSION=v0.1.0
OS=linux # linux | darwin | windows
ARCH=amd64 # amd64 | arm64
BASE="https://github.com/chatbotkit/rook/releases/download/${VERSION}"
# download the archive and checksums
curl -sSLO "${BASE}/rook-${VERSION}-${OS}-${ARCH}.tar.gz"
curl -sSLO "${BASE}/checksums.txt"
# verify (optional but recommended)
sha256sum --ignore-missing -c checksums.txt
# extract and install
tar -xzf "rook-${VERSION}-${OS}-${ARCH}.tar.gz"
sudo mv "rook-${VERSION}-${OS}-${ARCH}/rook" /usr/local/bin/rook
rook versionOn Windows, download rook-<version>-windows-amd64.tar.gz, extract it, and add
rook.exe to a directory on your PATH.
go install github.com/chatbotkit/rook/cmd/rook@latestOr clone and build with the provided Makefile:
make build # → ./rookRook talks to the ChatBotKit API, so it needs an API token supplied via
CHATBOTKIT_API_SECRET.
- Create a ChatBotKit account at chatbotkit.com or console.cbk.ai.
- Create an API token from the Tokens page
(chatbotkit.com/tokens) and set it as
CHATBOTKIT_API_SECRET(export it, or put it in a.envfile).
For better isolation, cost control and observability, we suggest running Rook under a dedicated sub-account rather than your main account - each engagement, tool or user then gets its own usage, billing and logs. For a sub-account that is fully dedicated to Rook, a standard token is enough.
We also recommend a scoped token, which limits the token to specific ChatBotKit API routes (principle of least privilege), so a leaked key can't touch the rest of your account. This matters less for a fully dedicated sub-account, but it is good practice everywhere.
Rook runs statelessly, so it only needs the stateless completion route.
When creating the token, set its allowedRoutes to:
allowedRoutes:
- conversation/completeRoute patterns omit the /v1/ prefix. See
How to Create Scoped API Tokens
for the full guide.
export CHATBOTKIT_API_SECRET="your-api-key"
# Audit a local codebase
rook --scope "repo: ./server, no network access" \
"Audit the HTTP handlers in ./server for injection and auth bypass bugs"
# Hunt with reasoning streamed to the terminal
rook -v --scope-file scope.txt "Find SSRF in the URL-fetching service"
# Version
rook versionRook loads a .env file automatically if present (see .env.example).
| Flag | Default | Description |
|---|---|---|
--model |
qwen-3.6-plus |
Model the agent reasons with |
--max-iterations |
10000 |
Maximum agent iterations before a forced stop |
--scope |
- | Authorization boundary (hosts, repos, paths) |
--scope-file |
- | Read the authorization scope from a file |
-v, --verbose |
false |
Stream the agent's reasoning tokens to stdout |
-V, --version |
- | Print version and exit |
The agent's findings stream to stderr; with --verbose, reasoning tokens
stream to stdout. The final report is delivered as the agent's response -
Rook does not write files on its own. If you want the report (or any other
artifact) saved to disk, ask for it in the task and the agent will use its
write tool.
Rook ships with 51 security skills - each a SKILL.md playbook under
skills/, embedded into the binary at build time and offered to the
agent as it works. They cover, roughly:
- Methodology & mindset -
bug-bounty,bb-methodology,redteam-mindset,bb-local-toolkit,hunt-dispatch. - Web/API vulnerability hunting (24
hunt-*classes +security-arsenal) - IDOR, SQLi, XSS, SSRF, RCE, SSTI, XXE, CSRF, OAuth, SAML, GraphQL, auth/MFA bypass, ATO, business logic, cache poisoning, HTTP smuggling, file upload, API misconfig, race conditions, and more. - Enterprise & infrastructure attack chains -
m365-entra-attack,okta-attack,cloud-iam-deep,vmware-vcenter-attack,enterprise-vpn-attack,hunt-sharepoint,hunt-aspnet,hunt-ntlm-info,apk-redteam-pipeline,supply-chain-attack-recon. - Recon & OSINT -
web2-recon,offensive-osint,osint-methodology,hunt-subdomain. - Web3 -
web3-audit,meme-coin-audit. - Triage, reporting & hygiene -
triage-validation,bugcrowd-reporting,report-writing,redteam-report-template,evidence-hygiene,mid-engagement-ir-detection.
These skills are sourced from the claude-bughunter project - see Credits.
Create skills/<name>/SKILL.md with YAML front matter:
---
name: My Skill
description: One sentence the model uses to decide when to apply this skill.
---
# My Skill
Step-by-step guidance...Rebuild the binary - the new skill is picked up automatically by the embed
directive. No registration code required.
cmd/rook CLI: flags, .env, signal handling, version
internal/config Central config: default model, max iterations, system prompt
internal/agent Loads embedded skills, registers tools, drives the agent loop
internal/version Build-time version + GitHub release update check
embed.go //go:embed skills → the embedded skill library
skills/ SKILL.md playbooks compiled into the binary
The default model and the agent's system prompt (backstory) live in one place -
internal/config/config.go - so they can be tuned
without touching the CLI or the agent loop.
At startup Rook loads the embedded skills with agent.LoadSkillsFromFS,
registers agent.DefaultTools(), builds a security-focused backstory that
pins the agent to your authorized scope, and runs agent.ExecuteWithTools
until the agent calls exit.
The committed go.mod pins a published version of the Go SDK, so the
standalone repository builds from a clean clone with no extra steps:
git clone https://github.com/chatbotkit/rook
cd rook
go build ./... # or: make buildmake build # build ./rook
make test # run tests
make vet # go vet
make dist # cross-platform release archives under dist/To build against a local checkout of the Go SDK instead of the published
module, place it at ../go-sdk (or anywhere) and create a Go workspace:
make workspace # writes a gitignored go.workgo.work is gitignored, so it only affects your local builds. See
RELEASES.md for the release flow.
Rook's embedded skill library is sourced from the claude-bughunter project by Sachin Sharma:
The skills are used under the MIT License (Copyright © 2026 Sachin Sharma). The full upstream license is preserved in NOTICE.md. Our thanks to the author and the bug-bounty community whose disclosed reports informed them.
Rook itself is MIT licensed - see LICENSE. Bundled third-party content retains its original license; see NOTICE.md.