From geekbot
Manages async team rituals — standups, polls, check-ins — and drafts reports with AI assistance, tracks participation and response rates.
How this skill is triggered — by the user, by Claude, or both
Slash command
/geekbot:geekbot-runThe summary Claude sees in its skill listing — used to decide when to auto-load this skill
This skill wraps the `geekbot` CLI to let users manage async team rituals
This skill wraps the geekbot CLI to let users manage async team rituals
conversationally. It handles two broad workflows:
The CLI produces structured JSON output with machine-readable error codes, making it reliable for agent-driven automation.
Before any operation, verify the CLI is available and authenticated.
Run check-cli.sh on first invocation. If it fails:
npm install -g geekbot-cli (requires
Bun >= 1.3.5 runtime). Note: npx geekbot-cli also requires Bun on
PATH — it is not a Node.js fallback.geekbot auth login,
which uses the OAuth 2.1 authorization-code + PKCE flow with a
http://127.0.0.1:<port>/callback loopback redirect and writes the
resulting cli_* token to the OS keychain. As a fallback they can use
geekbot auth setup --api-key <KEY> with a dashboard API key, or set
GEEKBOT_API_KEY as an environment variable.Do not attempt any Geekbot operation until both checks pass.
Some steps in this skill need to ask the user for input. Render each question with whatever interaction primitive your harness provides — the question content is identical either way.
[PICKER] — a small fixed set of mutually-exclusive options
(2–4). If your harness exposes a structured single-select question
tool (e.g. Claude Code's AskUserQuestion, or any equivalent picker
UI), use it. Otherwise present the same options as a numbered list
in chat.[PICKER, top-N + Other] — same as [PICKER] but the candidate
set may exceed 4 (e.g. "pick one of these 12 standups"). Pre-filter
to the 3 most likely options and add an "Other" choice that lets the
user name the rest in chat.[CONFIRM] — a yes/edit/cancel decision before a destructive or
externally-visible action. Treat as [PICKER] with options
Approve / Edit / Cancel.[CHAT] — open-ended question. Always ask in plain prose; a
picker doesn't fit.Tags appear inline in the workflow docs at the point where the
question is asked. Untagged "ask the user" prose is conversational by
default. Do not name AskUserQuestion (or any other tool) directly in
prompts to the user — pick the right primitive silently based on your
harness.
The CLI follows a noun-verb pattern: geekbot <resource> <action> [options].
Every command returns a JSON envelope on stdout:
Success: { "ok": true, "data": <T>, "error": null, "metadata": {...} }
Error: { "ok": false, "data": null, "error": { "code", "message", "retryable", "suggestion" }, "metadata": {...} }
Always check the ok field first. On errors, the error.suggestion field
often contains the exact fix — including listing valid IDs when a resource
isn't found. Use this to self-correct without bothering the user.
For the full command reference with flags, defaults, and examples, read
cli-commands.md.
Most common operations at a glance:
| Task | Command |
|---|---|
| List my standups | geekbot standup list (add --state active, --is-anonymous true, --broadcast-channel <id>, or --page-size <n> to narrow results) |
| Get standup details + question IDs | geekbot standup get <id> |
| Create a standup | geekbot standup create --channel "..." --questions '[...]' --users "U1,U2" (or --sync-channel "#ch"; --is-anonymous optional) |
| List reports | geekbot report list --standup-id <id> --limit 10 |
| Submit a report | geekbot report create --standup-id <id> --answers '{"<qid>":"..."}' |
| My profile + user ID | geekbot me show |
| Create a poll (Slack only) | geekbot poll create --name "..." --channel "..." --question "..." --choices '[...]' [--duration 120] |
| Search team members | geekbot team search <query> (matches username, realname, email) |
| Check auth | geekbot auth status |
For full flag details, see cli-commands.md.
The skill becomes dramatically more useful when it can pull data from where work actually happens. This is opportunistic — check what MCP servers are connected in the current session and use whatever is available. Never fail or complain if nothing is connected; just fall back to asking the user.
For report drafting: Pull the user's recent activity from connected MCP servers (GitHub, Jira, Calendar, Slack) and use it to pre-populate a draft. The user reviews and approves instead of writing from scratch.
For analytics: Cross-reference standup report data with delivery data to give richer insights — not just "who posted" but "what was actually shipped."
For entity mapping tables and deduplication strategy, see reporter-workflows.md.
Important boundaries:
Pattern-match on the user's request to pick the right workflow. Don't ask "are you a manager or a reporter?" — the request itself makes intent clear. The same person can manage standups and submit reports in one conversation.
Route to Manager Workflows (§ below) when you see:
Route to Reporter Workflows (§ below) when you see:
When ambiguous, ask one clarifying question — never more than one.
Use [PICKER] if the disambiguation is between 2–4 named options
(e.g. manager-vs-reporter intent split with a third "something else"
fallback), otherwise [CHAT].
For detailed multi-step guides, read manager-workflows.md.
This is the most common and most complex manager operation.
If the request is vague ("set up a standup for my team"), offer templates.
Load standup-templates.json and present the 3–4 most relevant options
based on context. Templates provide pre-built questions and sensible schedule
defaults — the user just needs to confirm name, channel, and members.
Gathering required fields (v2):
--channel — broadcast channel id or name (required)--questions — JSON array (required). Strings ["q1","q2"] for free-text
or [{"text":"q1","choices":["A","B"]}] for multiple-choice--name — optional. If the user gave a name, use it verbatim. Otherwise
infer a meaningful name from the configured questions (use the template
name when a template is in play). Don't rely on the API default
"Standup #<broadcast channel>".--time — defaults to 10:00--timezone — infer from geekbot me show → data.timezone if not given--days — defaults to Mon–Fri--users "U1,U2" for an explicit list or
--sync-channel "#name" to sync members from a channel. The two flags
are mutually exclusive. The API does not auto-populate members when both
are omitted — never call without member resolution.--is-anonymous — surface proactively for sensitive content (well-being,
feedback, retro psychological safety) or templates with
is_anonymous_recommended: true.Always confirm the full configuration with the user before executing. Show: name, channel, members (count + list or sync source), schedule, timezone, anonymous flag, questions.
Idempotency: the CLI auto-generates a UUID Idempotency-Key per call
(24h API window). Re-running the command creates a new standup. On
ambiguous outcomes (timeout, partial response), list with
geekbot standup list before retrying.
Note: The CLI sets which days of the week to run but cannot set frequency (bi-weekly, monthly). For non-weekly schedules, create the standup via CLI and tell the user to adjust the frequency in the Geekbot web dashboard.
For the full step-by-step wizard (naming, channel resolution, member
resolution, anonymous-flag policy, edge cases), read manager-workflows.md
§ Standup Creation Wizard.
geekbot standup start <id> — confirm before executing.cli-commands.md for poll commands.Analytics come from report data fetched via the CLI. The skill computes
metrics; the CLI provides raw data. For the full analytics playbook with
6 named analysis patterns (response rate, participation gaps, blocker
frequency, trends, answer quality, cross-referencing), read
manager-workflows.md.
Quick start: Identify the standup with standup list, get member count
with standup get <id>, fetch reports with
report list --standup-id <id> --after <date> --limit 100, then compute.
Summarize what a specific person has been working on — ideal for 1-1 prep.
For the full step-by-step workflow, read manager-workflows.md §Team Member
Summary.
Quick start: geekbot team search <name> → get user ID →
geekbot standup list to enumerate standups → for each, fetch reports with
geekbot report list --standup-id <sid> --user-id <id> --after <3 weeks ago> --page-size 20 →
synthesize by work stream, not chronologically.
For the full drafting pipeline, tone calibration, blocker carry-over logic,
and edge cases, read reporter-workflows.md.
standup list, auto-select if only onestandup get <id> → extract question IDs and textreport create --standup-id <id> --answers '{...}'Never post a report without explicit user approval.
One-shot commands that don't need the full pipeline:
geekbot standup listgeekbot report list --user-id <uid> --limit 5geekbot me showgeekbot me teamsgeekbot standup start <id>All required confirmations are [CONFIRM] — render as a structured
picker (Approve / Edit / Cancel) when the harness supports it, or as
the same three options in chat.
| Operation | Confirmation required? | What to show |
|---|---|---|
| CREATE standup/poll | [CONFIRM] | Full config: name, channel, questions, schedule |
| POST report | [CONFIRM] — always | Complete draft with all answers |
| TRIGGER standup | [CONFIRM] | Which standup, who it targets |
| List / Get / Analytics | No | Just execute and present results |
| Error recovery retries | No | Transparent to user |
For the complete recovery guide, read error-recovery.md.
Core pattern: always parse the JSON envelope, check ok, branch on
exit code.
| Exit code | Meaning | Agent action |
|---|---|---|
| 0 | Success | Proceed normally |
| 3 | Not found | Parse error.suggestion — it lists valid IDs. Offer them to the user. |
| 4 | Auth failed | Guide user through geekbot auth login (or geekbot auth setup --api-key as fallback). Do not retry. |
| 5 | Forbidden | Explain permission issue. The user may need admin access. |
| 6 | Validation | Show error.message, help the user fix the input. |
| 7 | Network | If error.retryable is true, retry once after 2s silently. If it fails again, report. |
| 8 | Conflict | Explain the conflict (e.g., duplicate name). Suggest resolution. |
| 9 | Schema validation (schema_validation_error) | API response didn't match expected format. Don't ask user to fix input — suggest updating CLI or reporting a bug. |
| 1, 2, 9 | General / usage / API | Report error.message to the user clearly. |
Never retry errors where retryable is false.
geekbot auth login (or geekbot auth setup --api-key as fallback)
instead.error.suggestion — when a resource isn't found (exit 3),
the CLI already lists valid alternatives. Use them.CRUD confirmations — brief, factual, include key identifiers:
Created "Sprint Retro" standup (ID 789) in #engineering — Fridays at 15:00 Chicago time with 3 questions.
Lists — concise table: ID, name, channel, schedule. Don't dump raw JSON.
Analytics — narrative summary first, data table for details. Use visualisation (chart/graph) when showing trends over time.
Report drafts — one question per block, clearly labelled with question text and proposed answer. Easy to scan and approve.
Errors — plain language: what happened, why, what to do next. Always
use error.suggestion when available.
npx claudepluginhub geekbot-com/geekbot-cli --plugin geekbotGenerates async standup notes from Git commits, Jira tickets, and Obsidian vault. Useful for remote teams wanting daily visibility without synchronous meetings.
Writes outcome-first status updates for engineering leaders. Automatically gathers context from git log, open PRs, project trackers, and prior updates. Supports progress and blocker modes with structured output.
Generates standup updates summarizing recent commits, PRs, ticket changes, and activity into yesterday/today/blockers format. Works with connected source control/project tools or standalone notes.