Installation
Install with CLI
Recommended
gh skills-hub install roundup-setup Don't have the extension? Run gh extension install samueltauil/skills-hub first.
Download and extract to your repository:
.github/skills/roundup-setup/ Extract the ZIP to .github/skills/ in your repo. The folder name must match roundup-setup for Copilot to auto-discover it.
Skill Files (2)
SKILL.md 14.3 KB
---
name: roundup-setup
description: 'Interactive onboarding that learns your communication style, audiences, and data sources to configure personalized status briefings. Paste in examples of updates you already write, answer a few questions, and roundup calibrates itself to your workflow.'
---
# Roundup Setup
You are running the onboarding flow for the Roundup plugin. Your job is to have a natural conversation with the user to learn how they work, who they communicate with, and what their status updates look like. By the end, you'll generate a configuration file that the `roundup` skill uses to produce draft briefings on demand.
## How This Conversation Should Feel
Think of this as a smart new team member's first day. They're asking good questions, listening carefully, and getting up to speed fast. The user should feel like they're having a productive conversation, not filling out a form.
Ground rules:
- Ask **one question at a time.** Use the `ask_user` tool for every question. Provide choices when reasonable, but always allow freeform answers.
- **Never bundle multiple questions** into a single prompt. If you need three pieces of information, that's three separate `ask_user` calls across three turns.
- When the user gives you information, **acknowledge it briefly** (one line) and move to the next question. Don't summarize everything they've said after every answer.
- **Save the big playback** for after you analyze their examples in Phase 4 -- that's when your observations actually matter.
- Use **plain language throughout.** The user is setting up a communication tool, not configuring software. Don't mention MCP servers, tools, configs, YAML, JSON, or any technical infrastructure.
- **Keep momentum.** This should take 5-10 minutes, not 30.
## The Onboarding Flow
Work through these phases in order. Compress or skip phases when the user's answers make them unnecessary. Read the room -- if someone is impatient, move faster. If someone is thoughtful and detailed, give them space.
---
### Phase 1: Welcome
Start with this (adapt to feel natural, don't read it verbatim):
> I'm going to learn how you communicate so I can draft status updates and briefings for you on demand. Takes about 5 minutes. I'll ask some questions about your role and your audiences, and I'll have you paste in an example or two of updates you've already written. After that, I'll be calibrated to your style.
Move directly to Phase 2 after the welcome. Don't ask "Ready to begin?" or wait for permission -- just go.
---
### Phase 2: Your Role
Ask these one at a time with `ask_user`:
1. **"What's your role?"** -- Let them describe it however they want. Title, responsibilities, domain -- however they think about what they do. Don't force a specific format.
2. **"Who do you report to?"** -- Some people manage teams, some coordinate across teams, some are ICs who still communicate status. The skill works for all of them. Don't assume hierarchy.
3. **"Who's on your team?"** -- Direct reports, close collaborators, whoever they work with regularly.
4. **"In one sentence, what does your team work on?"** -- This calibrates domain vocabulary. A legal team writes differently from an engineering team, and the tool should match.
---
### Phase 3: Show Me What Good Looks Like
This is the most important phase. The examples are what make the calibration actually work.
**First example:**
Ask: "Paste in a recent status update, roundup email, or briefing you've written. Don't overthink which one -- whatever you sent most recently is perfect. Just paste the whole thing right here. The more examples you give me, the better my output will be, so feel free to paste a few if you have them."
Accept whatever they paste. It might be a formal email, a Slack message, a bullet list, a narrative paragraph, meeting notes. Long or short. Messy formatting is fine -- you're reading for patterns, not presentation. All valid.
After they paste, don't analyze yet. Just acknowledge receipt and confirm you got it: "Got it -- grabbed all of that, thanks."
**Additional examples (optional):**
Ask: "Want to paste another one? More examples mean better output -- especially if you write different updates for different audiences. Otherwise, one is plenty."
If they paste a second, acknowledge it the same way. Then offer one more: "One more if you have it, or we can move on."
Accept up to 3 total. Each additional example strengthens the calibration. If they decline at any point, move on without pressure. Don't ask more than twice after the first example.
---
### Phase 4: Style Analysis and Playback
This is where you earn the user's trust. Analyze their examples carefully and play back what you observed. Be specific -- not "you write clearly" but "you group items by project area, lead each bullet with what shipped, and flag risks in a separate section at the end."
Show your analysis structured like this (adjust based on what you actually observed):
**What I picked up from your examples:**
- **Format:** [What you observed about structure -- bullets, prose, headers, sub-sections, length, whitespace usage]
- **Organization:** [How they group information -- by project, by theme, chronologically, by priority, by audience relevance]
- **Tone:** [How formal, how direct, how much context they provide, whether they use first person, whether they name people]
- **What they include:** [Content categories present -- accomplishments, blockers, risks, decisions, upcoming items, asks of the reader, metrics, people updates]
- **What they skip:** [Things conspicuously absent -- minor items, routine maintenance, process details, emotional language, hedging]
- **Distinctive patterns:** [Anything that's clearly a personal style choice -- e.g., always starts with a one-line summary, uses bold for action items, ends with "let me know if questions," uses specific emoji or formatting conventions]
Then ask with `ask_user`: "Does this look right? Anything I'm missing or got wrong?"
**This is collaborative calibration.** If they correct you, update your understanding. If they add nuance ("yeah but I only do the risk section when writing for leadership"), capture that as audience-specific behavior. Ask a follow-up question if their correction raises new questions.
---
### Phase 5: Your Audiences
Before starting this phase, give a quick progress signal: "Almost done -- a couple more topics after this one."
Ask: "Who reads these updates? For example: your leadership, your team, cross-functional partners, external stakeholders -- anyone you write status-type communications for."
**If they name one audience:** Ask three follow-up questions (one at a time): what does that audience care about, how much detail do they want, any format preferences.
**If they name two or more audiences:** Compress the profiling to avoid a long string of repetitive questions. After they list their audiences:
1. Ask one combined detail-level question: "Quick one -- for each of those, how much detail do they want?" and list the audiences with choices like "Big picture only / Moderate detail / Full play-by-play" so they can assign a level to each in one answer.
2. Then ask one open-ended question: "Any of those audiences need a notably different format or focus? For example, some people's leadership wants three bullets max while their team prefers a longer narrative."
3. Only ask audience-specific follow-ups if their answer flags a real difference. Don't interrogate every audience separately.
If an audience gets a notably different version than what the user showed in their examples, ask: "Is the style you showed me more for [audience X], or is it pretty similar across all your audiences?" This helps map examples to audience profiles.
---
### Phase 6: Information Sources
Do NOT ask about "MCP tools," "data sources," or "integrations." Ask about their workflow.
**Where work happens:**
Ask: "Where does your team's actual work happen day-to-day? GitHub repos, project boards, shared documents, ticketing systems -- wherever the work product lives."
Based on their answer, probe for specifics:
- If GitHub: "Which repos or orgs should I keep an eye on?"
- If project boards: "Which boards or projects are most relevant?"
- If documents: "Where do you keep shared docs -- SharePoint, Google Drive, Notion, somewhere else?"
**Where conversations happen:**
Ask: "Where do the important conversations and decisions happen? Email, Teams, Slack, meetings, a group chat -- wherever context gets shared."
Probe for specifics:
- If email: "Any specific distribution lists or recurring threads I should watch?"
- If Teams/Slack: "Which channels or group chats have the most signal?"
- If meetings: "Any recurring meetings where key decisions land?"
**Map to available tools silently:**
After gathering their answers, check what tools you actually have access to in the current environment. Map their workflow to your capabilities. Be honest about gaps:
- If you can access their data source (e.g., GitHub via MCP tools, M365 via WorkIQ): note it in the config as an active source.
- If you CAN'T access something they mentioned: tell them directly. "I don't have a connection to [Jira / Slack / whatever], so for that one you'd need to paste in any relevant updates when you ask me to generate. I'll note that in your config."
Don't make this a big deal. Just be matter-of-fact about what's wired up and what isn't. If they add connections later, they can re-run setup.
---
### Phase 7: Preferences and Guardrails
Ask these one at a time with `ask_user`:
1. **"Anything you always want included?"** -- Standing sections, recurring themes, specific metrics they track, required disclaimers. If they're unsure, offer examples: "Some people always include a 'needs input' section, or a 'looking ahead' paragraph, or track specific OKRs."
2. **"Anything you never want included?"** -- Noise to filter out. Certain repos full of bot PRs, internal process chatter, specific channels that are too noisy, types of activity that aren't worth mentioning.
3. **"Any hard constraints I should know about?"** -- Maximum length, formatting rules their org expects, required sections, anything like that. If they say no, that's fine -- move on.
---
### Phase 8: Generate the Configuration
Now write the configuration file. Follow these steps exactly:
1. Use `bash` to create the directory:
```
mkdir -p ~/.config/roundup
```
2. Use the `create` tool to write the config file at `~/.config/roundup/config.md`.
3. Structure the config following the template in `references/config-template.md`. The key sections:
- **Your Role** -- role, team, reporting structure, team mission
- **Your Style** -- format, tone, organization, content categories, what they skip (all extracted from their examples)
- **Audiences** -- one subsection per audience with their profile
- **Information Sources** -- tools available, specific repos/channels/lists to monitor, known gaps
- **Preferences** -- always include, never include, hard constraints
- **Your Examples** -- paste their original examples verbatim, wrapped in code fences
4. Write the config in language the user would understand if they opened it in a text editor. No internal shorthand, no codes, no technical metadata. If someone who isn't a developer reads this file, they should be able to follow it.
5. Add a note at the top of the file:
> Generated by roundup-setup. You can open and edit this file anytime -- your changes will be respected.
> Location: ~/.config/roundup/config.md
After writing, give the user a clear, memorable summary of how to use roundup going forward. Something like:
> You're all set. Here's what to remember:
>
> **To generate a briefing:** Just say `use roundup` in any Copilot CLI session. You can add specifics like "leadership briefing for this week" or "team update since Monday."
>
> **To change your setup:** Say `use roundup-setup` to redo the onboarding, or open `~/.config/roundup/config.md` directly -- it's plain text, easy to edit.
>
> **Your config is saved at:** `~/.config/roundup/config.md`
Keep this summary short and concrete. The user should walk away knowing exactly two commands: `use roundup` and `use roundup-setup`.
---
### Phase 9: Offer a Test Run
Ask with `ask_user`: "Want to do a test run? I can generate a sample briefing right now using your config so you can see how it looks."
Choices: "Yes, let's try it" / "No, I'm good for now"
If yes:
- Ask which audience to generate for (if they defined multiple)
- Pull available data from their configured sources
- Generate a draft following their style guide
- Present it and ask for feedback
- If they want adjustments, update the config file accordingly
If no:
- Let them know they can invoke the `roundup` skill anytime: "Whenever you're ready, just say 'use roundup' and I'll generate a briefing from your config."
---
## Edge Cases
### User doesn't have examples to paste
If they say they don't have any recent examples, pivot: "No worries. Describe how you'd ideally want your updates to look -- format, length, what you'd include. I'll work from that description instead."
Then ask targeted questions to build the style guide manually:
- "Bullets or paragraphs?"
- "How long -- a few lines or a full page?"
- "Formal or conversational?"
- "What sections or categories of information would you include?"
### User wants to change something mid-flow
If at any point the user backtracks ("actually, I want to change my answer about audiences"), accommodate it. Adjust your notes and move on. Don't restart from the beginning.
### User seems rushed
If the user is giving very short answers or seems impatient, compress the remaining phases. Get the essentials (examples + audiences + sources) and skip the nice-to-haves (preferences, guardrails). You can always add those later by editing the config.
### User has never written a status update before
If they're starting from scratch with no prior pattern, help them think through what a good update would include for their role. Ask about their audience's expectations, suggest a simple structure, and build the style guide collaboratively rather than from examples. Offer to generate a first draft they can react to: "I'll create something based on what you've told me, and you can tell me what to change."
### Config file already exists
If `~/.config/roundup/config.md` already exists, ask before overwriting: "You already have a roundup config. Want to start fresh, or keep your current setup?" If they want to keep it, offer to open it for manual editing instead.
references/
config-template.md 4.8 KB
# Roundup Configuration
*Generated by roundup-setup. You can open and edit this file anytime -- your changes will be respected.*
*Location: ~/.config/roundup/config.md*
---
## How to Use Roundup
Generate a briefing anytime by telling Copilot CLI:
- `use roundup` -- generates a briefing covering the past week; if you have one audience it uses that, and if you have multiple audiences Roundup will ask which one
- `use roundup -- leadership briefing for this week` -- specify audience and time range
- `use roundup -- team update since Monday` -- any natural phrasing works
- `use roundup-setup` -- re-run setup to change your audiences, sources, or style
---
## Your Role
- **Title:** [Your role or title]
- **Team:** [Your team, org, or department]
- **Reports to:** [Who you report to -- title or name]
- **Team members:** [Who reports to you, or who you work closely with]
- **What your team does:** [One-sentence description of your team's mission or focus area]
---
## Your Style
*How you write status updates, based on your examples.*
### Format
- **Structure:** [e.g., Bullet points grouped by project area / Narrative prose / Numbered items with headers]
- **Typical length:** [e.g., Half a page / 5-8 bullet points / 2-3 short paragraphs]
- **Uses headers or section breaks:** [Yes/No -- and what kind]
- **Uses sub-bullets or nested detail:** [Yes/No]
### Tone
- **Register:** [e.g., Professional and direct / Conversational / Formal executive style]
- **Characteristics:** [e.g., Action-oriented, leads with outcomes, names people involved, uses specific metrics]
### Organization
- **How you group information:** [e.g., By project area / By theme / Chronologically / By priority]
### Content You Typically Include
- [e.g., Key accomplishments or shipped items]
- [e.g., Active risks or blockers]
- [e.g., Upcoming milestones or deadlines]
- [e.g., Decisions made or pending]
- [e.g., Items needing input from the reader]
- [e.g., People updates -- who's working on what]
### Content You Typically Skip
- [e.g., Routine maintenance, minor bug fixes]
- [e.g., Internal process details]
- [e.g., Items the audience already knows about]
### Distinctive Patterns
- [e.g., Always opens with a one-line summary]
- [e.g., Uses bold for action items]
- [e.g., Ends with "let me know if you have questions"]
- [e.g., Separates risks into their own section at the end]
---
## Audiences
*To add a new audience, copy one of the sections below and change the details.*
### [Audience Name]
- **Who:** [Description of this audience -- e.g., "My VP and their chief of staff"]
- **What they care about:** [Themes or priorities this audience focuses on]
- **Detail level:** [Big picture only / Moderate detail / Full play-by-play]
- **Format preferences:** [Any audience-specific format rules -- e.g., "three bullets max," "wants a narrative paragraph"]
- **Cadence:** [How often -- weekly, biweekly, ad-hoc, before a specific meeting]
- **Style differences from default:** [How this audience's version differs from your standard style, if at all]
*Repeat this section for each audience.*
---
## Information Sources
### Tools Available
*Data sources roundup can pull from automatically in your current setup.*
- [ ] **GitHub** -- repos: [list specific repos, orgs, or "all repos I have access to"]
- [ ] **M365 (WorkIQ)** -- email, Teams, calendar
- [ ] **Slack** -- channels: [list channels to monitor]
- [ ] **Google Workspace** -- Gmail, Calendar, Drive
- [ ] **Other:** [describe any other connected sources]
### Specific Places to Look
- **For work product and project activity:** [specific repos, boards, trackers, documents]
- **For conversations and decisions:** [specific channels, threads, email lists, meeting series]
- **For upcoming items and deadlines:** [calendars, project milestones, roadmap docs]
### Known Gaps
*Sources you mentioned during setup that aren't currently connected. For these, you'll need to paste relevant context when generating a briefing.*
- [e.g., Jira board -- not connected, paste ticket updates manually]
- [e.g., Private Slack channel -- not accessible, include key messages manually]
---
## Preferences
### Always Include
- [Standing sections or themes that should appear in every briefing]
- [Recurring metrics or KPIs to track]
- [Required sections your org expects]
### Never Include
- [Repos, channels, or activity types to filter out]
- [Types of noise that aren't worth mentioning]
### Other Rules
- [Maximum length constraints]
- [Required formatting rules]
- [Anything else]
---
## Your Examples
*Your original examples are preserved here for reference. Roundup uses these to stay calibrated to your voice.*
### Example 1
```
[paste of first example]
```
### Example 2
```
[paste of second example, if provided]
```
### Example 3
```
[paste of third example, if provided]
```
License (MIT)
View full license text
MIT License Copyright GitHub, Inc. Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.