akm-cli 0.8.0-rc2 → 0.8.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 (295) hide show
  1. package/{.github/CHANGELOG.md → CHANGELOG.md} +191 -3
  2. package/README.md +22 -6
  3. package/SECURITY.md +93 -0
  4. package/dist/cli/config-migrate.js +144 -0
  5. package/dist/cli/config-validate.js +39 -0
  6. package/dist/cli/confirm.js +73 -0
  7. package/dist/cli/parse-args.js +93 -3
  8. package/dist/cli/shared.js +129 -0
  9. package/dist/cli.js +2141 -1268
  10. package/dist/commands/add-cli.js +279 -0
  11. package/dist/commands/agent-dispatch.js +20 -12
  12. package/dist/commands/agent-support.js +11 -5
  13. package/dist/commands/completions.js +3 -0
  14. package/dist/commands/config-cli.js +129 -517
  15. package/dist/commands/consolidate.js +1533 -144
  16. package/dist/commands/curate.js +44 -3
  17. package/dist/commands/db-cli.js +23 -0
  18. package/dist/commands/distill-promotion-policy.js +5 -3
  19. package/dist/commands/distill.js +906 -100
  20. package/dist/commands/env.js +213 -0
  21. package/dist/commands/eval-cases.js +3 -0
  22. package/dist/commands/events.js +3 -0
  23. package/dist/commands/extract-cli.js +127 -0
  24. package/dist/commands/extract-prompt.js +204 -0
  25. package/dist/commands/extract.js +477 -0
  26. package/dist/commands/feedback-cli.js +331 -0
  27. package/dist/commands/graph.js +260 -5
  28. package/dist/commands/health.js +977 -51
  29. package/dist/commands/help/help-accept.md +6 -3
  30. package/dist/commands/help/help-improve.md +36 -8
  31. package/dist/commands/help/help-proposals.md +7 -4
  32. package/dist/commands/help/help-reject.md +5 -2
  33. package/dist/commands/history.js +51 -16
  34. package/dist/commands/improve-auto-accept.js +97 -0
  35. package/dist/commands/improve-cli.js +236 -0
  36. package/dist/commands/improve-profiles.js +184 -0
  37. package/dist/commands/improve-result-file.js +167 -0
  38. package/dist/commands/improve.js +1725 -332
  39. package/dist/commands/info.js +3 -0
  40. package/dist/commands/init.js +49 -1
  41. package/dist/commands/installed-stashes.js +6 -23
  42. package/dist/commands/knowledge.js +3 -0
  43. package/dist/commands/lint/agent-linter.js +3 -0
  44. package/dist/commands/lint/base-linter.js +199 -5
  45. package/dist/commands/lint/command-linter.js +3 -0
  46. package/dist/commands/lint/default-linter.js +3 -0
  47. package/dist/commands/lint/env-key-rules.js +154 -0
  48. package/dist/commands/lint/index.js +92 -3
  49. package/dist/commands/lint/knowledge-linter.js +3 -0
  50. package/dist/commands/lint/markdown-insertion.js +343 -0
  51. package/dist/commands/lint/memory-linter.js +3 -0
  52. package/dist/commands/lint/registry.js +3 -0
  53. package/dist/commands/lint/skill-linter.js +3 -0
  54. package/dist/commands/lint/task-linter.js +15 -12
  55. package/dist/commands/lint/types.js +3 -0
  56. package/dist/commands/lint/workflow-linter.js +3 -0
  57. package/dist/commands/lint.js +3 -0
  58. package/dist/commands/migration-help.js +5 -2
  59. package/dist/commands/proposal-drain-policies.js +128 -0
  60. package/dist/commands/proposal-drain.js +477 -0
  61. package/dist/commands/proposal.js +60 -6
  62. package/dist/commands/propose.js +24 -19
  63. package/dist/commands/reflect.js +1004 -94
  64. package/dist/commands/registry-cli.js +150 -0
  65. package/dist/commands/registry-search.js +3 -0
  66. package/dist/commands/remember-cli.js +257 -0
  67. package/dist/commands/remember.js +15 -6
  68. package/dist/commands/schema-repair.js +88 -15
  69. package/dist/commands/search.js +99 -14
  70. package/dist/commands/secret.js +173 -0
  71. package/dist/commands/self-update.js +3 -0
  72. package/dist/commands/show.js +32 -13
  73. package/dist/commands/source-add.js +7 -35
  74. package/dist/commands/source-clone.js +3 -0
  75. package/dist/commands/source-manage.js +3 -0
  76. package/dist/commands/tasks.js +161 -95
  77. package/dist/commands/url-checker.js +3 -0
  78. package/dist/core/action-contributors.js +3 -0
  79. package/dist/core/asset-ref.js +13 -2
  80. package/dist/core/asset-registry.js +9 -2
  81. package/dist/core/asset-serialize.js +88 -0
  82. package/dist/core/asset-spec.js +61 -5
  83. package/dist/core/common.js +93 -5
  84. package/dist/core/concurrent.js +3 -0
  85. package/dist/core/config-io.js +347 -0
  86. package/dist/core/config-migration.js +622 -0
  87. package/dist/core/config-schema.js +558 -0
  88. package/dist/core/config-sources.js +108 -0
  89. package/dist/core/config-types.js +4 -0
  90. package/dist/core/config-walker.js +337 -0
  91. package/dist/core/config.js +366 -1077
  92. package/dist/core/errors.js +42 -20
  93. package/dist/core/events.js +31 -25
  94. package/dist/core/file-lock.js +104 -0
  95. package/dist/core/frontmatter.js +75 -10
  96. package/dist/core/lesson-lint.js +3 -0
  97. package/dist/core/markdown.js +3 -0
  98. package/dist/core/memory-belief.js +62 -0
  99. package/dist/core/memory-contradiction-detect.js +274 -0
  100. package/dist/core/memory-improve.js +142 -14
  101. package/dist/core/parse.js +3 -0
  102. package/dist/core/paths.js +218 -50
  103. package/dist/core/proposal-quality-validators.js +380 -0
  104. package/dist/core/proposal-validators.js +11 -3
  105. package/dist/core/proposals.js +464 -5
  106. package/dist/core/state-db.js +349 -56
  107. package/dist/core/text-truncation.js +107 -0
  108. package/dist/core/time.js +3 -0
  109. package/dist/core/tty.js +59 -0
  110. package/dist/core/warn.js +7 -2
  111. package/dist/core/write-source.js +12 -0
  112. package/dist/indexer/db-backup.js +391 -0
  113. package/dist/indexer/db-search.js +136 -28
  114. package/dist/indexer/db.js +661 -166
  115. package/dist/indexer/ensure-index.js +3 -0
  116. package/dist/indexer/file-context.js +3 -0
  117. package/dist/indexer/graph-boost.js +162 -40
  118. package/dist/indexer/graph-db.js +241 -51
  119. package/dist/indexer/graph-dedup.js +3 -7
  120. package/dist/indexer/graph-extraction.js +242 -149
  121. package/dist/indexer/index-context.js +3 -9
  122. package/dist/indexer/indexer.js +84 -14
  123. package/dist/indexer/llm-cache.js +24 -19
  124. package/dist/indexer/manifest.js +3 -0
  125. package/dist/indexer/matchers.js +184 -11
  126. package/dist/indexer/memory-inference.js +94 -50
  127. package/dist/indexer/metadata-contributors.js +3 -0
  128. package/dist/indexer/metadata.js +110 -50
  129. package/dist/indexer/path-resolver.js +3 -0
  130. package/dist/indexer/project-context.js +192 -0
  131. package/dist/indexer/ranking-contributors.js +134 -7
  132. package/dist/indexer/ranking.js +8 -1
  133. package/dist/indexer/search-fields.js +5 -9
  134. package/dist/indexer/search-hit-enrichers.js +91 -2
  135. package/dist/indexer/search-source.js +20 -1
  136. package/dist/indexer/semantic-status.js +4 -1
  137. package/dist/indexer/staleness-detect.js +447 -0
  138. package/dist/indexer/usage-events.js +12 -9
  139. package/dist/indexer/walker.js +3 -0
  140. package/dist/integrations/agent/builders.js +135 -0
  141. package/dist/integrations/agent/config.js +121 -401
  142. package/dist/integrations/agent/detect.js +3 -0
  143. package/dist/integrations/agent/index.js +6 -14
  144. package/dist/integrations/agent/model-aliases.js +55 -0
  145. package/dist/integrations/agent/profiles.js +3 -0
  146. package/dist/integrations/agent/prompts.js +137 -8
  147. package/dist/integrations/agent/runner.js +208 -0
  148. package/dist/integrations/agent/sdk-runner.js +8 -2
  149. package/dist/integrations/agent/spawn.js +54 -14
  150. package/dist/integrations/github.js +3 -0
  151. package/dist/integrations/lockfile.js +22 -51
  152. package/dist/integrations/session-logs/index.js +4 -0
  153. package/dist/integrations/session-logs/inline-refs.js +35 -0
  154. package/dist/integrations/session-logs/pre-filter.js +152 -0
  155. package/dist/integrations/session-logs/providers/claude-code.js +226 -0
  156. package/dist/integrations/session-logs/providers/opencode.js +231 -25
  157. package/dist/integrations/session-logs/types.js +3 -0
  158. package/dist/llm/call-ai.js +14 -26
  159. package/dist/llm/client.js +16 -2
  160. package/dist/llm/embedder.js +20 -29
  161. package/dist/llm/embedders/cache.js +3 -7
  162. package/dist/llm/embedders/local.js +42 -1
  163. package/dist/llm/embedders/remote.js +20 -8
  164. package/dist/llm/embedders/types.js +3 -7
  165. package/dist/llm/feature-gate.js +92 -56
  166. package/dist/llm/graph-extract.js +401 -30
  167. package/dist/llm/index-passes.js +44 -29
  168. package/dist/llm/memory-infer.js +30 -2
  169. package/dist/llm/metadata-enhance.js +3 -7
  170. package/dist/llm/prompts/extract-session.md +80 -0
  171. package/dist/llm/prompts/graph-extract-user-prompt.md +24 -1
  172. package/dist/output/cli-hints-full.md +60 -32
  173. package/dist/output/cli-hints-short.md +10 -7
  174. package/dist/output/cli-hints.js +5 -2
  175. package/dist/output/context.js +60 -8
  176. package/dist/output/renderers.js +170 -194
  177. package/dist/output/shapes/curate.js +56 -0
  178. package/dist/output/shapes/distill.js +10 -0
  179. package/dist/output/shapes/env-list.js +19 -0
  180. package/dist/output/shapes/events.js +11 -0
  181. package/dist/output/shapes/helpers.js +424 -0
  182. package/dist/output/shapes/history.js +7 -0
  183. package/dist/output/shapes/passthrough.js +105 -0
  184. package/dist/output/shapes/proposal-accept.js +7 -0
  185. package/dist/output/shapes/proposal-diff.js +7 -0
  186. package/dist/output/shapes/proposal-list.js +7 -0
  187. package/dist/output/shapes/proposal-producer.js +11 -0
  188. package/dist/output/shapes/proposal-reject.js +7 -0
  189. package/dist/output/shapes/proposal-show.js +7 -0
  190. package/dist/output/shapes/registry-search.js +6 -0
  191. package/dist/output/shapes/registry.js +30 -0
  192. package/dist/output/shapes/search.js +6 -0
  193. package/dist/output/shapes/secret-list.js +19 -0
  194. package/dist/output/shapes/show.js +6 -0
  195. package/dist/output/shapes/vault-list.js +19 -0
  196. package/dist/output/shapes.js +51 -549
  197. package/dist/output/text/add.js +6 -0
  198. package/dist/output/text/clone.js +6 -0
  199. package/dist/output/text/config.js +6 -0
  200. package/dist/output/text/curate.js +6 -0
  201. package/dist/output/text/distill.js +7 -0
  202. package/dist/output/text/enable-disable.js +7 -0
  203. package/dist/output/text/events.js +10 -0
  204. package/dist/output/text/feedback.js +6 -0
  205. package/dist/output/text/helpers.js +1059 -0
  206. package/dist/output/text/history.js +7 -0
  207. package/dist/output/text/import.js +6 -0
  208. package/dist/output/text/index.js +6 -0
  209. package/dist/output/text/info.js +6 -0
  210. package/dist/output/text/init.js +6 -0
  211. package/dist/output/text/list.js +6 -0
  212. package/dist/output/text/proposal-producer.js +8 -0
  213. package/dist/output/text/proposal.js +12 -0
  214. package/dist/output/text/registry-commands.js +11 -0
  215. package/dist/output/text/registry.js +30 -0
  216. package/dist/output/text/remember.js +6 -0
  217. package/dist/output/text/remove.js +6 -0
  218. package/dist/output/text/save.js +6 -0
  219. package/dist/output/text/search.js +6 -0
  220. package/dist/output/text/show.js +6 -0
  221. package/dist/output/text/update.js +6 -0
  222. package/dist/output/text/upgrade.js +6 -0
  223. package/dist/output/text/vault.js +16 -0
  224. package/dist/output/text/wiki.js +15 -0
  225. package/dist/output/text/workflow.js +14 -0
  226. package/dist/output/text.js +44 -1329
  227. package/dist/registry/build-index.js +3 -0
  228. package/dist/registry/create-provider-registry.js +3 -0
  229. package/dist/registry/factory.js +4 -1
  230. package/dist/registry/origin-resolve.js +3 -0
  231. package/dist/registry/providers/index.js +3 -0
  232. package/dist/registry/providers/skills-sh.js +11 -2
  233. package/dist/registry/providers/static-index.js +10 -1
  234. package/dist/registry/providers/types.js +3 -24
  235. package/dist/registry/resolve.js +11 -16
  236. package/dist/registry/types.js +3 -0
  237. package/dist/scripts/migrate-storage.js +17767 -0
  238. package/dist/scripts/migrations/import-fs-improve-runs-to-db.js +9031 -0
  239. package/dist/scripts/migrations/v16-to-v17.js +141 -0
  240. package/dist/setup/detect.js +3 -0
  241. package/dist/setup/ripgrep-install.js +3 -0
  242. package/dist/setup/ripgrep-resolve.js +3 -0
  243. package/dist/setup/setup.js +306 -67
  244. package/dist/setup/steps.js +3 -15
  245. package/dist/sources/include.js +3 -0
  246. package/dist/sources/provider-factory.js +3 -11
  247. package/dist/sources/provider.js +3 -20
  248. package/dist/sources/providers/filesystem.js +19 -23
  249. package/dist/sources/providers/git.js +171 -21
  250. package/dist/sources/providers/index.js +3 -0
  251. package/dist/sources/providers/install-types.js +3 -13
  252. package/dist/sources/providers/npm.js +3 -4
  253. package/dist/sources/providers/provider-utils.js +3 -0
  254. package/dist/sources/providers/sync-from-ref.js +3 -11
  255. package/dist/sources/providers/tar-utils.js +3 -0
  256. package/dist/sources/providers/website.js +18 -22
  257. package/dist/sources/resolve.js +3 -0
  258. package/dist/sources/types.js +3 -0
  259. package/dist/sources/website-ingest.js +3 -0
  260. package/dist/tasks/backends/cron.js +3 -0
  261. package/dist/tasks/backends/exec-utils.js +3 -0
  262. package/dist/tasks/backends/index.js +3 -11
  263. package/dist/tasks/backends/launchd.js +3 -0
  264. package/dist/tasks/backends/schtasks.js +3 -0
  265. package/dist/tasks/parser.js +51 -38
  266. package/dist/tasks/resolveAkmBin.js +3 -0
  267. package/dist/tasks/runner.js +35 -9
  268. package/dist/tasks/schedule.js +20 -1
  269. package/dist/tasks/schema.js +5 -3
  270. package/dist/tasks/validator.js +6 -3
  271. package/dist/version.js +3 -0
  272. package/dist/wiki/wiki-templates.js +3 -0
  273. package/dist/wiki/wiki.js +3 -0
  274. package/dist/workflows/authoring.js +3 -0
  275. package/dist/workflows/cli.js +3 -0
  276. package/dist/workflows/db.js +140 -10
  277. package/dist/workflows/document-cache.js +3 -10
  278. package/dist/workflows/parser.js +3 -0
  279. package/dist/workflows/renderer.js +3 -0
  280. package/dist/workflows/runs.js +18 -1
  281. package/dist/workflows/schema.js +3 -0
  282. package/dist/workflows/scope-key.js +3 -0
  283. package/dist/workflows/validator.js +5 -9
  284. package/docs/README.md +7 -2
  285. package/docs/data-and-telemetry.md +225 -0
  286. package/docs/migration/release-notes/0.7.5.md +2 -2
  287. package/docs/migration/release-notes/0.8.0.md +57 -5
  288. package/docs/migration/v0.7-to-v0.8.md +1378 -0
  289. package/package.json +28 -11
  290. package/.github/LICENSE +0 -374
  291. package/dist/commands/install-audit.js +0 -385
  292. package/dist/commands/vault.js +0 -310
  293. package/dist/indexer/match-contributors.js +0 -141
  294. package/dist/integrations/agent/pipeline.js +0 -39
  295. package/dist/integrations/agent/runners.js +0 -31
