@fredcallagan/arn-spark 5.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (130) hide show
  1. package/.claude-plugin/plugin.json +9 -0
  2. package/.opencode/plugins/arn-spark.js +272 -0
  3. package/package.json +17 -0
  4. package/plugins/arn-spark/.claude-plugin/plugin.json +9 -0
  5. package/plugins/arn-spark/LICENSE +21 -0
  6. package/plugins/arn-spark/README.md +25 -0
  7. package/plugins/arn-spark/agents/arn-spark-brand-strategist.md +299 -0
  8. package/plugins/arn-spark/agents/arn-spark-dev-env-builder.md +228 -0
  9. package/plugins/arn-spark/agents/arn-spark-doctor.md +92 -0
  10. package/plugins/arn-spark/agents/arn-spark-forensic-investigator.md +181 -0
  11. package/plugins/arn-spark/agents/arn-spark-market-researcher.md +232 -0
  12. package/plugins/arn-spark/agents/arn-spark-marketing-pm.md +225 -0
  13. package/plugins/arn-spark/agents/arn-spark-persona-architect.md +259 -0
  14. package/plugins/arn-spark/agents/arn-spark-persona-impersonator.md +183 -0
  15. package/plugins/arn-spark/agents/arn-spark-product-strategist.md +191 -0
  16. package/plugins/arn-spark/agents/arn-spark-prototype-builder.md +497 -0
  17. package/plugins/arn-spark/agents/arn-spark-scaffolder.md +228 -0
  18. package/plugins/arn-spark/agents/arn-spark-spike-runner.md +209 -0
  19. package/plugins/arn-spark/agents/arn-spark-style-capture.md +196 -0
  20. package/plugins/arn-spark/agents/arn-spark-tech-evaluator.md +229 -0
  21. package/plugins/arn-spark/agents/arn-spark-ui-interactor.md +235 -0
  22. package/plugins/arn-spark/agents/arn-spark-use-case-writer.md +280 -0
  23. package/plugins/arn-spark/agents/arn-spark-ux-judge.md +215 -0
  24. package/plugins/arn-spark/agents/arn-spark-ux-specialist.md +200 -0
  25. package/plugins/arn-spark/agents/arn-spark-visual-sketcher.md +285 -0
  26. package/plugins/arn-spark/agents/arn-spark-visual-test-engineer.md +224 -0
  27. package/plugins/arn-spark/references/copilot-tools.md +62 -0
  28. package/plugins/arn-spark/skills/arn-brainstorming/SKILL.md +520 -0
  29. package/plugins/arn-spark/skills/arn-brainstorming/references/add-feature-flow.md +155 -0
  30. package/plugins/arn-spark/skills/arn-spark-arch-vision/SKILL.md +226 -0
  31. package/plugins/arn-spark/skills/arn-spark-arch-vision/references/architecture-vision-template.md +153 -0
  32. package/plugins/arn-spark/skills/arn-spark-arch-vision/references/technology-evaluation-guide.md +86 -0
  33. package/plugins/arn-spark/skills/arn-spark-clickable-prototype/SKILL.md +471 -0
  34. package/plugins/arn-spark/skills/arn-spark-clickable-prototype/references/clickable-prototype-criteria.md +65 -0
  35. package/plugins/arn-spark/skills/arn-spark-clickable-prototype/references/journey-template.md +62 -0
  36. package/plugins/arn-spark/skills/arn-spark-clickable-prototype/references/review-report-template.md +75 -0
  37. package/plugins/arn-spark/skills/arn-spark-clickable-prototype/references/showcase-capture-guide.md +213 -0
  38. package/plugins/arn-spark/skills/arn-spark-clickable-prototype-teams/SKILL.md +642 -0
  39. package/plugins/arn-spark/skills/arn-spark-clickable-prototype-teams/references/debate-protocol.md +242 -0
  40. package/plugins/arn-spark/skills/arn-spark-clickable-prototype-teams/references/debate-review-report-template.md +161 -0
  41. package/plugins/arn-spark/skills/arn-spark-clickable-prototype-teams/references/expert-interaction-review-template.md +152 -0
  42. package/plugins/arn-spark/skills/arn-spark-concept-review/SKILL.md +350 -0
  43. package/plugins/arn-spark/skills/arn-spark-concept-review/references/conflict-resolution-protocol.md +145 -0
  44. package/plugins/arn-spark/skills/arn-spark-concept-review/references/review-report-template.md +185 -0
  45. package/plugins/arn-spark/skills/arn-spark-dev-setup/SKILL.md +366 -0
  46. package/plugins/arn-spark/skills/arn-spark-dev-setup/references/dev-setup-checklist.md +84 -0
  47. package/plugins/arn-spark/skills/arn-spark-dev-setup/references/dev-setup-template.md +205 -0
  48. package/plugins/arn-spark/skills/arn-spark-discover/SKILL.md +303 -0
  49. package/plugins/arn-spark/skills/arn-spark-discover/references/competitive-landscape-template.md +87 -0
  50. package/plugins/arn-spark/skills/arn-spark-discover/references/discovery-questions.md +120 -0
  51. package/plugins/arn-spark/skills/arn-spark-discover/references/persona-profile-template.md +97 -0
  52. package/plugins/arn-spark/skills/arn-spark-discover/references/product-concept-template.md +253 -0
  53. package/plugins/arn-spark/skills/arn-spark-ensure-config/SKILL.md +23 -0
  54. package/plugins/arn-spark/skills/arn-spark-ensure-config/references/ensure-config.md +388 -0
  55. package/plugins/arn-spark/skills/arn-spark-ensure-config/references/step-0-fast-path.md +25 -0
  56. package/plugins/arn-spark/skills/arn-spark-ensure-config/scripts/cache-check.sh +127 -0
  57. package/plugins/arn-spark/skills/arn-spark-feature-extract/SKILL.md +483 -0
  58. package/plugins/arn-spark/skills/arn-spark-feature-extract/references/feature-backlog-template.md +176 -0
  59. package/plugins/arn-spark/skills/arn-spark-feature-extract/references/feature-entry-template.md +209 -0
  60. package/plugins/arn-spark/skills/arn-spark-help/SKILL.md +149 -0
  61. package/plugins/arn-spark/skills/arn-spark-help/references/pipeline-map.md +211 -0
  62. package/plugins/arn-spark/skills/arn-spark-init/SKILL.md +312 -0
  63. package/plugins/arn-spark/skills/arn-spark-init/references/agent-models-presets/all-opus.md +23 -0
  64. package/plugins/arn-spark/skills/arn-spark-init/references/agent-models-presets/balanced.md +23 -0
  65. package/plugins/arn-spark/skills/arn-spark-init/references/bkt-setup.md +55 -0
  66. package/plugins/arn-spark/skills/arn-spark-init/references/jira-mcp-setup.md +61 -0
  67. package/plugins/arn-spark/skills/arn-spark-init/references/platform-labels.md +97 -0
  68. package/plugins/arn-spark/skills/arn-spark-naming/SKILL.md +275 -0
  69. package/plugins/arn-spark/skills/arn-spark-naming/references/creative-brief-template.md +146 -0
  70. package/plugins/arn-spark/skills/arn-spark-naming/references/naming-methodology.md +237 -0
  71. package/plugins/arn-spark/skills/arn-spark-naming/references/naming-report-template.md +122 -0
  72. package/plugins/arn-spark/skills/arn-spark-naming/references/trademark-databases.md +88 -0
  73. package/plugins/arn-spark/skills/arn-spark-naming/references/whois-server-map.md +164 -0
  74. package/plugins/arn-spark/skills/arn-spark-naming/scripts/whois-check.js +502 -0
  75. package/plugins/arn-spark/skills/arn-spark-naming/scripts/whois-check.py +533 -0
  76. package/plugins/arn-spark/skills/arn-spark-prototype-lock/SKILL.md +260 -0
  77. package/plugins/arn-spark/skills/arn-spark-prototype-lock/references/lock-report-template.md +68 -0
  78. package/plugins/arn-spark/skills/arn-spark-prototype-lock/references/pretooluse-hook-template.json +35 -0
  79. package/plugins/arn-spark/skills/arn-spark-prototype-lock/references/prototype-guardrail-rules.md +38 -0
  80. package/plugins/arn-spark/skills/arn-spark-report/SKILL.md +144 -0
  81. package/plugins/arn-spark/skills/arn-spark-report/references/issue-template.md +81 -0
  82. package/plugins/arn-spark/skills/arn-spark-report/references/spark-knowledge-base.md +293 -0
  83. package/plugins/arn-spark/skills/arn-spark-scaffold/SKILL.md +239 -0
  84. package/plugins/arn-spark/skills/arn-spark-scaffold/references/scaffold-checklist.md +79 -0
  85. package/plugins/arn-spark/skills/arn-spark-scaffold/references/scaffold-summary-template.md +74 -0
  86. package/plugins/arn-spark/skills/arn-spark-spike/SKILL.md +209 -0
  87. package/plugins/arn-spark/skills/arn-spark-spike/references/spike-report-template.md +123 -0
  88. package/plugins/arn-spark/skills/arn-spark-static-prototype/SKILL.md +362 -0
  89. package/plugins/arn-spark/skills/arn-spark-static-prototype/references/review-report-template.md +65 -0
  90. package/plugins/arn-spark/skills/arn-spark-static-prototype/references/showcase-capture-guide.md +153 -0
  91. package/plugins/arn-spark/skills/arn-spark-static-prototype/references/static-prototype-criteria.md +54 -0
  92. package/plugins/arn-spark/skills/arn-spark-static-prototype-teams/SKILL.md +518 -0
  93. package/plugins/arn-spark/skills/arn-spark-static-prototype-teams/references/debate-protocol.md +230 -0
  94. package/plugins/arn-spark/skills/arn-spark-static-prototype-teams/references/debate-review-report-template.md +148 -0
  95. package/plugins/arn-spark/skills/arn-spark-static-prototype-teams/references/expert-visual-review-template.md +130 -0
  96. package/plugins/arn-spark/skills/arn-spark-stress-competitive/SKILL.md +166 -0
  97. package/plugins/arn-spark/skills/arn-spark-stress-competitive/references/competitive-report-template.md +139 -0
  98. package/plugins/arn-spark/skills/arn-spark-stress-competitive/references/gap-analysis-framework.md +111 -0
  99. package/plugins/arn-spark/skills/arn-spark-stress-interview/SKILL.md +257 -0
  100. package/plugins/arn-spark/skills/arn-spark-stress-interview/references/interview-protocol.md +140 -0
  101. package/plugins/arn-spark/skills/arn-spark-stress-interview/references/interview-report-template.md +165 -0
  102. package/plugins/arn-spark/skills/arn-spark-stress-interview/references/persona-casting-spec.md +138 -0
  103. package/plugins/arn-spark/skills/arn-spark-stress-premortem/SKILL.md +181 -0
  104. package/plugins/arn-spark/skills/arn-spark-stress-premortem/references/premortem-protocol.md +112 -0
  105. package/plugins/arn-spark/skills/arn-spark-stress-premortem/references/premortem-report-template.md +158 -0
  106. package/plugins/arn-spark/skills/arn-spark-stress-prfaq/SKILL.md +206 -0
  107. package/plugins/arn-spark/skills/arn-spark-stress-prfaq/references/prfaq-report-template.md +139 -0
  108. package/plugins/arn-spark/skills/arn-spark-stress-prfaq/references/prfaq-workflow.md +118 -0
  109. package/plugins/arn-spark/skills/arn-spark-style-explore/SKILL.md +281 -0
  110. package/plugins/arn-spark/skills/arn-spark-style-explore/references/style-brief-template.md +198 -0
  111. package/plugins/arn-spark/skills/arn-spark-use-cases/SKILL.md +359 -0
  112. package/plugins/arn-spark/skills/arn-spark-use-cases/references/expert-review-template.md +94 -0
  113. package/plugins/arn-spark/skills/arn-spark-use-cases/references/review-protocol.md +150 -0
  114. package/plugins/arn-spark/skills/arn-spark-use-cases/references/use-case-index-template.md +108 -0
  115. package/plugins/arn-spark/skills/arn-spark-use-cases/references/use-case-template.md +125 -0
  116. package/plugins/arn-spark/skills/arn-spark-use-cases-teams/SKILL.md +306 -0
  117. package/plugins/arn-spark/skills/arn-spark-use-cases-teams/references/debate-protocol.md +272 -0
  118. package/plugins/arn-spark/skills/arn-spark-use-cases-teams/references/review-report-template.md +112 -0
  119. package/plugins/arn-spark/skills/arn-spark-visual-readiness/SKILL.md +293 -0
  120. package/plugins/arn-spark/skills/arn-spark-visual-readiness/references/readiness-checklist.md +196 -0
  121. package/plugins/arn-spark/skills/arn-spark-visual-sketch/SKILL.md +376 -0
  122. package/plugins/arn-spark/skills/arn-spark-visual-sketch/references/aesthetic-philosophy.md +210 -0
  123. package/plugins/arn-spark/skills/arn-spark-visual-sketch/references/sketch-gallery-guide.md +282 -0
  124. package/plugins/arn-spark/skills/arn-spark-visual-sketch/references/visual-direction-template.md +174 -0
  125. package/plugins/arn-spark/skills/arn-spark-visual-strategy/SKILL.md +447 -0
  126. package/plugins/arn-spark/skills/arn-spark-visual-strategy/references/baseline-capture-script-template.js +89 -0
  127. package/plugins/arn-spark/skills/arn-spark-visual-strategy/references/journey-schema.md +375 -0
  128. package/plugins/arn-spark/skills/arn-spark-visual-strategy/references/spike-checklist.md +122 -0
  129. package/plugins/arn-spark/skills/arn-spark-visual-strategy/references/strategy-layers-guide.md +132 -0
  130. package/plugins/arn-spark/skills/arn-spark-visual-strategy/references/visual-strategy-template.md +141 -0
