钩子命令行
openhook-cli
by berkantay
安装
claude skill add --url github.com/openclaw/skills/tree/main/skills/berkantay/openhook-cli文档
openhook CLI
Use the openhook CLI to receive real-time events from external platforms and communicate with other agents through channels.
When to use
- Receiving webhook events from GitHub, Stripe, Linear, Vercel, Slack
- Listening for external platform events in real-time
- Sending messages to other agents through channels
- Coordinating multi-agent workflows
Installation
brew tap openhook-dev/openhook && brew install openhook
Authentication
Requires an API key from openhook. The user must:
- Sign up at https://openhook.dev/signup
- Go to Settings > API Keys
- Create a new API key (starts with
oh_live_oroh_test_)
Then authenticate:
openhook auth login --key oh_live_xxxxxxxx
# Verify authentication worked
openhook whoami
Receiving Events
Subscribe to platform events
# GitHub
openhook subscribe github --repo owner/repo --events push,pull_request,issues
# Stripe
openhook subscribe stripe --events payment_intent.succeeded,customer.created
# Linear
openhook subscribe linear --events issue.created,issue.updated
Listen for events
# Interactive output
openhook listen
# JSON output (for parsing)
openhook listen --json
# Pipe to your processing script
openhook listen --json | jq '.payload'
Background daemon
openhook daemon start
openhook daemon status
openhook daemon logs -f
openhook daemon stop
Channels (Agent-to-Agent Communication)
Channels let agents send messages to each other. Each agent subscribes to a channel with a unique name, then messages can be sent to specific agents or broadcast to all.
Create a channel
openhook channel create <name> [--description "..."]
# Example
openhook channel create deploy-team --description "Deployment coordination"
Subscribe to a channel
Each subscription needs:
--endpoint: The HTTP endpoint ID that will receive messages--name: A unique alias for this agent in the channel
openhook channel subscribe <channel-id> --endpoint <endpoint-id> --name <alias>
# Example: Subscribe the "deployer" agent
openhook channel subscribe ch_abc123 --endpoint ep_xyz789 --name deployer
List channel members
openhook channel members <channel-id>
openhook channel members <channel-id> --json
Send messages
# Send to specific agent
openhook channel send <channel-id> "<message>" --to <agent-name>
# Broadcast to all agents
openhook channel send <channel-id> "<message>" --to all
# Include sender info
openhook channel send <channel-id> "<message>" --to <agent-name> --from <your-name>
Channel workflow example
# 1. Create coordination channel
openhook channel create release-v2 --description "v2.0 release coordination"
# 2. Agents join with their endpoints
openhook channel subscribe ch_xxx --endpoint ep_builder --name builder
openhook channel subscribe ch_xxx --endpoint ep_tester --name tester
openhook channel subscribe ch_xxx --endpoint ep_deployer --name deployer
# 3. Coordinate the release
openhook channel send ch_xxx "build v2.0.0" --to builder --from coordinator
openhook channel send ch_xxx "run integration tests" --to tester --from builder
openhook channel send ch_xxx "deploy to staging" --to deployer --from tester
openhook channel send ch_xxx "v2.0.0 deployed successfully" --to all --from deployer
Managing subscriptions
# List all subscriptions
openhook list
# View event history
openhook events
# Remove subscription
openhook unsubscribe <subscription-id>
Common patterns
Wait for specific event
# Listen until you get the event you need
openhook listen --json | while read -r event; do
type=$(echo "$event" | jq -r '.event_type')
if [ "$type" = "push" ]; then
echo "$event" | jq '.payload'
break
fi
done
React to GitHub push
openhook subscribe github --repo myorg/myrepo --events push
openhook listen --json | jq -c 'select(.event_type == "push") | .payload.commits'
Reference
| Command | Description |
|---|---|
openhook whoami | Show authenticated user |
openhook subscribe <platform> | Subscribe to platform events |
openhook list | List subscriptions |
openhook unsubscribe <id> | Remove subscription |
openhook listen [--json] | Listen for events |
openhook events | View event history |
openhook channel create <name> | Create channel |
openhook channel list | List channels |
openhook channel subscribe <ch> --endpoint <ep> --name <alias> | Join channel |
openhook channel members <ch> | List members |
openhook channel send <ch> <msg> --to <name|all> | Send message |
Links
- Website: https://openhook.dev
- Dashboard: https://openhook.dev/dashboard
- GitHub: https://github.com/openhook-dev/openhook-cli
相关 Skills
表格处理
by anthropics
围绕 .xlsx、.xlsm、.csv、.tsv 做读写、修复、清洗、格式整理、公式计算与格式转换,适合修改现有表格、生成新报表或把杂乱数据整理成交付级电子表格。
✎ 做 Excel/CSV 相关任务很省心,能直接读写、修复、清洗和格式转换,尤其擅长把乱七八糟的表格整理成交付级文件。
PDF处理
by anthropics
遇到 PDF 读写、文本表格提取、合并拆分、旋转加水印、表单填写或加解密时直接用它,也能提取图片、生成新 PDF,并把扫描件通过 OCR 变成可搜索文档。
✎ PDF杂活别再来回切工具了,文本表格提取、合并拆分到OCR识别一次搞定,连扫描件也能变可搜索。
Word文档
by anthropics
覆盖Word/.docx文档的创建、读取、编辑与重排,适合生成报告、备忘录、信函和模板,也能处理目录、页眉页脚、页码、图片替换、查找替换、修订批注及内容提取整理。
✎ 搞定 .docx 的创建、改写与精排版,目录、批量替换、批注修订和图片更新都能自动化,做正式文档尤其省心。
相关 MCP 服务
文件系统
编辑精选by Anthropic
Filesystem 是 MCP 官方参考服务器,让 LLM 安全读写本地文件系统。
✎ 这个服务器解决了让 Claude 直接操作本地文件的痛点,比如自动整理文档或生成代码文件。适合需要自动化文件处理的开发者,但注意它只是参考实现,生产环境需自行加固安全。
by wonderwhy-er
Desktop Commander 是让 AI 直接执行终端命令、管理文件和进程的 MCP 服务器。
✎ 这工具解决了 AI 无法直接操作本地环境的痛点,适合需要自动化脚本调试或文件批量处理的开发者。它能让你用自然语言指挥终端,但权限控制需谨慎,毕竟让 AI 执行 rm -rf 可不是闹着玩的。
EdgarTools
编辑精选by dgunning
EdgarTools 是无需 API 密钥即可解析 SEC EDGAR 财报的开源 Python 库。
✎ 这个工具解决了金融数据获取的痛点——直接让 AI 读取结构化财报,比如让 Claude 分析苹果的 10-K 文件。适合量化分析师或金融开发者快速构建数据管道。但注意,它依赖 SEC 网站稳定性,高峰期可能延迟。