cookbook/91_tools/google/README.md
Agents for Gmail, Google Calendar, Google Drive, and Google Slides using OAuth or service account authentication.
from agno.agent import Agent
from agno.models.openai import OpenAIChat
from agno.tools.google.calendar import GoogleCalendarTools
agent = Agent(
model=OpenAIChat(id="gpt-4o"),
tools=[GoogleCalendarTools()],
add_datetime_to_context=True,
markdown=True,
)
agent.print_response("What meetings do I have tomorrow?", stream=True)
from agno.agent import Agent
from agno.models.openai import OpenAIChat
from agno.tools.google.slides import GoogleSlidesTools
agent = Agent(
model=OpenAIChat(id="gpt-4o"),
tools=[GoogleSlidesTools()],
markdown=True,
)
agent.print_response("Create a presentation titled 'Q3 Review'", stream=True)
Go to APIs & Services > Enable APIs and Services and enable:
| Toolkit | API to Enable |
|---|---|
GoogleCalendarTools | Google Calendar API |
GmailTools | Gmail API |
GoogleDriveTools | Google Drive API |
GoogleSlidesTools | Google Slides API + Google Drive API |
export GOOGLE_CLIENT_ID=your_client_id
export GOOGLE_CLIENT_SECRET=your_client_secret
export GOOGLE_PROJECT_ID=your_project_id
pip install google-api-python-client google-auth-httplib2 google-auth-oauthlib
On first run, a browser window opens for OAuth consent. A token.json file is saved for subsequent runs.
For server/bot deployments with no browser:
export GOOGLE_SERVICE_ACCOUNT_FILE=/path/to/service-account-key.json
export [email protected] # required for Gmail, optional for Calendar/Slides
| File | Description |
|---|---|
gmail_tools.py | Core examples: read-only agent, safe agent, label manager, full agent, thread reply |
gmail_daily_digest.py | Structured email digest with priority classification |
gmail_inbox_triage.py | Personal inbox triage agent with LearningMachine |
gmail_draft_reply.py | Thread-aware draft replies |
gmail_followup_tracker.py | Find unanswered sent emails, draft follow-ups |
gmail_action_items.py | Extract structured action items from email threads |
| File | Description |
|---|---|
calendar_event_creator.py | Event creation with attendees, Google Meet, and timezone handling |
calendar_daily_briefing.py | Structured daily briefing with conflict detection and prep notes |
calendar_meeting_scheduler.py | Multi-person scheduling with availability checking |
| File | Description |
|---|---|
drive_tools.py | Read-only and full-access agents: search, read, upload, and download files |
drive_file_search.py | Search files with structured output schema and pagination |
drive_document_reader.py | Read and summarize Google Docs, Sheets, and Slides as text |
drive_folder_organizer.py | Browse folder structure, upload local files, and download from Drive |
| File | Description |
|---|---|
slide_tools.py | Core examples: create presentation, add slides, read content, list, delete |
slides_presentation_builder.py | Multi-slide deck builder with tables, layouts, and text annotations |
slides_content_reader.py | Read and summarize existing presentations with structured output |
slides_media_slides.py | Background images, YouTube embeds, and Drive video integration |
| File | Description |
|---|---|
calendar_gmail_meeting_prep.py | Calendar + Gmail: meeting prep briefs with attendee email context |