From eai-gofer
Define the business problem and scenario for Gofer to analyse and solve.
How this skill is triggered — by the user, by Claude, or both
Slash command
/eai-gofer:0_business_scenarioThe summary Claude sees in its skill listing — used to decide when to auto-load this skill
---
Before spawning agents, calling tools, or loading large files:
.specify/memory/gofer-model-policy.yaml as the repo-owned source of truth for simple, medium, hard, and arbiter model routing. If it is missing, run /gofer:bootstrap-workspace before continuing..specify/specs/{feature}/context-bundle.md, then work from summaries.Before doing stage/helper work:
.specify/.gofer-version.specify/commands/0_business_scenario.md.specify/templates/spec-template.md.specify/scripts/bash/create-new-feature.sh.specify/scripts/node/parse-stage-command.mjs.specify/scripts/hooks/post-tool-use.mjs.specify/scripts/powershell/install-optional-tools.ps1.specify/templates/gofer-model-policy.yaml.specify/memory/gofer-model-policy.yaml.specify/specs/.specify/memory/AGENTS.md, CLAUDE.md, .claude/settings.jsonAGENTS.md.github/copilot-instructions.mdnode .specify/scripts/node/gofer-workspace-check.mjs --host auto --jsonYou are the Gofer orchestrator. Your job is to understand the user's business scenario and route them through the unified Gofer pipeline.
┌─────────────────────────────────────────────────────────────────┐
│ UNIFIED GOFER PIPELINE │
├─────────────────────────────────────────────────────────────────┤
│ │
│ 0. /0_business_scenario → kickoff, routing, discovery │
│ Business scenario intake + optional problem validation │
│ ↓ AUTO │
│ 1. /1_gofer_research → research.md │
│ Deep codebase exploration + supporting review context │
│ ↓ AUTO │
│ 2. /2_gofer_specify → spec.md │
│ Feature specification informed by research │
│ ↓ AUTO │
│ 3. /3_gofer_plan → plan.md, data-model.md, contracts/ │
│ Technical architecture and design │
│ ↓ AUTO │
│ 4. /4_gofer_tasks → tasks.md, traceability.md, issues.md │
│ Dependency-ordered task breakdown │
│ ↓ AUTO │
│ 5. /5_gofer_implement → [source code] │
│ Execute tasks phase by phase │
│ ↓ AUTO │
│ 6. /6_gofer_validate → validation artifacts │
│ Validation, blast radius, and final engineering review │
│ │
│ All artifacts go to: .specify/specs/{feature}/ │
└─────────────────────────────────────────────────────────────────┘
| Command | Purpose |
|---|---|
/0a_problem_validation | Optional deeper problem framing before research |
/7_gofer_save | Save session checkpoint mid-implementation |
/8_gofer_resume | Resume work from saved checkpoint |
/9_gofer_tests | Define acceptance test cases using DSL |
/10_gofer_cloud | READ-ONLY cloud infrastructure analysis |
/7a_stakeholder_comms | Optional post-validation communications package |
/gofer_hydrate | Reverse-engineer spec from existing code |
/gofer_constitution | Create/update project constitution |
/gofer:check-workspace | Check whether the repo scaffold is healthy |
/gofer:bootstrap-workspace | Create or update the repo-owned Gofer scaffold |
Before asking questions, scan the workspace for existing state:
# Check for Gofer artifacts
ls -la .specify/specs/ 2>/dev/null
# Check for session checkpoints
find .specify/specs -name "session-checkpoint.md" -type f 2>/dev/null
# Check for constitution
ls -la .specify/memory/constitution.md 2>/dev/null
| Artifact | Location | Indicates |
|---|---|---|
spec.md | .specify/specs/{feature}/ | Feature specified |
research.md | .specify/specs/{feature}/ | Research complete |
proposal-review.md | .specify/specs/{feature}/ | Optional supporting review context |
plan.md | .specify/specs/{feature}/ | Planning complete |
tasks.md | .specify/specs/{feature}/ | Ready for implement |
session-checkpoint.md | .specify/specs/{feature}/ | Work paused (resumable) |
validation-report.md | .specify/specs/{feature}/ | Feature validated |
constitution.md | .specify/memory/ | Project principles set |
Report what you found before proceeding.
ALWAYS ask the user what they want to do - even if artifacts exist. Existing artifacts might be for OTHER features, not what the user wants to work on now.
"What would you like to accomplish today?"
Present these options using the AskUserQuestion tool:
| Option | Description |
|---|---|
| A. New Feature | Build something new from scratch with clear requirements |
| B. Modify Existing | Change or extend existing functionality in the codebase |
| C. Fix a Bug | Diagnose and fix a specific issue |
| D. Explore/Research | Understand the codebase before making changes |
| E. Resume Work | Continue from where I left off |
| F. Setup Project | Initialize constitution and project guidelines |
If the context scan found existing artifacts, list them and ask:
"I found these existing features/work items:"
.specify/specs/*/ with its name and statusThen ask: "Do you want to continue one of these, or start something new?"
When the user selects A. New Feature, B. Modify Existing, or C. Fix a Bug, conduct a consultative discovery interview BEFORE routing to the pipeline.
First, offer the option to skip:
| Option | Description |
|---|---|
| Continue with Discovery | Answer a few questions to ensure we build the right thing (Recommended) |
| Skip Discovery | I have clear requirements, go straight to implementation |
If user selects "Skip Discovery", proceed directly to Step 3.
"What problem are you trying to solve?"
Recommended: Based on initial context, suggest the most likely problem type.
| Option | Description | Implications |
|---|---|---|
| A | Users can't find what they need quickly | Focus on search/navigation UX |
| B | Manual processes taking too much time | Focus on automation/efficiency |
| C | Data is siloed across systems | Focus on integration/consolidation |
| D | Quality/reliability issues | Focus on testing/monitoring |
| E | [Context-specific suggestion] | [Based on user's initial description] |
| Custom | Describe your specific problem | We'll tailor the approach |
You can reply with the option letter, accept the recommendation by saying "yes", or provide your own answer.
Store response in discovery context.
"Who are the primary users of this feature?"
Recommended: Suggest based on problem type selected.
| Option | Description | Implications |
|---|---|---|
| A | End customers (external) | Focus on UX, onboarding, support |
| B | Internal team members | Focus on efficiency, integrations |
| C | Developers/technical users | Focus on APIs, documentation |
| D | Business stakeholders | Focus on reporting, dashboards |
| Custom | Describe your users | We'll create appropriate personas |
Store response in discovery context.
"What specific value should this deliver?"
Recommended: Suggest based on problem and user type.
| Option | Description | Implications |
|---|---|---|
| A | Time savings (reduce X by Y%) | Need baseline metrics, time tracking |
| B | Cost reduction (save $X/month) | Need cost analysis, ROI tracking |
| C | Quality improvement (reduce errors by Y%) | Need error tracking, quality metrics |
| D | User satisfaction (increase NPS by Y) | Need feedback collection, surveys |
| Custom | Define your value metric | We'll build appropriate tracking |
Store response in discovery context.
"How will you measure success?"
Based on the value type selected, suggest relevant metrics:
| Value Type | Suggested Metrics |
|---|---|
| Time savings | Task completion time, manual steps eliminated |
| Cost reduction | Monthly costs before/after, resource utilization |
| Quality | Error rate, defect count, test coverage |
| Satisfaction | NPS score, support tickets, feature adoption |
Ask user to confirm or customize the metrics.
"Would you like me to research how leading companies solve this problem?"
| Option | Description |
|---|---|
| Yes | Research competitors and document insights |
| Skip | Continue without competitive analysis |
If user selects Yes, note for research phase. If skipped, mark "Competitive Analysis: Skipped".
If user responds with uncertainty signals ("I'm not sure", "what would you suggest?", "not certain"):
After completing discovery questions, create
.specify/specs/{feature}/discovery.md:
---
feature: '[Feature Name]'
created: '[ISO timestamp]'
discoveredBy: Claude + [User]
status: complete
---
# Business Discovery: [Feature Name]
## Problem Statement
**Pain Point**: [From Question 1] **Current State**: [If mentioned] **Impact**:
[If mentioned]
## Target Users
### Primary Users
- **Persona**: [From Question 2]
- **Technical Level**: [Inferred or asked]
- **Key Needs**: [Captured from context]
## Value Proposition
**Primary Value**: [From Question 3] **Quantified Goal**: [From Question 4]
## Success Metrics
| Metric | Target | Measurement |
| ---------- | -------- | -------------- |
| [Metric 1] | [Target] | [How measured] |
## Competitive Analysis
**Status**: [Researched / Skipped] [Insights if researched]
## Discovery Decisions
| Decision | Choice | Rationale |
| ------------- | -------- | --------- |
| Problem Focus | [Choice] | [Why] |
| User Target | [Choice] | [Why] |
| Value Metric | [Choice] | [Why] |
## AI-Readable Blocks Bridge
| Field | Decision |
| ----- | -------- |
| Profile Choice | External / Internal / Hybrid |
| Package Lane | {{public-package | internal-app | hybrid-adapter | app-local}} |
| Coupling Status | {{source-platform-coupled | source-platform-decoupled | hybrid-adapter}} |
| Public-Readiness Target | {{required | deferred | not-applicable}} |
| Block Porting Need | {{reuse | port | custom-block-exception}} |
Create Memory entries for key discovery findings:
Category: 'discovery'
Tags: ['#problem', '#feature-{id}']
Content: 'Problem: [pain point]. Impact: [who affected].'
Category: 'discovery'
Tags: ['#users', '#personas', '#feature-{id}']
Content: 'Primary users: [persona]. Technical level: [level]. Key needs: [needs].'
Category: 'discovery'
Tags: ['#value', '#metrics', '#feature-{id}']
Content: 'Primary value: [benefit]. Success metric: [metric] target [goal].'
status: incompleteBefore journey mapping, classify the request as application delivery or non-application work.
In EnterpriseAI mode, assume the request is application delivery unless the user's intent is clearly non-app. Roughly 90% of Gofer business requests should be treated this way: the user is trying to improve a customer journey or business process by building an app, workflow, portal, dashboard, mobile experience, form, assistant, or vertical application.
Treat the request as application delivery when it includes any of these signals:
Classify as non-app only when the user is asking for work such as:
If non-app, record this explicitly in discovery.md:
## Application Classification
| Field | Decision |
| ----- | -------- |
| Classification | Non-application work |
| Reason | {{why-this-is-not-an-app-or-workflow}} |
| Four-step AI journey required | No |
Then continue through the pipeline without creating a four-step AI-augmented app journey.
If app delivery is selected or inferred, continue to Step 2.7 and create the AI-augmented journey.
Gofer MUST keep the same numbered stages for both classifications. The classification changes the behavior inside the shared stages; it does not remove existing non-app functionality or fork Gofer into unrelated products.
| Mode | Stage Behavior |
|---|---|
| Application delivery | Shared stages gain a UI-first interview, a Vertical Template constrained preview loop, preview self-review, optional branding intake, an explicit UI approval gate, and a post-approval EnterpriseAI service-fit gate before plan/tasks are finalized |
| Non-app work | Shared stages preserve the current research, documentation, exploration, bug-fix, migration, audit, and other non-app workflows without app-only preview, branding, or service-fit requirements |
When the request is classified as application delivery, confirm the customer journey before routing to the rest of the pipeline. For application delivery, the default target is a concise four-step or fewer AI-augmented process. Even when the current business process has more than four steps, Gofer should use generative AI to compress, combine, or simplify the process into four business-goal-driven stages unless the user explicitly rejects that structure.
For app delivery, the default early process is:
eai, rather than
from an unconstrained custom UI.For EnterpriseAI app delivery, the interview must also capture the packaging and coupling path before research starts:
| Intake Field | Required Decision |
|---|---|
| Profile choice | External, internal, or hybrid package profile |
| Package lane | Public reusable block package, internal vertical app, hybrid adapter, or app-local implementation |
| Coupling status | source-platform-coupled, source-platform-decoupled, or hybrid adapter boundary |
| Public-readiness target | Whether the first delivery must be ready for external package consumers |
| Block porting need | Reuse existing block, port a Vertical Template block, or request a custom-block exception |
External and hybrid profile choices require explicit public-readiness, block-porting, source-platform decoupling, Storybook, and theme-override evidence in the later Gofer artifacts. Restricted-source choices still record why public readiness is not required now.
First, offer the option to skip:
| Option | Description |
|---|---|
| Confirm AI Journey (Recommended) | Review the four-step AI-augmented process for this app |
| Classify as Non-App / Skip AI Journey | Use only when this is strategy, research, documentation, audit, or analysis |
If the user selects "Classify as Non-App / Skip AI Journey", capture the non-application rationale in discovery and proceed directly to Step 3. If the request is still an app, do not silently skip journey mapping; create a draft four-step journey with assumptions and ask the user to confirm or correct it.
Based on the discovery answers, extract:
Actors: Who interacts with this feature?
Steps: What is the main flow?
Touchpoints: Where do interactions happen?
AI augmentation: How does generative AI help?
Use AskUserQuestion to present the extracted journey:
Question 1: Confirm Actors
"Based on your description, I've identified these actors in the journey:"
| Option | Description |
|---|---|
| A | [Actor 1] - [role description] |
| B | [Actor 2] - [role description] |
| C | [System] - [role description] |
| Custom | Add or modify actors |
Question 2: Confirm Journey Steps
"Here's the main flow I've identified:"
| Option | Description |
|---|---|
| A | Step 1: [goal] → Step 2: [goal] → Step 3: [goal] → Step 4: [goal] (Confirm this AI-augmented flow) |
| B | I need to modify some steps |
| C | Show me all steps, AI assistance, and completion criteria in detail first |
Question 2a: Confirm AI Assistance
"For each step, how should generative AI help the user complete the goal?"
| Option | Description |
|---|---|
| A | Chat/voice/accessibility/translations help the user understand and complete the step |
| B | Prefill or recommend data using screen context, user context, and EnterpriseAI data |
| C | Validate completion, explain missing information, and guide the user to success |
| D | Mix all of the above, with human review and audit trail controls |
| Custom | Describe the AI assistance for each step |
Question 3: Identify Key Touchpoints
"What are the main interaction points for this feature?"
| Option | Description |
|---|---|
| A | UI-heavy: Multiple screens and forms |
| B | API-driven: Primarily backend/integration work |
| C | Mixed: Both UI and API touchpoints |
| Custom | Describe your touchpoints |
After confirmation, save to .specify/specs/{feature}/journeys/base-journey.md:
---
id: {{feature-id}}-journey
name: {{journey-name}}
featureId: {{feature-id}}
status: confirmed
created: {{ISO-timestamp}}
modified: {{ISO-timestamp}}
applicationClassification: app
aiAugmentedJourney: true
maxSteps: 4
---
# AI-Augmented Customer Journey: {{feature-name}}
## Overview
{{discovery-problem-statement}}
## Actors
| ID | Name | Type | Role |
| ------ | ----------- | ------ | --------------------------- |
| user | End User | user | Primary user of the feature |
| system | Backend API | system | Handles business logic |
## Journey Steps
### Step 1: {{business-goal}}
**Actor**: {{actor-id}}
**User action**: {{action-description}}
**AI assistance**:
{{chatbot-or-voice-or-accessibility-or-translation-or-prefill-or-guidance}}
**Context used**: {{screen-context-user-data-enterpriseai-data-documents}}
**Completion criteria**: {{how-we-know-this-step-is-successful}}
**Controls**: {{human-review-confidence-evidence-audit-escalation}}
### Step 2: {{business-goal}}
...
### Step 4: {{business-goal}}
...
## Journey Diagram
```mermaid
sequenceDiagram
participant user as End User
participant system as Backend API
user->>system: Step 1 action
system-->>user: AI-guided response, prefill, or validation
user->>system: Step 2 action
```
## AI Augmentation Matrix
| Step | Business Goal | AI Assistance | Data / Context Used | Completion Signal |
| ---- | ------------- | ------------- | ------------------- | ----------------- |
| 1 | {{goal}} | {{assist}} | {{context}} | {{signal}} |
| 2 | {{goal}} | {{assist}} | {{context}} | {{signal}} |
| 3 | {{goal}} | {{assist}} | {{context}} | {{signal}} |
| 4 | {{goal}} | {{assist}} | {{context}} | {{signal}} |
## Touchpoints
| ID | Type | Description | Actors | Steps |
| ---------- | ---- | ----------------------- | ------ | ----- |
| login-form | ui | Login screen | user | 1 |
| auth-api | api | Authentication endpoint | system | 1, 2 |
## Confirmation
- [x] Actors confirmed
- [x] Steps confirmed
- [x] Touchpoints identified
Category: 'journey' Tags: ['#journey', '#feature-{id}', '#confirmed'] Content:
'Journey for {feature}: {actor-count} actors, {step-count} steps. Main flow:
{step-summary}.'
Based on user selection and detected state:
All three scenarios use the same pipeline - the difference is in the research focus:
| Scenario | Research Focus |
|---|---|
| New Feature | Technology research + codebase patterns |
| Modify Existing | Understanding existing implementation + integration points |
| Fix Bug | Root cause analysis + affected code paths |
Pipeline State Check (Priority):
Before file-existence checks, read pipeline-state.json for authoritative
resume information:
.specify/scripts/bash/pipeline-state.sh read --json
If pipeline-state.json exists and status is in_progress, resume from
currentStage. This takes priority over file-existence heuristics because
pipeline-state.json is updated atomically by each stage on completion.
Fallback — File-existence heuristics (used when no pipeline-state.json exists):
| Has This | Missing This | Start At |
|---|---|---|
| tasks.md (unchecked) | - | /5_gofer_implement |
| plan.md | tasks.md | /4_gofer_tasks |
| spec.md | plan.md | /3_gofer_plan |
| research.md | spec.md | /2_gofer_specify |
| Nothing | research.md | /1_gofer_research |
| Nothing | Everything | /1_gofer_research |
.specify/specs/{feature-name}//1_gofer_research to start the pipelineOutput:
ROUTING: GOFER PIPELINE
FEATURE: {feature-name}
STARTING: /1_gofer_research
AUTO-CHAIN: research → specify → plan → tasks → implement → validate
NOTE: research may also create optional supporting review artifacts
REASON: [explanation]
If user chose to continue an existing feature:
Output:
ROUTING: GOFER PIPELINE
FEATURE: {feature-name}
STARTING: /[N]_gofer_[stage]
REMAINING: [remaining stages]
REASON: Continuing from existing artifacts
Start with /1_gofer_research without auto-chaining:
ROUTING: GOFER RESEARCH (STANDALONE)
COMMAND: /1_gofer_research
AUTO-CHAIN: disabled after research until the user asks to continue
REASON: User wants to explore the codebase first
Check for session checkpoints:
find .specify/specs -name "session-checkpoint.md" -type f 2>/dev/null
If checkpoint found → Invoke /8_gofer_resume
If no checkpoint but unchecked tasks exist:
- [ ] in tasks.md/5_gofer_implementOutput:
ROUTING: GOFER RESUME
FEATURE: {feature-name}
COMMAND: /8_gofer_resume
CHECKPOINT: {path to checkpoint}
REASON: Resuming from saved session
For new projects or establishing guidelines:
ROUTING: GOFER CONSTITUTION
COMMAND: /gofer_constitution
REASON: User wants to establish project principles
After determining the route:
The unified Gofer pipeline automatically chains commands:
/1_gofer_research completes → auto-invokes /2_gofer_specify unless user pauses
/2_gofer_specify completes → auto-invokes /3_gofer_plan
/3_gofer_plan completes → auto-invokes /4_gofer_tasks
/4_gofer_tasks completes → auto-invokes /5_gofer_implement
/5_gofer_implement completes→ auto-invokes /6_gofer_validate
/6_gofer_validate completes → pipeline complete
The user only needs to run /0_business_scenario once - the orchestrator
handles everything else automatically.
If the user needs to pause:
/7_gofer_save to create checkpoint/8_gofer_resumeIf context window is filling up:
/7_gofer_save/8_gofer_resume in new session| Stage | Command | Main output | Description |
|---|---|---|---|
| 0 | /0_business_scenario | Full pipeline kickoff | Business scenario intake and routing |
| 1 | /1_gofer_research | research.md | Research and supporting review prep |
| 2 | /2_gofer_specify | spec.md | Feature specification |
| 3 | /3_gofer_plan | plan.md, data-model.md, contracts/ | Technical architecture and contracts |
| 4 | /4_gofer_tasks | tasks.md, traceability.md, issues.md | Dependency-ordered task breakdown |
| 5 | /5_gofer_implement | Code and doc changes | Execute the planned work |
| 6 | /6_gofer_validate | Validation artifacts | Terminal quality gate, including review |
| Command | Purpose |
|---|---|
/0a_problem_validation | Optional deeper problem framing before research |
/7_gofer_save | Save session checkpoint |
/7a_stakeholder_comms | Post-validation communications |
/8_gofer_resume | Resume from checkpoint |
/9_gofer_tests | Define test cases (DSL approach) |
/10_gofer_cloud | Cloud infrastructure analysis (READ-ONLY) |
/gofer_hydrate | Reverse-engineer spec from code |
/gofer_constitution | Project principles and standards |
/gofer:check-workspace | Check whether the repo scaffold is healthy |
/gofer:bootstrap-workspace | Create or update the repo-owned scaffold |
The standard Gofer workflow is the public default. EnterpriseAI guidance is a
legacy compatibility profile and must be used only when workflowProfile is
explicitly set to enterpriseai or the user asks for that migration path. The
sections below add EnterpriseAI guardrails on top of the standard orchestrator;
standard-profile outputs remain unchanged.
When the workflow profile is explicitly enterpriseai:
Every EnterpriseAI discovery must preserve enough information for downstream stages to create these artifacts without re-interviewing the user:
| Artifact | Required Content |
|---|---|
journeys/base-journey.md | Application classification, four-step-or-fewer AI-augmented customer journey, step goals, AI assistance, context used, controls, completion criteria |
ui-preview-brief.md | App-delivery-only preview brief: target screens, Vertical Template component constraints, branding inputs, preview validation expectations |
ui-review-log.md | App-delivery-only iteration log: preview evidence, requested changes, accepted changes, unresolved issues |
ui-approval.md | App-delivery-only approval gate: approved preview, approved branding, approved component exceptions, approver and timestamp |
service-fit-matrix.md | App-delivery-only service selection evidence: desired platform capability, evidence source, accessible now vs purchasable vs unavailable, selected direction |
context-bundle.md | Compact feature context, selected scenario, app/non-app decision, AI-augmented journey summary, EnterpriseAI object types, tenant assumptions, API surfaces, deployment assumptions, validation criteria |
contract-pack.md | Actors, object types, workflows/journeys, four-step AI assistance contract, permissions, tenant boundaries, APIs/events, runtime assumptions, acceptance tests |
reuse-scan.md | Existing specs, platform references, object types, APIs, workflows, modules, and the reuse/extend/create decision |
audit-history.md | Stable finding IDs, recurring-finding history, accepted exceptions, owner, expiry, and review cadence |
Use these artifacts as decision evidence for executive, architecture, CISO, data, delivery, CIO, CFO, COO, and risk/compliance stakeholders.
For application delivery, downstream stages must preserve the four-step AI-augmented journey as the default scope spine. If a later stage expands beyond four user-facing steps, it must explain why the extra complexity is necessary and whether generative AI could combine or automate the additional steps. Non-app work keeps the same numbered stages without requiring the app-delivery preview, branding, approval, or service-fit artifacts.
Assume the user is a first-time student or business learner with no prior platform experience.
Log orchestrator routing:
.specify/scripts/bash/log-stage.sh 0_orchestrator --route [command] --feature [name]
npx claudepluginhub eai-tools/eai-gofer --plugin eai-goferProvides behavioral guidelines to reduce common LLM coding mistakes, focusing on simplicity, surgical changes, assumption surfacing, and verifiable success criteria.
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.
Creates, edits, and optimizes skills for Claude Code, including drafting, evaluating with test prompts, iterating on performance, and improving skill descriptions for better triggering accuracy.