🧪 Skills
Gmail Auto Draft
Monitor Gmail inbox, read incoming emails, generate personalized follow-up replies with OpenAI, and save replies into Gmail Drafts for human review. Use when...
v1.0.0
Description
name: gmail-auto-draft description: Monitor Gmail inbox, read incoming emails, generate personalized follow-up replies with OpenAI, and save replies into Gmail Drafts for human review. Use when the user wants Gmail auto-monitoring, AI-assisted client email responses, draft-before-send workflows, or agency inbox automation.
Gmail Auto Draft
Use this skill to build or run a review-safe Gmail reply workflow: read new emails, generate AI reply text, and save drafts instead of sending directly.
Quick workflow
- Prepare Google OAuth credentials.
- Use local GMN endpoint (
openclaw:main) or set external OpenAI key. - Run one-shot mode to validate draft creation.
- Tune query and prompt style.
- Switch to polling mode for continuous monitoring.
Run commands
Install dependencies:
cd skills/gmail-auto-draft/scripts
python3 -m pip install -r requirements.txt
Default backend (local GMN via OpenClaw gateway):
export OPENAI_BASE_URL="http://127.0.0.1:18789/v1"
export OPENAI_MODEL="openclaw:main"
Or use OpenAI directly:
export OPENAI_API_KEY="your_openai_key"
export OPENAI_MODEL="gpt-4o-mini"
One-shot test:
./run_once.sh --auth-mode local --max-emails 3
Continuous monitor:
./run_once.sh --poll-interval 60 --max-emails 5 --mark-read
Upwork demo profile (lead-focused query + fixed agency tone):
./run_upwork_demo.sh --auth-mode local --max-emails 5
Common options
--query: Gmail search filter for target emails.--max-emails: max messages per cycle.--poll-interval: seconds between cycles (0means run once).--openai-model: model name (defaultopenclaw:main).--openai-base-url: OpenAI-compatible base URL (defaulthttp://127.0.0.1:18789/v1).--agency-profile: business context for OpenAI prompt.--agency-profile-file: load agency context from a text file.--style-rules: response style constraints.--style-rules-file: load style rules from a text file.--query-file: load Gmail query from a text file.--mark-read: mark processed messages as read.--processed-label: label for already drafted emails (defaultopenclaw_auto_drafted).
Output behavior
The script prints JSON for each cycle:
processed: number of drafted repliescreated_drafts: draft metadataskipped: skipped message reasonserrors: per-message errors
Resources
- Script:
scripts/gmail_auto_draft.py - Runner:
scripts/run_once.sh - Demo runner:
scripts/run_upwork_demo.sh - Dependencies:
scripts/requirements.txt - Setup guide:
references/setup.md - Prompt/query tuning:
references/prompt-tuning.md - Demo config:
references/upwork-demo/agency_profile.txt - Demo config:
references/upwork-demo/style_rules.txt - Demo config:
references/upwork-demo/gmail_query.txt
Reviews (0)
Sign in to write a review.
No reviews yet. Be the first to review!
Comments (0)
No comments yet. Be the first to share your thoughts!