pi-google-services

Google Calendar & Gmail MCP server for Pi — login once, manage your calendar and emails from your AI agent.

Packages

Package details

extensionskill

Install pi-google-services from npm and Pi will load the resources declared by the package manifest.

$ pi install npm:pi-google-services
Package
pi-google-services
Version
0.1.12
Published
Jun 11, 2026
Downloads
not available
Author
lucasvidela94
License
MIT
Types
extension, skill
Size
17.4 MB
Dependencies
0 dependencies · 0 peers
Pi manifest JSON
{
  "skills": [
    "./SKILL.md"
  ],
  "extensions": [
    "./extensions"
  ]
}

Security note

Pi packages can execute code and influence agent behavior. Review the source before installing third-party packages.

README

pi-google-services

Google Calendar, Gmail, and Google Meet MCP server for Pi. Single binary, zero runtime deps. Login once, manage everything from your agent.

Quick Install

pi install npm:pi-google-services
pi-google-services setup
# Restart Pi session, then:
# "show my events", "read my inbox", "create a meeting with Meet"

Updates

# Via Pi (recommended)
pi update pi-google-services

# Via binary
pi-google-services update

After updating, restart your Pi session.

Tools

Calendar (7)

Tool Description
list-events List events in a date range
create-event Create event with attendees + Meet link
update-event Modify existing event
delete-event Remove event
search-events Search by text
list-calendars Show all calendars
get-freebusy Check availability

Gmail (5)

Tool Description
list-inbox Show recent emails
get-email Read full email by ID
search-emails Search with Gmail syntax
send-email Send new email
reply-to-email Reply to thread

Tasks (5)

Tool Description
list-tasklists Show all task lists
list-tasks List tasks (pending/completed)
create-task Create a new task
complete-task Mark task as done
delete-task Remove a task

Meet

Pass "withMeet": true to create-event to auto-generate a Google Meet link.

Architecture

pi-google-services/          npm package (pi-package)
├── main.go                  CLI entry point
├── package.json             Pi manifest + npm
├── SKILL.md                 Pi skill
├── install.js               postinstall: download binary + credentials
├── internal/
│   ├── mcp/                 MCP protocol (JSON-RPC 2.0 / stdio)
│   ├── services/            Service interface + tool implementations
│   │   ├── calendar.go      7 tools
│   │   └── gmail.go         5 tools
│   ├── calendar/api.go      Google Calendar API wrapper
│   ├── gmail/api.go         Gmail API wrapper
│   ├── auth/                OAuth2 PKCE (browser login)
│   └── config/              Token storage
└── .github/workflows/
    └── release.yml          CI: build + npm publish (OIDC)

Credentials are stored as a GitHub secret (GOOGLE_OAUTH_CREDENTIALS_JSON), NOT in the repository. install.js downloads them during npm postinstall.

Transparency & Security

Open Source, Auditable Code

This entire project is open source. Every line of code can be reviewed, audited, and verified. The Go binary is built from this source in GitHub Actions with provenance attestation — you can verify the build matches the published source.

How OAuth Works

pi-google-services uses OAuth 2.0 with PKCE (Proof Key for Code Exchange), the industry standard for desktop applications:

  1. You run login or setup
  2. Your browser opens to Google's consent screen
  3. You see exactly what permissions are being requested (calendar, email, tasks, drive, contacts)
  4. You authorize with your Google account
  5. A token is saved locally on your machine (~/.config/pi-google-services/)
  6. The token never leaves your machine — all API calls go directly from your binary to Google

About the Client ID

The package ships with a pre-registered Google Cloud OAuth client ID. This is not a secret — it's the same mechanism used by every app that offers "Sign in with Google" (Todoist, Notion, Fantastical, etc.).

The client ID is publicly visible in the authorization URL and only serves to identify which app is requesting access. The actual security is in the OAuth consent screen where you decide what to share.

Credential Storage

What Where
OAuth client ID Embedded in the binary (public by design)
Access/Refresh tokens ~/.config/pi-google-services/tokens.json (0600 permissions)
No data leaves your machine All Google API calls are direct from your binary

The binary never phones home, tracks usage, or sends telemetry.

Development

cp /path/to/credentials.json .
go build -o pi-google-services .
./pi-google-services login
./pi-google-services serve

Tests

go test ./... -v

15 unit tests (MCP protocol, config, service metadata, services).

License

MIT