Back to skills
SkillHub ClubShip Full StackFull Stack
gws-calendar
Google Calendar: Manage calendars and events.
Packaged view
This page reorganizes the original catalog entry around fit, installability, and workflow context first. The original raw source lives below.
Stars
21,248
Hot score
99
Updated
March 20, 2026
Overall rating
C4.0
Composite score
4.0
Best-practice grade
A85.2
Install command
npx @skill-hub/cli install googleworkspace-cli-gws-calendar
Repository
googleworkspace/cli
Skill path: skills/gws-calendar
Google Calendar: Manage calendars and events.
Open repositoryBest for
Primary workflow: Ship Full Stack.
Technical facets: Full Stack.
Target audience: everyone.
License: Unknown.
Original source
Catalog source: SkillHub Club.
Repository owner: googleworkspace.
This is still a mirrored public skill entry. Review the repository before installing into production workflows.
What it helps with
- Install gws-calendar into Claude Code, Codex CLI, Gemini CLI, or OpenCode workflows
- Review https://github.com/googleworkspace/cli before adding gws-calendar to shared team environments
- Use gws-calendar for development workflows
Works across
Claude CodeCodex CLIGemini CLIOpenCode
Favorites: 0.
Sub-skills: 0.
Aggregator: No.
Original source / Raw SKILL.md
---
name: gws-calendar
version: 1.0.0
description: "Google Calendar: Manage calendars and events."
metadata:
openclaw:
category: "productivity"
requires:
bins: ["gws"]
cliHelp: "gws calendar --help"
---
# calendar (v3)
> **PREREQUISITE:** Read `../gws-shared/SKILL.md` for auth, global flags, and security rules. If missing, run `gws generate-skills` to create it.
```bash
gws calendar <resource> <method> [flags]
```
## Helper Commands
| Command | Description |
|---------|-------------|
| [`+insert`](../gws-calendar-insert/SKILL.md) | create a new event |
| [`+agenda`](../gws-calendar-agenda/SKILL.md) | Show upcoming events across all calendars |
## API Resources
### acl
- `delete` — Deletes an access control rule.
- `get` — Returns an access control rule.
- `insert` — Creates an access control rule.
- `list` — Returns the rules in the access control list for the calendar.
- `patch` — Updates an access control rule. This method supports patch semantics.
- `update` — Updates an access control rule.
- `watch` — Watch for changes to ACL resources.
### calendarList
- `delete` — Removes a calendar from the user's calendar list.
- `get` — Returns a calendar from the user's calendar list.
- `insert` — Inserts an existing calendar into the user's calendar list.
- `list` — Returns the calendars on the user's calendar list.
- `patch` — Updates an existing calendar on the user's calendar list. This method supports patch semantics.
- `update` — Updates an existing calendar on the user's calendar list.
- `watch` — Watch for changes to CalendarList resources.
### calendars
- `clear` — Clears a primary calendar. This operation deletes all events associated with the primary calendar of an account.
- `delete` — Deletes a secondary calendar. Use calendars.clear for clearing all events on primary calendars.
- `get` — Returns metadata for a calendar.
- `insert` — Creates a secondary calendar.
The authenticated user for the request is made the data owner of the new calendar.
Note: We recommend to authenticate as the intended data owner of the calendar. You can use domain-wide delegation of authority to allow applications to act on behalf of a specific user. Don't use a service account for authentication. If you use a service account for authentication, the service account is the data owner, which can lead to unexpected behavior.
- `patch` — Updates metadata for a calendar. This method supports patch semantics.
- `update` — Updates metadata for a calendar.
### channels
- `stop` — Stop watching resources through this channel
### colors
- `get` — Returns the color definitions for calendars and events.
### events
- `delete` — Deletes an event.
- `get` — Returns an event based on its Google Calendar ID. To retrieve an event using its iCalendar ID, call the events.list method using the iCalUID parameter.
- `import` — Imports an event. This operation is used to add a private copy of an existing event to a calendar. Only events with an eventType of default may be imported.
Deprecated behavior: If a non-default event is imported, its type will be changed to default and any event-type-specific properties it may have will be dropped.
- `insert` — Creates an event.
- `instances` — Returns instances of the specified recurring event.
- `list` — Returns events on the specified calendar.
- `move` — Moves an event to another calendar, i.e. changes an event's organizer. Note that only default events can be moved; birthday, focusTime, fromGmail, outOfOffice and workingLocation events cannot be moved.
- `patch` — Updates an event. This method supports patch semantics.
- `quickAdd` — Creates an event based on a simple text string.
- `update` — Updates an event.
- `watch` — Watch for changes to Events resources.
### freebusy
- `query` — Returns free/busy information for a set of calendars.
### settings
- `get` — Returns a single user setting.
- `list` — Returns all user settings for the authenticated user.
- `watch` — Watch for changes to Settings resources.
## Discovering Commands
Before calling any API method, inspect it:
```bash
# Browse resources and methods
gws calendar --help
# Inspect a method's required params, types, and defaults
gws schema calendar.<resource>.<method>
```
Use `gws schema` output to build your `--params` and `--json` flags.
---
## Referenced Files
> The following files are referenced in this skill and included for context.
### ../gws-calendar-insert/SKILL.md
```markdown
---
name: gws-calendar-insert
version: 1.0.0
description: "Google Calendar: Create a new event."
metadata:
openclaw:
category: "productivity"
requires:
bins: ["gws"]
cliHelp: "gws calendar +insert --help"
---
# calendar +insert
> **PREREQUISITE:** Read `../gws-shared/SKILL.md` for auth, global flags, and security rules. If missing, run `gws generate-skills` to create it.
create a new event
## Usage
```bash
gws calendar +insert --summary <TEXT> --start <TIME> --end <TIME>
```
## Flags
| Flag | Required | Default | Description |
|------|----------|---------|-------------|
| `--calendar` | — | primary | Calendar ID (default: primary) |
| `--summary` | ✓ | — | Event summary/title |
| `--start` | ✓ | — | Start time (ISO 8601, e.g., 2024-01-01T10:00:00Z) |
| `--end` | ✓ | — | End time (ISO 8601) |
| `--location` | — | — | Event location |
| `--description` | — | — | Event description/body |
| `--attendee` | — | — | Attendee email (can be used multiple times) |
## Examples
```bash
gws calendar +insert --summary 'Standup' --start '2026-06-17T09:00:00-07:00' --end '2026-06-17T09:30:00-07:00'
gws calendar +insert --summary 'Review' --start ... --end ... --attendee [email protected]
```
## Tips
- Use RFC3339 format for times (e.g. 2026-06-17T09:00:00-07:00).
- For recurring events or conference links, use the raw API instead.
> [!CAUTION]
> This is a **write** command — confirm with the user before executing.
## See Also
- [gws-shared](../gws-shared/SKILL.md) — Global flags and auth
- [gws-calendar](../gws-calendar/SKILL.md) — All manage calendars and events commands
```
### ../gws-calendar-agenda/SKILL.md
```markdown
---
name: gws-calendar-agenda
version: 1.0.0
description: "Google Calendar: Show upcoming events across all calendars."
metadata:
openclaw:
category: "productivity"
requires:
bins: ["gws"]
cliHelp: "gws calendar +agenda --help"
---
# calendar +agenda
> **PREREQUISITE:** Read `../gws-shared/SKILL.md` for auth, global flags, and security rules. If missing, run `gws generate-skills` to create it.
Show upcoming events across all calendars
## Usage
```bash
gws calendar +agenda
```
## Flags
| Flag | Required | Default | Description |
|------|----------|---------|-------------|
| `--today` | — | — | Show today's events |
| `--tomorrow` | — | — | Show tomorrow's events |
| `--week` | — | — | Show this week's events |
| `--days` | — | — | Number of days ahead to show |
| `--calendar` | — | — | Filter to specific calendar name or ID |
| `--timezone` | — | — | IANA timezone override (e.g. America/Denver). Defaults to Google account timezone. |
## Examples
```bash
gws calendar +agenda
gws calendar +agenda --today
gws calendar +agenda --week --format table
gws calendar +agenda --days 3 --calendar 'Work'
gws calendar +agenda --today --timezone America/New_York
```
## Tips
- Read-only — never modifies events.
- Queries all calendars by default; use --calendar to filter.
- Uses your Google account timezone by default; override with --timezone.
## See Also
- [gws-shared](../gws-shared/SKILL.md) — Global flags and auth
- [gws-calendar](../gws-calendar/SKILL.md) — All manage calendars and events commands
```