@@ -1,3 +1,6 @@
1
+ // This Source Code Form is subject to the terms of the Mozilla Public
2
+ // License, v. 2.0. If a copy of the MPL was not distributed with this
3
+ // file, You can obtain one at https://mozilla.org/MPL/2.0/.
1
4
  import { randomUUID } from "node:crypto";
2
5
  import fs from "node:fs";
3
6
  import { parseAssetRef } from "../core/asset-ref";
@@ -22,7 +25,7 @@ async function withWorkflowDb(fn) {
22
25
  closeWorkflowDatabase(db);
23
26
  }
24
27
  }
25
- export async function startWorkflowRun(ref, params = {}) {
28
+ export async function startWorkflowRun(ref, params = {}, options) {
26
29
  const asset = await loadWorkflowAsset(ref);
27
30
  return withWorkflowDb(async (db) => {
28
31
  const now = new Date().toISOString();
@@ -30,6 +33,20 @@ export async function startWorkflowRun(ref, params = {}) {
30
33
  const scopeKey = getCurrentWorkflowScopeKey();
31
34
  const currentStepId = asset.steps[0]?.id ?? null;
32
35
  const workflowEntryId = resolveWorkflowEntryId(asset.sourcePath, asset.ref);
36
+ // Concurrency guard (#485): if an active run already exists in this
37
+ // (workflow_ref, scope_key) pair, refuse to create a parallel run unless
38
+ // `force: true` is set. Previously every call inserted unconditionally,
39
+ // so two terminals running `akm workflow start <ref>` left two runs
40
+ // racing; `akm workflow next` then non-deterministically picked one.
41
+ if (!options?.force) {
42
+ const existing = db
43
+ .prepare("SELECT id, current_step_id FROM workflow_runs WHERE workflow_ref = ? AND scope_key = ? AND status = 'active' ORDER BY updated_at DESC LIMIT 1")
44
+ .get(asset.ref, scopeKey);
45
+ if (existing) {
46
+ throw new UsageError(`Workflow ${asset.ref} already has an active run in this scope (id=${existing.id}, step=${existing.current_step_id ?? "—"}). ` +
47
+ `Use 'akm workflow next ${asset.ref}' to resume it, 'akm workflow abandon ${existing.id}' to give up on it, or pass --force to start a parallel run.`, "RESOURCE_ALREADY_EXISTS");
48
+ }
49
+ }
33
50
  db.transaction(() => {
34
51
  db.prepare(`INSERT INTO workflow_runs (
35
52
  id, workflow_ref, scope_key, workflow_entry_id, workflow_title, status, params_json, current_step_id, created_at, updated_at
@@ -1,3 +1,6 @@
1
+ // This Source Code Form is subject to the terms of the Mozilla Public
2
+ // License, v. 2.0. If a copy of the MPL was not distributed with this
3
+ // file, You can obtain one at https://mozilla.org/MPL/2.0/.
1
4
  /**
2
5
  * Validated JSON shape for a workflow asset.
3
6
  *
@@ -1,3 +1,6 @@
1
+ // This Source Code Form is subject to the terms of the Mozilla Public
2
+ // License, v. 2.0. If a copy of the MPL was not distributed with this
3
+ // file, You can obtain one at https://mozilla.org/MPL/2.0/.
1
4
  import { createHash } from "node:crypto";
2
5
  import fs from "node:fs";
3
6
  import path from "node:path";
@@ -1,12 +1,8 @@
1
- /**
2
- * Cross-cutting semantic checks over an assembled WorkflowDocument draft.
3
- *
4
- * The parser handles per-line shape checks; this module runs rules that need
5
- * the whole document or the raw frontmatter at once: duplicate step IDs,
6
- * step-id format, and the frontmatter key whitelist.
7
- */
1
+ // This Source Code Form is subject to the terms of the Mozilla Public
2
+ // License, v. 2.0. If a copy of the MPL was not distributed with this
3
+ // file, You can obtain one at https://mozilla.org/MPL/2.0/.
8
4
  const STEP_ID_REGEX = /^[A-Za-z0-9][A-Za-z0-9._-]*$/;
9
- const ALLOWED_FRONTMATTER_KEYS = new Set(["description", "tags", "params", "name", "updated"]);
5
+ const ALLOWED_FRONTMATTER_KEYS = new Set(["description", "tags", "params", "name", "updated", "when_to_use"]);
10
6
  export function runSemanticChecks(draft, frontmatterData, frontmatterEndLine, errors) {
11
7
  checkFrontmatterKeys(frontmatterData, frontmatterEndLine, errors);
12
8
  checkStepIdFormat(draft, errors);
@@ -18,7 +14,7 @@ function checkFrontmatterKeys(data, fmEndLine, errors) {
18
14
  continue;
19
15
  errors.push({
20
16
  line: fmEndLine,
21
- message: `Workflow frontmatter "${key}" is not supported. Use only: description, tags, params.`,
17
+ message: `Workflow frontmatter "${key}" is not supported. Use only: description, tags, params, when_to_use.`,
22
18
  });
23
19
  }
24
20
  }
package/docs/README.md CHANGED
@@ -10,8 +10,9 @@
10
10
 
11
11
  ## Upgrading
12
12
 
13
+ - [Roadmap](roadmap.md) -- High-level focus for the 0.9 and 1.0 releases
13
14
  - [v1 migration guide](migration/v1.md) -- The path from 0.x to v1.0, including the `.stash.json` removal scheduled for v0.8.0
14
- - [Release notes (latest: 0.7.0)](migration/release-notes/0.7.0.md) -- Per-release notes drop into `migration/release-notes/`, including current pre-release removals
15
+ - [Release notes (latest: 0.8.0)](migration/release-notes/0.8.0.md) -- Per-release notes drop into `migration/release-notes/`, including current pre-release removals
15
16
  - [v0.5 → v0.6 migration guide](migration/v0.5-to-v0.6.md) -- Every breaking change with before/after code, publisher checklist, and troubleshooting
16
17
 
17
18
  ## Reference
@@ -28,6 +29,10 @@
28
29
  - [itlackey/akm-plugins](https://github.com/itlackey/akm-plugins) -- optional integrations for tools like OpenCode
29
30
  - [itlackey/akm-bench](https://github.com/itlackey/akm-bench) -- the standalone benchmark and evaluation repo for akm
30
31
 
32
+ ## Operations
33
+
34
+ - Analyzing `akm improve` runs -- use [`akm health`](../src/commands/health.ts) (0.8.0+): `--since`, `--detail per-run`, `--window-compare`, `--windows`. See [health-command-enhancements.md](technical/health-command-enhancements.md).
35
+
31
36
  ## Internals
32
37
 
33
38
  - [Search](technical/search.md) -- Hybrid search architecture and scoring
@@ -41,7 +46,7 @@
41
46
  - [Ref Format](technical/ref.md) -- Wire format for asset references
42
47
  - [Test Coverage Guide](technical/test-coverage-guide.md) -- High-value testing areas
43
48
  - [Core Principles](technical/akm-core-principles.md) -- Design principles and constraints
44
- - [akm-bench](technical/benchmark.md) -- Search-quality benchmark suite
49
+ - `technical/benchmark.md` (planned) -- Search-quality benchmark suite
45
50
 
46
51
  ## Posts
47
52
 
@@ -0,0 +1,225 @@
1
+ # AKM Data & Telemetry
2
+
3
+ AKM stores data locally on your machine. **It has no remote telemetry.** No data is sent to Anthropic, the AKM project, or any third party. This document describes exactly what AKM reads and writes on your machine.
4
+
5
+ ## No Remote Data Collection
6
+
7
+ AKM does not:
8
+ - Send usage data, events, or crash reports to any server
9
+ - Contact any AKM-operated endpoint at runtime (only your own configured LLM/embedding endpoints)
10
+ - Include any analytics SDK or beacon
11
+ - Collect email, name, or any personally-identifying information
12
+
13
+ The only network requests AKM makes are:
14
+ 1. Fetching registry metadata and stash packages from sources you explicitly configure (GitHub, npm, websites)
15
+ 2. Calls to your configured LLM/embedding endpoint (if you enabled those features)
16
+ 3. `akm upgrade` — fetches the latest release from GitHub releases
17
+ 4. `akm setup` — a single DNS lookup for `github.com` to decide whether to skip network-dependent steps (Ollama detection, remote embedding probes) when offline. No HTTP request is made by this probe; if it succeeds, akm proceeds with the network-dependent steps you already configured.
18
+
19
+ ---
20
+
21
+ ## Local On-Disk Surface
22
+
23
+ AKM writes to these locations on your machine. All paths follow [XDG Base Directory](https://specifications.freedesktop.org/basedir-spec/latest/) conventions on Linux/macOS and Windows conventions on Windows.
24
+
25
+ ### Config Directory (`$XDG_CONFIG_HOME/akm` or `~/.config/akm/`)
26
+
27
+ | Path | Contents | Safe to delete? |
28
+ |---|---|---|
29
+ | `config.json` | Your AKM configuration: LLM endpoints, stash paths, feature flags, profiles | **No** — deleting resets all settings |
30
+
31
+ Override: set `AKM_CONFIG_DIR` or `XDG_CONFIG_HOME`.
32
+
33
+ ### Data Directory (`$XDG_DATA_HOME/akm` or `~/.local/share/akm/`)
34
+
35
+ | Path | Contents | Safe to delete? |
36
+ |---|---|---|
37
+ | `index.db` | Search index for all your stash assets (FTS5 + metadata) | Yes — rebuilds via `akm index --full` |
38
+ | `workflow.db` | Workflow run state and history | Caution — deletes run history |
39
+ | `state.db` | Events, proposals, task history, improve run results | **No** — deletes event log, proposal queue, improve history |
40
+ | `akm.lock` | Inter-process write lock | Yes — recreated automatically |
41
+ | `akm.lock.lck` | Lock write sentinel | Yes — recreated automatically |
42
+
43
+ Override: set `AKM_DATA_DIR` or `XDG_DATA_HOME`.
44
+
45
+ ### Cache Directory (`$XDG_CACHE_HOME/akm` or `~/.cache/akm/`)
46
+
47
+ Everything in the cache is regenerable. It is safe to delete the entire cache directory; AKM will recreate what it needs on next use.
48
+
49
+ | Path | Contents | Safe to delete? |
50
+ |---|---|---|
51
+ | `config-backups/config-<timestamp>.json` | Pre-migration config snapshots (5 retained) | Yes |
52
+ | `config-backups/config.latest.json` | Latest backup alias | Yes |
53
+ | `registry/` | Downloaded registry tarballs (stash packages from npm, GitHub, etc.) | Yes — re-downloaded on next `akm add` or `akm update` |
54
+ | `registry-index/` | Legacy per-URL JSON cache (v0.7 artifact) | Yes — fully replaced by `index.db` in 0.8.0 |
55
+ | `semantic-status.json` | Semantic index build status marker | Yes |
56
+ | `bin/` | Downloaded AKM binary cache (used by `akm upgrade`) | Yes |
57
+ | `tasks/logs/` | Scheduled task log files | Yes — ephemeral logs |
58
+ | `tasks/history/` | Legacy task history JSONL (v0.7 migration artifact) | Yes |
59
+
60
+ Override: set `AKM_CACHE_DIR` or `XDG_CACHE_HOME`.
61
+
62
+ ### Stash Directory (`~/akm/` by default, or user-configured)
63
+
64
+ | Path | Contents | Safe to delete? |
65
+ |---|---|---|
66
+ | `<stash>/` | All your asset files: agents, skills, commands, knowledge, workflows, memories, vaults, wikis, lessons | **No** — this is YOUR data |
67
+ | `<stash>/.akm/` | Hidden AKM metadata (v0.7 proposals, legacy runs) | Caution — check for pending proposals first |
68
+
69
+ Override: set `AKM_STASH_DIR` (or configure `stashDir` in `config.json`).
70
+
71
+ ---
72
+
73
+ ## What Is Stored in `state.db`
74
+
75
+ `state.db` holds three categories of non-regenerable data:
76
+
77
+ ### 1. Events Table
78
+
79
+ An append-only log of every mutating action you perform with AKM. Events are stored locally for self-improvement (the improve loop uses them to surface usage patterns) and for inspection via `akm events`.
80
+
81
+ **What is recorded:**
82
+ - `event_type` — what action was taken (see full list below)
83
+ - `ts` — ISO-8601 UTC timestamp
84
+ - `ref` — the asset ref affected (e.g. `skill:code-review`), if applicable
85
+ - `metadata` — structured payload specific to the event type (e.g. query text for `search`, score for `feedback`)
86
+
87
+ **What is NOT recorded:**
88
+ - File contents
89
+ - LLM prompts or responses
90
+ - API keys or secrets (config is not stored in events)
91
+ - Personal information
92
+
93
+ **Retention:** Events older than 90 days are purged automatically when `akm improve` runs its maintenance pass. Purge is controlled by `purgeOldEvents()` with a 90-day default.
94
+
95
+ **Full event type list:**
96
+
97
+ | Event type | When emitted | Key metadata fields |
98
+ |---|---|---|
99
+ | `add` | `akm add <source>` | `ref`, `provider` |
100
+ | `remove` | `akm remove <source>` | `ref` |
101
+ | `update` | `akm update [source]` | `ref` |
102
+ | `remember` | `akm remember <text>` | `ref` |
103
+ | `import` | `akm import <file>` | `ref` |
104
+ | `save` | `akm save <ref>` | `ref` |
105
+ | `feedback` | `akm feedback <ref>` | `signal` (positive/negative) |
106
+ | `search` | `akm search <query>` | `query`, `source`, `signal` |
107
+ | `curate` | `akm curate <prompt>` | `query`, `source` |
108
+ | `show` | `akm show <ref>` | `ref`, `type`, `name` |
109
+ | `select` | `akm show` after a search returning the same ref | `ref`, `entryId` |
110
+ | `promoted` | `akm proposal accept <id>` | `ref` |
111
+ | `rejected` | `akm proposal reject <id>` | `ref` |
112
+ | `reflect_invoked` | Start of reflect phase in `akm improve` | `ref`, profile |
113
+ | `reflect_completed` | Reflect phase produced a proposal | `ref` |
114
+ | `improve_reflect_outcome` | Per-asset reflect result | `ref`, `ok`, `durationMs`, `reason` |
115
+ | `propose_invoked` | `akm propose` | `ref` |
116
+ | `distill_invoked` | `akm distill` | |
117
+ | `improve_skipped` | Asset skipped by cooldown or budget | `ref`, `reason` |
118
+ | `improve_completed` | `akm improve` run finished | run stats |
119
+ | `improve_failed` | `akm improve` run errored | error |
120
+ | `improve_lock_recovered` | Stale lock cleared at startup | |
121
+ | `proposal_orphan_purge` | Stale proposals pruned | `checked`, `rejected` |
122
+ | `proposal_creation_rejected` | `createProposal()` validation failed | `ref`, `reason`, `source` |
123
+ | `proposal_expired` | Proposal expired | `ref` |
124
+ | `events_purged` | Old events deleted by maintenance | `purgedCount`, `retentionDays` |
125
+ | `workflow_started` | `akm workflow start <ref>` | `ref`, `runId` |
126
+ | `workflow_step_completed` | `akm workflow next` | `ref`, `runId`, `stepId` |
127
+ | `workflow_finished` | `akm workflow complete` | `ref`, `runId` |
128
+ | `schema_repair_invoked` | `akm lint --repair` triggered schema repair | `ref` |
129
+ | `archive_cleanup` | Archive cleanup during consolidation | |
130
+
131
+ ### 2. Proposals Table
132
+
133
+ The proposal queue: pending, accepted, and rejected improvement proposals for your stash assets. Generated by `akm reflect` and the improve loop.
134
+
135
+ Contents:
136
+ - Proposal UUID (primary key)
137
+ - Target asset ref
138
+ - Status (pending/accepted/rejected)
139
+ - Source (which process generated it — e.g. `reflect`, `distill`)
140
+ - Full proposal content (Markdown text)
141
+ - Created/updated timestamps
142
+
143
+ ### 3. Task History Table
144
+
145
+ A record of scheduled task runs (from `akm tasks`):
146
+ - Task ID, status, start/end times
147
+ - Log file path (the log content stays in `$CACHE/tasks/logs/`)
148
+
149
+ ---
150
+
151
+ ## How to Inspect and Clear Local Data
152
+
153
+ ### Inspect events
154
+
155
+ ```sh
156
+ # List recent events
157
+ akm events list
158
+
159
+ # Stream live events (tail)
160
+ akm events tail
161
+
162
+ # Filter by type
163
+ akm events list --type search --limit 20
164
+
165
+ # Filter by asset ref
166
+ akm events list --ref skill:code-review
167
+ ```
168
+
169
+ ### Inspect proposals
170
+
171
+ ```sh
172
+ # List pending proposals
173
+ akm proposal list
174
+
175
+ # Show a specific proposal
176
+ akm proposal show <id>
177
+ ```
178
+
179
+ ### Clear specific data
180
+
181
+ ```sh
182
+ # Delete the search index (safe — rebuilds with akm index --full)
183
+ rm ~/.local/share/akm/index.db
184
+
185
+ # Delete all cached registry downloads
186
+ rm -rf ~/.cache/akm/registry/
187
+
188
+ # Delete config backups
189
+ rm -rf ~/.cache/akm/config-backups/
190
+
191
+ # Delete the events log from state.db (non-reversible)
192
+ # There is no akm CLI command to do this directly in 0.8.0.
193
+ # Use SQLite directly:
194
+ sqlite3 ~/.local/share/akm/state.db "DELETE FROM events;"
195
+
196
+ # Delete all proposals
197
+ sqlite3 ~/.local/share/akm/state.db "DELETE FROM proposals;"
198
+ ```
199
+
200
+ ### Start completely fresh (nuclear reset)
201
+
202
+ ```sh
203
+ rm -f ~/.config/akm/config.json
204
+ rm -rf ~/.local/share/akm/
205
+ rm -rf ~/.cache/akm/
206
+ # Your stash files in ~/akm/ are NOT touched by the above.
207
+ ```
208
+
209
+ ---
210
+
211
+ ## Environment Variable Overrides
212
+
213
+ You can redirect any AKM directory to a custom path:
214
+
215
+ | Variable | Overrides |
216
+ |---|---|
217
+ | `AKM_CONFIG_DIR` | Config directory (`~/.config/akm/`) |
218
+ | `AKM_DATA_DIR` | Data directory (`~/.local/share/akm/`) |
219
+ | `AKM_STATE_DIR` | State directory (`~/.local/state/akm/`) |
220
+ | `AKM_CACHE_DIR` | Cache directory (`~/.cache/akm/`) |
221
+ | `AKM_STASH_DIR` | Default stash directory (`~/akm/`) |
222
+ | `XDG_CONFIG_HOME` | XDG base — akm appends `/akm` |
223
+ | `XDG_DATA_HOME` | XDG base — akm appends `/akm` |
224
+ | `XDG_STATE_HOME` | XDG base — akm appends `/akm` |
225
+ | `XDG_CACHE_HOME` | XDG base — akm appends `/akm` |
@@ -15,6 +15,6 @@ No manual migration is required for most users, but note these operator-facing d
15
15
 
16
16
  1. If you were relying on ref-based workflow runs being globally shared across repos or directories, that behavior is gone. Use direct run IDs when you intentionally need to resume a specific run created elsewhere.
17
17
  2. Existing older workflow runs created before the new workspace scope key was introduced are still accessible by direct run ID, but ref-based commands now prefer runs created in the current scope.
18
- 3. `akm help migrate latest` now resolves to 0.7.5 and uses the published `.github/CHANGELOG.md` path.
18
+ 3. `akm help migrate latest` now resolves to 0.7.5 and uses the published `CHANGELOG.md` path.
19
19
 
20
- Full changelog: https://github.com/itlackey/akm/blob/main/.github/CHANGELOG.md
20
+ Full changelog: https://github.com/itlackey/akm/blob/main/CHANGELOG.md
@@ -9,6 +9,11 @@ Key operator-facing changes:
9
9
  - Plain `akm index` now owns metadata enhancement only.
10
10
  - Memory inference and graph extraction now run from `akm improve` after
11
11
  consolidation, not from `akm index`.
12
+ - Graph schema redesign (DB_VERSION 12 → 13): `graph_files` re-keyed on
13
+ `entry_id` with FK cascade to `entries(id)`, child tables follow.
14
+ Upgrade drops the graph tables and repopulates them on the next
15
+ `akm improve` cycle; non-graph tables rebuild automatically. Run
16
+ `akm improve` once after the storage migration to repopulate graph data.
12
17
  - Manual QA and sandbox guidance now require isolating `AKM_DATA_DIR` in
13
18
  addition to `HOME`, XDG dirs, and `AKM_STASH_DIR`.
14
19
  - `akm health` is available for post-upgrade runtime checks against `state.db`,
@@ -18,11 +23,11 @@ Primary public command family for 0.8.0:
18
23
 
19
24
  - `akm improve [<type>|<ref>]`
20
25
  - `akm propose <type> <name> (--task "..." | --file <path>)`
21
- - `akm proposals`
22
- - `akm show proposal <id>`
23
- - `akm diff proposal <id>`
24
- - `akm accept <id>`
25
- - `akm reject <id> --reason "..."`
26
+ - `akm proposal list`
27
+ - `akm proposal show <id>`
28
+ - `akm proposal diff <id>`
29
+ - `akm proposal accept <id>`
30
+ - `akm proposal reject <id> --reason "..."`
26
31
 
27
32
  Proposal-queue and improvement workflows are consolidated around this family.
28
33
  Update scripts, prompts, docs, and agent instructions before upgrading.
@@ -36,6 +41,53 @@ Behavior changes worth noting:
36
41
  `wikis/<name>/raw/`.
37
42
  - `akm health --since 24h` provides a fast operator check for state-db
38
43
  round-trip health, task-log backing, and recent improve outcomes.
44
+ - The `akm improve` lock is now properly released even when `openStateDatabase()`
45
+ or budget-timer setup throws, preventing lock leaks (up to 4 hours) on error
46
+ paths.
47
+
48
+ New in the final 0.8.0 RC cycle:
49
+
50
+ ### End-of-Run Git Sync (`akm improve --sync`)
51
+
52
+ `akm improve` now auto-commits the git-backed primary stash at the end of every
53
+ non-dry-run pass. Detection is based on a `.git` directory — no remote required.
54
+
55
+ - `default` and `thorough` profiles: sync + push enabled by default
56
+ - `quick` and `memory-focus` profiles: sync disabled (lightweight passes)
57
+ - `--sync` / `--no-sync`: force on or off for a single run
58
+ - `--push` / `--no-push`: push or commit-only override for a single run
59
+
60
+ The commit message defaults to `akm improve auto-sync` and supports `{token}`
61
+ placeholders: `{timestamp}`, `{date}`, `{time}`, `{scope}`, `{refs}`,
62
+ `{accepted}`. Configure via `profiles.improve.<name>.sync.message` in config.
63
+
64
+ The result envelope includes a `sync` field: `{ committed, pushed, skipped,
65
+ reason? }`. A `stash_synced` event is emitted to `state.db`. Sync failures are
66
+ non-fatal — they never fail a successful improve run.
67
+
68
+ ### Consolidate Reliability
69
+
70
+ - Pre-flight stale-DB filter: consolidate now filters out entries that have
71
+ become stale in the DB before making any LLM calls, eliminating wasted tokens
72
+ on already-processed content.
73
+ - Defense-in-depth merge guards: three layers of guards prevent incorrect merges,
74
+ improving consolidation correctness on edge cases.
75
+
76
+ ### Proposal Drain Refinements
77
+
78
+ - `DrainDeferReason` now has two variants: `"mid-band"` and `"possible-dup"`.
79
+ The `"possible-contradiction"` variant has been removed.
80
+ - `DrainResult` gains a `staged` field: items the judgment tier resolved as
81
+ "accept" that were not yet promoted in queue mode. These are reported as
82
+ resolved, not deferred.
83
+ - `contentBodyLineCount` now uses the canonical `parseFrontmatter` for consistent
84
+ CRLF/BOM handling.
85
+
86
+ ### Workflow `when_to_use` Now Optional
87
+
88
+ Workflow frontmatter no longer requires `when_to_use`. The field is still
89
+ supported and recommended but the validator no longer rejects workflows that
90
+ omit it.
39
91
 
40
92
  Release validation status for the final 0.8.0 cut:
41
93