Install
openclaw skills install calendar-cliSecure Google Calendar API CLI. Use when the user wants to list, search, or read Google Calendar events; creating, updating, deleting, or responding to event...
openclaw skills install calendar-cliUse porteden calendar to list, search, and read Google Calendar events in the active account. Use -jc flags for AI-optimized output.
If porteden is not installed: brew install porteden/tap/porteden (or go install github.com/porteden/cli/cmd/porteden@latest).
porteden auth login — opens browser, sign in with the Google account, credentials stored in system keyringporteden auth login --token <key> — stored in system keyringporteden auth statusPE_API_KEY is set in the environment, the CLI uses it automatically (no login needed).create, update, delete, and respond change shared state and often send notifications to attendees. Before running any of them, echo back the target profile/account, the calendar ID and event ID (or summary + time for create), the attendee list if it's changing, and the intended change, then wait for the user to confirm. Be especially careful with --notify (sends invites) and delete without --no-notify (sends cancellations to all attendees).--profile (or PE_PROFILE) to isolate Google Calendar accounts so a task touches only the calendar it needs. Prefer the narrowest Google scope at login. When a task is done — especially on a shared machine — run porteden auth logout to clear the keyring entry, and revoke access from the Google account's security page (myaccount.google.com → Security → Third-party access) if a token may have been exposed.porteden calendar calendars -jcporteden calendar events --today -jcporteden calendar events --from 2026-02-01 --to 2026-02-07 -jcporteden calendar events --week --all -jcporteden calendar events -q "meeting" --today -jcporteden calendar by-contact "user@example.com" -jc (or --name "John Smith")porteden calendar event <eventId> -jcporteden calendar create --calendar <id> --summary "Meeting" --from "..." --to "..." --location "Room A" --attendees "a@b.com,c@d.com"porteden calendar update <eventId> --summary "New Title" (also: --from, --to, --location)porteden calendar update <eventId> --add-attendees "new@example.com" (or --remove-attendees; add --notify to send notifications)porteden calendar delete <eventId> (add --no-notify to skip attendee notifications)porteden calendar respond <eventId> accepted (or: declined, tentative)confirmed - Accepted/scheduledtentative - Maybe attendingneedsAction - Requires response from usercancelled - Event was cancelled2026-02-01T10:00:00Z--all-day flagstartUtc, endUtc, durationMinutes fieldsPE_PROFILE=work to avoid repeating --profile.-jc is shorthand for --json --compact: filters noise, truncates descriptions, limits attendees, reduces tokens.--all to auto-fetch all pages; check meta.hasMore and meta.totalCount in JSON output.--limit 100 --offset 0, then --offset 100, etc.primary (your main calendar), your account email, or <random>@group.calendar.google.com (secondary, shared, or resource calendars). Get them via porteden calendar calendars -jc.by-contact supports partial matching: "@acme.com" for email domain, --name "Smith" for name.porteden calendar calendars -jc.PE_API_KEY, PE_PROFILE, PE_TIMEZONE, PE_FORMAT, PE_COLOR, PE_VERBOSE.brew install porteden/tap/portedengo install github.com/porteden/cli/cmd/porteden@latest