JIRA Assistant
This hub routes requests to specialized JIRA skills. It does not execute JIRA operations directly—it helps find the right skill.
Risk Levels
| Operation | Risk | Notes |
|-----------|------|-------|
| Route to skill | - | Read-only routing decision |
| Skill discovery | - | Lists available skills |
| Context tracking | - | In-memory only |
Risk Legend: - Safe, read-only | ! Caution, modifiable | !! Warning, destructive but recoverable | !!! Danger, irreversible
Quick Reference
| I want to... | Use this skill | Risk | |--------------|----------------|:----:| | Create/edit/delete a single issue, view/show issue details | jira-issue | ⚠️ | | Search with JQL, export results | jira-search | - | | Change status, assign, resolve, manage versions/components | jira-lifecycle | ⚠️ | | Manage sprints, epics, subtasks, story points | jira-agile | - | | Add comments, attachments, watchers | jira-collaborate | - | | Link issues, view dependencies, blocker chains | jira-relationships | - | | Log time, manage worklogs, time reports | jira-time | - | | Handle service desk requests, SLAs, queues, approvals, assets, knowledge base | jira-jsm | - | | Bulk operations on many issues (50+) with dry-run preview | jira-bulk | ⚠️⚠️ | | Git branch names, commits, PR descriptions | jira-dev | - | | Custom field discovery and Agile field configuration | jira-fields | - | | Project discovery, cache management, diagnostics | jira-ops | - | | Project settings, permissions, automation rules | jira-admin | ⚠️⚠️ |
Risk Legend: - Read-only/safe | ⚠️ Has destructive ops (confirm) | ⚠️⚠️ High-risk (confirm + dry-run)
Routing Rules
- Explicit skill mention wins - If user says "use jira-agile", use it
- Entity signals - Issue key present → likely jira-issue or jira-lifecycle
- Quantity determines bulk - 50+ issues → jira-bulk (consider bulk for 10+, required for 50+)
- Keywords drive routing:
- "show", "view", "display", "get", "retrieve", "see", "details", "look up", "check" (with issue reference) → jira-issue
- "create", "update", "delete" (single issue) → jira-issue
- "search", "find", "JQL", "filter" → jira-search
- "sprint", "epic", "backlog", "story points", "subtask" → jira-agile
- "transition", "move to", "assign", "close", "version", "release", "component", "resolve", "reopen", "archive" → jira-lifecycle
- "comment", "attach", "watch", "notify", "notification", "activity", "history", "changelog" → jira-collaborate
- "link", "blocks", "depends on", "clone", "dependency graph", "blocker chain" → jira-relationships
- "log time", "worklog", "estimate", "time report", "timesheet" → jira-time
- "service desk", "SLA", "customer", "request", "queue", "approval", "knowledge base", "asset" → jira-jsm
- "branch name", "commit", "PR" → jira-dev
- "custom field", "field ID" → jira-fields
- "cache", "warm cache", "project discovery", "diagnostics", "performance", "request batching" → jira-ops
- "permissions", "project settings", "automation", "automation rule", "users", "groups", "notifications", "screens", "issue types", "workflows", "notification scheme", "permission scheme" → jira-admin
Negative Triggers
| Skill | Does NOT handle | Route to instead | |-------|-----------------|------------------| | jira-issue | Bulk (50+), transitions, comments, sprints, time | jira-bulk, jira-lifecycle, jira-collaborate, jira-agile, jira-time | | jira-search | Single issue lookup, issue modifications | jira-issue, jira-bulk | | jira-lifecycle | Field updates, bulk transitions | jira-issue, jira-bulk | | jira-agile | Issue CRUD (except epic/subtask), JQL, time tracking | jira-issue, jira-search, jira-time | | jira-bulk | Single issue ops, sprint management | jira-issue, jira-agile | | jira-collaborate | Field updates, bulk comments | jira-issue, jira-bulk | | jira-relationships | Field updates, epic/sprint linking | jira-issue, jira-agile | | jira-time | SLA tracking, date-based searches | jira-jsm, jira-search | | jira-jsm | Standard project issues, non-service-desk searches | jira-issue, jira-search | | jira-dev | Issue field updates, JQL searches | jira-issue, jira-search | | jira-fields | Field value searching, field value updates | jira-search, jira-issue | | jira-ops | Project configuration, issue operations | jira-admin, jira-issue | | jira-admin | Issue CRUD, bulk operations | jira-issue, jira-bulk |
When to Clarify First
Ask the user before routing when:
- Request matches 2+ skills with similar likelihood
- Request is vague or could be interpreted multiple ways
- Destructive operations are implied
Disambiguation Table
| Pattern | Ambiguity | Question | Options | |---------|-----------|----------|---------| | "update issues" (no count) | Single vs multiple | "One issue or multiple?" | jira-issue, jira-bulk | | "show the sprint" | Details vs issues | "Sprint details or issues in sprint?" | jira-agile, jira-search | | "link PR" | Link to JIRA or create link | "Link PR to JIRA issue or create issue relationship?" | jira-dev, jira-relationships | | "close them" (after search) | Single vs bulk | "Close all N issues found?" | jira-bulk (with confirmation) | | "delete issues" | Count unclear | "How many issues? (One uses jira-issue, multiple uses jira-bulk)" | jira-issue, jira-bulk |
Disambiguation Examples
"Show me the sprint" Could mean:
- Sprint metadata (dates, goals, capacity) → jira-agile
- Issues in the current sprint → jira-search
Ask: "Do you want sprint details or the issues in the sprint?"
"Update the issue" Could mean:
- Change fields on one issue → jira-issue
- Transition status → jira-lifecycle
- Update multiple issues → jira-bulk
Ask: "What would you like to update - fields, status, or multiple issues?"
"Create an issue in the epic" Context determines:
- Epic context explicit → jira-agile
- Just issue creation → jira-issue
"Find all P1 bugs and close them" Multi-step workflow:
- First search with jira-search to find issues
- Then confirm count before using jira-bulk to close
Ask: "I found N bugs. Want me to close them all?"
Context Awareness
Pronoun Resolution
When user says "it" or "that issue":
- If exactly one issue mentioned in last 3 messages → use it
- If multiple issues mentioned → ask: "Which issue - TES-123 or TES-456?"
- If no issue in last 5 messages → ask: "Which issue are you referring to?"
After CREATE:
User: "create a bug in TES" → TES-789 created
User: "assign it to me"
→ "it" = TES-789 (the issue just created)
User: "create a bug in DEMO" → DEMO-105 created
User: "show me the details of the bug we just created"
→ "the bug we just created" = DEMO-105 (use jira-issue to retrieve details)
After SEARCH:
User: "find all open bugs" → Found TES-100, TES-101, TES-102
User: "close them"
→ "them" = the search results (use jira-bulk)
Project Scope
When user mentions a project:
- Remember it for subsequent requests in this conversation
- "Create a bug in TES" → TES is now the active project
- "Create another bug" → Use TES implicitly
- Explicit project mention updates the active project
Context Expiration
After 5+ messages or 5+ minutes since last reference:
- Re-confirm rather than assume: "Do you mean TES-123 from earlier?"
- Don't guess when context is stale
Common Workflows
Create Epic with Stories
- Use jira-agile to create the epic → Note epic key (e.g., TES-100)
- Use jira-issue to create each story with
--epic TES-100flag to link during creation- Alternatively: create stories first, then use
jira-as agile epic add-issuesto link existing issues
- Alternatively: create stories first, then use
- Confirm: "Created epic TES-100 with N stories"
Bulk Close from Search
- Use jira-search to find matching issues
- Use jira-bulk with --dry-run to preview
- Confirm count with user before executing
Data Passing Between Steps
When one skill's output feeds another:
- Capture entity IDs from responses (e.g., epic key from jira-agile)
- State this explicitly: "Created EPIC-123. Now creating stories..."
- Reference captured data in subsequent operations
Error Handling
If a skill fails:
- Report the error clearly
- Suggest recovery options from docs/SAFEGUARDS.md
- Offer alternative approaches
If a skill is not available:
- Acknowledge the limitation
- Suggest alternatives from the Quick Reference table
Permission Awareness
Before operations that might fail due to access:
- Check if user has mentioned permission issues before
- Suggest
jira-adminfor permission checks when blocked
Discoverability
/jira-assistant-skills:browse-skills- List all skills with descriptions/jira-assistant-skills:skill-info <name>- Detailed skill information
If user asks "what can you do?" or similar:
- Show the Quick Reference table
- Offer to explain specific skills
What This Hub Does NOT Do
- Execute JIRA operations directly (always delegates)
- Guess when uncertain (asks instead)
- Perform destructive operations without confirmation
- Route to deprecated or unavailable skills without warning