agentera 0.0.0 → 3.0.0-dev.1

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 (256) hide show
  1. package/README.md +6 -45
  2. package/bundle/.agentera-npx-bundle.json +4 -0
  3. package/bundle/references/adapters/cursor.md +213 -0
  4. package/bundle/references/adapters/opencode.md +530 -0
  5. package/bundle/references/adapters/package-manifest-interface-model.yaml +337 -0
  6. package/bundle/references/adapters/package-registry.yaml +247 -0
  7. package/bundle/references/adapters/package-surface-characterization.md +48 -0
  8. package/bundle/references/adapters/runtime-adapter-characterization.md +79 -0
  9. package/bundle/references/adapters/runtime-adapter-interface-model.yaml +200 -0
  10. package/bundle/references/adapters/runtime-adapter-registry.yaml +548 -0
  11. package/bundle/references/adapters/runtime-feature-parity.md +189 -0
  12. package/bundle/references/analysis/benchmark.md +267 -0
  13. package/bundle/references/analysis/startup-measurement-contract.yaml +424 -0
  14. package/bundle/references/artifacts/artifact-registry-interface-model.yaml +288 -0
  15. package/bundle/references/cli/agent-ready-state-contract.yaml +950 -0
  16. package/bundle/references/cli/app-lifecycle-vocabulary.yaml +241 -0
  17. package/bundle/references/cli/audience-namespace-cli-migration.yaml +355 -0
  18. package/bundle/references/cli/bundle-skill-vocabulary.yaml +278 -0
  19. package/bundle/references/cli/capability-instruction-contract.yaml +123 -0
  20. package/bundle/references/cli/capability-tool-classification.yaml +53 -0
  21. package/bundle/references/cli/routing-execution-vocabulary.yaml +281 -0
  22. package/bundle/references/cli/update-channels.yaml +147 -0
  23. package/bundle/references/cli/vocabulary-index.yaml +160 -0
  24. package/bundle/references/cli/vocabulary.md +566 -0
  25. package/bundle/references/meta/documentation-inventory.md +43 -0
  26. package/bundle/references/v1-section-mapping.md +47 -0
  27. package/bundle/registry.json +39 -0
  28. package/bundle/skills/agentera/.claude-plugin/plugin.json +27 -0
  29. package/bundle/skills/agentera/SKILL.md +470 -0
  30. package/bundle/skills/agentera/agents/dokumentera.toml +6 -0
  31. package/bundle/skills/agentera/agents/hej.toml +6 -0
  32. package/bundle/skills/agentera/agents/inspektera.toml +6 -0
  33. package/bundle/skills/agentera/agents/inspirera.toml +6 -0
  34. package/bundle/skills/agentera/agents/optimera.toml +6 -0
  35. package/bundle/skills/agentera/agents/orkestrera.toml +6 -0
  36. package/bundle/skills/agentera/agents/planera.toml +6 -0
  37. package/bundle/skills/agentera/agents/profilera.toml +6 -0
  38. package/bundle/skills/agentera/agents/realisera.toml +6 -0
  39. package/bundle/skills/agentera/agents/resonera.toml +6 -0
  40. package/bundle/skills/agentera/agents/visionera.toml +6 -0
  41. package/bundle/skills/agentera/agents/visualisera.toml +6 -0
  42. package/bundle/skills/agentera/capabilities/dokumentera/instructions.md +428 -0
  43. package/bundle/skills/agentera/capabilities/dokumentera/schemas/artifacts.yaml +73 -0
  44. package/bundle/skills/agentera/capabilities/dokumentera/schemas/exit.yaml +35 -0
  45. package/bundle/skills/agentera/capabilities/dokumentera/schemas/triggers.yaml +35 -0
  46. package/bundle/skills/agentera/capabilities/dokumentera/schemas/validation.yaml +139 -0
  47. package/bundle/skills/agentera/capabilities/hej/instructions.md +331 -0
  48. package/bundle/skills/agentera/capabilities/hej/schemas/artifacts.yaml +69 -0
  49. package/bundle/skills/agentera/capabilities/hej/schemas/exit.yaml +32 -0
  50. package/bundle/skills/agentera/capabilities/hej/schemas/triggers.yaml +58 -0
  51. package/bundle/skills/agentera/capabilities/hej/schemas/validation.yaml +55 -0
  52. package/bundle/skills/agentera/capabilities/inspektera/instructions.md +514 -0
  53. package/bundle/skills/agentera/capabilities/inspektera/schemas/artifacts.yaml +76 -0
  54. package/bundle/skills/agentera/capabilities/inspektera/schemas/exit.yaml +36 -0
  55. package/bundle/skills/agentera/capabilities/inspektera/schemas/triggers.yaml +38 -0
  56. package/bundle/skills/agentera/capabilities/inspektera/schemas/validation.yaml +113 -0
  57. package/bundle/skills/agentera/capabilities/inspirera/instructions.md +280 -0
  58. package/bundle/skills/agentera/capabilities/inspirera/schemas/artifacts.yaml +24 -0
  59. package/bundle/skills/agentera/capabilities/inspirera/schemas/exit.yaml +33 -0
  60. package/bundle/skills/agentera/capabilities/inspirera/schemas/triggers.yaml +34 -0
  61. package/bundle/skills/agentera/capabilities/inspirera/schemas/validation.yaml +58 -0
  62. package/bundle/skills/agentera/capabilities/optimera/instructions.md +437 -0
  63. package/bundle/skills/agentera/capabilities/optimera/schemas/artifacts.yaml +69 -0
  64. package/bundle/skills/agentera/capabilities/optimera/schemas/exit.yaml +35 -0
  65. package/bundle/skills/agentera/capabilities/optimera/schemas/triggers.yaml +39 -0
  66. package/bundle/skills/agentera/capabilities/optimera/schemas/validation.yaml +91 -0
  67. package/bundle/skills/agentera/capabilities/orkestrera/instructions.md +433 -0
  68. package/bundle/skills/agentera/capabilities/orkestrera/schemas/artifacts.yaml +64 -0
  69. package/bundle/skills/agentera/capabilities/orkestrera/schemas/exit.yaml +34 -0
  70. package/bundle/skills/agentera/capabilities/orkestrera/schemas/triggers.yaml +42 -0
  71. package/bundle/skills/agentera/capabilities/orkestrera/schemas/validation.yaml +107 -0
  72. package/bundle/skills/agentera/capabilities/planera/instructions.md +368 -0
  73. package/bundle/skills/agentera/capabilities/planera/schemas/artifacts.yaml +62 -0
  74. package/bundle/skills/agentera/capabilities/planera/schemas/exit.yaml +33 -0
  75. package/bundle/skills/agentera/capabilities/planera/schemas/triggers.yaml +34 -0
  76. package/bundle/skills/agentera/capabilities/planera/schemas/validation.yaml +61 -0
  77. package/bundle/skills/agentera/capabilities/profilera/instructions.md +419 -0
  78. package/bundle/skills/agentera/capabilities/profilera/schemas/artifacts.yaml +18 -0
  79. package/bundle/skills/agentera/capabilities/profilera/schemas/exit.yaml +34 -0
  80. package/bundle/skills/agentera/capabilities/profilera/schemas/triggers.yaml +45 -0
  81. package/bundle/skills/agentera/capabilities/profilera/schemas/validation.yaml +57 -0
  82. package/bundle/skills/agentera/capabilities/realisera/instructions.md +403 -0
  83. package/bundle/skills/agentera/capabilities/realisera/schemas/artifacts.yaml +80 -0
  84. package/bundle/skills/agentera/capabilities/realisera/schemas/exit.yaml +35 -0
  85. package/bundle/skills/agentera/capabilities/realisera/schemas/triggers.yaml +39 -0
  86. package/bundle/skills/agentera/capabilities/realisera/schemas/validation.yaml +110 -0
  87. package/bundle/skills/agentera/capabilities/resonera/instructions.md +329 -0
  88. package/bundle/skills/agentera/capabilities/resonera/schemas/artifacts.yaml +47 -0
  89. package/bundle/skills/agentera/capabilities/resonera/schemas/exit.yaml +35 -0
  90. package/bundle/skills/agentera/capabilities/resonera/schemas/triggers.yaml +46 -0
  91. package/bundle/skills/agentera/capabilities/resonera/schemas/validation.yaml +77 -0
  92. package/bundle/skills/agentera/capabilities/visionera/instructions.md +309 -0
  93. package/bundle/skills/agentera/capabilities/visionera/schemas/artifacts.yaml +57 -0
  94. package/bundle/skills/agentera/capabilities/visionera/schemas/exit.yaml +35 -0
  95. package/bundle/skills/agentera/capabilities/visionera/schemas/triggers.yaml +41 -0
  96. package/bundle/skills/agentera/capabilities/visionera/schemas/validation.yaml +74 -0
  97. package/bundle/skills/agentera/capabilities/visualisera/instructions.md +400 -0
  98. package/bundle/skills/agentera/capabilities/visualisera/schemas/artifacts.yaml +44 -0
  99. package/bundle/skills/agentera/capabilities/visualisera/schemas/exit.yaml +34 -0
  100. package/bundle/skills/agentera/capabilities/visualisera/schemas/triggers.yaml +33 -0
  101. package/bundle/skills/agentera/capabilities/visualisera/schemas/validation.yaml +80 -0
  102. package/bundle/skills/agentera/capability_schema_contract.yaml +385 -0
  103. package/bundle/skills/agentera/protocol.yaml +463 -0
  104. package/bundle/skills/agentera/references/contract.md +1039 -0
  105. package/bundle/skills/agentera/schemas/artifacts/changelog.yaml +60 -0
  106. package/bundle/skills/agentera/schemas/artifacts/decisions.yaml +461 -0
  107. package/bundle/skills/agentera/schemas/artifacts/design.yaml +55 -0
  108. package/bundle/skills/agentera/schemas/artifacts/docs.yaml +402 -0
  109. package/bundle/skills/agentera/schemas/artifacts/experiments.yaml +373 -0
  110. package/bundle/skills/agentera/schemas/artifacts/health.yaml +484 -0
  111. package/bundle/skills/agentera/schemas/artifacts/objective.yaml +399 -0
  112. package/bundle/skills/agentera/schemas/artifacts/plan.yaml +342 -0
  113. package/bundle/skills/agentera/schemas/artifacts/progress.yaml +325 -0
  114. package/bundle/skills/agentera/schemas/artifacts/todo.yaml +110 -0
  115. package/bundle/skills/agentera/schemas/artifacts/vision.yaml +262 -0
  116. package/bundle/skills/hej/.claude-plugin/plugin.json +6 -0
  117. package/bundle/skills/hej/SKILL.md +69 -0
  118. package/bundle/skills/hej/agents/hej.toml +11 -0
  119. package/bundle/skills/hej/agents/openai.yaml +8 -0
  120. package/dist/analytics/extractCorpus.js +1791 -0
  121. package/dist/analytics/extractCorpus.js.map +1 -0
  122. package/dist/analytics/usageStats.js +487 -0
  123. package/dist/analytics/usageStats.js.map +1 -0
  124. package/dist/bin/agentera.js +4 -0
  125. package/dist/bin/agentera.js.map +1 -0
  126. package/dist/cli/appContext.js +226 -0
  127. package/dist/cli/appContext.js.map +1 -0
  128. package/dist/cli/argvalidate.js +41 -0
  129. package/dist/cli/argvalidate.js.map +1 -0
  130. package/dist/cli/capabilityContext.js +2421 -0
  131. package/dist/cli/capabilityContext.js.map +1 -0
  132. package/dist/cli/commands/backfill.js +84 -0
  133. package/dist/cli/commands/backfill.js.map +1 -0
  134. package/dist/cli/commands/capability.js +44 -0
  135. package/dist/cli/commands/capability.js.map +1 -0
  136. package/dist/cli/commands/compact.js +148 -0
  137. package/dist/cli/commands/compact.js.map +1 -0
  138. package/dist/cli/commands/doctor.js +180 -0
  139. package/dist/cli/commands/doctor.js.map +1 -0
  140. package/dist/cli/commands/lint.js +179 -0
  141. package/dist/cli/commands/lint.js.map +1 -0
  142. package/dist/cli/commands/prime.js +544 -0
  143. package/dist/cli/commands/prime.js.map +1 -0
  144. package/dist/cli/commands/query.js +346 -0
  145. package/dist/cli/commands/query.js.map +1 -0
  146. package/dist/cli/commands/report.js +210 -0
  147. package/dist/cli/commands/report.js.map +1 -0
  148. package/dist/cli/commands/schema.js +306 -0
  149. package/dist/cli/commands/schema.js.map +1 -0
  150. package/dist/cli/commands/state.js +1012 -0
  151. package/dist/cli/commands/state.js.map +1 -0
  152. package/dist/cli/commands/upgrade.js +48 -0
  153. package/dist/cli/commands/upgrade.js.map +1 -0
  154. package/dist/cli/commands/validate.js +519 -0
  155. package/dist/cli/commands/validate.js.map +1 -0
  156. package/dist/cli/commands/verify.js +204 -0
  157. package/dist/cli/commands/verify.js.map +1 -0
  158. package/dist/cli/dispatch.js +958 -0
  159. package/dist/cli/dispatch.js.map +1 -0
  160. package/dist/cli/orientation.js +595 -0
  161. package/dist/cli/orientation.js.map +1 -0
  162. package/dist/cli/prime-blob.js +3 -0
  163. package/dist/cli/prime-blob.js.map +1 -0
  164. package/dist/cli/stateQuery.js +292 -0
  165. package/dist/cli/stateQuery.js.map +1 -0
  166. package/dist/cli/structured.js +18 -0
  167. package/dist/cli/structured.js.map +1 -0
  168. package/dist/core/difflib.js +274 -0
  169. package/dist/core/difflib.js.map +1 -0
  170. package/dist/core/git.js +43 -0
  171. package/dist/core/git.js.map +1 -0
  172. package/dist/core/paths.js +50 -0
  173. package/dist/core/paths.js.map +1 -0
  174. package/dist/core/pyjson.js +101 -0
  175. package/dist/core/pyjson.js.map +1 -0
  176. package/dist/core/sourceRoot.js +72 -0
  177. package/dist/core/sourceRoot.js.map +1 -0
  178. package/dist/core/toml.js +11 -0
  179. package/dist/core/toml.js.map +1 -0
  180. package/dist/core/yaml.js +25 -0
  181. package/dist/core/yaml.js.map +1 -0
  182. package/dist/eval/evalSkills.js +258 -0
  183. package/dist/eval/evalSkills.js.map +1 -0
  184. package/dist/eval/semanticEval.js +148 -0
  185. package/dist/eval/semanticEval.js.map +1 -0
  186. package/dist/eval/semanticFixtures.js +227 -0
  187. package/dist/eval/semanticFixtures.js.map +1 -0
  188. package/dist/hooks/common.js +160 -0
  189. package/dist/hooks/common.js.map +1 -0
  190. package/dist/hooks/compaction.js +935 -0
  191. package/dist/hooks/compaction.js.map +1 -0
  192. package/dist/hooks/cursorPreToolUse.js +19 -0
  193. package/dist/hooks/cursorPreToolUse.js.map +1 -0
  194. package/dist/hooks/cursorSessionStart.js +71 -0
  195. package/dist/hooks/cursorSessionStart.js.map +1 -0
  196. package/dist/hooks/sessionStart.js +209 -0
  197. package/dist/hooks/sessionStart.js.map +1 -0
  198. package/dist/hooks/sessionStop.js +212 -0
  199. package/dist/hooks/sessionStop.js.map +1 -0
  200. package/dist/hooks/validateArtifact.js +933 -0
  201. package/dist/hooks/validateArtifact.js.map +1 -0
  202. package/dist/registries/artifactRegistry.js +206 -0
  203. package/dist/registries/artifactRegistry.js.map +1 -0
  204. package/dist/registries/capabilityContract.js +310 -0
  205. package/dist/registries/capabilityContract.js.map +1 -0
  206. package/dist/registries/packageRegistry.js +641 -0
  207. package/dist/registries/packageRegistry.js.map +1 -0
  208. package/dist/registries/runtimeAdapterRegistry.js +315 -0
  209. package/dist/registries/runtimeAdapterRegistry.js.map +1 -0
  210. package/dist/setup/codex.js +1056 -0
  211. package/dist/setup/codex.js.map +1 -0
  212. package/dist/setup/copilot.js +227 -0
  213. package/dist/setup/copilot.js.map +1 -0
  214. package/dist/setup/cursor.js +127 -0
  215. package/dist/setup/cursor.js.map +1 -0
  216. package/dist/setup/doctor.js +1276 -0
  217. package/dist/setup/doctor.js.map +1 -0
  218. package/dist/state/installRoot.js +279 -0
  219. package/dist/state/installRoot.js.map +1 -0
  220. package/dist/state/progressCommit.js +289 -0
  221. package/dist/state/progressCommit.js.map +1 -0
  222. package/dist/state/startupAnalysis.js +1953 -0
  223. package/dist/state/startupAnalysis.js.map +1 -0
  224. package/dist/upgrade/appModel.js +189 -0
  225. package/dist/upgrade/appModel.js.map +1 -0
  226. package/dist/upgrade/channels.js +208 -0
  227. package/dist/upgrade/channels.js.map +1 -0
  228. package/dist/upgrade/compatibility.js +201 -0
  229. package/dist/upgrade/compatibility.js.map +1 -0
  230. package/dist/upgrade/doctor.js +373 -0
  231. package/dist/upgrade/doctor.js.map +1 -0
  232. package/dist/upgrade/migrateArtifactsV2ToV3.js +332 -0
  233. package/dist/upgrade/migrateArtifactsV2ToV3.js.map +1 -0
  234. package/dist/upgrade/runtimeMigration.js +484 -0
  235. package/dist/upgrade/runtimeMigration.js.map +1 -0
  236. package/dist/upgrade/upgradeCommands.js +36 -0
  237. package/dist/upgrade/upgradeCommands.js.map +1 -0
  238. package/dist/upgrade/upgradeOrchestrator.js +299 -0
  239. package/dist/upgrade/upgradeOrchestrator.js.map +1 -0
  240. package/dist/upgrade/versionResolution.js +179 -0
  241. package/dist/upgrade/versionResolution.js.map +1 -0
  242. package/dist/validate/appHomeContract.js +150 -0
  243. package/dist/validate/appHomeContract.js.map +1 -0
  244. package/dist/validate/capability.js +412 -0
  245. package/dist/validate/capability.js.map +1 -0
  246. package/dist/validate/crossCapability.js +145 -0
  247. package/dist/validate/crossCapability.js.map +1 -0
  248. package/dist/validate/lifecycleAdapters.js +772 -0
  249. package/dist/validate/lifecycleAdapters.js.map +1 -0
  250. package/dist/validate/selfAudit.js +107 -0
  251. package/dist/validate/selfAudit.js.map +1 -0
  252. package/package.json +28 -8
  253. package/LICENSE +0 -201
  254. package/bin/agentera.mjs +0 -50
  255. package/lib/exec.mjs +0 -116
  256. package/lib/resolve.mjs +0 -129
