Agent-almanac create-github-issues
git clone https://github.com/pjt222/agent-almanac
T=$(mktemp -d) && git clone --depth=1 https://github.com/pjt222/agent-almanac "$T" && mkdir -p ~/.claude/skills && cp -r "$T/i18n/wenyan-ultra/skills/create-github-issues" ~/.claude/skills/pjt222-agent-almanac-create-github-issues-f8e0ba && rm -rf "$T"
i18n/wenyan-ultra/skills/create-github-issues/SKILL.mdCreate GitHub Issues
Structured GitHub issue creation from review findings or task breakdowns. Converts a list of findings (from
review-codebase, security-audit-codebase, or manual analysis) into well-formed GitHub issues with labels, acceptance criteria, and cross-references.
When to Use
- After a codebase review produces a findings table that needs tracking
- After a planning session identifies work items that should become issues
- When converting a TODO list or backlog into trackable GitHub issues
- When batch-creating related issues that need consistent formatting and labeling
Inputs
- Required:
— a list of items, each with at minimum a title and description. Ideally also includes: severity, affected files, and suggested labelsfindings - Optional:
— how to batch findings into issues:group_by
,severity
,file
(default:theme
)theme
— prefix for auto-created labels (default: none)label_prefix
— whether to create missing labels (default:create_labels
)true
— preview issues without creating them (default:dry_run
)false
Procedure
Step 1: Prepare Labels
Ensure all needed labels exist in the repository.
- List existing labels:
gh label list --limit 100 - Identify labels needed by the findings (from severity, phase, or explicit label fields)
- Map severities to labels if not already mapped:
,critical
,high-priority
,medium-prioritylow-priority - Map phases/themes to labels:
,security
,architecture
,code-quality
,accessibility
,testingperformance - If
is true, create missing labels:create_labelsgh label create "name" --color "hex" --description "desc" - Use consistent colors: red for critical/security, orange for high, yellow for medium, blue for architecture, green for testing
Expected: All labels referenced by findings exist in the repository. No duplicate labels created.
On failure: If
gh CLI is not authenticated, instruct the user to run gh auth login. If label creation is denied (insufficient permissions), proceed without creating labels and note which labels are missing.
Step 2: Group Findings
Batch related findings into logical issues to avoid issue sprawl.
- If
isgroup_by
: group findings by their phase or category (all security findings → 1-2 issues, all a11y → 1 issue)theme - If
isgroup_by
: group findings by severity level (all CRITICAL → 1 issue, all HIGH → 1 issue)severity - If
isgroup_by
: group findings by primary affected filefile - Within each group, order findings by severity (CRITICAL first)
- If a group has more than 8 findings, split into sub-groups by sub-theme
- Each group becomes one GitHub issue
Expected: A set of issue groups, each containing 1-8 related findings. The total number of issues should be manageable (typically 5-15 for a full codebase review).
On failure: If findings have no grouping metadata, fall back to one issue per finding. This is acceptable for small finding sets (< 10) but produces too many issues for larger sets.
Step 3: Compose Issues
Build each issue using a standard template.
- Title:
— e.g.,[Severity] Theme: Brief description[HIGH] Security: Eliminate innerHTML injection in panel.js - Body structure:
## Summary One-paragraph overview of what this issue addresses and why it matters. ## Findings 1. **[SEVERITY]** Finding description (`file.js:line`) — brief explanation 2. **[SEVERITY]** Finding description (`file.js:line`) — brief explanation ## Acceptance Criteria - [ ] Criterion derived from finding 1 - [ ] Criterion derived from finding 2 - [ ] All changes pass existing tests ## Context Generated from codebase review on YYYY-MM-DD. Related: #issue_numbers (if applicable) - Apply labels: severity label + theme label + any custom labels
- If findings reference specific files, mention them in the body (not as assignees)
Expected: Each issue has a clear title, numbered findings with severity badges, checkbox acceptance criteria, and appropriate labels.
On failure: If the body exceeds GitHub's issue size limit (65536 chars), split the issue into parts and cross-reference them.
Step 4: Create Issues
Create the issues using
gh CLI and report results.
- If
is true, print each issue title and body without creating, then stopdry_run - For each composed issue, create it:
gh issue create --title "title" --body "$(cat <<'EOF' body content EOF )" --label "label1,label2" - Record the URL of each created issue
- After all issues are created, print a summary table:
#number | Title | Labels | Findings count - If issues should be sequenced, add cross-references: edit the first issue to mention "Blocked by #X" or "See also #Y"
Expected: All issues created successfully. A summary table with issue numbers and URLs is printed.
On failure: If an individual issue fails to create, log the error and continue with remaining issues. Report failures at the end. Common failures: authentication expired, label not found (if
create_labels was false), network timeout.
Validation
- All findings are represented in at least one issue
- Each issue has at least one label
- Each issue has checkbox acceptance criteria
- No duplicate issues were created (check titles against existing open issues)
- Issue count is reasonable for the finding count (not 1:1 for large sets)
- Summary table was printed with all issue URLs
Common Pitfalls
- Issue sprawl: Creating one issue per finding produces 20+ issues that are hard to manage. Group aggressively — 5-10 issues from a full review is ideal
- Missing acceptance criteria: Issues without checkboxes cannot be verified as complete. Every finding should map to at least one checkbox
- Label chaos: Creating too many labels makes filtering useless. Stick to severity + theme, not per-finding labels
- Stale references: If creating issues from an old review, verify findings still apply before creating issues. Code may have changed
- Forgetting dry run: For large finding sets, always preview with
first. It is much easier to edit a plan than to close 15 incorrect issuesdry_run: true
Related Skills
— produces the findings table this skill consumesreview-codebase
— produces PR-scoped findings that can also be converted to issuesreview-pull-request
— organizes issues into sprints and priorities after creationmanage-backlog
— creates PRs that reference and close the issuescreate-pull-request
— commits the fixes that resolve the issuescommit-changes