Goose-skills meeting-brief
Daily meeting preparation system that checks your calendar each morning, deeply researches external attendees (LinkedIn, company info, GitHub, past notes), and sends you personalized briefs via email (1 per person). Use when you want automated preparation for upcoming meetings with context about each person you're meeting.
git clone https://github.com/gooseworks-ai/goose-skills
T=$(mktemp -d) && git clone --depth=1 https://github.com/gooseworks-ai/goose-skills "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/composites/meeting-brief" ~/.claude/skills/gooseworks-ai-goose-skills-meeting-brief && rm -rf "$T"
skills/composites/meeting-brief/SKILL.mdMeeting Brief
Automated daily meeting preparation system that researches meeting attendees and sends you personalized briefs.
What It Does
Every morning (configurable time):
- Checks your calendar for today's meetings (via gcalcli)
- Extracts attendees from each meeting
- Filters out your team members (configurable)
- Deep researches each external person:
- LinkedIn profile (web search)
- Company information
- GitHub profile (if engineer)
- Past interactions/notes (memory search)
- Recent news/activity
- Generates AI-powered brief per person
- Sends 1 email per person to your inbox
Setup
1. Configure Team Members
Edit
config.json to list your team members (these will be skipped):
{ "team_members": [ "alice@yourcompany.com", "bob@yourcompany.com", "team@yourcompany.com" ], "team_domains": [ "@yourcompany.com" ], "schedule": "0 7 * * *", "timezone": "America/Los_Angeles", "your_email": "you@yourcompany.com", "brief_from": "Meeting Brief <briefbot@yourcompany.com>", "slack_webhook": "https://hooks.slack.com/services/YOUR/WEBHOOK/URL", "send_email": true, "send_slack": true, "include_calendar_details": true, "research_depth": "standard" }
Config options:
: Emails to skip (exact match)team_members
: Domain patterns to skip (e.g., skip all @yourcompany.com)team_domains
: Cron expression for daily run (default: 7am)schedule
: Timezone for scheduletimezone
: Where to send briefsyour_email
: From address for briefsbrief_from
: Slack incoming webhook URL (optional)slack_webhook
: Whether to send email briefs (default: true)send_email
: Whether to send Slack notifications (default: false)send_slack
: Include meeting time/location in briefinclude_calendar_details
:research_depth
(web only),quick
(web + GitHub),standard
(web + GitHub + past notes)deep
2. Run Daily (Manual or Scheduled)
Run manually each morning:
cd skills/meeting-brief ./scripts/run_daily.sh
How It Works
Main Workflow (scripts/run_daily.sh
)
scripts/run_daily.sh-
Fetch today's meetings (
)scripts/check_calendar.sh- Uses gcalcli to get today's agenda
- Parses meeting times, titles, attendees
- Outputs JSON with meeting details
-
Filter external attendees (built into run_daily.sh)
- Loads config.json
- Filters out team members and team domains
- Creates list of people to research
-
Research each person (
)scripts/research_person.js- Web search: LinkedIn profile, company info
- GitHub search: Profile and repos (if applicable)
- Memory search: Past interactions/notes
- News search: Recent activity
- Outputs structured research JSON
-
Generate brief (
)scripts/generate_brief.js- Uses AI agent to generate the brief
- Inputs: research data + meeting context
- Outputs: Two formats:
- Email: Concise bullet-point brief
- Slack: Rich paragraph-style story with deeper context and narrative
-
Send brief
- Email: Uses Gmail skill (
)send_email: true - Slack: Uses webhook (
,send_slack: true
)scripts/send_slack.sh - Subject: "Meeting Brief: [Person Name] - [Meeting Title]"
- Body: AI-generated brief with research
- Email: Uses Gmail skill (
-
Save to personal CRM (
)supernotes/people/- Each researched person saved as markdown file
- Includes: research data, meeting context, date
- Builds personal relationship database over time
-
Track sent briefs (logs to
)data/sent/YYYY-MM-DD.json- Prevents duplicates
- Enables analytics
Research Process
For each external attendee, the system researches:
Web Search (Always)
- LinkedIn profile (name + company)
- Company information
- Recent news mentions
- Professional background
GitHub (If research_depth
is standard
or deep
)
research_depthstandarddeep- GitHub profile lookup (by name/email)
- Recent repos and contributions
- Technical focus areas
Memory/Past Notes (If research_depth
is deep
)
research_depthdeep- Search MEMORY.md and daily notes
- Past meeting notes
- Previous interactions
- Context from past conversations
Output Format
Research is structured as JSON:
{ "person": { "name": "Jane Doe", "email": "jane@example.com", "company": "Example Corp", "title": "VP Engineering" }, "linkedin": { "url": "...", "bio": "...", "experience": [...] }, "github": { "username": "janedoe", "profile_url": "...", "recent_repos": [...] }, "company": { "name": "Example Corp", "industry": "...", "recent_news": [...] }, "past_interactions": [ "Met at conference in 2024", "Discussed partnership opportunity" ] }
Brief Generation
The AI-generated brief comes in two formats:
Email Format (Concise Bullets)
-
Quick Overview
- Who they are (name, title, company)
- Why you're meeting (meeting title/description)
-
Background
- Professional background (LinkedIn)
- Company context
- Technical expertise (GitHub, if applicable)
-
Conversation Starters
- Based on recent activity
- Shared interests/connections
- Relevant topics
-
Action Items / Notes
- Past interactions (if any)
- Things to remember
- Follow-up items
Slack Format (Rich Story)
Deeper, narrative-driven brief with:
- Paragraph-style storytelling about the person
- Context about their journey and recent work
- Compelling hooks and conversation angles
- More background color and detail
- Stronger narrative flow than bullet points
Example Brief:
Subject: Meeting Brief: Jane Doe - Product Partnership Discussion Hi, You're meeting with Jane Doe today at 2pm. ## Quick Overview Jane is VP of Engineering at Example Corp, a B2B SaaS company in the dev tools space. She's been there for 3 years and previously worked at GitHub and Microsoft. ## Background - Strong background in developer tooling and infrastructure - Recently led Example Corp's API platform overhaul (launched Q4 2025) - Active on GitHub (janedoe) - maintains several open-source CLI tools - Technical blog focuses on API design and developer experience ## Conversation Starters - Their new API platform (just launched, getting good traction) - Recent blog post on GraphQL vs REST (published last week) - Shared interest in developer experience (noted in her LinkedIn) ## Notes - You met briefly at DevTools Summit 2024 - She mentioned interest in partnering on integration opportunities --- Meeting: Product Partnership Discussion Time: Today at 2:00 PM Location: Zoom (link in calendar)
Manual Usage
Run for a specific person:
# Research a person node scripts/research_person.js "Jane Doe" "jane@example.com" "Example Corp" # Generate brief node scripts/generate_brief.js research_output.json meeting_context.json # Send brief ./scripts/send_brief.sh brief.html "Jane Doe"
Run for today's meetings:
./scripts/run_daily.sh
Data & Logs
meeting-brief/ ├── data/ │ ├── sent/ # Sent brief logs (by date) │ │ └── 2026-02-21.json │ ├── research/ # Research cache (by person) │ │ └── jane-doe.json │ └── meetings/ # Meeting data (by date) │ └── 2026-02-21.json └── logs/ └── run.log # Execution logs
Tips
- Test with dry-run first: Set
in run_daily.sh to preview without sendingDRY_RUN=true - Adjust research depth: Start with
, upgrade toquick
orstandard
as neededdeep - Refine team filter: Add domains/emails to skip internal meetings
- Review briefs: Check data/sent/ logs to see what's being sent
- Iterate on prompts: Edit generate_brief.js to customize AI prompt
Troubleshooting
No briefs sent:
- Check gcalcli authentication (
)gcalcli agenda today tomorrow - Verify calendar has events with external attendees
- Check logs in
logs/run.log
Briefs missing information:
- Increase
in config.jsonresearch_depth - Check web_search and GitHub CLI are working
- Review research data in
data/research/
Duplicate briefs:
- Check
for already-sent trackingdata/sent/ - Verify cron job isn't running multiple times
Tools Used
- gcalcli: For fetching today's meetings from Google Calendar
- web_search: For LinkedIn and company research
- GitHub CLI (
): For GitHub profile lookup (optional)gh - Gmail: For sending brief emails (optional — can also output to file)
Privacy & Security
- Research data is cached locally in
data/research/ - No external APIs (uses web_search, GitHub CLI, memory_search)
- Briefs sent only to configured email
- Team member filtering prevents leaking internal info
- All data stored in skill directory (no cloud storage)