From all-skills
Manages Linear issues via MCP or GraphQL API: query by key, create/update, transition states, author/audit VantageEx epics, attach GitHub PRs.
npx claudepluginhub vinnie357/claude-skills --plugin alliumThis skill uses the workspace's default tool permissions.
Manage Linear issues, author VantageEx-compatible epics, and interact with the Linear API via MCP or direct GraphQL.
Searches, retrieves, and installs Agent Skills from prompts.chat registry using MCP tools like search_skills and get_skill. Activates for finding skills, browsing catalogs, or extending Claude.
Searches prompts.chat for AI prompt templates by keyword or category, retrieves by ID with variable handling, and improves prompts via AI. Use for discovering or enhancing prompts.
Checks Next.js compilation errors using a running Turbopack dev server after code edits. Fixes actionable issues before reporting complete. Replaces `next build`.
Manage Linear issues, author VantageEx-compatible epics, and interact with the Linear API via MCP or direct GraphQL.
Activate when:
The Linear MCP server provides tool-based access to Linear. Set up once:
claude mcp add --transport http linear-server https://mcp.linear.app/mcp
Then run /mcp in a Claude Code session to complete OAuth authentication (opens browser).
After setup, use MCP tools directly for all Linear operations. The MCP server handles authentication and provides structured tool interfaces.
For full setup details, troubleshooting, and alternative client configurations, read references/mcp-setup.md.
When MCP is unavailable (headless environments, scripting, CI), use the GraphQL API directly.
Endpoint: https://api.linear.app/graphql
Auth: Bearer token via LINEAR_API_KEY environment variable
# Test connectivity
curl -s -H "Authorization: Bearer $LINEAR_API_KEY" \
-H "Content-Type: application/json" \
-d '{"query": "{ viewer { id name email } }"}' \
https://api.linear.app/graphql
For the full query catalog, read references/graphql-api.md.
The nushell client at scripts/0.1.0/linear.nu wraps common GraphQL operations.
By key (e.g., MT-686):
query IssueByKey($key: String!) {
issue(id: $key) {
id identifier title url description
state { id name type }
project { id name }
labels { nodes { name } }
attachments { nodes { title url sourceType } }
}
}
mutation CreateIssue($teamId: String!, $title: String!, $description: String, $stateId: String, $labelIds: [String!]) {
issueCreate(input: {
teamId: $teamId
title: $title
description: $description
stateId: $stateId
labelIds: $labelIds
}) {
success
issue { id identifier url }
}
}
Always fetch team workflow states first to get the exact stateId:
query IssueTeamStates($id: String!) {
issue(id: $id) {
team {
states { nodes { id name type } }
}
}
}
Then transition:
mutation MoveIssue($id: String!, $stateId: String!) {
issueUpdate(id: $id, input: { stateId: $stateId }) {
success
issue { id identifier state { name } }
}
}
mutation CreateComment($issueId: String!, $body: String!) {
commentCreate(input: { issueId: $issueId, body: $body }) {
success
comment { id url }
}
}
Prefer the GitHub-specific mutation for PR metadata:
mutation AttachPR($issueId: String!, $url: String!, $title: String) {
attachmentLinkGitHubPR(issueId: $issueId, url: $url, title: $title, linkKind: links) {
success
attachment { id title url }
}
}
query TeamStates($teamId: String!) {
team(id: $teamId) {
states { nodes { id name type position } }
}
}
When an unfamiliar mutation or type is needed, query the schema:
query ListMutations {
__type(name: "Mutation") { fields { name } }
}
query InspectInput($typeName: String!) {
__type(name: $typeName) {
inputFields { name type { kind name ofType { kind name } } }
}
}
VantageEx epics follow a three-level hierarchy: Epic (user-authored) -> Issues (team leader creates) -> Tasks (agents create).
The user authors the epic description in Linear. The epic body uses markdown sections that VantageEx parses.
| Section | Purpose | Author |
|---|---|---|
## Objective | 2-3 sentences defining success criteria | User (immutable) |
## Skills | Domain-specific skills needed (core skills implicit) | User (immutable) |
## Repos | Target repositories | User (immutable) |
| Section | Purpose | Author |
|---|---|---|
## Instructions | User guidance added at re-queue (ADR-027) | User or dashboard |
## Constraints | Boundaries (defaults: mise run ci, no attribution, squash merge) | User |
## Team | Lead model, default model, escalation policy | User |
## Escalation | Failure and ambiguity policies | User |
## PR | Pull request URL when submitted | Agent |
oauth-pkce-flow)feature/<epic-slug>For the full epic specification with examples and anti-patterns, read references/epic-format.md.
Linear uses typed workflow states. VantageEx maps these to its lifecycle:
| VantageEx Status | Linear State | Meaning |
|---|---|---|
ready | Backlog / Ready | Epic in backlog, all fields present |
up_next | Up Next | User approved for agent work |
in_progress | In Progress | Agent actively working |
needs_help | Needs Help | Agent exhausted fix cycles |
review | In Review | CI passed, PR created |
complete | Done | PR merged |
archived | Archived | Hidden from dashboard |
Key transitions:
ready -> up_next: User only (the gate)up_next -> in_progress: EpicPickerWorker (automatic)in_progress -> needs_help: ValidateWorker (after 3 fix cycles)needs_help -> up_next: User re-queues with ## Instructionsin_progress -> review: Agent submits PRreview -> complete: User merges PRFor the full state machine and cross-system mapping, read references/workflow-states.md.
| Command | Purpose |
|---|---|
/linear:plan-epic | Create a new VantageEx-compatible epic in Linear |
/linear:audit-epics | Audit existing epics for VantageEx compatibility |
/linear:groom-epics | Fix issues found by audit |
| File | Content |
|---|---|
references/mcp-setup.md | Linear MCP server setup and troubleshooting |
references/graphql-api.md | Full GraphQL query catalog |
references/epic-format.md | VantageEx epic specification |
references/audit-checklist.md | Epic validation checks |
references/workflow-states.md | State machine and cross-system mapping |
| File | Content |
|---|---|
templates/0.1.0/epic.md | Epic description template |
templates/0.1.0/audit-report.md | Audit output format |
templates/0.1.0/team-definition.md | Team section template |
| File | Content |
|---|---|
scripts/0.1.0/linear.nu | Nushell GraphQL client for non-MCP use |
stateId valuesattachmentLinkGitHubPR over attachmentLinkURL when linking GitHub PRserrors array in GraphQL responses as failures