Teams Meeting Pipeline
Operate the Teams meeting summary pipeline via AigenLabs CLI — summarize meetings, inspect pipeline status, replay jobs, manage Microsoft Graph subscriptions.
Skill metadata
| Source | Bundled (installed by default) |
| Path | skills/productivity/teams-meeting-pipeline |
| Version | 1.1.0 |
| Author | AigenLabs Agent + Teknium |
| License | MIT |
| Tags | Teams, Microsoft Graph, Meetings, Productivity, Operations |
Reference: full SKILL.md
The following is the complete skill definition that AigenLabs loads when this skill is triggered. This is what the agent sees as instructions when the skill is active.
Teams Meeting Pipeline
Use this skill whenever the user asks about Microsoft Teams meeting summaries, transcripts, recordings, action items, Graph subscriptions, or any operational question about the Teams meeting pipeline. Works in any language — the triggers below are examples, not an exhaustive list.
Everything operator-facing is a aigenlabs teams-pipeline subcommand run via the terminal tool. There are no new model tools for this pipeline — the CLI is the surface.
When to use this skill
The user is asking to:
- summarize a Teams meeting / extract action items / pull meeting notes
- check pipeline status, inspect a stored meeting job, or see recent meetings
- replay / re-run a stored job that failed or needs a fresh summary
- validate Microsoft Graph setup after changing env or config
- troubleshoot "meeting summary never arrived" or "no new meetings are ingesting"
- manage Graph webhook subscriptions (create, renew, delete, inspect)
- set up automated subscription renewal (see pitfall below)
Multilingual trigger examples (not exhaustive):
- English: "summarize the Teams meeting", "pipeline status", "replay job X"
- Turkish: "Teams meeting özetle", "action item çıkar", "toplantı notu", "pipeline durumu", "replay job"
Prerequisites
Before using the pipeline, verify these are set in ~/.aigenlabs/.env:
MSGRAPH_TENANT_ID=...
MSGRAPH_CLIENT_ID=...
MSGRAPH_CLIENT_SECRET=...
If any are missing, direct the user to the Azure app registration guide at /guides/microsoft-graph-app-registration — they need an Azure AD app registration with admin-consented Graph application permissions before the pipeline will work.
Command reference
Status and inspection (start here)
aigenlabs teams-pipeline validate # config snapshot — run first after any change
aigenlabs teams-pipeline token-health # Graph token status
aigenlabs teams-pipeline token-health --force-refresh # force a fresh token acquisition
aigenlabs teams-pipeline list # recent meeting jobs
aigenlabs teams-pipeline list --status failed # only failed jobs
aigenlabs teams-pipeline show <job-id> # full detail of one job
aigenlabs teams-pipeline subscriptions # current Graph webhook subscriptions
Re-running / debugging
aigenlabs teams-pipeline run <job-id> # replay a stored job (re-summarize, re-deliver)
aigenlabs teams-pipeline fetch --meeting-id <id> # dry-run: resolve meeting + transcript without persisting
aigenlabs teams-pipeline fetch --join-web-url "<url>" # dry-run by join URL
Subscription management
aigenlabs teams-pipeline subscribe \
--resource communications/onlineMeetings/getAllTranscripts \
--notification-url https://<your-public-host>/msgraph/webhook \
--client-state "$MSGRAPH_WEBHOOK_CLIENT_STATE"
aigenlabs teams-pipeline renew-subscription <sub-id> --expiration <iso-8601>
aigenlabs teams-pipeline delete-subscription <sub-id>
aigenlabs teams-pipeline maintain-subscriptions # renew near-expiry ones
aigenlabs teams-pipeline maintain-subscriptions --dry-run # show what would be renewed
Decision tree for common asks
- User asks "why didn't I get a summary for today's meeting?" → start with
list --status failed, thenshow <job-id>on the relevant row. If the job doesn't exist at all, checksubscriptions— the webhook may have expired (see pitfall below). - User asks "is setup working?" →
validate, thentoken-health, thensubscriptions. If all three pass, request a test meeting and checklistfor a fresh row. - User asks "re-run summary for meeting X" →
listto find the job ID,run <job-id>to replay. If it fails again,show <job-id>to inspect the error andfetch --meeting-idto dry-run the artifact resolution. - User asks "add meeting X to the pipeline" → usually you don't — the pipeline is subscription-driven, not per-meeting. If they want a specific past meeting summarized, use
fetchto pull transcript +runafter a job is created.
Critical pitfall: Graph subscriptions expire in 72 hours
Microsoft Graph caps webhook subscriptions at 72 hours and will not auto-renew them. If maintain-subscriptions is not scheduled, meeting notifications silently stop arriving 3 days after any manual subscription creation.
When the user reports "the pipeline worked yesterday but nothing is arriving today":
- Run
aigenlabs teams-pipeline subscriptions— if it's empty or all entries showexpirationDateTimein the past, that's the cause. - Recreate with
subscribeas shown above. - Set up automated renewal immediately via
aigenlabs cron add, a systemd timer, or plain crontab. The operator runbook at/guides/operate-teams-meeting-pipeline#automating-subscription-renewal-required-for-productionhas all three options. 12-hour interval is safe (6x headroom against the 72h limit).
Other pitfalls
- Transcript not available yet. Teams takes some time after a meeting ends to generate the transcript artifact.
fetch --meeting-idon a just-ended meeting may return empty. Wait 2-5 minutes and retry, or let the Graph webhook drive ingestion naturally. - Delivery mode mismatch. If summaries are produced (
listshows success) but nothing lands in Teams, checkplatforms.teams.extra.delivery_modeand the matching target config (incoming_webhook_urlORchat_idORteam_id+channel_id). The writer reads these from config.yaml orTEAMS_*env vars. - Graph app permissions. A token acquires cleanly (
token-healthpasses) but Graph API calls return 401/403 when permissions were added but admin consent wasn't re-granted. Have the user revisit the app registration in the Azure portal and click "Grant admin consent" again.
Related docs
Point the user to these when they need more depth than this skill covers:
- Azure app registration walkthrough:
/guides/microsoft-graph-app-registration - Full pipeline setup:
/user-guide/messaging/teams-meetings - Operator runbook (renewal automation, troubleshooting, go-live checklist):
/guides/operate-teams-meeting-pipeline - Webhook listener setup:
/user-guide/messaging/msgraph-webhook