From maister
Orchestrates research workflows for technical questions, codebase patterns, requirements, and best practices with multi-source gathering, synthesis, and evidence-based reporting.
npx claudepluginhub skillpanel/maister --plugin maisterThis skill uses the workspace's default tool permissions.
Systematic research workflow from question definition to evidence-based documentation.
Orchestrates research workflows from question definition to evidence-based findings documentation for technical, requirements, literature, and codebase topics.
Orchestrates multi-step research projects by scaffolding plans, generating atomic tasks with dependencies, and persisting state via Tasks or files. Use for new research or complex workflows.
Guides agents through structured research phases: planning queries, multi-query execution, source analysis, and synthesis for comprehensive investigations or reports.
Share bugs, ideas, or general feedback.
Systematic research workflow from question definition to evidence-based documentation.
BEFORE executing any phase, you MUST complete these steps:
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 resolutionTaskCreate for all phases (see Phase Configuration), then set dependencies with TaskUpdate addBlockedBy.maister/tasks/research/YYYY-MM-DD-task-name/orchestrator-state.yml with research contextOutput:
🚀 Research Orchestrator Started
Task: [research question]
Directory: [task-path]
Starting Phase 1: Initialize research...
Use when:
DO NOT use for: Development tasks, bug fixes, performance optimization.
| 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 | 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 |
| 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 |
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.
Artifacts: planning/research-brief.md
Resume check: If planning/research-brief.md exists, skip to Step 2
--type flag)research_context.research_type, research_question, scopeArtifacts: 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
Artifacts: analysis/findings/*.md (category-specific)
Resume check: If any analysis/findings/*.md files exist, skip to Step 4
Determine gatherer count and categories:
planning/research-plan.md for Gathering Strategy sectionresearch_context.gathering_strategyCRITICAL: 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
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:
analysis/synthesis.md)outputs/research-report.md)Update state: research_context.confidence_level
→ Pause
AskUserQuestion - "Research foundation complete (initialized, planned, gathered, synthesized). Continue to brainstorming evaluation?"
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:
analysis/synthesis.md summary and research_type from statebrainstorming_enabled not already set by flag, AskUserQuestion:
design_enabled not already set by flag, AskUserQuestion:
brainstorming_enabled and design_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
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 pathresearch_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
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.
outputs/solution-exploration.mdSELF-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.
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 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):
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)research_type, research_question, confidence_level, phase_summariesSELF-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:
→ Pause
AskUserQuestion - "Design complete. Continue to output generation?"
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:
outputs/research-report.md (always), plus conditional: solution-exploration.md, high-level-design.md, decision-log.mdTo start development based on this research, clear context first or start a new session, then run:
/maister:development [task-path]
→ End of workflow
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
.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)
| 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 |
Command: /maister:research [research-question]
Flow: Complete all phases, save outputs in task directory
Invoked by: development orchestrator, migration orchestrator
Integration:
analysis/research/ directoryHandoff:
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]"
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 phaseDesign flags:
--design: Force high-level design phase (auto-resolves Phase 2 design decision to "enable")--no-design: Skip high-level design phaseTask directory: .maister/tasks/research/YYYY-MM-DD-task-name/