npx claudepluginhub skillpanel/maister --plugin maisterWant just this skill?
Then install: npx claudepluginhub u/[userId]/[slug]
Orchestrates comprehensive research workflows from question definition through findings documentation. Handles technical, requirements, literature, and mixed research types with adaptive methodology, multi-source gathering, pattern synthesis, and evidence-based reporting. Supports standalone research tasks and embedded research phase in other workflows.
This skill uses the workspace's default tool permissions.
references/brainstorming-techniques.mdreferences/design-techniques.mdreferences/research-methodologies.mdResearch Orchestrator
Systematic research workflow from question definition to evidence-based documentation.
Initialization
BEFORE executing any phase, you MUST complete these steps:
Step 1: Load Framework Patterns
Read the framework reference file NOW using the Read tool:
../orchestrator-framework/references/orchestrator-patterns.md- Delegation rules, interactive mode, state schema, initialization, context passing, issue resolution
Step 2: Initialize Workflow
- Create Task Items: Use
TaskCreatefor all phases (see Phase Configuration), then set dependencies withTaskUpdate addBlockedBy - Create Task Directory:
.maister/tasks/research/YYYY-MM-DD-task-name/ - Initialize State: Create
orchestrator-state.ymlwith research context
Output:
š Research Orchestrator Started
Task: [research question]
Directory: [task-path]
Starting Phase 1: Initialize research...
When to Use
Use when:
- Need comprehensive research on a topic
- Exploring codebase patterns or architecture
- Gathering requirements or best practices
- Want systematic evidence-based answers
- Research will feed into development workflows
DO NOT use for: Development tasks, bug fixes, performance optimization.
Core Principles
- Evidence-Based: Every finding must have source citation
- Systematic: Follow structured methodology for consistent results
- Multi-Source: Gather from codebase, docs, config, external sources
- Synthesized: Cross-reference findings, identify patterns
- Actionable: Produce outputs that enable next steps
Local References
| File | When to Use | Purpose |
|---|---|---|
references/research-methodologies.md | Phase 1 | Research type classification, methodology selection, gathering strategies, analysis frameworks |
references/brainstorming-techniques.md | Phase 3 | Divergent/convergent thinking, interactive exploration, scope guardrails |
references/design-techniques.md | Phase 5 | Decision documentation (MADR), ADR guidance, decision linking |
Phase Configuration
| Phase | content | activeForm | Agent/Skill |
|---|---|---|---|
| 1 | "Research foundation (init, plan, gather, synthesize)" | "Executing research foundation" | Direct + research-planner + information-gatherer (xN) + research-synthesizer |
| 2 | "Evaluate brainstorming value" | "Evaluating brainstorming value" | Direct |
| 3 | "Generate solution alternatives" | "Generating solution alternatives" | solution-brainstormer |
| 4 | "Evaluate brainstorming alternatives" | "Evaluating brainstorming alternatives" | Direct (interactive) |
| 5 | "Design high-level architecture" | "Designing high-level architecture" | Direct + solution-designer |
| 6 | "Summarize research and suggest next steps" | "Completing research" | Direct |
Research Types
| Type | Keywords | Focus | Typical Outputs |
|---|---|---|---|
| Technical | "how does", "where is", "implementation" | Codebase analysis | Knowledge base, architecture docs |
| Requirements | "what are requirements", "user needs" | User/business needs | Specifications, requirements doc |
| Literature | "best practices", "industry standards" | External research | Recommendations, comparisons |
| Mixed | Multiple keywords, broad questions | Comprehensive investigation | All output types |
Workflow Phases
Phase 1: Research Foundation
Purpose: Initialize research, plan methodology, gather information from all sources, and synthesize findings into a research report
Execute: Multi-step: Direct + research-planner + information-gatherer (xN) + research-synthesizer
Output: planning/research-brief.md, planning/research-plan.md, planning/sources.md, analysis/findings/*.md, analysis/synthesis.md, outputs/research-report.md
State: Set research_context.research_type, research_question, scope, methodology, sources, confidence_level, gathering_strategy
This phase executes 4 sequential steps. On resume, check existing artifacts to skip completed steps.
Step 1: Initialize (Direct)
Artifacts: planning/research-brief.md
Resume check: If planning/research-brief.md exists, skip to Step 2
- Parse research question (from command or prompt user)
- Classify research type (auto-detect from keywords or use
--typeflag) - Determine scope (included, excluded, constraints)
- Define success criteria
- Create research brief
- Update state: set
research_context.research_type,research_question,scope
Step 2: Plan (Subagent)
Artifacts: planning/research-plan.md, planning/sources.md
Resume check: If planning/research-plan.md AND planning/sources.md exist, skip to Step 3
Read references/research-methodologies.md NOW using the Read tool ā research type classification, methodology selection, gathering strategies
INVOKE NOW: Use Task tool with subagent_type: maister:research-planner
Context to pass: task_path, research_brief_path, research_type, research_question, scope
Update state: research_context.methodology, sources
Step 3: Gather + Merge (Parallel Subagents + Direct)
Artifacts: analysis/findings/*.md (category-specific)
Resume check: If any analysis/findings/*.md files exist, skip to Step 4
Determine gatherer count and categories:
- Read
planning/research-plan.mdfor Gathering Strategy section - If gathering strategy found: use specified categories and count (cap at 8 max)
- If no gathering strategy: fall back to default 4 categories (codebase, documentation, configuration, external)
- Update state:
research_context.gathering_strategy
CRITICAL: Launch all N agents in ONE message for parallel execution.
Parallel Execution Pattern:
Read gathering strategy from research-plan.md
For each category in strategy:
Use Task tool: source_category=[category_id] ā analysis/findings/[prefix]-*.md
Step 4: Synthesize (Subagent)
Artifacts: analysis/synthesis.md, outputs/research-report.md
Resume check: If analysis/synthesis.md AND outputs/research-report.md exist, skip (Phase 1 complete)
INVOKE NOW: Use Task tool with subagent_type: maister:research-synthesizer
Context to pass: task_path, findings_directory_path, research_question, research_type, methodology
Synthesizer produces:
- Pattern analysis and cross-references (
analysis/synthesis.md) - Comprehensive research report answering research question (
outputs/research-report.md) - Confidence levels for each finding
- Documented gaps and uncertainties
Update state: research_context.confidence_level
ā Pause
AskUserQuestion - "Research foundation complete (initialized, planned, gathered, synthesized). Continue to brainstorming evaluation?"
Phase 2: Optional Phases Decision
Phase gate: Requires
AskUserQuestionconfirmation from Phase 1 before executing.
Purpose: Evaluate whether brainstorming and/or design phases would be valuable (independently)
Execute: Direct
Output: Updated orchestrator-state.yml
State: Set options.brainstorming_enabled, options.design_enabled
Auto-resolve if: --brainstorm/--no-brainstorm flags (brainstorming only), --design/--no-design flags (design only)
Process:
- Read
analysis/synthesis.mdsummary andresearch_typefrom state - Evaluate brainstorming value based on:
- Number of viable approaches identified in synthesis (multiple ā valuable)
- Problem novelty (new domain ā valuable; well-understood ā less so)
- Whether synthesis identified competing trade-offs (yes ā valuable)
- Evaluate design value based on:
- Whether research suggests architectural decisions (yes ā valuable)
- Research type (requirements/mixed ā likely valuable; technical ā depends)
- Whether design artifacts would feed into development workflow
- If
brainstorming_enablednot already set by flag, AskUserQuestion:- "[Brainstorming recommendation]. Would you like to explore solution alternatives?"
- Options: "Yes, explore alternatives" / "No, skip brainstorming"
- If
design_enablednot already set by flag, AskUserQuestion:- "[Design recommendation]. Would you like to generate a high-level design?"
- Options: "Yes, generate design" / "No, skip design"
- Update state: set
brainstorming_enabledanddesign_enabled
ā If brainstorming enabled: continue to Phase 3 ā If brainstorming disabled AND design enabled: skip to Phase 5 ā If both disabled: skip to Phase 6
Phase 3: Solution Generation
Purpose: Generate solution alternatives from research evidence using specialized brainstormer subagent
Execute: solution-brainstormer subagent
Output: outputs/solution-exploration.md
State: Update phase_summaries.phase-3
Skip if: brainstorming_enabled = false (user chose to skip in Phase 2, or --no-brainstorm flag)
Read references/brainstorming-techniques.md NOW using the Read tool ā divergent/convergent thinking techniques, scope guardrails
ANTI-PATTERN: Do NOT generate solution alternatives inline. The solution-brainstormer agent has specialized multi-perspective analysis capabilities.
INVOKE NOW: Use Task tool with subagent_type: maister:solution-brainstormer
Context to pass (Pattern 7):
task_path,synthesis_path,research_report_pathoutput_path:outputs/solution-exploration.mdā brainstormer MUST write to this exact path- Accumulated context:
research_type,research_question,confidence_level,phase_summaries(Phase 1)
SELF-CHECK: After Task tool returns, verify
outputs/solution-exploration.mdexists and contains alternatives. If missing: STOP. Do NOT proceed to Phase 4 or Phase 5. Re-invoke the brainstormer with corrected context (ensureoutput_pathisoutputs/solution-exploration.md). If second attempt also fails, use AskUserQuestion to report the failure and ask whether to retry or skip brainstorming.
ā AUTO-CONTINUE
Phase 4: Solution Convergence
Purpose: Present brainstorming alternatives to user for decision-making on each decision area
Execute: Direct (interactive)
Output: Updated orchestrator-state.yml with chosen approaches
State: Update phase_summaries.phase-4 with decision_areas and deferred_ideas
Skip if: brainstorming_enabled = false
Resume check: If phase_summaries.phase-4.decision_areas has entries with chosen_approach set, skip already-resolved areas
ANTI-PATTERN: Do NOT present all decision areas in a single summary table and ask one combined "do you agree?" question. Each area MUST get its own detailed presentation and its own AskUserQuestion call.
ANTI-PATTERN: Do NOT show full alternatives/pros/cons for the first area and then shortcut remaining areas to just a recommendation line + question. EVERY area gets the SAME level of detail ā all alternatives with descriptions, pros, and cons. No exceptions.
- Read
outputs/solution-exploration.md - For each decision area sequentially, output ALL of the following (steps a-d) BEFORE calling AskUserQuestion:
a. Area header: area name and why this decision matters (1-2 sentences of context)
b. Alternatives detail: For EVERY alternative in this area, show:
- Name and description (2-3 sentences)
- Pros (bullet list)
- Cons (bullet list) c. Recommendation: which alternative is recommended and why (1 sentence) d. AskUserQuestion: this area's alternatives as options (mark recommended with "(Recommended)") + "Need more info" option e. If user picks ā record choice, move to next area f. If "Need more info" ā present the detailed trade-off analysis for the requested alternative, then re-ask
SELF-CHECK before each AskUserQuestion: Did you output the alternatives with pros/cons for THIS area? If you only showed a recommendation line without listing all alternatives and their pros/cons, STOP and output the full detail before asking.
- After all areas resolved, present a brief summary of the chosen combination
- Update state with chosen approaches per decision area
GATE CHECK: Verify that AskUserQuestion was called for EACH decision area. If any decision area was skipped for any reason (e.g., output file missing, read failure), STOP and resolve before continuing. Do NOT mark Phase 4 complete without user convergence on all decision areas.
ā Pause
AskUserQuestion - "Brainstorming complete. Continue to high-level design?"
Phase 5: High-Level Design
Phase gate: Requires
AskUserQuestionconfirmation from the preceding phase before executing.
Purpose: Create architecture design from selected solution approach
Execute: Orchestrator-Direct Hybrid
Output: outputs/high-level-design.md, outputs/decision-log.md
State: Update phase_summaries.phase-5
Skip if: design_enabled = false
Read references/design-techniques.md NOW using the Read tool ā MADR format, ADR guidance, decision documentation patterns
Part A ā Design Direction (Direct):
- If Phase 4 ran: confirm selected approaches from convergence
- If Phase 4 was skipped: use research report recommendations as design input
- AskUserQuestion for any design preferences or constraints (e.g., "Any architectural constraints or preferences?")
Part B ā Design Generation (Subagent):
ANTI-PATTERN: Do NOT generate C4 architecture diagrams or ADRs inline. The solution-designer agent has specialized architecture and MADR documentation capabilities.
INVOKE NOW: Use Task tool with subagent_type: maister:solution-designer
Context to pass (Pattern 7):
task_path,synthesis_path,research_report_pathsolution_exploration_path(only if Phase 3-4 ran)selected_approach(from Phase 4 convergence if ran, or from research report recommendations)design_preferences(from Part A)- Accumulated context:
research_type,research_question,confidence_level,phase_summaries
SELF-CHECK: After Task tool returns, verify both
outputs/high-level-design.mdandoutputs/decision-log.mdexist. If missing: STOP. Do NOT proceed to Part C. Re-invoke the designer with corrected context. If second attempt also fails, use AskUserQuestion to report the failure and ask whether to retry or skip design.
Part C ā Summary (Direct):
3. Read outputs/high-level-design.md and outputs/decision-log.md
4. Present executive summary to user:
- Architecture style and key components
- Number of architectural decisions recorded
- Key decision highlights (1 line each)
- Integration points with existing system (if applicable)
ā Pause
AskUserQuestion - "Design complete. Continue to output generation?"
Phase 6: Completion
Phase gate: Requires
AskUserQuestionconfirmation from the preceding phase before executing.
Purpose: Summarize research results and suggest next steps Execute: Direct Output: No new files ā summarizes existing outputs
Process:
- Inventory all generated outputs:
outputs/research-report.md(always), plus conditional:solution-exploration.md,high-level-design.md,decision-log.md - Present executive summary to user:
- Key findings and confidence level
- Which optional phases ran (brainstorming, design)
- Key decision highlights (if brainstorming/design ran)
- If design artifacts exist, suggest starting development in a fresh session:
To start development based on this research, clear context first or start a new session, then run: /maister:development [task-path]
ā End of workflow
Domain Context (State Extensions)
Research-specific fields in orchestrator-state.yml:
research_context:
research_type: "technical" | "requirements" | "literature" | "mixed"
research_question: "[user's question]"
scope:
included: []
excluded: []
constraints: []
methodology: []
sources: []
confidence_level: "high" | "medium" | "low"
gathering_strategy:
categories: [] # e.g., ["codebase", "documentation", "external-apis"]
count: 4 # number of gatherer instances
source: "planner" | "default" # where strategy came from
phase_summaries:
phase-1:
summary: "..."
steps_completed: [] # track which steps completed for resume
phase-3:
summary: "..."
phase-4:
summary: "..."
decision_areas: [] # list of {area, alternatives_count, chosen_approach}
deferred_ideas: []
phase-5:
summary: "..."
architecture_style: null
decisions_count: 0
options:
brainstorming_enabled: null # null=not yet decided, set by Phase 2 or --brainstorm/--no-brainstorm flag
design_enabled: null # independent, set by Phase 2 or --design/--no-design flag
Task Structure
.maister/tasks/research/YYYY-MM-DD-research-name/
āāā orchestrator-state.yml
āāā planning/
ā āāā research-brief.md # Phase 1, Step 1
ā āāā research-plan.md # Phase 1, Step 2
ā āāā sources.md # Phase 1, Step 2
āāā analysis/
ā āāā findings/
ā ā āāā codebase-*.md # Phase 1, Step 3
ā ā āāā docs-*.md # Phase 1, Step 3
ā ā āāā config-*.md # Phase 1, Step 3
ā ā āāā external-*.md # Phase 1, Step 3
ā ā āāā [custom-category]-*.md # Phase 1, Step 3 (dynamic categories)
ā āāā synthesis.md # Phase 1, Step 4 (reasoning log)
āāā outputs/
ā āāā research-report.md # Phase 1, Step 4 (main deliverable)
ā āāā solution-exploration.md # Phase 3 (conditional)
ā āāā high-level-design.md # Phase 5 (conditional)
ā āāā decision-log.md # Phase 5 (conditional)
Auto-Recovery
| Phase | Max Attempts | Strategy |
|---|---|---|
| 1 (Step 1) | 1 | Prompt user for clarification if question unclear |
| 1 (Step 2) | 2 | Expand search patterns, use fallback mixed methodology |
| 1 (Step 3) | 3 | Retry failed agents only, continue with successful categories |
| 1 (Step 4) | 2 | Request targeted re-gathering for gaps |
| 2 | 1 | Re-evaluate recommendation if synthesis unclear |
| 3 | 2 | Re-invoke solution-brainstormer with adjusted context |
| 4 | 1 | Re-read exploration file, re-present decision areas |
| 5 | 2 | Re-invoke solution-designer with adjusted context |
| 6 | 0 | Summary only |
Integration with Other Workflows
As Standalone Research
Command: /maister:research [research-question]
Flow: Complete all phases, save outputs in task directory
As Embedded Research Phase
Invoked by: development orchestrator, migration orchestrator
Integration:
- Parent orchestrator invokes research skill
- Research executes phases 1-5 (skip Phase 6 completion ā parent orchestrator handles next steps)
- Design outputs fed into parent's specification phase
- Research report saved in parent task's
analysis/research/directory
Handoff:
research_outputs:
research_report: "[path to outputs/research-report.md]"
findings_directory: "[path to analysis/findings/]"
solution_exploration: "[path to outputs/solution-exploration.md]"
high_level_design: "[path to outputs/high-level-design.md]"
decision_log: "[path to outputs/decision-log.md]"
Command Integration
Invoked via:
/maister:research [question] [--type=TYPE] [--brainstorm] [--no-brainstorm] [--design] [--no-design](new)/maister:research [task-path] [--from=PHASE](resume)
Brainstorming flags:
--brainstorm: Force brainstorming phase (auto-resolves Phase 2 brainstorming decision to "enable")--no-brainstorm: Skip brainstorming phase- Neither: Phase 2 presents recommendation and asks user
Design flags:
--design: Force high-level design phase (auto-resolves Phase 2 design decision to "enable")--no-design: Skip high-level design phase- Neither: Phase 2 presents recommendation and asks user
Task directory: .maister/tasks/research/YYYY-MM-DD-task-name/
Similar Skills
Activates when the user asks about AI prompts, needs prompt templates, wants to search for prompts, or mentions prompts.chat. Use for discovering, retrieving, and improving prompts.