pp-cal-com
Cal.com — Printing Press CLI
Prerequisites: Install the CLI
This skill drives the cal-com-pp-cli binary. You must verify the CLI is installed before invoking any command from this skill. If it is missing, install it first:
- Install via the Printing Press installer:
npx -y @mvanhorn/printing-press install cal-com --cli-only - Verify:
cal-com-pp-cli --version - Ensure
$GOPATH/bin(or$HOME/go/bin) is on$PATH.
If the npx install fails (no Node, offline, etc.), fall back to a direct Go install (requires Go 1.23+):
go install github.com/mvanhorn/printing-press-library/library/productivity/cal-com/cmd/cal-com-pp-cli@latest
If --version reports "command not found" after install, the install step did not put the binary on $PATH. Do not proceed with skill commands until verification succeeds.
When to Use This CLI
Reach for cal-com-pp-cli whenever an agent needs to read or mutate a Cal.com calendar without burning context on the multi-call dance the API requires for booking and rescheduling. The local store makes 'what's on my calendar', 'when am I free', 'who is overloaded', and 'where are my conflicts' near-instant offline answers. The composed book and reschedule next commands are the right tools for transactional bookings; the endpoint-mirror coverage is there for everything else.
Unique Capabilities
These capabilities aren't available in any other tool for this API.
Composed booking flows
-
book— Schedule an attendee onto one of your event types in a single composed call — slot check, optional reservation, create, optional confirm.For the host scripting an attendee onto their calendar (admin onboarding, recruiter pre-fill, test fixtures). For the normal flow where the attendee picks their own time, share a URL from
link listinstead.cal-com-pp-cli book --event-type-id 96531 --start 2026-05-06T17:00:00Z --attendee-name Guest --attendee-email guest@example.com --dry-run -
slots find— Find first available slots across multiple event-type IDs in one call, ranked by start time.Use this when you don't know which event type fits — let the caller pick from a ranked merged list.
cal-com-pp-cli slots find --event-type-ids 96531 --start tomorrow --end "tomorrow 23:59" --json -
reschedule next— Move an existing booking to the next available slot for the same event type, after a cutoff.Use this for last-minute bumps — one command instead of three, with dry-run safety.
cal-com-pp-cli reschedule next --uid <booking-uid> --after tomorrow --dry-run
Local state that compounds
-
agenda— Upcoming bookings in a window — today, this week, or any duration — read from the local store.Use this whenever an agent needs 'what's on my calendar'; single command across any time window.
cal-com-pp-cli agenda --window today --json --select id,start,title,attendees -
analytics no-show— No-show, cancellation, volume, and density metrics over a window. Sister subcommands under analytics: bookings (volume), cancellations, no-show, density. --by accepts event-type, attendee, or weekday on the rate commands; analytics density --unit hour adds hourly heatmaps.Use this for capacity planning, no-show trend analysis, or attendee follow-up — answers no single API call provides.
cal-com-pp-cli analytics no-show --window 90d --by attendee --json -
conflicts— Detects overlapping bookings within a time window — pairs whose time ranges intersect get reported. Reads the local store, no API call.Run before sending confirmations or after a bulk reschedule — surfaces double-bookings the API silently allows.
cal-com-pp-cli conflicts --window 7d --json -
gaps— Finds open windows in your schedule that are available but unbooked, filtered by minimum block size.Use this for capacity planning — answers 'when can I take a meeting' rather than 'what's on my plate'.
cal-com-pp-cli gaps --window 7d --min-minutes 60 --json -
workload— Booking distribution across team members over a window — surfaces overloaded vs underutilized hosts.Use this for round-robin tuning or to spot host burnout before it shows up as no-shows.
cal-com-pp-cli workload --team-id 42 --window 30d --json -
event-types stale— Event types with zero bookings in the last N days — candidates for removal.Use this for quarterly cleanup — keeps your bookable surface from drifting.
cal-com-pp-cli event-types stale --days 90 --json
Host control surface
-
link create— Create a new bookable link (event type) on your Cal.com account; prints the cal.com// URL ready to share.The host's primary creative act. Bookable links are how attendees book time; this is the command to make one.
cal-com-pp-cli link create --slug 30min --length 30 --title "30 Min Meeting" -
link list— List every bookable link you own with the full URL pre-rendered for copy-share.Use this to see what links you have and grab their URLs without hand-composing cal.com//.
cal-com-pp-cli link list --json -
ooo set— Mark yourself out-of-office for a date range so Cal.com excludes the period from slot search.Going on vacation? Sick? Run this once and stop getting booked. Optional --redirect-to-user forwards bookings to a teammate (round-robin only).
cal-com-pp-cli ooo set --start 2026-05-12 --end 2026-05-18 --reason vacation --notes "Hawaii trip" -
ooo list— List your active and upcoming OOO entries.cal-com-pp-cli ooo list --json
Agent-native plumbing
-
webhooks coverage— Audits registered webhook triggers against the canonical set and reports lifecycle events with no subscriber.Run this whenever you add a new automation — surfaces missed triggers like BOOKING_NO_SHOW_UPDATED before they bite.
cal-com-pp-cli webhooks coverage --json
Command Reference
api-keys — Manage api keys
cal-com-pp-cli api-keys— Generate a new API key and delete the current one. Provide API key to refresh as a Bearer token in the Authorization...
bookings — Manage bookings
cal-com-pp-cli bookings create— POST /v2/bookings is used to create regular bookings, recurring bookings and instant bookings. The request bodies...cal-com-pp-cli bookings get— Please make sure to pass in the cal-api-version header value as mentioned in the Headers section. Not passing...cal-com-pp-cli bookings get-bookinguid—:bookingUidcan be 1. uid of a normal booking 2. uid of one of the recurring booking recurrences 3. uid of...cal-com-pp-cli bookings get-by-seat-uid— Get a seated booking by its seat reference UID. This is useful when you have a seatUid from a seated booking and...
cal-com-auth — Manage cal com auth
cal-com-pp-cli cal-com-auth— RFC 6749-compliant token endpoint. Pass client_id in the request body (Section 2.3.1). Use grant_type...
cal-com-auth-2 — Manage cal com auth 2
cal-com-pp-cli cal-com-auth-2 <clientId>— Returns the OAuth2 client information for the given client ID
calendars — Manage calendars
cal-com-pp-cli calendars check-ics-feed— If accessed using an OAuth access token, theAPPS_READscope is required.cal-com-pp-cli calendars create-ics-feed— If accessed using an OAuth access token, theAPPS_WRITEscope is required.cal-com-pp-cli calendars get— If accessed using an OAuth access token, theAPPS_READscope is required.cal-com-pp-cli calendars get-busy-times— Get busy times from a calendar. Example request URL is `https://api.cal.com/v2/calendars/busy-times?timeZone=Europe%2...
conferencing — Manage conferencing
cal-com-pp-cli conferencing get-default— If accessed using an OAuth access token, theAPPS_READscope is required.cal-com-pp-cli conferencing list-installed-apps— If accessed using an OAuth access token, theAPPS_READscope is required.
credits — Manage credits
cal-com-pp-cli credits charge— Charge credits for a completed AI agent interaction. Uses externalRef for idempotency to prevent double-charging.cal-com-pp-cli credits get-available— Check if the authenticated user (or their org/team) has available credits and return the current balance.
destination-calendars — Manage destination calendars
cal-com-pp-cli destination-calendars— If accessed using an OAuth access token, theAPPS_WRITEscope is required.
event-types — Manage event types
cal-com-pp-cli event-types create— Please make sure to pass in the cal-api-version header value as mentioned in the Headers section. Not passing...cal-com-pp-cli event-types delete— Please make sure to pass in the cal-api-version header value as mentioned in the Headers section. Not passing...cal-com-pp-cli event-types get— Hidden event types are returned only if authentication is provided and it belongs to the event type owner. Use the...cal-com-pp-cli event-types get-by-id— Please make sure to pass in the cal-api-version header value as mentioned in the Headers section. Not passing...cal-com-pp-cli event-types update— Please make sure to pass in the cal-api-version header value as mentioned in the Headers section. Not passing...
me — Manage me
cal-com-pp-cli me clear-my-booking-limits— Removes all of the authenticated user's global booking limits. Only available to organization members — non-org...cal-com-pp-cli me get— If accessed using an OAuth access token, thePROFILE_READscope is required.cal-com-pp-cli me get-my-booking-limits— Returns the authenticated user's global booking limits. Unset bounds are returned as null. Only available to...cal-com-pp-cli me update— Updates the authenticated user's profile. Email changes require verification and the primary email stays unchanged...cal-com-pp-cli me update-my-booking-limits— Partially updates the authenticated user's global booking limits. Only fields present in the request body are...cal-com-pp-cli me user-ooocontroller-create-my-ooo— If accessed using an OAuth access token, theSCHEDULE_WRITEscope is required.cal-com-pp-cli me user-ooocontroller-delete-my-ooo— If accessed using an OAuth access token, theSCHEDULE_WRITEscope is required.cal-com-pp-cli me user-ooocontroller-get-my-ooo— If accessed using an OAuth access token, theSCHEDULE_READscope is required.cal-com-pp-cli me user-ooocontroller-update-my-ooo— If accessed using an OAuth access token, theSCHEDULE_WRITEscope is required.
notifications — Manage notifications
cal-com-pp-cli notifications subscriptions-register— Register an app push subscriptioncal-com-pp-cli notifications subscriptions-remove— Remove an app push subscription
oauth — Manage oauth
oauth-clients — Manage oauth clients
cal-com-pp-cli oauth-clients create— These endpoints are deprecated and will be removed in the future.cal-com-pp-cli oauth-clients delete— These endpoints are deprecated and will be removed in the future.cal-com-pp-cli oauth-clients get— These endpoints are deprecated and will be removed in the future.cal-com-pp-cli oauth-clients get-by-id— These endpoints are deprecated and will be removed in the future.cal-com-pp-cli oauth-clients update— These endpoints are deprecated and will be removed in the future.
organizations — Manage organizations
routing-forms — Manage routing forms
schedules — Manage schedules
cal-com-pp-cli schedules create— Create a schedule for the authenticated user. The point of creating schedules is for event types to be available at...cal-com-pp-cli schedules delete— Please make sure to pass in the cal-api-version header value as mentioned in the Headers section. Not passing...cal-com-pp-cli schedules get— Get all schedules of the authenticated user. Please make sure to pass in the cal-api-version header value as...cal-com-pp-cli schedules get-default— Get the default schedule of the authenticated user. Please make sure to pass in the cal-api-version header...cal-com-pp-cli schedules get-scheduleid— Please make sure to pass in the cal-api-version header value as mentioned in the Headers section. Not passing...cal-com-pp-cli schedules update— Please make sure to pass in the cal-api-version header value as mentioned in the Headers section. Not passing...
selected-calendars — Manage selected calendars
cal-com-pp-cli selected-calendars add— If accessed using an OAuth access token, theAPPS_WRITEscope is required.cal-com-pp-cli selected-calendars delete— If accessed using an OAuth access token, theAPPS_WRITEscope is required.
slots — Manage slots
cal-com-pp-cli slots delete-reserved— Please make sure to pass in the cal-api-version header value as mentioned in the Headers section. Not passing...cal-com-pp-cli slots get-available— There are 4 ways to get available slots for event type of an individual user: 1. By event type id. Example...cal-com-pp-cli slots get-reserved— Please make sure to pass in the cal-api-version header value as mentioned in the Headers section. Not passing...cal-com-pp-cli slots reserve— Make a slot not available for others to book for a certain period of time. If you authenticate using oAuth...cal-com-pp-cli slots update-reserved— Please make sure to pass in the cal-api-version header value as mentioned in the Headers section. Not passing...
stripe — Manage stripe
cal-com-pp-cli stripe check— Check Stripe connectioncal-com-pp-cli stripe redirect— Get Stripe connect URLcal-com-pp-cli stripe save— Save Stripe credentials
teams — Manage teams
cal-com-pp-cli teams create— If accessed using an OAuth access token, theTEAM_PROFILE_WRITEscope is required.cal-com-pp-cli teams delete— If accessed using an OAuth access token, theTEAM_PROFILE_WRITEscope is required.cal-com-pp-cli teams get— If accessed using an OAuth access token, theTEAM_PROFILE_READscope is required.cal-com-pp-cli teams get-teamid— If accessed using an OAuth access token, theTEAM_PROFILE_READscope is required.cal-com-pp-cli teams update— If accessed using an OAuth access token, theTEAM_PROFILE_WRITEscope is required.
verified-resources — Manage verified resources
cal-com-pp-cli verified-resources user-get-verified-email-by-id— If accessed using an OAuth access token, theVERIFIED_RESOURCES_READscope is required.cal-com-pp-cli verified-resources user-get-verified-emails— If accessed using an OAuth access token, theVERIFIED_RESOURCES_READscope is required.cal-com-pp-cli verified-resources user-get-verified-phone-by-id— If accessed using an OAuth access token, theVERIFIED_RESOURCES_READscope is required.cal-com-pp-cli verified-resources user-get-verified-phone-numbers— If accessed using an OAuth access token, theVERIFIED_RESOURCES_READscope is required.cal-com-pp-cli verified-resources user-request-email-verification-code— Sends a verification code to the email. If accessed using an OAuth access token, theVERIFIED_RESOURCES_WRITE...cal-com-pp-cli verified-resources user-request-phone-verification-code— Sends a verification code to the phone number. If accessed using an OAuth access token, the...cal-com-pp-cli verified-resources user-verify-email— Use code to verify an email. If accessed using an OAuth access token, theVERIFIED_RESOURCES_WRITEscope is required.cal-com-pp-cli verified-resources user-verify-phone-number— Use code to verify a phone number. If accessed using an OAuth access token, theVERIFIED_RESOURCES_WRITEscope is...
webhooks — Manage webhooks
cal-com-pp-cli webhooks create— If accessed using an OAuth access token, theWEBHOOK_WRITEscope is required.cal-com-pp-cli webhooks delete— If accessed using an OAuth access token, theWEBHOOK_WRITEscope is required.cal-com-pp-cli webhooks get— Gets a paginated list of webhooks for the authenticated user. If accessed using an OAuth access token, the...cal-com-pp-cli webhooks get-webhookid— If accessed using an OAuth access token, theWEBHOOK_READscope is required.cal-com-pp-cli webhooks update— If accessed using an OAuth access token, theWEBHOOK_WRITEscope is required.
Finding the right command
When you know what you want to do but not which command does it, ask the CLI directly:
cal-com-pp-cli which "<capability in your own words>"
which resolves a natural-language capability query to the best matching command from this CLI's curated feature index. Exit code 0 means at least one match; exit code 2 means no confident match — fall back to --help or use a narrower query.
Recipes
Create a bookable link and share its URL
cal-com-pp-cli link create --slug 30min --length 30 --title "30 Min Meeting"
cal-com-pp-cli link list --json --select links.slug,links.bookable_url
link create returns the bookable URL pre-rendered (cal.com//); link list is the host's view of every link they've published.
Mark yourself out-of-office
cal-com-pp-cli ooo set --start 2026-05-12 --end 2026-05-18 --reason vacation --notes "Hawaii trip"
cal-com-pp-cli ooo list --json
While the OOO entry is active, Cal.com excludes the range from slot search so you don't get booked.
Today's agenda from the local store
cal-com-pp-cli agenda --window today --json --select bookings.uid,bookings.title,bookings.start,bookings.attendees
Returns just the four fields an agent needs from the agenda envelope — keeps context tight against deeply-nested booking payloads.
Cross-event-type slot search ranked by start
cal-com-pp-cli slots find --event-type-ids 96531 --start tomorrow --end "tomorrow 23:59" --json --first-only
Fans out /v2/slots per event-type ID; returns only the earliest slot.
No-show rate by attendee for capacity planning
cal-com-pp-cli analytics no-show --window 90d --by attendee --json
Local SQL aggregation over synced bookings; no API call.
Audit webhook coverage before adding automation
cal-com-pp-cli webhooks coverage --json
Compares your registered triggers against the canonical Cal.com lifecycle set and surfaces missing subscribers.
Reschedule a booking to the next free slot
cal-com-pp-cli reschedule next --uid <booking-uid> --after tomorrow --dry-run
One composed command replaces three; --dry-run prints the planned move without committing.
Auth Setup
Cal.com uses bearer tokens prefixed with cal_live_ (live) or cal_test_ (test). Set CAL_COM_TOKEN in your environment, or run auth set-token once. The CLI also accepts managed-user access tokens and OAuth access tokens through the same Authorization header. Per-resource API-version pinning via cal-api-version is handled automatically by the client.
Run cal-com-pp-cli doctor to verify setup.
Agent Mode
Add --agent to any command. Expands to: --json --compact --no-input --no-color --yes.
-
Pipeable — JSON on stdout, errors on stderr
-
Filterable —
--selectkeeps a subset of fields. Dotted paths descend into nested structures; arrays traverse element-wise. Critical for keeping context small on verbose APIs:cal-com-pp-cli bookings get --agent --select id,name,status -
Previewable —
--dry-runshows the request without sending -
Offline-friendly — sync/search commands can use the local SQLite store when available
-
Non-interactive — never prompts, every input is a flag
Response envelope
Commands that read from the local store or the API wrap output in a provenance envelope:
{
"meta": {"source": "live" | "local", "synced_at": "...", "reason": "..."},
"results": <data>
}
Parse .results for data and .meta.source to know whether it's live or local. A human-readable N results (live) summary is printed to stderr only when stdout is a terminal — piped/agent consumers get pure JSON on stdout.
Agent Feedback
When you (or the agent) notice something off about this CLI, record it:
cal-com-pp-cli feedback "the --since flag is inclusive but docs say exclusive"
cal-com-pp-cli feedback --stdin < notes.txt
cal-com-pp-cli feedback list --json --limit 10
Entries are stored locally at ~/.cal-com-pp-cli/feedback.jsonl. They are never POSTed unless CAL_COM_FEEDBACK_ENDPOINT is set AND either --send is passed or CAL_COM_FEEDBACK_AUTO_SEND=true. Default behavior is local-only.
Write what surprised you, not a bug report. Short, specific, one line: that is the part that compounds.
Output Delivery
Every command accepts --deliver <sink>. The output goes to the named sink in addition to (or instead of) stdout, so agents can route command results without hand-piping. Three sinks are supported:
| Sink | Effect |
|---|---|
stdout |
Default; write to stdout only |
file:<path> |
Atomically write output to <path> (tmp + rename) |
webhook:<url> |
POST the output body to the URL (application/json or application/x-ndjson when --compact) |
Unknown schemes are refused with a structured error naming the supported set. Webhook failures return non-zero and log the URL + HTTP status on stderr.
Named Profiles
A profile is a saved set of flag values, reused across invocations. Use it when a scheduled agent calls the same command every run with the same configuration - HeyGen's "Beacon" pattern.
cal-com-pp-cli profile save briefing --json
cal-com-pp-cli --profile briefing bookings get
cal-com-pp-cli profile list --json
cal-com-pp-cli profile show briefing
cal-com-pp-cli profile delete briefing --yes
Explicit flags always win over profile values; profile values win over defaults. agent-context lists all available profiles under available_profiles so introspecting agents discover them at runtime.
Exit Codes
| Code | Meaning |
|---|---|
| 0 | Success |
| 2 | Usage error (wrong arguments) |
| 3 | Resource not found |
| 4 | Authentication required |
| 5 | API error (upstream issue) |
| 7 | Rate limited (wait and retry) |
| 10 | Config error |
Argument Parsing
Parse $ARGUMENTS:
- Empty,
help, or--help→ showcal-com-pp-cli --helpoutput - Starts with
install→ ends withmcp→ MCP installation; otherwise → see Prerequisites above - Anything else → Direct Use (execute as CLI command with
--agent)
MCP Server Installation
- Install the MCP server:
go install github.com/mvanhorn/printing-press-library/library/productivity/cal-com/cmd/cal-com-pp-mcp@latest - Register with Claude Code:
claude mcp add cal-com-pp-mcp -- cal-com-pp-mcp - Verify:
claude mcp list
Direct Use
- Check if installed:
which cal-com-pp-cliIf not found, offer to install (see Prerequisites at the top of this skill). - Match the user query to the best command from the Unique Capabilities and Command Reference above.
- Execute with the
--agentflag:cal-com-pp-cli <command> [subcommand] [args] --agent - If ambiguous, drill into subcommand help:
cal-com-pp-cli <command> --help.
More from mvanhorn/printing-press-library
pp-flight-goat
Search Google Flights, scan Kayak long-haul routes, and join FlightAware AeroAPI reliability, alerts, and tracking from one CLI.
169pp-espn
Use this skill whenever the user asks about live sports scores, standings, team stats, game summaries (with box score, leaders, scoring plays, odds, and win probability), NFL / NBA / MLB / NHL / NCAA / MLS / EPL / WNBA games, team schedules, polls, or rankings. ESPN sports CLI with live scores across 10 leagues, offline search, head-to-head comparisons, and rich per-game summary payloads. No API key required. Triggers on natural phrasings like 'what's the score of the Lakers game', 'Patriots schedule this week', 'NFL standings', 'box score for tonight's Mavs game', 'Chiefs vs Eagles head to head', 'who's on top of the AP poll'.
150pp-recipe-goat
Printing Press CLI for Recipe Goat. Recipe GOAT — find the best version of any recipe across 37 trusted sites, with offline cookbook, pantry match,...
127pp-movie-goat
The movie CLI that combines TMDb's discovery engine with OMDb's multi-source ratings — and ships a SQLite watchlist that flags what's streaming on your services right now. Trigger phrases: `what should I watch tonight`, `where can I stream <title>`, `rate <title>`, `compare <title> and <title>`, `what's <person>'s filmography`, `plan a <franchise> marathon`, `use movie-goat`, `run movie-goat`.
126pp-company-goat
Look up startups across SEC Form D, GitHub, Hacker News, Companies House, YC, and Wikidata in one command — including the SEC fundraising data hidden behind paid Crunchbase tiers. Trigger phrases: `look up this startup`, `research <company>`, `what does <company> do`, `form D for <company>`, `is <company> still active`, `compare <a> and <b>`, `use company-goat`, `run company-goat-pp-cli`.
67pp-hackernews
Hacker News from your terminal — with a local SQLite store, snapshot history, and agent-native output no other HN tool has. Trigger phrases: `check hacker news`, `search hn`, `what is hn saying about`, `diff the hn front page`, `pulse on hn`, `look up hn user`, `hn who is hiring`, `hn top stories`, `use hackernews`, `run hackernews`.
56