EasyPlatform plan-fast
[Planning] No research. Only analyze and create an implementation plan
git clone https://github.com/duc01226/EasyPlatform
T=$(mktemp -d) && git clone --depth=1 https://github.com/duc01226/EasyPlatform "$T" && mkdir -p ~/.claude/skills && cp -r "$T/.claude/skills/plan-fast" ~/.claude/skills/duc01226-easyplatform-plan-fast && rm -rf "$T"
.claude/skills/plan-fast/SKILL.md<!-- SYNC:critical-thinking-mindset -->[IMPORTANT] Use
to break ALL work into small tasks BEFORE starting — including tasks for each file read. This prevents context loss from long files. For simple tasks, AI MUST ATTENTION ask user whether to skip.TaskCreate
<!-- /SYNC:critical-thinking-mindset --> <!-- SYNC:ai-mistake-prevention -->Critical Thinking Mindset — Apply critical thinking, sequential thinking. Every claim needs traced proof, confidence >80% to act. Anti-hallucination: Never present guess as fact — cite sources for every claim, admit uncertainty freely, self-check output for errors, cross-reference independently, stay skeptical of own confidence — certainty without evidence root of all hallucination.
<!-- /SYNC:ai-mistake-prevention --> <!-- SYNC:understand-code-first -->AI Mistake Prevention — Failure modes to avoid on every task:
- Check downstream references before deleting. Deleting components causes documentation and code staleness cascades. Map all referencing files before removal.
- Verify AI-generated content against actual code. AI hallucinates APIs, class names, and method signatures. Always grep to confirm existence before documenting or referencing.
- Trace full dependency chain after edits. Changing a definition misses downstream variables and consumers derived from it. Always trace the full chain.
- Trace ALL code paths when verifying correctness. Confirming code exists is not confirming it executes. Always trace early exits, error branches, and conditional skips — not just happy path.
- When debugging, ask "whose responsibility?" before fixing. Trace whether bug is in caller (wrong data) or callee (wrong handling). Fix at responsible layer — never patch symptom site.
- Assume existing values are intentional — ask WHY before changing. Before changing any constant, limit, flag, or pattern: read comments, check git blame, examine surrounding code.
- Verify ALL affected outputs, not just the first. Changes touching multiple stacks require verifying EVERY output. One green check is not all green checks.
- Holistic-first debugging — resist nearest-attention trap. When investigating any failure, list EVERY precondition first (config, env vars, DB names, endpoints, DI registrations, data preconditions), then verify each against evidence before forming any code-layer hypothesis.
- Surgical changes — apply the diff test. Bug fix: every changed line must trace directly to the bug. Don't restyle or improve adjacent code. Enhancement task: implement improvements AND announce them explicitly.
- Surface ambiguity before coding — don't pick silently. If request has multiple interpretations, present each with effort estimate and ask. Never assume all-records, file-based, or more complex path.
<!-- /SYNC:understand-code-first --> <!-- SYNC:estimation-framework -->Understand Code First — HARD-GATE: Do NOT write, plan, or fix until you READ existing code.
- Search 3+ similar patterns (
/grep) — citeglobevidencefile:line- Read existing files in target area — understand structure, base classes, conventions
- Run
whenpython .claude/scripts/code_graph trace <file> --direction both --jsonexists.code-graph/graph.db- Map dependencies via
orconnections— know what depends on your targetcallers_of- Write investigation to
for non-trivial tasks (3+ files).ai/workspace/analysis/- Re-read analysis file before implementing — never work from memory alone
- NEVER invent new patterns when existing ones work — match exactly or document deviation
BLOCKED until:
Read target files- [ ]Grep 3+ patterns- [ ]Graph trace (if graph.db exists)- [ ]Assumptions verified with evidence- [ ]
<!-- /SYNC:estimation-framework -->Estimation — Modified Fibonacci: 1(trivial) → 2(small) → 3(medium) → 5(large) → 8(very large) → 13(epic, SHOULD split) → 21(MUST ATTENTION split). Output
andstory_pointsin plan frontmatter. Complexity auto-derived: 1-2=Low, 3-5=Medium, 8=High, 13+=Critical.complexity
— Domain entity catalog, relationships, cross-service sync (read when task involves business entities/models) (content auto-injected by hook — check for [Injected: ...] header before reading)docs/project-reference/domain-entities-reference.md
— Test specifications by module (read existing TCs to include test strategy in plan)docs/test-specs/
<!-- /SYNC:plan-quality --> <!-- SYNC:iterative-phase-quality -->Plan Quality — Every plan phase MUST ATTENTION include test specifications.
- Add
section with TC-{FEAT}-{NNN} IDs to every phase file## Test Specifications- Map every functional requirement to ≥1 TC (or explicit
with rationale)TBD- TC IDs follow
format — reference by ID, never embed full contentTC-{FEATURE}-{NNN}- Before any new workflow step: call
and re-read the phase fileTaskList- On context compaction: call
FIRST — never create duplicate tasksTaskList- Verify TC satisfaction per phase before marking complete (evidence must be
, not TBD)file:lineMode: TDD-first → reference existing TCs with
. Implement-first → use TBD →Evidence: TBDfills after./tdd-spec
<!-- /SYNC:iterative-phase-quality --> <!-- SYNC:fix-layer-accountability -->Iterative Phase Quality — Score complexity BEFORE planning.
Complexity signals: >5 files +2, cross-service +3, new pattern +2, DB migration +2 Score >=6 → MUST ATTENTION decompose into phases. Each phase:
- ≤5 files modified
- ≤3h effort
- Follows cycle: plan → implement → review → fix → verify
- Do NOT start Phase N+1 until Phase N passes VERIFY
Phase success = all TCs pass + code-reviewer agent approves + no CRITICAL findings.
<!-- /SYNC:fix-layer-accountability -->Fix-Layer Accountability — NEVER fix at the crash site. Trace the full flow, fix at the owning layer.
AI default behavior: see error at Place A → fix Place A. This is WRONG. The crash site is a SYMPTOM, not the cause.
MANDATORY before ANY fix:
- Trace full data flow — Map the complete path from data origin to crash site across ALL layers (storage → backend → API → frontend → UI). Identify where the bad state ENTERS, not where it CRASHES.
- Identify the invariant owner — Which layer's contract guarantees this value is valid? That layer is responsible. Fix at the LOWEST layer that owns the invariant — not the highest layer that consumes it.
- One fix, maximum protection — Ask: "If I fix here, does it protect ALL downstream consumers with ONE change?" If fix requires touching 3+ files with defensive checks, you are at the wrong layer — go lower.
- Verify no bypass paths — Confirm all data flows through the fix point. Check for: direct construction skipping factories, clone/spread without re-validation, raw data not wrapped in domain models, mutations outside the model layer.
BLOCKED until:
Full data flow traced (origin → crash)- [ ]Invariant owner identified with- [ ]evidencefile:lineAll access sites audited (grep count)- [ ]Fix layer justified (lowest layer that protects most consumers)- [ ]Anti-patterns (REJECT these):
- "Fix it where it crashes" — Crash site ≠ cause site. Trace upstream.
- "Add defensive checks at every consumer" — Scattered defense = wrong layer. One authoritative fix > many scattered guards.
- "Both fix is safer" — Pick ONE authoritative layer. Redundant checks across layers send mixed signals about who owns the invariant.
Even for fast plans: assess complexity score. Score >=3 → MUST ATTENTION produce multiple phases with per-phase quality cycles.
Quick Summary
Goal: Analyze codebase and create a structured implementation plan without writing any code.
Workflow:
- Check Plan Context — Reuse active plan or create new directory per naming convention
- Analyze Codebase — Read
,backend-patterns-reference.md
,frontend-patterns-reference.mdproject-structure-reference.md - Create Plan — Generate
+plan.md
files with YAML frontmatterphase-XX-*.md - Validate — Run
and ask user to confirm before implementation/plan-review
Key Rules:
- Do NOT use
tool; do NOT implement any codeEnterPlanMode - Collaborate with user: ask decision questions, present options with recommendations
- Always validate plan with
after creation/plan-review
Greenfield Mode
Auto-detected: If no existing codebase is found (no code directories like
,src/,app/,lib/,server/, etc., no manifest files likepackages//package.json/*.sln, no populatedgo.mod), this skill redirects toproject-config.json. Planning artifacts (docs/, plans/, .claude/) don't count — the project must have actual code directories with content./plan-hard
When greenfield is detected:
- REDIRECT to
— greenfield inception requires deep research, not quick plans/plan-hard - Inform user: "Greenfield project detected. Redirecting to /plan-hard for thorough research and planning."
- Rationale: Fast planning skips research, but greenfield projects need market research, tech evaluation, and domain modeling — all impossible without deep analysis
Be skeptical. Apply critical thinking, sequential thinking. Every claim needs traced proof, confidence percentages (Idea should be more than 80%).
Activate
planning skill.
PLANNING-ONLY — Collaboration Required
DO NOT use the
tool — you are ALREADY in a planning workflow. DO NOT implement or execute any code changes. COLLABORATE with the user: ask decision questions, present options with recommendations. After plan creation, ALWAYS runEnterPlanModeto validate the plan. ASK user to confirm the plan before any next step./plan-review
Your mission
<task> $ARGUMENTS </task>Pre-Creation Check (Active vs Suggested Plan)
Check the
## Plan Context section in the injected context:
- If "Plan:" shows a path → Active plan exists. Ask user: "Continue with this? [Y/n]"
- If "Suggested:" shows a path → Branch-matched hint only. Ask if they want to activate or create new.
- If "Plan: none" → Create new plan using naming from
section.## Naming
Workflow
Use
planner subagent to:
- If creating new: Create directory using
fromPlan dir:
section, then run## Naming
If reusing: Use the active plan path from Plan Context. Make sure you pass the directory path to every subagent during the process.node .claude/scripts/set-active-plan.cjs {plan-dir} - Follow strictly to the "Plan Creation & Organization" rules of
skill.planning - Analyze the codebase by reading
,backend-patterns-reference.md
, andfrontend-patterns-reference.md
file. 3.5. External Memory: Write analysis findings toproject-structure-reference.md
. Re-read this file before creating the plan..ai/workspace/analysis/{task-name}.analysis.md - Gathers all information and create an implementation plan of this task.
- Ask user to review the plan.
Output Requirements
Plan Directory Structure (use
Plan dir: from ## Naming section)
{plan-dir}/ ├── reports/ │ ├── XX-report.md │ └── ... ├── plan.md ├── phase-XX-phase-name-here.md └── ...
Plan File Specification
-
Every
MUST ATTENTION start with YAML frontmatter:plan.md--- title: '{Brief title}' description: '{One sentence for card preview}' status: pending priority: P2 effort: { sum of phases, e.g., 4h } story_points: { sum of phase SPs, e.g., 8 } branch: { current git branch } tags: [relevant, tags] created: { YYYY-MM-DD } --- -
Save the overview access point at
. Keep it generic, under 80 lines, and list each implementation phase with status and progress plus links to phase files.{plan-dir}/plan.md -
For each phase, create
containing the following sections in order: Context links (reference parent plan, dependencies, docs), Overview (date, description, priority, implementation status, review status), Key Insights, Requirements, Architecture, UI Layout (see below), Related code files, Implementation Steps, Todo list, Success Criteria, Risk Assessment, Security Considerations, Next steps.{plan-dir}/phase-XX-phase-name-here.md -
UI Layout: For frontend-facing phases, include ASCII wireframe. Classify components by tier (common/domain-shared/page-app). For backend-only phases:
→## UI LayoutN/A — Backend-only change.
IMPORTANT Task Planning Notes (MUST ATTENTION FOLLOW)
- Always plan and break work into many small todo tasks using
TaskCreate - Always add a final review todo task to verify work quality and identify fixes/enhancements
- MANDATORY FINAL TASKS: After creating all planning todo tasks, ALWAYS add these three final tasks:
- Task: "Write test specifications for each phase" — Add
with TC-{FEAT}-{NNN} IDs to every phase file. Use## Test Specifications
if feature docs exist. Use/tdd-spec
for TDD-first mode.Evidence: TBD - Task: "Run /plan-validate" — Trigger
skill to interview the user with critical questions and validate plan assumptions/plan-validate - Task: "Run /plan-review" — Trigger
skill to auto-review plan for validity, correctness, and best practices/plan-review
- Task: "Write test specifications for each phase" — Add
Post-Plan Validation
After plan creation, use the
AskUserQuestion tool to ask: "Want me to run /plan-review to validate, or proceed to implementation?" with options:
- "Run /plan-review (Recommended)" — Execute
to validate the plan/plan-review - "Proceed to implementation" — Skip validation and start implementing
Important Notes
- IMPORTANT: Ensure token consumption efficiency while maintaining high quality.
- IMPORTANT: Analyze the skills catalog and activate the skills that are needed for the task during the process.
- IMPORTANT: Sacrifice grammar for the sake of concision when writing reports.
- IMPORTANT: In reports, list any unresolved questions at the end, if any.
REMINDER — Planning-Only Command
DO NOT use
tool. DO NOT start implementing. ALWAYS validate withEnterPlanModeafter plan creation. ASK user to confirm the plan before any implementation begins. ASK user decision questions with your recommendations when multiple approaches exist./plan-review
Post-Plan Granularity Self-Check (MANDATORY)
<!-- SYNC:plan-granularity --><!-- /SYNC:plan-granularity -->Plan Granularity — Every phase must pass 5-point check before implementation:
- Lists exact file paths to modify (not generic "implement X")
- No planning verbs (research, investigate, analyze, determine, figure out)
- Steps ≤30min each, phase total ≤3h
- ≤5 files per phase
- No open decisions or TBDs in approach
Failing phases → create sub-plan. Repeat until ALL leaf phases pass (max depth: 3). Self-question: "Can I start coding RIGHT NOW? If any step needs 'figuring out' → sub-plan it."
Preservation Inventory (MANDATORY for bugfixes)
<!-- SYNC:preservation-inventory --><!-- /SYNC:preservation-inventory -->Preservation Inventory — MANDATORY for bugfix plans. Trigger keywords in plan title/frontmatter:
,fix,bug,regression,broken. Author MUST produce this table BEFORE writing implementation steps.defectColumns:
Invariant | file:line | Why (data consequence if broken) | Verification (TC-ID or grep)BLOCKED until: ≥3 rows · every File cell has
· every Verification cell has TC-ID or grep (not "manually verify")file:line
After creating all phase files, run the recursive decomposition loop:
- Score each phase against the 5-point criteria (file paths, no planning verbs, ≤30min steps, ≤5 files, no open decisions)
- For each FAILING phase → create task to decompose it into a sub-plan (with its own /plan → /plan-review → /plan-validate → fix cycle)
- Re-score new phases. Repeat until ALL leaf phases pass (max depth: 3)
- Self-question: "For each phase, can I start coding RIGHT NOW? If any needs 'figuring out' → sub-plan it."
Next Steps (Standalone: MUST ATTENTION ask user via AskUserQuestion
. Skip if inside workflow.)
AskUserQuestionMANDATORY IMPORTANT MUST ATTENTION — NO EXCEPTIONS: If this skill was called outside a workflow, you MUST ATTENTION use
to present these options. Do NOT skip because the task seems "simple" or "obvious" — the user decides:AskUserQuestion
- "Proceed with full workflow (Recommended)" — I'll detect the best workflow to continue from here (plan created). This ensures review, validation, implementation, and testing steps aren't skipped.
- "/plan-review" — Auto-review plan for validity and best practices
- "/plan-validate" — Interview user to confirm plan decisions
- "Skip, continue manually" — user decides
If already inside a workflow, skip — the workflow handles sequencing.
Closing Reminders
- MANDATORY IMPORTANT MUST ATTENTION break work into small todo tasks using
BEFORE startingTaskCreate - MANDATORY IMPORTANT MUST ATTENTION search codebase for 3+ similar patterns before creating new code
- MANDATORY IMPORTANT MUST ATTENTION cite
evidence for every claim (confidence >80% to act)file:line - MANDATORY IMPORTANT MUST ATTENTION add a final review todo task to verify work quality
- MANDATORY IMPORTANT MUST ATTENTION include Test Specifications section and story_points in plan frontmatter <!-- SYNC:plan-granularity:reminder -->
- MANDATORY IMPORTANT MUST ATTENTION verify all phases pass 5-point granularity check. Failing phases → sub-plan. "Can I start coding RIGHT NOW?" <!-- /SYNC:plan-granularity:reminder --> <!-- SYNC:understand-code-first:reminder -->
- MANDATORY IMPORTANT MUST ATTENTION search 3+ existing patterns and read code BEFORE any modification. Run graph trace when graph.db exists. <!-- /SYNC:understand-code-first:reminder --> <!-- SYNC:estimation-framework:reminder -->
- MANDATORY IMPORTANT MUST ATTENTION include
andstory_points
in plan frontmatter. SP > 8 = split. <!-- /SYNC:estimation-framework:reminder --> <!-- SYNC:plan-quality:reminder -->complexity - MANDATORY IMPORTANT MUST ATTENTION include
with TC IDs per phase. Call## Test Specifications
before creating new tasks. <!-- /SYNC:plan-quality:reminder --> <!-- SYNC:iterative-phase-quality:reminder -->TaskList - MANDATORY IMPORTANT MUST ATTENTION score complexity first. Score >=6 → decompose. Each phase: plan → implement → review → fix → verify. No skipping. <!-- /SYNC:iterative-phase-quality:reminder --> <!-- SYNC:fix-layer-accountability:reminder -->
- MANDATORY IMPORTANT MUST ATTENTION trace full data flow and fix at the owning layer, not the crash site. Audit all access sites before adding
. <!-- /SYNC:fix-layer-accountability:reminder --> <!-- SYNC:critical-thinking-mindset:reminder -->?. - MUST ATTENTION apply critical thinking — every claim needs traced proof, confidence >80% to act. Anti-hallucination: never present guess as fact. <!-- /SYNC:critical-thinking-mindset:reminder --> <!-- SYNC:ai-mistake-prevention:reminder -->
- MUST ATTENTION apply AI mistake prevention — holistic-first debugging, fix at responsible layer, surface ambiguity before coding, re-read files after compaction. <!-- /SYNC:ai-mistake-prevention:reminder -->