@@ -0,0 +1,47 @@
1
+ # v1-to-v2 Section Mapping
2
+
3
+ Maps every behavioral section in the 12 v1 SKILL.md files to the v2 capability schema groups.
4
+ No unmappable content.
5
+
6
+ ## Mapping Table
7
+
8
+ | v1 Section | v2 Target | Rationale |
9
+ |---|---|---|
10
+ | Frontmatter: `name`, `description` | `instructions.md` (header) + `TRIGGERS` group | Name is prose identity. Description is prose metadata. Trigger patterns extracted to TRIGGERS entries. |
11
+ | Frontmatter: `spec_sections` | Dropped | SPEC.md dissolves into per-capability schemas (ROADMAP: "Spec dissolves into schemas"). No central spec to reference. |
12
+ | `## State artifacts` (artifact list) | `ARTIFACTS` group | Each consumed/produced artifact becomes an ARTIFACTS entry with stable ID. |
13
+ | `### Artifact path resolution` | `ARTIFACTS` group (path metadata) | Path resolution rules become path field metadata on artifact entries. |
14
+ | `### Contract` (inlined values) | `VALIDATION` group + `protocol.yaml` | Inlined contract values (severity arrows, trend arrows, glyphs, token budgets) become shared protocol primitives referenced by VALIDATION entries. |
15
+ | `references/contract.md` | `protocol.yaml` | Centralized contract reference replaced by shared protocol schema. |
16
+ | `## Step N: ...` (workflow steps) | `instructions.md` | Behavioral instructions the agent reads. Steps remain prose. |
17
+ | `## Brainstorm: ...` (sub-workflows) | `instructions.md` | Interactive sub-workflows are behavioral instructions. |
18
+ | `## Personality` / `## Interaction rules` | `instructions.md` | Personality and interaction rules are agent-facing behavioral guidance. |
19
+ | `## Safety rails` | `VALIDATION` group | Each safety rail becomes a VALIDATION entry with rule, severity, and checks. |
20
+ | `## Exit signals` | `EXIT_CONDITIONS` group | Each exit signal becomes an EXIT_CONDITIONS entry with condition, description, and exit_code. |
21
+ | `## Cross-skill integration` | `ARTIFACTS` group (cross-capability refs) + `instructions.md` | Cross-skill dependencies become ARTIFACTS entries with cross-capability ID references. Integration guidance stays in prose. |
22
+ | `## Getting started` | `instructions.md` | First-run guidance is behavioral instruction. |
23
+ | `references/templates/` | `instructions.md` (embedded or referenced) | Templates are part of the capability's behavioral instructions. |
24
+ | `scripts/` (Python helpers) | Kept at repo level or capability-local | Scripts are tooling, not behavioral. Location unchanged for v2. |
25
+
26
+ ## Per-Skill Coverage
27
+
28
+ Every section found in each v1 SKILL.md is covered by the mapping above. Verification:
29
+
30
+ | Skill | Sections | All Mapped? |
31
+ |---|---|---|
32
+ | dokumentera | State artifacts, Contract, Conventions, Artifact Mapping, Index, Steps 0, First-run, Intent-first, Explore-and-generate, Update-and-verify, Safety rails, Exit signals, Cross-skill, Getting started | Yes |
33
+ | hej | State artifacts, Contract, Steps 0-2 (Detect, Welcome, Briefing, Route), Safety rails, Exit signals, Cross-skill, Getting started | Yes |
34
+ | inspektera | State artifacts, Contract, Audit template, Steps 1-7, Dimensions, Evidence, Confidence, Findings, Safety rails, Exit signals, Cross-skill, Getting started | Yes |
35
+ | inspirera | Steps 1-5, Source overview, Concepts, Applicability, Next steps, Exit signals, State artifacts, Cross-skill, Safety rails, Getting started, Notes on depth | Yes |
36
+ | optimera | State artifacts, Objective template, Experiment template, Closure template, Brainstorm, Cycle, Hypothesis, Constraints, Safety rails, Blocked handling, Exit signals, Cross-skill, Getting started | Yes |
37
+ | orkestrera | State artifacts, Personality, Conductor protocol, Task template, Acceptance template, Context, Verification, Output format, Lean conductor, Safety rails, Exit signals, Cross-skill, Getting started | Yes |
38
+ | planera | State artifacts, Contract, Steps 0-6, Plan template (quick + full), Acceptance criteria, Handoff, How realisera reads PLAN, Safety rails, Exit signals, Cross-skill, Getting started | Yes |
39
+ | profilera | State artifacts, Steps 0, Full mode, Profile template, Validate mode, Safety rails, Exit signals, Cross-skill, Getting started, Notes on depth | Yes |
40
+ | realisera | State artifacts, Contract, VISION template, PROGRESS template, TODO template, CHANGELOG template, Brainstorm, Cycle, Task, Constraints, Safety rails, Blocked handling, Exit signals, Cross-skill | Yes |
41
+ | resonera | State artifacts, Decision template, Personality, Interaction rules, Starting a session, Running state, Good questions, Done handling, Safety rails, Exit signals, Cross-skill, Getting started | Yes |
42
+ | visionera | State artifacts, Contract, VISION template, Steps 0, Create mode, Refine mode, Safety rails, Exit signals, Cross-skill, Getting started | Yes |
43
+ | visualisera | State artifacts, Contract, Design template, Steps 0, Create, Refine, Audit modes, Safety rails, Exit signals, Cross-skill, Getting started | Yes |
44
+
45
+ ## Unmappable Content
46
+
47
+ None. Every section in every v1 SKILL.md maps to one of: `instructions.md`, `TRIGGERS`, `ARTIFACTS`, `VALIDATION`, `EXIT_CONDITIONS`, or `protocol.yaml` (shared primitives extracted from Contract sections).
@@ -0,0 +1,39 @@
1
+ {
2
+ "$schema": "https://json-schema.org/draft/2020-12/schema",
3
+ "version": "1",
4
+ "skills": [
5
+ {
6
+ "name": "agentera",
7
+ "version": "2.7.6",
8
+ "description": "Compound agent orchestration suite — 12 capabilities in one bundled skill; exact bare hej uses the Agentera dashboard path",
9
+ "path": "skills/agentera",
10
+ "capabilities": [
11
+ "hej",
12
+ "realisera",
13
+ "resonera",
14
+ "planera",
15
+ "inspektera",
16
+ "optimera",
17
+ "orkestrera",
18
+ "visionera",
19
+ "visualisera",
20
+ "dokumentera",
21
+ "profilera",
22
+ "inspirera"
23
+ ],
24
+ "tags": [
25
+ "orchestration",
26
+ "autonomous",
27
+ "planning",
28
+ "optimization",
29
+ "audit",
30
+ "documentation",
31
+ "vision",
32
+ "research",
33
+ "deliberation",
34
+ "design"
35
+ ],
36
+ "added": "2026-05-04"
37
+ }
38
+ ]
39
+ }
@@ -0,0 +1,27 @@
1
+ {
2
+ "name": "agentera",
3
+ "version": "2.0.3",
4
+ "description": "The open protocol for turning AI agents into engineering teams. One bundled skill with twelve capabilities. Use for /agentera and for a complete user message exactly `hej`; bare `hej` runs the Agentera dashboard path.",
5
+ "author": {
6
+ "name": "jgabor"
7
+ },
8
+ "agentera": {
9
+ "packageShape": "bundled-skill",
10
+ "capabilities": [
11
+ "hej",
12
+ "visionera",
13
+ "resonera",
14
+ "inspirera",
15
+ "planera",
16
+ "realisera",
17
+ "optimera",
18
+ "inspektera",
19
+ "dokumentera",
20
+ "profilera",
21
+ "visualisera",
22
+ "orkestrera"
23
+ ],
24
+ "schemas": "schemas",
25
+ "protocol": "protocol.yaml"
26
+ }
27
+ }
@@ -0,0 +1,470 @@
1
+ ---
2
+ name: agentera
3
+ description: >
4
+ The open protocol for turning AI agents into engineering teams.
5
+ One Agentera skill with twelve capabilities, each defined by human-readable
6
+ prose and machine-readable schemas. The agent reads this file to route
7
+ incoming requests to the right capability. Use this skill for /agentera,
8
+ Agentera capability requests, and a complete user message exactly `hej`;
9
+ bare `hej` runs the agentera prime orientation dashboard path instead of a generic greeting.
10
+ version: "2.7.6"
11
+ spec_sections: [1, 2, 3, 4, 5, 6, 11, 13, 18, 19, 20, 22, 23]
12
+ ---
13
+
14
+ # agentera
15
+
16
+ One install, one entry point, one query interface to all project state. Twelve capabilities live inside one Agentera skill.
17
+
18
+ ---
19
+
20
+ ## Shared Protocol
21
+
22
+ All capabilities reference shared primitives defined in `protocol.yaml`:
23
+
24
+ - **Confidence scale**: 0-100, five tiers with explicit boundaries
25
+ - **Severity levels**: finding vocabulary and issue vocabulary
26
+ - **Visual tokens**: status, severity, confidence, and trend glyphs
27
+ - **Phase model**: five phases with valid transitions
28
+
29
+ Capabilities import these by name. The schema contract ensures consistent usage.
30
+
31
+ ---
32
+
33
+ ## Capabilities
34
+
35
+ | | Capability | Primary route | Purpose |
36
+ |---|---|---|---|
37
+ | ⌂ | hej | `/agentera status` | Orientation and routing |
38
+ | ⛥ | visionera | `/agentera vision` | Define project direction |
39
+ | ❈ | resonera | `/agentera discuss` | Structured deliberation |
40
+ | ⬚ | inspirera | `/agentera research` | External pattern analysis |
41
+ | ≡ | planera | `/agentera plan` | Planning with acceptance criteria |
42
+ | ⧉ | realisera | `/agentera build` | Autonomous development |
43
+ | ⎘ | optimera | `/agentera optimize` | Metric-driven optimization |
44
+ | ⛶ | inspektera | `/agentera audit` | Codebase health audit |
45
+ | ▤ | dokumentera | `/agentera document` | Documentation |
46
+ | ♾ | profilera | `/agentera profile` | Decision profiling |
47
+ | ◰ | visualisera | `/agentera design` | Visual identity system |
48
+ | ⎈ | orkestrera | `/agentera orchestrate` | Multi-cycle orchestration |
49
+
50
+ ---
51
+
52
+ ## Routing Logic
53
+
54
+ When a request arrives, route to the matching capability using the five-layer routing model from Decision 42.
55
+
56
+ ### Prerequisite: Single-call installed CLI gate
57
+
58
+ This gate is mandatory, but the gate and the orientation dashboard source are the same
59
+ installed CLI invocation. For bare `/agentera` or bare `hej`, the first normal
60
+ state-access tool call is:
61
+
62
+ ```bash
63
+ npx -y agentera prime
64
+ ```
65
+
66
+ Resolve `RESOLVED_AGENTERA_HOME` with the app-home precedence `AGENTERA_HOME`
67
+ when set, otherwise the platform data home. Do not run `glob`, `grep`, `read`,
68
+ `ls`, `python`, `doctor`, `--help`, `registry.json`,
69
+ or `.agentera-bundle.json` preflight checks before this call. The CLI owns app
70
+ validation, v1 detection, profile detection, artifact condensation, and the
71
+ `source_contract` that tells the caller how to render the dashboard.
72
+ Never combine the app-home assignment with the same shell command that expands
73
+ the managed app script path; shell expansion can otherwise turn an unset
74
+ `AGENTERA_HOME` into `npx -y agentera` before the assignment takes effect.
75
+
76
+ If the command exits successfully, inspect the CLI-provided `bundle.status`
77
+ installed-app status object. If its value is `fresh`, treat the installed app gate as passed
78
+ for that briefing and render from the output. The object includes
79
+ `expectedVersion`, `expectedVersionSource`, `appHome`, `managedAppRoot`,
80
+ `userDataRoot`, repair commands, and approval text.
81
+
82
+ ### User-facing repair wording
83
+
84
+ Recovery and troubleshooting prompts must be plain enough for a non-technical
85
+ user. Never ask the user to choose between technical install concepts, internal
86
+ directory states, command-mode flags, or package-layout terms. Keep those as
87
+ internal facts.
88
+ User-facing copy must answer four questions in this order:
89
+
90
+ 1. What happened: `Agentera found an old or broken local copy of itself.`
91
+ 2. What the preview did: `Nothing was changed.`
92
+ 3. What the recommended fix will do: `Install a fresh Agentera app copy in the normal Agentera directory.`
93
+ 4. What it will not do: `It will not edit your project files, shell startup files, or unknown directories.`
94
+
95
+ Use recommendation-first choices only when a choice is unavoidable. Put the safe
96
+ default first and name it as the recommendation. Good labels: `Use the safe fix
97
+ (Recommended)`, `Choose a different directory`, `Stop`. Bad labels: `Use platform
98
+ home`, `Force old directory`, or labels that expose internal flags and app-file
99
+ packaging terms.
100
+ Only mention commands and paths after the plain explanation, as technical detail.
101
+
102
+ If the command cannot execute because `AGENTERA_HOME` names the old default
103
+ `$HOME/.agents/agentera` and `npx -y agentera` is missing,
104
+ do not require a successful failed CLI invocation and do not first ask the user to
105
+ unset `AGENTERA_HOME`. Tell the user: `Agentera found an old or broken local copy
106
+ of itself. The safe fix is to install a fresh copy in the normal Agentera directory.`
107
+ Then show this preview command and say it changes nothing:
108
+
109
+ ```bash
110
+ npx -y agentera@latest doctor
111
+ ```
112
+
113
+ This preview writes nothing. Because no explicit `--install-root` is supplied,
114
+ upgrade can choose the normal platform app directory and preview repair for app
115
+ files, managed runtime surfaces, and cleanup of the old directory. Ask for
116
+ explicit approval before writes, using plain wording such as
117
+ `Approve the safe Agentera repair at <directory>`. After approval, apply the same
118
+ safe repair path:
119
+
120
+ ```bash
121
+ npx -y agentera@latest prime
122
+ ```
123
+
124
+ After apply, retry the installed command from the platform app home reported by
125
+ the upgrade output, not from the old default directory. If the command executes but
126
+ fails before argparse, reports `invalid choice` for `prime`, or reports a status of
127
+ `outdated`, `manual_review_needed`, missing-command, or repair-needed:
128
+
129
+ - Say `Agentera found an old or broken local copy of itself.`
130
+ - Say whether the preview changed anything; preview commands change nothing.
131
+ - State the safe recommendation in plain language before paths or commands.
132
+ - Show the clone-free preview command from `bundle.dryRunCommand` when present:
133
+
134
+ ```bash
135
+ npx -y agentera@latest doctor
136
+ ```
137
+
138
+ Ask for explicit approval before writes. A normal affirmative response is
139
+ acceptable only when it clearly authorizes the same Agentera repair and directory.
140
+ If approved, apply:
141
+
142
+ ```bash
143
+ npx -y agentera@latest prime
144
+ ```
145
+
146
+ After apply, retry:
147
+
148
+ ```bash
149
+ npx -y agentera prime
150
+ ```
151
+
152
+ If `AGENTERA_HOME` names the old default `$HOME/.agents/agentera`, no explicit
153
+ `--install-root` was supplied, and `npx -y agentera` is
154
+ missing or out of date, treat this as safe to preview with the normal Agentera
155
+ directory above. Do not first ask the user to unset `AGENTERA_HOME`; do not claim to
156
+ prove where the environment value came from. If `AGENTERA_HOME` names any other
157
+ missing path, file, or directory with unknown files and the single command cannot
158
+ run, do not overwrite it silently or fall back to a local checkout. Say:
159
+ `Agentera was told to use a directory it cannot safely use. Choose a different
160
+ Agentera directory, or approve --force only after checking that directory is safe to
161
+ replace.`
162
+
163
+ If a leftover 1.x managed marker block (`# agentera: AGENTERA_HOME (managed)`) is
164
+ reported in shell startup diagnostics, say plainly that Agentera will not edit
165
+ those files. Cleanup is user-owned manual cleanup, not a repair write. Upgrade
166
+ does not scan shell startup files.
167
+
168
+ Only after the installed CLI succeeds, proceed to Step -1 and the routing layers
169
+ below. Do not fall through to a local checkout as a workaround; the npx commands
170
+ above are portable and require no local checkout.
171
+
172
+ ### Step -1: Top-level CLI-first state access
173
+
174
+ The `agentera` CLI is the authoritative interface to project state. Use
175
+ top-level state commands for routine access. `agentera query` is reserved for
176
+ advanced/custom artifact inspection when no normal command serves the needed
177
+ state.
178
+
179
+ Before any artifact-backed briefing, route decision, or capability state read,
180
+ run the top-level command that owns the needed state. The app health gate
181
+ above must have already confirmed the installed CLI is usable.
182
+
183
+ Routine commands are: `prime`, `state plan`, `state progress`, `state health`,
184
+ `state todo`, `state decisions`, `state docs`, `state objective`, and
185
+ `state experiments`. Top-level aliases for legacy commands remain during migration with stderr deprecation; see [audience-namespace-cli-migration.yaml](references/cli/audience-namespace-cli-migration.yaml) for the full list. Discovery and custom
186
+ inspection remain available through `agentera schema --format json`
187
+ (with legacy `describe` alias),
188
+ `state query --list-artifacts`, and `state query <artifact-name> --format json|yaml`.
189
+ Structured discovery includes an artifact-location contract with mapped paths,
190
+ normal read commands, and raw-access boundaries; use that contract before
191
+ reading `.agentera/docs.yaml` or probing `.agentera/` for path discovery.
192
+
193
+ Do not silently bypass the CLI and read raw `.agentera/*.yaml` files first. If
194
+ CLI state declares complete startup coverage, do not perform defensive raw
195
+ artifact reads for normal startup. If CLI state is unavailable or incomplete,
196
+ try the CLI-provided fallback commands first; use raw artifact reads only as a
197
+ last-resort fallback after those paths fail or still declare incomplete state.
198
+ When `agentera state plan --format json` returns
199
+ `source_contract.complete_for_plan_artifact=true`, treat its `summary`,
200
+ `entries`, and `source_contract` as complete for normal `PLAN.md` startup and
201
+ evaluation context; do not read `.agentera/plan.yaml` merely to re-check task
202
+ dependencies, acceptance criteria, evidence, overall acceptance, surprises,
203
+ prior-plan archive references, or plan metadata. This no-raw-read rule is for
204
+ normal read-only startup/evaluation. Raw mapped plan artifact access remains valid
205
+ for writes, archives, validation, corruption diagnostics, or unavailable or
206
+ incomplete CLI state after CLI fallbacks.
207
+
208
+ When artifact paths are the only missing fact, prefer the CLI discovery contract:
209
+ `agentera schema --format json` exposes `artifact_locations`, and
210
+ `agentera state query --list-artifacts --format json` exposes the same compact records
211
+ with a `names` compatibility list. Plain `state query --list-artifacts` remains the
212
+ human names list. These discovery surfaces do not replace routine state commands
213
+ for normal artifact content reads.
214
+
215
+ For bare `/agentera` or a bare user message exactly `hej`, run `agentera prime`
216
+ first and render the README-style hej dashboard from that single composite
217
+ result. The CLI output is source data, not the user-facing dashboard; do not
218
+ relay raw `agentera prime` lines as the final briefing. Do not run individual `state plan`, `state progress`, `state health`,
219
+ `state todo`, or `state decisions` commands unless `agentera prime` fails or explicitly asks
220
+ for fallback. The final response must
221
+ transform source labels such as `mode:`, `profile:`, `health:`, `issues:`,
222
+ `plan:`, `objective:`, `attention:`, `next_action:`, `app_home:`,
223
+ `v1_migration:`, and `source_contract:` into the dashboard below; never paste
224
+ those labels as the briefing.
225
+
226
+ Bare `/agentera` returning-project output must include these visible markers:
227
+
228
+ ```text
229
+ ┌─┐┌─┐┌─┐┌┐┌┌┬┐┌─┐┬─┐┌─┐
230
+ ├─┤│ ┬├┤ │││ │ ├┤ ├┬┘├─┤
231
+ ┴ ┴└─┘└─┘┘└┘ ┴ └─┘┴└─┴ ┴
232
+
233
+ ─── status ─────────────────────────────
234
+ [metric lines: health, issues, plan, objective, profile as available]
235
+ [1-2 sentence narrative read closing the status section]
236
+ ─── attention ──────────────────────────
237
+ ─── next ───────────────────────────────
238
+ ```
239
+
240
+ Use the README-style layout from hej Step 1b: metrics first, narrative read
241
+ inside `status`, then attention and next. The issues summary line uses
242
+ `critical · degraded · annoying` only. Omit `attention` only when the source has no attention items. Always include the
243
+ mandatory `⌂ hej · <status>` marker below the dashboard code fence, and ask for
244
+ confirmation before invoking the suggested downstream capability. For
245
+ `/agentera <capability-name>` or `/agentera <alias>`, do not assume the route
246
+ word is a CLI command. The CLI command surface is state-oriented, not
247
+ capability-oriented:
248
+ use the supported routine state command or commands that own the capability's
249
+ needed artifacts, as declared by that capability's artifact schema. For example,
250
+ `resonera` reads decisions through `agentera state decisions`, not through the
251
+ unsupported capability-name command `agentera resonera`. Never run unsupported
252
+ capability-name commands such as `agentera resonera`, `agentera planera`, or
253
+ `agentera realisera` as a bootstrap step. Shared words stay split by interface:
254
+ `/agentera plan` routes to planera, while `agentera state plan` reads plan state from
255
+ the CLI. When capability-specific startup context is needed, request it through
256
+ `agentera prime --context <capability> --format json`. Use returned
257
+ `capability_context.state.included` directly, and for
258
+ `capability_context.state.missing`, run the listed
259
+ `capability_context.state.fallback_commands` before raw file access. Historical
260
+ v2 paths `hej --capability-context` and `--context-profile` are removed in 3.0.
261
+ For normal ≡ planera execution, use
262
+ `capability_context.context.planning_context.startup_contract` from
263
+ `agentera prime --context planera --format json`
264
+ before reading `skills/agentera/capabilities/planera/instructions.md`. Read Planera prose only when
265
+ editing Planera, resolving contradiction or ambiguity, validating detailed
266
+ behavior not covered by the compact contract, or investigating benchmark/read-trigger
267
+ evidence. This preserves Planera prose as detailed authority and does not add
268
+ `agentera planera`; `/agentera plan` remains routing while `agentera state plan`
269
+ remains plan state (top-level `agentera plan` is a migration alias).
270
+ For normal DECISIONS.md context, use `agentera state decisions --format json` and its
271
+ source_contract. When `complete_for_normal_deliberation_context=true`, preserve
272
+ returned `missing_fields`, `compacted`, `caveats`, and `satisfaction.review_needed`
273
+ instead of raw-reading `.agentera/decisions.yaml` to reconstruct missing history.
274
+ Raw decision artifact access is reserved for Resonera-owned writes/repairs,
275
+ artifact corruption diagnostics, or CLI defect investigation.
276
+ Reading a capability's `instructions.md` file is not itself a capability invocation;
277
+ invocation means routing to the capability, following its prose, and using the
278
+ CLI state layer first for artifact-backed state.
279
+
280
+ Capability handoffs use glyph plus canonical capability name, for example
281
+ `⧉ realisera` or `≡ planera`. Reserve `/agentera <alias>` wording for explicit
282
+ slash-route documentation and do not use standalone slash-capability names such
283
+ as `/realisera` or `/planera` as handoff labels. SG priority codes such as `SG2`
284
+ are internal protocol references; do not render them in user-facing handoff
285
+ labels.
286
+
287
+ Handoff verbs are normative:
288
+
289
+ - `route`: the user directly invoked a capability by canonical name, primary
290
+ alias, or slash route. This is consent to invoke that capability; do not ask
291
+ for extra handoff confirmation.
292
+ - `suggest`: recommend a downstream capability and wait for user confirmation.
293
+ - `handoff prompt`: ask whether to run the suggested capability. Use the native
294
+ question tool for multi-choice prompts and for a single state-changing
295
+ Proceed/Cancel handoff. State-changing means the proposed next step may write
296
+ artifacts, edit code, run optimization or orchestration cycles, apply
297
+ migrations, refresh app/runtime state, or otherwise mutate project/runtime
298
+ state. Use the behavior rule first, with common examples such as ⧉ realisera,
299
+ ≡ planera when creating or updating plans, ▤ dokumentera when writing docs,
300
+ ⎘ optimera when running or applying optimization cycles, and ⎈ orkestrera
301
+ when dispatching cycles. A single non-mutating suggestion may use a free-form
302
+ prompt; clear replies such as `yes`, `start`, `do it`, or `run <capability>`
303
+ confirm the named suggestion. Ambiguous replies get one clarifying question.
304
+ - `dispatch`: invoke another capability autonomously only when the current
305
+ capability explicitly owns that orchestration flow.
306
+ - `chain`: dispatch multiple capabilities autonomously only inside an explicitly
307
+ orchestrated flow; otherwise suggest the next capability and wait.
308
+
309
+ The first Agentera/hej response in a fresh interaction should deliver the brief
310
+ and a free-form continuation prompt, not a native question menu, unless the user
311
+ explicitly asks for bounded choices or the suggested next step is a
312
+ state-changing Proceed/Cancel handoff. Mid-conversation, use the runtime's
313
+ native question tool only when there are at least two meaningful non-terminal
314
+ next actions or a consequential Proceed/Cancel decision; state-changing
315
+ capability handoffs are consequential Proceed/Cancel decisions even when there
316
+ is only one suggested action. Do not count `Done` or free-form/custom answer
317
+ affordances as alternatives. Current host examples are Claude Code
318
+ `AskUserQuestion`, Copilot `ask_user`, Codex `request_user_input`, and OpenCode
319
+ `question`. Put the recommended choice first with `(Recommended)` in its label
320
+ and include `Done`. Selecting a downstream capability option is confirmation to
321
+ invoke that capability; selecting `Done` stops without routing. This generic
322
+ question-tool gating applies to hej and capability handoff prompts. Once a
323
+ capability is invoked, that capability's own interaction rules control whether
324
+ the runtime-native question tool is required.
325
+
326
+ ### Step 0: V1 migration handling
327
+
328
+ Do not perform separate v1 Markdown/YAML discovery before a normal prime briefing.
329
+ The top-level CLI owns v1 detection. For bare `/agentera` or bare `hej`, render
330
+ any `v1 artifacts detected` attention item and affected-file list from
331
+ `agentera prime`; do not spend extra tool calls on `.agentera/*.md`,
332
+ `.agentera/*.yaml`, or `VISION.md` globs.
333
+
334
+ If the CLI reports v1 state, use the `v1_migration.dry_run_command` preview it
335
+ supplies. A no-write preview is mandatory before any apply command. Tell the
336
+ user the preview changes nothing, then ask before applying. Only after
337
+ confirmation, run `v1_migration.apply_command`.
338
+ Never infer consent from the presence of v1 artifacts.
339
+ The preview command shape is
340
+ `npx -y agentera@latest doctor`
341
+ or, from a local checkout, `node packages/cli/dist/bin/agentera.js doctor`
342
+ when supplied by the CLI.
343
+ Do not replace the CLI-owned preview with manual artifact inspection,
344
+ hand-written migration steps, or raw YAML reads. Only the apply step requires confirmation.
345
+
346
+ The upgrade command is idempotent. It installs or updates Agentera app files
347
+ when invoked through `uvx`, migrates v1 artifacts, wires runtime config to that
348
+ app home, and removes fixable outdated v1 runtime artifacts.
349
+ The artifacts phase migrates supported v1 Markdown files to YAML with backups
350
+ after preview and confirmation. Package refreshes that run `npx skills remove`
351
+ for v1 skill entries and `npx skills add` for `/agentera` remain explicit opt-in
352
+ via `--update-packages`. `npx skills update` by itself updates only the visible
353
+ skill; if `/agentera` then finds missing or out-of-date app files, run the
354
+ plain-language repair preview above so upgrade updates the app and cleans up
355
+ the old default directory when it is recoverable.
356
+
357
+ ### Layer 1: Bare `/agentera` or bare `hej` — delegate to prime
358
+
359
+ If the request is `/agentera` with no additional text, or the complete user
360
+ message is exactly `hej`, delegate immediately to hej. Hej performs state-aware
361
+ routing through the `agentera prime` composite result, which condenses project
362
+ artifacts and suggests the most useful next capability. This is deterministic
363
+ and never wrong. Bare `hej` must not be handled as a generic greeting.
364
+
365
+ ### Layer 2: capability name or `/agentera <primary-alias>` — direct route
366
+
367
+ If the request text exactly matches a capability name (case-insensitive, e.g.,
368
+ "resonera", "planera", "hej"), route directly to that capability without
369
+ evaluating natural-language trigger patterns. Canonical Swedish names remain the
370
+ protocol identity and bypass natural-language matching.
371
+
372
+ If the request begins with a canonical capability name followed by more text, or
373
+ uses `/agentera <capability-name> <topic>`, route directly to that capability and
374
+ pass the remaining text as the user's topic or instruction. For example,
375
+ `resonera decide whether to keep this API` invokes ❈ resonera; it must not
376
+ receive a generic analysis response and must not try the unsupported CLI command
377
+ `agentera resonera`.
378
+
379
+ If the request text exactly matches one primary alias from
380
+ `capability_schema_contract.yaml` `ROUTE_ALIASES.primary_aliases`, route directly
381
+ to that alias's capability without evaluating natural-language trigger patterns.
382
+ Each capability has exactly one primary alias. Secondary user wording stays in
383
+ capability trigger schemas below this layer. Examples: `deliberate`,
384
+ `brainstorm`, and `rubber duck` remain resonera trigger wording; `brief` and
385
+ `what's next` remain hej trigger wording. These are not primary aliases.
386
+
387
+ ### Layer 3: Natural language with high-confidence match
388
+
389
+ If the request is natural language (e.g., "help me think through this"), evaluate capability trigger schemas and route when the schema-owned semantics produce a high-confidence match.
390
+
391
+ ### Layer 4: Borderline match — disambiguation
392
+
393
+ If the schema-owned routing semantics produce competing borderline matches, present a disambiguation prompt instead of silently choosing. List the matching capabilities with brief descriptions and ask the user to confirm or clarify.
394
+
395
+ ### Layer 5: No match — fallback to hej
396
+
397
+ If no capability matches with sufficient confidence, route to hej for orientation. Hej handles greetings, status requests, and ambiguous inputs.
398
+
399
+ ### Trigger Pattern Discovery
400
+
401
+ The trigger-to-capability map for Layers 3-4 is derived from each capability's `schemas/triggers.yaml`, not hardcoded here. Pattern matching, priority, thresholds, fallback, and disambiguation metadata belong to those trigger schemas and the capability schema contract. This keeps the routing layer focused on request-to-capability routing; capability directories and schemas remain the detailed Interface sources.
402
+
403
+ ---
404
+
405
+ ## Safety rails
406
+
407
+ <critical>
408
+ - NEVER push to remote repos without explicit user instruction
409
+ - NEVER modify `.agentera/vision.yaml` or objective state during execution cycles (only the user or the owning capability may change these)
410
+ - NEVER commit secrets or credentials to any artifact or file
411
+ - Respect artifact path resolution: check `.agentera/docs.yaml` for path overrides before accessing any agent-facing artifact
412
+ </critical>
413
+
414
+ ---
415
+
416
+ ## Exit signals
417
+
418
+ All capabilities use the exit vocabulary defined by `protocol.yaml` `EXIT_SIGNALS`. Capability `schemas/exit.yaml` files reference that protocol authority; the routing layer does not maintain a separate exit-signal table.
419
+
420
+ ---
421
+
422
+ ## Cross-skill integration
423
+
424
+ The twelve-skill suite is collapsed into one Agentera skill. Each capability's schemas define cross-capability artifact references using stable IDs. Cross-capability routing is handled through capability trigger schemas described in the Routing Logic section. Capabilities read from and write to the same artifact store (`.agentera/` for agent-facing, project root for human-facing), so inter-capability data flows through shared artifacts, not direct invocation.
425
+
426
+ ### Artifact path resolution
427
+
428
+ Before reading or writing any artifact, check if `.agentera/docs.yaml` exists. If it has an Artifact Mapping section, use the path specified for each canonical filename. If `.agentera/docs.yaml` doesn't exist or has no mapping for a given artifact, use the default layout:
429
+
430
+ - Human-facing artifacts at the project root: `TODO.md`, `CHANGELOG.md`, `DESIGN.md`
431
+ - Agent-facing artifacts in `.agentera/` as YAML: `progress.yaml`, `decisions.yaml`, `health.yaml`, `plan.yaml`, `docs.yaml`, `vision.yaml`, `objective.yaml`, `experiments.yaml`
432
+
433
+ ---
434
+
435
+ ## Directory Structure
436
+
437
+ ```
438
+ skills/agentera/
439
+ SKILL.md # This file
440
+ protocol.yaml # Shared primitives
441
+ capability_schema_contract.yaml # Self-referential schema contract
442
+ capabilities/
443
+ hej/
444
+ instructions.md
445
+ schemas/
446
+ triggers.yaml
447
+ artifacts.yaml
448
+ validation.yaml
449
+ exit.yaml
450
+ resonera/
451
+ instructions.md
452
+ schemas/
453
+ triggers.yaml
454
+ artifacts.yaml
455
+ validation.yaml
456
+ exit.yaml
457
+ ... (12 capabilities total)
458
+ ```
459
+
460
+ Validate any capability against the contract through the canonical CLI:
461
+
462
+ ```bash
463
+ npx -y agentera check validate capability <name-or-path>
464
+ ```
465
+
466
+ Self-validate the contract:
467
+
468
+ ```bash
469
+ npx -y agentera check validate capability-contract --format json
470
+ ```
@@ -0,0 +1,6 @@
1
+ # agentera_managed: true
2
+ name = "dokumentera"
3
+ description = "Documentation updates and synchronization."
4
+ developer_instructions = """
5
+ You are the Agentera dokumentera capability subagent. You have file write and file edit tools available to create or update files, but shell execution is disabled — do not attempt to run command line tools or scripts. Read the authoritative instructions at ${AGENTERA_HOME}/app/skills/agentera/capabilities/dokumentera/instructions.md when available. For local checkout development, use skills/agentera/capabilities/dokumentera/instructions.md under the active Agentera source root. Stay within the dispatched capability task, use the Agentera CLI state seam first, and preserve Agentera artifact safety rails.
6
+ """
@@ -0,0 +1,6 @@
1
+ # agentera_managed: true
2
+ name = "hej"
3
+ description = "Agentera orientation and routing dashboard."
4
+ developer_instructions = """
5
+ You are the Agentera hej capability subagent. You are a read-only agent — do not write files or execute shell commands. Read the authoritative instructions at ${AGENTERA_HOME}/app/skills/agentera/capabilities/hej/instructions.md when available. For local checkout development, use skills/agentera/capabilities/hej/instructions.md under the active Agentera source root. Stay within the dispatched capability task, use the Agentera CLI state seam first, and preserve Agentera artifact safety rails.
6
+ """
@@ -0,0 +1,6 @@
1
+ # agentera_managed: true
2
+ name = "inspektera"
3
+ description = "Codebase health audit."
4
+ developer_instructions = """
5
+ You are the Agentera inspektera capability subagent. You have file write and file edit tools available to create or update files, but shell execution is disabled — do not attempt to run command line tools or scripts. Read the authoritative instructions at ${AGENTERA_HOME}/app/skills/agentera/capabilities/inspektera/instructions.md when available. For local checkout development, use skills/agentera/capabilities/inspektera/instructions.md under the active Agentera source root. Stay within the dispatched capability task, use the Agentera CLI state seam first, and preserve Agentera artifact safety rails.
6
+ """
@@ -0,0 +1,6 @@
1
+ # agentera_managed: true
2
+ name = "inspirera"
3
+ description = "External pattern research and synthesis."
4
+ developer_instructions = """
5
+ You are the Agentera inspirera capability subagent. You are a read-only agent — do not write files or execute shell commands. Read the authoritative instructions at ${AGENTERA_HOME}/app/skills/agentera/capabilities/inspirera/instructions.md when available. For local checkout development, use skills/agentera/capabilities/inspirera/instructions.md under the active Agentera source root. Stay within the dispatched capability task, use the Agentera CLI state seam first, and preserve Agentera artifact safety rails.
6
+ """
@@ -0,0 +1,6 @@
1
+ # agentera_managed: true
2
+ name = "optimera"
3
+ description = "Metric-driven optimization cycles."
4
+ developer_instructions = """
5
+ You are the Agentera optimera capability subagent. You have full file write, file edit, and shell execution tools available — use them to implement code changes, run tests, and commit results. Read the authoritative instructions at ${AGENTERA_HOME}/app/skills/agentera/capabilities/optimera/instructions.md when available. For local checkout development, use skills/agentera/capabilities/optimera/instructions.md under the active Agentera source root. Stay within the dispatched capability task, use the Agentera CLI state seam first, and preserve Agentera artifact safety rails.
6
+ """
@@ -0,0 +1,6 @@
1
+ # agentera_managed: true
2
+ name = "orkestrera"
3
+ description = "Multi-cycle orchestration over active plans."
4
+ developer_instructions = """
5
+ You are the Agentera orkestrera capability subagent. You have full file write, file edit, and shell execution tools available — use them to implement code changes, run tests, and commit results. Read the authoritative instructions at ${AGENTERA_HOME}/app/skills/agentera/capabilities/orkestrera/instructions.md when available. For local checkout development, use skills/agentera/capabilities/orkestrera/instructions.md under the active Agentera source root. Stay within the dispatched capability task, use the Agentera CLI state seam first, and preserve Agentera artifact safety rails.
6
+ """
@@ -0,0 +1,6 @@
1
+ # agentera_managed: true
2
+ name = "planera"
3
+ description = "Planning with acceptance criteria."
4
+ developer_instructions = """
5
+ You are the Agentera planera capability subagent. You have file write and file edit tools available to create or update files, but shell execution is disabled — do not attempt to run command line tools or scripts. Read the authoritative instructions at ${AGENTERA_HOME}/app/skills/agentera/capabilities/planera/instructions.md when available. For local checkout development, use skills/agentera/capabilities/planera/instructions.md under the active Agentera source root. Stay within the dispatched capability task, use the Agentera CLI state seam first, and preserve Agentera artifact safety rails.
6
+ """
@@ -0,0 +1,6 @@
1
+ # agentera_managed: true
2
+ name = "profilera"
3
+ description = "Decision profiling and preference memory."
4
+ developer_instructions = """
5
+ You are the Agentera profilera capability subagent. You have full file write, file edit, and shell execution tools available — use them to implement code changes, run tests, and commit results. Read the authoritative instructions at ${AGENTERA_HOME}/app/skills/agentera/capabilities/profilera/instructions.md when available. For local checkout development, use skills/agentera/capabilities/profilera/instructions.md under the active Agentera source root. Stay within the dispatched capability task, use the Agentera CLI state seam first, and preserve Agentera artifact safety rails.
6
+ """