@@ -0,0 +1,211 @@
1
+ # Spark Pipeline Map
2
+
3
+ Reference for the `arn-spark-help` skill. Contains pipeline templates, stage detection rules, and next-step suggestions for the Spark exploration pipeline.
4
+
5
+ ---
6
+
7
+ ## Spark Pipeline Template
8
+
9
+ The diagram below is the canonical Spark exploration pipeline. When rendering for the user, annotate the active stage with a `YOU ARE HERE` marker placed below the active stage name.
10
+
11
+ ```
12
+ Spark Exploration Pipeline
13
+ ==========================
14
+
15
+ gf-init --> discover --> stress-test --> concept-review --> naming --> arch-vision --> use-cases --> scaffold --> spike --> visual-sketch --> style-explore --> prototypes --> lock --> feature-extract
16
+ (optional) (optional) (optional) (optional)
17
+
18
+ Prototypes: arn-spark-static-prototype then arn-spark-clickable-prototype (in sequence)
19
+ Stress tests: arn-spark-stress-interview, arn-spark-stress-competitive, arn-spark-stress-premortem, arn-spark-stress-prfaq (multi-select)
20
+ Variants: arn-spark-use-cases-teams, arn-spark-static-prototype-teams, arn-spark-clickable-prototype-teams
21
+ Standalone: arn-spark-dev-setup, arn-spark-visual-readiness, arn-spark-visual-strategy
22
+ Guided: /arn-brainstorming -- walks through the entire pipeline with decision gates
23
+ ```
24
+
25
+ ---
26
+
27
+ ## Stage-to-Skill Mapping
28
+
29
+ | Stage | Primary Skill | Notes |
30
+ |-------|--------------|-------|
31
+ | `gf-init` | `/arn-brainstorming` or `/arn-spark-discover` | Brainstorming is the guided wizard; discover is the direct entry |
32
+ | `discover` | `/arn-spark-discover` | Produces product-concept.md with vision, personas, competitive landscape, pillars |
33
+ | `stress-test` | `/arn-spark-stress-interview`, `/arn-spark-stress-competitive`, `/arn-spark-stress-premortem`, `/arn-spark-stress-prfaq` | Multi-select: user picks which tests to run. All are read-only on product-concept.md |
34
+ | `concept-review` | `/arn-spark-concept-review` | Consolidates stress test findings. ONLY skill that modifies product-concept.md |
35
+ | `naming` | `/arn-spark-naming` | 4-step methodology: Brand DNA, creative generation, Six Senses scoring, WHOIS/trademark due diligence |
36
+ | `arch-vision` | `/arn-spark-arch-vision` | Technology choices, system design, packaging strategy |
37
+ | `use-cases` | `/arn-spark-use-cases` | Cockburn fully-dressed format. Teams variant: `/arn-spark-use-cases-teams` |
38
+ | `scaffold` | `/arn-spark-scaffold` | Creates project skeleton with chosen framework and dependencies |
39
+ | `spike` | `/arn-spark-spike` | Optional — validate risky technical assumptions with POC code |
40
+ | `visual-sketch` | `/arn-spark-visual-sketch` | Multiple visual direction proposals as live HTML/CSS |
41
+ | `style-explore` | `/arn-spark-style-explore` | Define complete design system from the visual direction |
42
+ | `prototypes` | `/arn-spark-static-prototype` then `/arn-spark-clickable-prototype` | Teams variants available for both. Includes UX judge validation |
43
+ | `lock` | `/arn-spark-prototype-lock` | Freezes validated prototype as development reference |
44
+ | `feature-extract` | `/arn-spark-feature-extract` | Extracts prioritized feature backlog. Optional issue tracker upload |
45
+
46
+ ---
47
+
48
+ ## Annotation Instructions
49
+
50
+ 1. Identify the user's current stage using the detection rules below.
51
+ 2. Place the `YOU ARE HERE` marker directly below the matching stage label.
52
+ 3. Spark is a single-track pipeline (no per-project subdirectories).
53
+
54
+ **Example:**
55
+
56
+ ```
57
+ Spark Exploration Pipeline
58
+ ==========================
59
+
60
+ gf-init --> discover --> stress-test --> concept-review --> naming --> arch-vision --> use-cases --> scaffold --> spike --> visual-sketch --> style-explore --> prototypes --> lock --> feature-extract
61
+ ^^^^^^^^^^^^^
62
+ YOU ARE HERE
63
+
64
+ Prototypes: arn-spark-static-prototype then arn-spark-clickable-prototype
65
+ Stress tests: arn-spark-stress-interview, arn-spark-stress-competitive, arn-spark-stress-premortem, arn-spark-stress-prfaq
66
+ Variants: arn-spark-use-cases-teams, arn-spark-static-prototype-teams, arn-spark-clickable-prototype-teams
67
+ Standalone: arn-spark-dev-setup, arn-spark-visual-readiness, arn-spark-visual-strategy
68
+ Guided: /arn-brainstorming
69
+ ```
70
+
71
+ ---
72
+
73
+ ## Stage Detection Rules
74
+
75
+ Check stages from **most advanced to least advanced**. The first matching rule determines the current stage. Spark detection uses artifact existence in the configured Spark directories.
76
+
77
+ **Prerequisites:** `## Arness` must contain at least one Spark field (Vision directory, Use cases directory, Prototypes directory). If none are present, Spark detection is skipped entirely.
78
+
79
+ | Stage | Key | Detection Rule | Artifact |
80
+ |-------|-----|----------------|----------|
81
+ | Feature backlog ready | `gf-feature-extract` | Feature backlog index exists | `<vision-dir>/features/feature-backlog.md` |
82
+ | Prototype locked | `gf-prototype-lock` | Locked prototype manifest exists | `<prototypes-dir>/locked/LOCKED.md` |
83
+ | Clickable prototype done | `gf-clickable-proto` | Clickable prototype final report exists | `<prototypes-dir>/clickable/final-report.md` |
84
+ | Static prototype done | `gf-static-proto` | Static prototype final report exists | `<prototypes-dir>/static/final-report.md` |
85
+ | Style defined | `gf-style-explore` | Style brief exists | `<vision-dir>/style-brief.md` |
86
+ | Visual direction chosen | `gf-visual-sketch` | Visual direction document exists | `<vision-dir>/visual-direction.md` |
87
+ | Spike complete | `gf-spike` | Spike results exist | `<vision-dir>/spike-results.md` |
88
+ | Scaffold built | `gf-scaffold` | Scaffold summary exists | `<vision-dir>/scaffold-summary.md` |
89
+ | Use cases written | `gf-use-cases` | Use case files exist | `<use-cases-dir>/UC-*.md` (at least one) |
90
+ | Architecture defined | `gf-arch-vision` | Architecture vision exists | `<vision-dir>/architecture-vision.md` |
91
+ | Naming complete | `gf-naming` | Naming brief or report exists | `<vision-dir>/naming-brief.md` OR `<reports-dir>/naming-report.md` |
92
+ | Concept reviewed | `gf-concept-review` | Concept review report exists | `<reports-dir>/stress-tests/concept-review-report.md` |
93
+ | Stress tests run | `gf-stress-test` | Any stress test report exists | `<reports-dir>/stress-tests/interview-report.md` OR `competitive-report.md` OR `premortem-report.md` OR `prfaq-report.md` |
94
+ | Product discovered | `gf-discover` | Product concept exists | `<vision-dir>/product-concept.md` |
95
+ | Spark initialized | `gf-init` | Spark fields exist in `## Arness` but no artifacts found | `## Arness` has Spark fields but directories are empty |
96
+
97
+ ### Spark Complete Detection
98
+
99
+ Spark exploration is considered **complete** when `<vision-dir>/features/feature-backlog.md` exists (the `gf-feature-extract` stage is reached). This signals the project is ready to transition from exploration to development.
100
+
101
+ ### Detection Notes
102
+
103
+ **Stress test stage:** Four independent reports can exist in any combination. The presence of ANY stress-test report triggers the `gf-stress-test` stage. If `concept-review-report.md` also exists, it takes precedence (concept-review > stress-test in detection order).
104
+
105
+ **Naming stage:** `naming-brief.md` gets written incrementally during the naming process. Any existence of naming-brief.md or naming-report.md is treated as naming complete. If naming is in-progress and the user runs `/arn-spark-naming`, it handles its own resume.
106
+
107
+ **Spike stage:** Optional. If a project skips spike and goes directly from scaffold to visual-sketch, the detection works correctly — `gf-visual-sketch` is detected based on `visual-direction.md` existence.
108
+
109
+ **Prototype-lock stage:** Optional. If a project skips lock and goes directly from clickable-prototype to feature-extract, the detection works correctly.
110
+
111
+ ---
112
+
113
+ ## Next Step Suggestions
114
+
115
+ After detecting the current Spark stage, suggest the next command.
116
+
117
+ | Current Stage | Next Command | Description |
118
+ |---------------|-------------|-------------|
119
+ | Spark initialized (`gf-init`) | `/arn-spark-discover` | Shape the product idea into a structured concept. Or run `/arn-brainstorming` for the guided wizard. |
120
+ | Product discovered (`gf-discover`) | `/arn-spark-stress-interview`, etc. OR `/arn-spark-arch-vision` | Run stress tests to validate the concept (optional), or skip to architecture. |
121
+ | Stress tests run (`gf-stress-test`) | `/arn-spark-concept-review` | Consolidate stress test findings and update the product concept. |
122
+ | Concept reviewed (`gf-concept-review`) | `/arn-spark-naming` or `/arn-spark-arch-vision` | Name your product (optional), or skip to architecture. |
123
+ | Naming complete (`gf-naming`) | `/arn-spark-arch-vision` | Choose technologies and design the system architecture. |
124
+ | Architecture defined (`gf-arch-vision`) | `/arn-spark-use-cases` | Write use cases (or `/arn-spark-use-cases-teams` for expert debate). |
125
+ | Use cases written (`gf-use-cases`) | `/arn-spark-scaffold` | Create the project skeleton with the chosen tech stack. |
126
+ | Scaffold built (`gf-scaffold`) | `/arn-spark-spike` or `/arn-spark-visual-sketch` | Validate risky assumptions (optional), or explore visual directions. |
127
+ | Spike complete (`gf-spike`) | `/arn-spark-visual-sketch` | Generate visual direction proposals on the dev server. |
128
+ | Visual direction chosen (`gf-visual-sketch`) | `/arn-spark-style-explore` | Define the complete design system from the visual direction. |
129
+ | Style defined (`gf-style-explore`) | `/arn-spark-static-prototype` | Build and validate a static HTML/CSS prototype. |
130
+ | Static prototype done (`gf-static-proto`) | `/arn-spark-clickable-prototype` | Build and validate an interactive prototype with linked screens. |
131
+ | Clickable prototype done (`gf-clickable-proto`) | `/arn-spark-prototype-lock` or `/arn-spark-feature-extract` | Lock the prototype (optional), or extract features directly. |
132
+ | Prototype locked (`gf-prototype-lock`) | `/arn-spark-feature-extract` | Extract features into a prioritized backlog for development. |
133
+ | Feature backlog ready (`gf-feature-extract`) | `/arn-planning` | Transition to development — start specifying features. Or `/arn-infra-wizard` for infrastructure. |
134
+
135
+ ---
136
+
137
+ ## Variant Commands
138
+
139
+ These can be used as alternatives at specific stages:
140
+
141
+ | Variant | Replaces | When to Suggest |
142
+ |---------|----------|-----------------|
143
+ | `/arn-spark-use-cases-teams` | `/arn-spark-use-cases` | User prefers expert debate format for use cases |
144
+ | `/arn-spark-static-prototype-teams` | `/arn-spark-static-prototype` | User prefers expert debate for prototype validation |
145
+ | `/arn-spark-clickable-prototype-teams` | `/arn-spark-clickable-prototype` | User prefers expert debate for prototype validation |
146
+
147
+ ### Standalone Commands
148
+
149
+ These operate outside the main pipeline and can be suggested at any time:
150
+
151
+ | Command | Purpose | Prerequisite |
152
+ |---------|---------|--------------|
153
+ | `/arn-spark-dev-setup` | Define or follow development environment setup | Greenfield config exists |
154
+ | `/arn-spark-prototype-lock` | Freeze approved prototypes with guardrail hooks | Prototypes directory configured, prototype approved |
155
+ | `/arn-spark-visual-readiness` | Check visual layer readiness before activating deferred tests | Visual strategy defined |
156
+ | `/arn-spark-visual-strategy` | Define layered visual testing strategy | Scaffold built, at least style-explore complete |
157
+
158
+ ### Entry Points
159
+
160
+ - `/arn-brainstorming` — Walks through the entire Spark exploration pipeline with guided decision gates. This is the recommended way to use Spark for new projects.
161
+ - `/arn-spark-discover` — Direct entry into product discovery without the wizard.
162
+ - `/arn-spark-init` — (Optional) Explicitly configure the greenfield environment. Not required — Arness auto-configures on first use.
163
+
164
+ When suggesting next steps at an early stage (`gf-init` or `gf-discover`):
165
+
166
+ ```
167
+ Tip: Run `/arn-brainstorming` for the guided pipeline, or invoke individual skills directly.
168
+ ```
169
+
170
+ ---
171
+
172
+ ## Cross-Plugin Hint Templates
173
+
174
+ When Step 0 detects other plugin activity, append these hints at the bottom of the status output.
175
+
176
+ **Code active:**
177
+ ```
178
+ Development pipeline: active — run `/arn-code-help` for details.
179
+ ```
180
+
181
+ **Infra active:**
182
+ ```
183
+ Infrastructure pipeline: active — run `/arn-infra-help` for details.
184
+ ```
185
+
186
+ **Code not started but configured:**
187
+ ```
188
+ Development pipeline: configured but not started.
189
+ ```
190
+
191
+ **Infra not started but configured:**
192
+ ```
193
+ Infrastructure pipeline: configured but not started.
194
+ ```
195
+
196
+ **When Spark pipeline is complete (`gf-feature-extract`):**
197
+ ```
198
+ Spark exploration is complete. Next steps:
199
+ - Start developing features: `/arn-planning`
200
+ - Deploy infrastructure: `/arn-infra-wizard`
201
+ ```
202
+
203
+ **When own plugin idle (`gf-init`) and other plugins have activity:**
204
+ Show own suggestions first:
205
+ ```
206
+ Ready to start: run `/arn-spark-discover` to shape your product idea, or `/arn-brainstorming` for the guided wizard.
207
+ ```
208
+ Then mention others:
209
+ ```
210
+ You also have active work in Code — run `/arn-code-help` for details.
211
+ ```
@@ -0,0 +1,312 @@
1
+ ---
2
+ name: arn-spark-init
3
+ description: >-
4
+ Optional customization tool for greenfield projects. This skill should be used when the user says
5
+ "greenfield init", "arn spark init", "initialize greenfield", "setup greenfield",
6
+ "greenfield setup", "start greenfield", "configure greenfield",
7
+ "set up greenfield", "init greenfield", "greenfield configuration",
8
+ "review greenfield config", "customize greenfield config", "greenfield settings",
9
+ "Figma setup", "Canva setup", "add Figma", "add Canva", "design tool setup",
10
+ or wants to customize Arness Spark configuration, add design tool integrations
11
+ (Figma, Canva), or review current greenfield settings. Arness Spark auto-configures
12
+ with sensible defaults on first skill invocation — this init is optional.
13
+ Design tool integration (Figma/Canva) remains available only through this skill.
14
+ version: 1.0.0
15
+ ---
16
+
17
+ # Arness Spark Init
18
+
19
+ Set up Arness for a greenfield project by configuring output directories for all greenfield artifacts and detecting the project's platform setup. This is optional — Arness Spark auto-configures with sensible defaults on first skill invocation. Use this to customize directories, add design tool integrations (Figma, Canva), or review your current settings.
20
+
21
+ This skill is lightweight and focused: it configures only what greenfield skills need (artifact directories and platform integration). It does NOT set up code patterns, report templates, plans, or documentation directories — those are handled when the project transitions to the development phase. Design tool integration (Figma/Canva) is only available through this skill — ensure-config does not configure design tools.
22
+
23
+ The `## Arness` section written by this skill is forward-compatible with Arness Code and Arness Infra. When either plugin's ensure-config or init runs later, it detects the existing configuration and adds the remaining fields without disrupting greenfield settings.
24
+
25
+ ## Workflow
26
+
27
+ ### Step 1: Check Existing Configuration
28
+
29
+ Read the project's arness.md and look for a `## Arness` section. If no arness.md exists, create one at the project root before proceeding.
30
+
31
+ **If the section does not exist:**
32
+ - Proceed to Step 2 (fresh init)
33
+
34
+ **If the section exists:**
35
+ 1. Parse all config fields from the existing `## Arness` block
36
+ 2. Read the current plugin version — use [PLATFORM_PLUGIN_METADATA] to read plugin version
37
+ 3. Show the user their current configuration
38
+ 4. Ask the user:
39
+ - **Review** — Show current configuration summary, no changes
40
+ - **Update** — Check for missing greenfield fields and fill them in
41
+ - **Reconfigure** — Re-run the full setup flow from scratch
42
+ - **Keep** — No changes
43
+ - If **Review** → display a clean summary of all `## Arness` fields relevant to Arness Spark, then exit the skill
44
+ - If **Keep** → done, exit the skill
45
+ - If **Reconfigure** → continue to Step 2, pre-filling known values as defaults
46
+ - If **Update** → check which greenfield fields are missing (Vision directory, Use cases directory, Prototypes directory, Spikes directory, Visual grounding directory, Reports directory, Git, Platform, Issue tracker, Figma, Canva) and only process those. For missing directory fields, ask the user with the existing value as the default. For missing Git/Platform/Issue tracker, re-run Step 3 detection. For missing Figma/Canva, re-run Step 3.4 design tool integration. Then proceed to Step 4 to write the updated config. Preserve all existing fields that are not managed by this skill (such as Plans directory, Specs directory, Report templates, etc.).
47
+
48
+ ---
49
+
50
+ ### Step 2: Configure Output Directories
51
+
52
+ Ask the user about each output directory. All defaults are under `.arness/` to centralize Arness artifacts in one place.
53
+
54
+ **2.1. Vision directory:**
55
+
56
+ "Where should Arness store greenfield vision documents (product concept, architecture vision, style brief, spike results, feature backlog)?"
57
+
58
+ - Default: `.arness/vision`
59
+ - Used by: `/arn-spark-discover`, `/arn-spark-arch-vision`, `/arn-spark-spike`, `/arn-spark-style-explore`, `/arn-spark-feature-extract`, `/arn-spark-dev-setup`
60
+
61
+ **2.2. Use cases directory:**
62
+
63
+ "Where should Arness store use case documents?"
64
+
65
+ - Default: `.arness/use-cases`
66
+ - Used by: `/arn-spark-use-cases`, `/arn-spark-use-cases-teams`
67
+
68
+ **2.3. Prototypes directory:**
69
+
70
+ "Where should Arness store prototype versions and review reports?"
71
+
72
+ - Default: `.arness/prototypes`
73
+ - Used by: `/arn-spark-static-prototype`, `/arn-spark-clickable-prototype`
74
+
75
+ **2.4. Spikes directory:**
76
+
77
+ "Where should Arness store technical spike POC code?"
78
+
79
+ - Default: `.arness/spikes`
80
+ - Used by: `/arn-spark-spike`
81
+
82
+ **2.5. Visual grounding directory:**
83
+
84
+ "Where should Arness store visual grounding assets (reference images, design mockups, brand assets)?"
85
+
86
+ - Default: `.arness/visual-grounding`
87
+ - Used by: `/arn-spark-style-explore`, `/arn-spark-static-prototype`, `/arn-spark-clickable-prototype`
88
+
89
+ Create three subfolders inside the visual grounding directory: `references/`, `designs/`, `brand/`.
90
+
91
+ **2.6. Reports directory:**
92
+
93
+ "Where should Arness store stress test reports and other analysis output?"
94
+
95
+ - Default: `.arness/reports`
96
+ - Used by: `/arn-spark-stress-interview`, `/arn-spark-stress-competitive`, `/arn-spark-stress-premortem`, `/arn-spark-stress-prfaq`, `/arn-spark-concept-review`
97
+
98
+ After creating the Reports directory (`mkdir -p <chosen-path>`), also create the `stress-tests/` subdirectory: `mkdir -p <chosen-path>/stress-tests/`
99
+
100
+ For each directory:
101
+ - Accept any relative path the user provides (relative to the project root)
102
+ - If updating an existing config (from Step 1), show the current path as the default
103
+ - Create the directory if it does not exist: `mkdir -p <chosen-path>`
104
+
105
+ ---
106
+
107
+ ### Step 3: Detect Git, Platform, and Issue Tracker
108
+
109
+ **Shared field preservation:** If `## Arness` already exists and the shared fields (Git, Platform, Issue tracker, Jira site, Jira project) are already present from a prior init (this plugin or another — e.g., arn-code-init or arn-infra-init), **skip detection and preserve the existing values** — unless the user chose **Reconfigure** in Step 1. This prevents overwriting values set by another plugin in a monorepo.
110
+
111
+ Check if the project uses Git, determine the code hosting platform, and identify the issue tracker.
112
+
113
+ **3.1. Git check:**
114
+ 1. Run `git rev-parse --is-inside-work-tree` to check for a git repository
115
+ 2. If Git is not detected, inform the user: "This project is not a git repository. Git-dependent skills (Arness Code: `/arn-code-ship`, `/arn-code-review-pr`, `/arn-code-create-issue`, `/arn-code-pick-issue`) will be unavailable." Record Git: no, Platform: none, Issue tracker: none and proceed to Step 4.
116
+
117
+ **3.2. Remote classification:**
118
+ 1. Run `git remote -v` and classify the remote URL:
119
+ - Contains `github.com` → candidate: **github**
120
+ - Contains `bitbucket.org` → candidate: **bitbucket**
121
+ - Neither → Platform: none, Issue tracker: none. Inform the user: "No supported platform detected. PR and issue management skills will be unavailable."
122
+
123
+ **3.3a. If candidate is github:**
124
+ 1. Run `gh auth status` to check for GitHub CLI authentication
125
+ 2. If authenticated → Platform: **github**, Issue tracker: **github**
126
+ 3. If NOT authenticated → warn the user, suggest `gh auth login`, and **STOP init** (do not continue until resolved)
127
+ 4. Create 7 Arness labels for issue management. Use `gh label create` for each label (the command is idempotent — it will skip labels that already exist):
128
+
129
+ | Label | Color | Description |
130
+ |-------|-------|-------------|
131
+ | `arness-backlog` | `d4c5f9` | Deferred items from PRs or postponed features |
132
+ | `arness-feature-issue` | `0e8a16` | Feature requests tracked via Arness |
133
+ | `arness-bug-issue` | `d93f0b` | Bug reports tracked via Arness |
134
+ | `arness-priority-high` | `b60205` | High priority |
135
+ | `arness-priority-medium` | `fbca04` | Medium priority |
136
+ | `arness-priority-low` | `c5def5` | Low priority |
137
+ | `arness-rejected` | `e4e669` | Issue reviewed and rejected as invalid or out of scope |
138
+
139
+ > Read `${CLAUDE_PLUGIN_ROOT}/skills/arn-spark-init/references/platform-labels.md` for label details and which skills use each label.
140
+
141
+ **3.3b. If candidate is bitbucket:**
142
+ 1. Run `bkt --version` to check if the Bitbucket CLI is installed
143
+ - If NOT available → read and show the setup instructions from `${CLAUDE_PLUGIN_ROOT}/skills/arn-spark-init/references/bkt-setup.md`, then **STOP init**
144
+ 2. Run `bkt auth status` to check authentication
145
+ - If NOT authenticated → read and show the auth instructions from `${CLAUDE_PLUGIN_ROOT}/skills/arn-spark-init/references/bkt-setup.md`, then **STOP init**
146
+ 3. Platform: **bitbucket** (confirmed)
147
+ 4. Ask the user:
148
+
149
+ > **Do you use Jira for issue tracking on this project?**
150
+ > 1. **Yes** — Verify Atlassian MCP server and select a Jira project
151
+ > 2. **No** — Skip issue tracker integration
152
+
153
+ - **Yes** → verify the Atlassian MCP server:
154
+ - Attempt to list Jira projects via the MCP tool
155
+ - If MCP NOT available → read and show the setup instructions from `${CLAUDE_PLUGIN_ROOT}/skills/arn-spark-init/references/jira-mcp-setup.md`, then **STOP init**
156
+ - If MCP available → list projects, present to user, user picks one
157
+ - Store: Issue tracker: **jira**, Jira site: (from MCP context or ask user), Jira project: (user's pick)
158
+ - No label creation needed (Jira labels are implicit — see `${CLAUDE_PLUGIN_ROOT}/skills/arn-spark-init/references/platform-labels.md`)
159
+ - **No** → Issue tracker: **none**
160
+ - Inform the user: "Issue management skills (Arness Code: `/arn-code-create-issue`, `/arn-code-pick-issue`) will be unavailable. PR and code workflow skills still work via bkt."
161
+
162
+ **3.4. Design tool integration:**
163
+
164
+ Detect design tool MCP availability, then ask the user's project-level decision.
165
+
166
+ **3.4a. Detection (automatic):**
167
+
168
+ 1. Check if a Figma MCP server is configured:
169
+ - Look for `figma` in the project's `.mcp.json` or attempt to invoke a Figma MCP tool
170
+ - Record: Figma MCP available: yes | no
171
+
172
+ 2. Check if a Canva MCP server is configured:
173
+ - Look for `canva` in the project's `.mcp.json` or attempt to invoke a Canva MCP tool
174
+ - Record: Canva MCP available: yes | no
175
+
176
+ **3.4b. User decision (ask):**
177
+
178
+ Present the detection results, then ask the user what they want to use for THIS project.
179
+
180
+ Show the detection context first:
181
+
182
+ - [If Figma MCP detected:] "Figma MCP is available on this machine."
183
+ - [If Figma MCP not detected:] "Figma MCP is not configured. ([Setup instructions](https://www.figma.com/blog/introducing-figma-mcp-server/))"
184
+ - [If Canva MCP detected:] "Canva MCP is available on this machine."
185
+ - [If Canva MCP not detected:] "Canva MCP is not configured. ([Setup instructions](https://www.canva.dev/docs/connect/mcp-server/))"
186
+
187
+ Then ask the user (multiSelect: true):
188
+
189
+ > **Which design tools do you want to use for this project?** (Even if an MCP is available, you may not need it for every project.)
190
+ > 1. **Figma** — Pull design data and export screens during style exploration and prototype validation [only show if MCP available]
191
+ > 2. **Canva** — Pull design assets during style exploration [only show if MCP available]
192
+ > 3. **None** — No design tool integration for this project
193
+
194
+ If the user selects a tool whose MCP is not available, inform them it requires MCP setup and suggest the setup link above.
195
+
196
+ Record the user's choices:
197
+ - **Figma:** yes | no (project-level decision, not just availability)
198
+ - **Canva:** yes | no (project-level decision, not just availability)
199
+
200
+ Downstream skills check these flags — not MCP availability — to decide whether to offer Figma/Canva integration. If the flag is `no`, the skill does not mention or attempt to use that MCP, even if it's technically available.
201
+
202
+ **3.5. Record results:**
203
+ - **Git:** yes | no
204
+ - **Platform:** github | bitbucket | none
205
+ - **Issue tracker:** github | jira | none
206
+ - **Jira site:** (only if Issue tracker is jira)
207
+ - **Jira project:** (only if Issue tracker is jira)
208
+ - **Figma:** yes | no
209
+ - **Canva:** yes | no
210
+
211
+ ---
212
+
213
+ ### Step 3.6: Choose Model Profile for arn-spark Agents
214
+
215
+ Run the **Profile selection** procedure documented in `${CLAUDE_PLUGIN_ROOT}/skills/arn-spark-ensure-config/references/step-0-fast-path.md` under the "Model profile field" section. That procedure is the single source of truth for the prompt + write + copy + checksum flow — do NOT duplicate the question prompt or file-copy logic here.
216
+
217
+ The procedure performs (in order):
218
+ 1. Cross-plugin default suggestion (read sibling plugin profile fields if present in the existing `## Arness` block — e.g., if the user previously chose `balanced` for arn-code, suggest `balanced` here too)
219
+ 2. Present the question with title "Choose model profile for arn-spark agents" and two options: `all-opus` (default unless a sibling chose `balanced`) and `balanced`
220
+ 3. Append `- **Spark agent model profile:** <choice>` to the `## Arness` block
221
+ 4. `mkdir -p .arness/agent-models/` then copy `${CLAUDE_PLUGIN_ROOT}/skills/arn-spark-init/references/agent-models-presets/<choice>.md` to `.arness/agent-models/spark.md`
222
+ 5. Compute SHA-256 and record it in `.arness/agent-models/.checksums.json` along with the profile name and version
223
+ 6. Inform the user with a one-line confirmation
224
+
225
+ The field write in step 3 of the procedure is captured for the arness.md write in Step 4 of this init flow — write the chosen value to a holding variable and let Step 4 emit it inline with all other fields. The preset copy + checksum (steps 4-5 of the procedure) happen here regardless of when the arness.md write is performed.
226
+
227
+ Record the chosen profile for the config write in Step 4.
228
+
229
+ ---
230
+
231
+ ### Step 4: Persist Configuration to arness.md
232
+
233
+ Write (or update) the `## Arness` section in the project's arness.md:
234
+
235
+ ```markdown
236
+ ## Arness
237
+
238
+ - **Vision directory:** [chosen-path]
239
+ - **Use cases directory:** [chosen-path]
240
+ - **Prototypes directory:** [chosen-path]
241
+ - **Spikes directory:** [chosen-path]
242
+ - **Visual grounding directory:** [chosen-path]
243
+ - **Reports directory:** [chosen-path]
244
+ - **Spark agent model profile:** all-opus | balanced | custom
245
+ - **Git:** yes | no
246
+ - **Platform:** github | bitbucket | none
247
+ - **Issue tracker:** github | jira | none
248
+ - **Jira site:** <site>.atlassian.net
249
+ - **Jira project:** <KEY>
250
+ - **Figma:** yes | no
251
+ - **Canva:** yes | no
252
+ ```
253
+
254
+ **Rules:**
255
+ - All directory paths MUST be relative to the project root, never absolute. This ensures portability across machines.
256
+ - The Jira site and Jira project fields are only written when Issue tracker is jira. Omit them entirely for other issue trackers.
257
+ - The Figma and Canva fields are only written when the user explicitly chooses to use them for this project. Omit fields set to `no`.
258
+ - Git, Platform, and Issue tracker fields are auto-detected in Step 3 and are not user-configurable. Figma and Canva are user-decided in Step 3.4.
259
+ - If updating an existing config that has additional fields from other plugins, **preserve all fields not managed by this skill**. This includes dev fields (Plans directory, Specs directory, Report templates, Template path, Template version, Template updates, Code patterns, Docs directory, Task list ID) and infra fields (Deferred, Experience level, Project topology, Application path, Providers, Providers config, Default IaC tool, Environments, Environments config, Tooling manifest, Resource manifest, Cost threshold, Validation ceiling, Infra plans directory, Infra specs directory, Infra docs directory, Infra report templates, Infra template path, Infra template version, CI/CD platform, Reference overrides, Reference version, Reference updates). For shared fields (Git, Platform, Issue tracker, Jira site, Jira project): if already present, preserve them — do not re-detect unless the user chose Reconfigure in Step 1. Replace only the greenfield fields listed above.
260
+ - Replace the existing `## Arness` section in place. Do not duplicate it.
261
+
262
+ ---
263
+
264
+ ### Step 5: Verify and Summarize
265
+
266
+ Confirm with the user:
267
+
268
+ - [ ] Vision directory configured and created: `[path]`
269
+ - [ ] Use cases directory configured and created: `[path]`
270
+ - [ ] Prototypes directory configured and created: `[path]`
271
+ - [ ] Spikes directory configured and created: `[path]`
272
+ - [ ] Visual grounding directory configured and created: `[path]`
273
+ - [ ] Visual grounding subfolders created: `references/`, `designs/`, `brand/`
274
+ - [ ] Reports directory configured and created: `[path]`
275
+ - [ ] Reports subdirectory created: `stress-tests/`
276
+ - [ ] Git detected: yes | no
277
+ - [ ] Platform detected: github | bitbucket | none
278
+ - [ ] Issue tracker detected: github | jira | none
279
+ - [ ] GitHub labels created (if Platform is github)
280
+ - [ ] Jira project selected (if Issue tracker is jira)
281
+ - [ ] Figma integration: yes | no (user's choice for this project)
282
+ - [ ] Canva integration: yes | no (user's choice for this project)
283
+ - [ ] `## Arness` section written to arness.md
284
+
285
+ List all created/modified files with their paths.
286
+
287
+ **Next steps:**
288
+
289
+ "Arness Spark is ready. Here is the recommended exploration pipeline:
290
+
291
+ 1. **Define the product:** Run `/arn-spark-discover` to shape your product idea into a structured concept
292
+ 2. **Stress-test the concept (optional):** Run `/arn-spark-stress-interview`, `/arn-spark-stress-competitive`, `/arn-spark-stress-premortem`, `/arn-spark-stress-prfaq` to validate the concept, then `/arn-spark-concept-review` to apply findings
293
+ 3. **Define the architecture:** Run `/arn-spark-arch-vision` to choose technologies and design the system
294
+ 4. **Write use cases:** Run `/arn-spark-use-cases` (or `/arn-spark-use-cases-teams` for expert debate) to specify system behavior
295
+ 5. **Scaffold the project:** Run `/arn-spark-scaffold` to create the project skeleton
296
+ 6. **Validate risks:** Run `/arn-spark-spike` to test critical technical assumptions
297
+ 7. **Explore visual direction:** Run `/arn-spark-visual-sketch` to generate visual direction proposals and select a direction
298
+ 8. **Define the style:** Run `/arn-spark-style-explore` to translate the visual direction into a complete design system
299
+ 9. **Prototype:** Run `/arn-spark-static-prototype` and `/arn-spark-clickable-prototype` to validate the UI
300
+ 10. **Extract features:** Run `/arn-spark-feature-extract` to build the backlog
301
+
302
+ When you are ready to transition from exploration to development: if you have the Arness Code plugin installed, run `/arn-planning` to start the development pipeline. Arness auto-configures code patterns, report templates, plans, and documentation directories on first use."
303
+
304
+ ---
305
+
306
+ ## Error Handling
307
+
308
+ - **User cancels at any step:** Confirm cancellation and exit gracefully. Do not leave partially written configuration. If some directories were already created, inform the user they can be removed manually.
309
+ - **Writing to arness.md fails:** Print the full `## Arness` config block in the conversation so the user can insert it manually. Suggest checking file permissions.
310
+ - **`gh auth login` or `bkt auth login` not resolved:** Explain the issue and stop init. The user must resolve authentication before proceeding. They can re-run `/arn-spark-init` after fixing auth.
311
+ - **Re-running is safe:** Step 1 detects the existing config and offers Update / Reconfigure / Keep. No data is lost on re-run.
312
+ - **Arness Init run after Spark Init:** Fully supported. Arness Init's upgrade flow detects the existing greenfield fields and adds the missing development fields (Plans, Specs, Templates, Code patterns, Docs). Greenfield fields are preserved.
@@ -0,0 +1,23 @@
1
+ # Profile: all-opus
2
+ # Version: 1.0.0
3
+
4
+ arn-spark-brand-strategist: opus
5
+ arn-spark-dev-env-builder: opus
6
+ arn-spark-doctor: opus
7
+ arn-spark-forensic-investigator: opus
8
+ arn-spark-marketing-pm: opus
9
+ arn-spark-market-researcher: opus
10
+ arn-spark-persona-architect: opus
11
+ arn-spark-persona-impersonator: opus
12
+ arn-spark-product-strategist: opus
13
+ arn-spark-prototype-builder: opus
14
+ arn-spark-scaffolder: opus
15
+ arn-spark-spike-runner: opus
16
+ arn-spark-style-capture: opus
17
+ arn-spark-tech-evaluator: opus
18
+ arn-spark-ui-interactor: opus
19
+ arn-spark-use-case-writer: opus
20
+ arn-spark-ux-judge: opus
21
+ arn-spark-ux-specialist: opus
22
+ arn-spark-visual-sketcher: opus
23
+ arn-spark-visual-test-engineer: opus
@@ -0,0 +1,23 @@
1
+ # Profile: balanced
2
+ # Version: 1.0.0
3
+
4
+ arn-spark-brand-strategist: opus
5
+ arn-spark-dev-env-builder: sonnet
6
+ arn-spark-doctor: sonnet
7
+ arn-spark-forensic-investigator: opus
8
+ arn-spark-marketing-pm: opus
9
+ arn-spark-market-researcher: opus
10
+ arn-spark-persona-architect: opus
11
+ arn-spark-persona-impersonator: sonnet
12
+ arn-spark-product-strategist: opus
13
+ arn-spark-prototype-builder: opus
14
+ arn-spark-scaffolder: sonnet
15
+ arn-spark-spike-runner: sonnet
16
+ arn-spark-style-capture: sonnet
17
+ arn-spark-tech-evaluator: opus
18
+ arn-spark-ui-interactor: sonnet
19
+ arn-spark-use-case-writer: sonnet
20
+ arn-spark-ux-judge: opus
21
+ arn-spark-ux-specialist: sonnet
22
+ arn-spark-visual-sketcher: sonnet
23
+ arn-spark-visual-test-engineer: sonnet
@@ -0,0 +1,55 @@
1
+ # Bitbucket CLI (bkt) Setup
2
+
3
+ The `bkt` CLI provides gh-like ergonomics for Bitbucket Cloud and Data Center. Arness uses it for all Bitbucket PR operations (create, list, merge, comment).
4
+
5
+ **Repository:** https://github.com/avivsinai/bitbucket-cli
6
+
7
+ ## Installation
8
+
9
+ Install `bkt` using one of the following methods:
10
+
11
+ | Method | Command |
12
+ |--------|---------|
13
+ | pipx (recommended) | `pipx install bitbucket-cli` |
14
+ | npm | `npm install -g bitbucket-cli` |
15
+ | Binary download | See [releases](https://github.com/avivsinai/bitbucket-cli/releases) |
16
+
17
+ ## Authentication
18
+
19
+ Authenticate with Bitbucket using `bkt auth login`:
20
+
21
+ ```bash
22
+ bkt auth login
23
+ ```
24
+
25
+ This opens a browser for OAuth authentication. Follow the prompts to authorize the CLI.
26
+
27
+ ### API Token (alternative)
28
+
29
+ You can also authenticate via an API token set as an environment variable:
30
+
31
+ ```bash
32
+ export BKT_TOKEN="your-api-token"
33
+ ```
34
+
35
+ Generate an API token from your Bitbucket account settings under **Personal settings > API tokens**.
36
+
37
+ > **Note:** Bitbucket App Passwords will be deprecated in June 2026. Use API tokens instead for new integrations.
38
+
39
+ ## Verification
40
+
41
+ After installation and authentication, verify both are working:
42
+
43
+ ```bash
44
+ bkt --version # Confirm installation
45
+ bkt auth status # Confirm authentication
46
+ ```
47
+
48
+ Both commands must succeed before Arness can use Bitbucket integration.
49
+
50
+ ## Notes
51
+
52
+ - `bkt` supports both Bitbucket Cloud and Bitbucket Data Center
53
+ - Arness currently targets Bitbucket Cloud only (Data Center is out of scope)
54
+ - `bkt` supports JSON and YAML output formats, which Arness uses for structured data parsing
55
+ - If `bkt` is not installed or not authenticated, Arness will skip Bitbucket platform detection during `/arn-spark-init` (or `/arn-code-init`)