whoop-cli
v0.3.1Companion skill for @andreasnlarsen/whoop-cli: agent-friendly WHOOP access via stable CLI JSON (day briefs, health flags, trends, exports) without raw API plumbing.
Installation
Please help me install the skill `whoop-cli` from SkillHub official store.
npx skills add andreasnlarsen/whoop-cli
whoop-cli
Use the installed whoop command.
Security + credential handling (required)
- Never ask users to paste client secrets/tokens into chat.
- For first-time auth, the user should run login locally on their own shell.
- Prefer read-only operational commands in agent flows (
summary,day-brief,health,trend,sync pull). - Do not run
whoop auth loginunless the user explicitly asks for login help. - Tokens are stored locally at
~/.whoop-cli/profiles/<profile>.jsonby the CLI.
Install / bootstrap
If whoop is missing:
npm install -g @andreasnlarsen/[email protected]
Optional OpenClaw skill install from package bundle:
whoop openclaw install-skill --force
Core checks
whoop auth status --json- If unauthenticated, ask the user to run local login:
whoop auth login --client-id ... --client-secret ... --redirect-uri ...- Validate:
whoop day-brief --json --pretty
Useful commands
- Daily:
whoop summary --json --prettywhoop day-brief --json --prettywhoop strain-plan --json --prettywhoop health flags --days 7 --json --pretty- Activity analysis:
whoop activity list --days 30 --json --prettywhoop activity trend --days 30 --json --prettywhoop activity types --days 30 --json --pretty- training-only:
whoop activity trend --days 30 --labeled-only --json --pretty
Activity interpretation guardrail (important)
- WHOOP generic
activityrows (oftensport_id=-1) are auto-detected and may be unlabeled movement (housework/incidental activity), not intentional training. - Do not treat generic
activityas confirmed training volume by default. - For coaching/training recommendations, default to
--labeled-onlyand report both total vs filtered counts.
Agent filtering pattern (jq-friendly)
- Canonical source:
whoop activity list --json - Prefer built-in filters first (
--labeled-only,--generic-only,--sport-id,--sport-name). - If custom slicing is needed and
jqis available, filter shell-side from raw JSON (example):
whoop activity list --days 30 --json | jq '.data.records | map(select(.sport_id != -1))'
- Export:
whoop sync pull --start YYYY-MM-DD --end YYYY-MM-DD --out ./whoop.jsonl --json --pretty
Experiment protocol (agent-required)
- Canonical state:
~/.whoop-cli/experiments.jsononly. - Plan experiments with context at creation time:
whoop experiment plan --name ... --behavior ... --start-date YYYY-MM-DD [--end-date YYYY-MM-DD] --description ... --why ... --hypothesis ... --success-criteria ... --protocol ... --json --pretty- Update context without creating duplicate state:
whoop experiment context --id ... [--description ... --why ... --hypothesis ... --success-criteria ... --protocol ...] --json --pretty- Check lifecycle/status with:
whoop experiment status [--status planned|running|completed] [--id ...] --json --pretty- Evaluate outcomes with:
whoop experiment report --id ... --json --pretty- Profile scope is strict by default (active
--profileonly). - Use
--all-profilesonly when cross-profile visibility is explicitly needed. - Prefer output field
sourceOfTruth(path to canonical state file);experimentsFileis kept as compatibility alias. - Avoid duplicating experiment state into other files unless the user explicitly asks for separate notes.
Safety
- Never print client secrets or raw tokens.
- Keep API errors concise and actionable.
- Treat this integration as unofficial/non-affiliated.