forgeos 0.1.0-alpha.0 → 0.1.0-alpha.10

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 (346) hide show
  1. package/.npmignore +9 -1
  2. package/AGENTS.md +43 -3
  3. package/CHANGELOG.md +109 -0
  4. package/CONTRIBUTING.md +22 -1
  5. package/README.md +82 -11
  6. package/adapters/go/README.md +23 -0
  7. package/adapters/go/go.mod +3 -0
  8. package/adapters/go/http.go +149 -0
  9. package/adapters/go/registry.go +234 -0
  10. package/adapters/go/types.go +136 -0
  11. package/bin/forge.mjs +4 -3
  12. package/docs/changelog.md +116 -0
  13. package/docs/forge-protocol.md +156 -0
  14. package/examples/go-billing/go.mod +7 -0
  15. package/examples/go-billing/main.go +120 -0
  16. package/package.json +18 -7
  17. package/packages/eslint-plugin-forge/index.ts +15 -15
  18. package/packages/eslint-plugin-forge/package.json +10 -10
  19. package/packages/eslint-plugin-forge/src/check-source.ts +95 -95
  20. package/packages/eslint-plugin-forge/src/load-artifacts.ts +24 -24
  21. package/packages/eslint-plugin-forge/src/rule-no-forge-guard-violation.ts +93 -93
  22. package/schemas/forge-manifest.schema.json +57 -0
  23. package/src/forge/_generated/actionSubscriptions.json +1 -2
  24. package/src/forge/_generated/actionSubscriptions.ts +3 -3
  25. package/src/forge/_generated/agentAdapterManifest.json +1 -2
  26. package/src/forge/_generated/agentAdapterManifest.ts +3 -3
  27. package/src/forge/_generated/agentContract.json +1 -2
  28. package/src/forge/_generated/agentContract.ts +6927 -7
  29. package/src/forge/_generated/agentQuickstart.md +3 -1
  30. package/src/forge/_generated/agentTools.json +1 -0
  31. package/src/forge/_generated/agentTools.md +16 -0
  32. package/src/forge/_generated/agentTools.ts +12 -0
  33. package/src/forge/_generated/aiContext.ts +67 -1
  34. package/src/forge/_generated/aiModels.json +1 -2
  35. package/src/forge/_generated/aiModels.ts +17 -1
  36. package/src/forge/_generated/aiProviders.json +0 -1
  37. package/src/forge/_generated/aiProviders.ts +1 -1
  38. package/src/forge/_generated/aiRegistry.json +1 -2
  39. package/src/forge/_generated/aiRegistry.ts +7 -5
  40. package/src/forge/_generated/api.json +1 -2
  41. package/src/forge/_generated/api.ts +7 -2
  42. package/src/forge/_generated/appGraph.json +1 -2
  43. package/src/forge/_generated/appGraph.ts +2186 -1346
  44. package/src/forge/_generated/appMap.md +21 -1
  45. package/src/forge/_generated/artifactManifest.json +1 -2
  46. package/src/forge/_generated/artifactManifest.ts +2 -2
  47. package/src/forge/_generated/authClaims.json +0 -1
  48. package/src/forge/_generated/authClaims.ts +1 -1
  49. package/src/forge/_generated/authConfig.json +0 -1
  50. package/src/forge/_generated/authConfig.ts +1 -1
  51. package/src/forge/_generated/authContext.ts +1 -1
  52. package/src/forge/_generated/authRegistry.json +0 -1
  53. package/src/forge/_generated/authRegistry.ts +1 -1
  54. package/src/forge/_generated/buildInfo.json +1 -2
  55. package/src/forge/_generated/buildInfo.ts +4 -4
  56. package/src/forge/_generated/capabilityMap.json +1 -2
  57. package/src/forge/_generated/capabilityMap.md +1 -1
  58. package/src/forge/_generated/capabilityMap.ts +2 -2
  59. package/src/forge/_generated/client.ts +88 -1
  60. package/src/forge/_generated/clientApi.ts +2 -1
  61. package/src/forge/_generated/clientManifest.json +1 -2
  62. package/src/forge/_generated/clientManifest.ts +6 -4
  63. package/src/forge/_generated/clientTypes.ts +19 -1
  64. package/src/forge/_generated/configRegistry.json +0 -1
  65. package/src/forge/_generated/configRegistry.ts +1 -1
  66. package/src/forge/_generated/dataGraph.json +1 -2
  67. package/src/forge/_generated/dataGraph.ts +3 -3
  68. package/src/forge/_generated/db.json +0 -1
  69. package/src/forge/_generated/db.ts +1 -1
  70. package/src/forge/_generated/dbSecurityManifest.json +0 -1
  71. package/src/forge/_generated/dbSecurityManifest.ts +1 -1
  72. package/src/forge/_generated/dbSessionContext.json +0 -1
  73. package/src/forge/_generated/dbSessionContext.ts +1 -1
  74. package/src/forge/_generated/deployManifest.json +1 -2
  75. package/src/forge/_generated/deployManifest.ts +7 -7
  76. package/src/forge/_generated/devManifest.json +1 -2
  77. package/src/forge/_generated/devManifest.ts +18 -3
  78. package/src/forge/_generated/envSchema.json +0 -1
  79. package/src/forge/_generated/envSchema.ts +1 -1
  80. package/src/forge/_generated/externalServices.json +1 -0
  81. package/src/forge/_generated/externalServices.ts +9 -0
  82. package/src/forge/_generated/frontendGraph.json +0 -1
  83. package/src/forge/_generated/frontendGraph.ts +1 -1
  84. package/src/forge/_generated/importGuards.json +1 -2
  85. package/src/forge/_generated/importGuards.ts +35 -1
  86. package/src/forge/_generated/index.ts +3 -1
  87. package/src/forge/_generated/liveProductionManifest.json +0 -1
  88. package/src/forge/_generated/liveProductionManifest.ts +1 -1
  89. package/src/forge/_generated/liveProtocol.json +0 -1
  90. package/src/forge/_generated/liveProtocol.ts +1 -1
  91. package/src/forge/_generated/liveQueryRegistry.json +1 -2
  92. package/src/forge/_generated/liveQueryRegistry.ts +3 -3
  93. package/src/forge/_generated/liveTransportConfig.json +0 -1
  94. package/src/forge/_generated/liveTransportConfig.ts +1 -1
  95. package/src/forge/_generated/makeRegistry.json +1 -2
  96. package/src/forge/_generated/makeRegistry.ts +16 -2
  97. package/src/forge/_generated/makeTemplates.json +1 -2
  98. package/src/forge/_generated/makeTemplates.ts +6 -1
  99. package/src/forge/_generated/mockMap.json +0 -1
  100. package/src/forge/_generated/mockMap.ts +1 -1
  101. package/src/forge/_generated/operationPlaybooks.md +40 -18
  102. package/src/forge/_generated/packageGraph.json +1 -2
  103. package/src/forge/_generated/packageGraph.ts +114376 -33611
  104. package/src/forge/_generated/packageUpgradeRegistry.json +1 -2
  105. package/src/forge/_generated/packageUpgradeRegistry.ts +2 -2
  106. package/src/forge/_generated/permissionMatrix.json +1 -2
  107. package/src/forge/_generated/permissionMatrix.ts +3 -3
  108. package/src/forge/_generated/policyRegistry.json +1 -2
  109. package/src/forge/_generated/policyRegistry.ts +3 -3
  110. package/src/forge/_generated/queryRegistry.json +1 -2
  111. package/src/forge/_generated/queryRegistry.ts +3 -3
  112. package/src/forge/_generated/react.d.ts +1 -1
  113. package/src/forge/_generated/react.ts +1 -1
  114. package/src/forge/_generated/reactManifest.json +1 -2
  115. package/src/forge/_generated/reactManifest.ts +3 -3
  116. package/src/forge/_generated/releaseManifest.json +1 -2
  117. package/src/forge/_generated/releaseManifest.ts +3 -3
  118. package/src/forge/_generated/rlsPolicies.json +0 -1
  119. package/src/forge/_generated/rlsPolicies.sql +1 -1
  120. package/src/forge/_generated/rlsPolicies.ts +1 -1
  121. package/src/forge/_generated/runtimeGraph.json +1 -2
  122. package/src/forge/_generated/runtimeGraph.ts +3 -3
  123. package/src/forge/_generated/runtimeMatrix.json +1 -2
  124. package/src/forge/_generated/runtimeMatrix.ts +118936 -13931
  125. package/src/forge/_generated/runtimeRegistry.ts +1 -1
  126. package/src/forge/_generated/runtimeRules.md +13 -1
  127. package/src/forge/_generated/secretRegistry.json +0 -1
  128. package/src/forge/_generated/secretRegistry.ts +1 -1
  129. package/src/forge/_generated/secretsContext.ts +1 -1
  130. package/src/forge/_generated/serverApi.ts +2 -1
  131. package/src/forge/_generated/sourceMapManifest.json +1 -2
  132. package/src/forge/_generated/sourceMapManifest.ts +2 -2
  133. package/src/forge/_generated/sqlPlan.json +0 -1
  134. package/src/forge/_generated/sqlPlan.ts +1 -1
  135. package/src/forge/_generated/subscriptionManifest.json +1 -2
  136. package/src/forge/_generated/subscriptionManifest.ts +3 -3
  137. package/src/forge/_generated/symbolicationManifest.json +1 -2
  138. package/src/forge/_generated/symbolicationManifest.ts +2 -2
  139. package/src/forge/_generated/telemetryRegistry.json +1 -2
  140. package/src/forge/_generated/telemetryRegistry.ts +3 -3
  141. package/src/forge/_generated/telemetrySinks.json +1 -2
  142. package/src/forge/_generated/telemetrySinks.ts +2 -2
  143. package/src/forge/_generated/tenantScope.json +1 -2
  144. package/src/forge/_generated/tenantScope.ts +3 -3
  145. package/src/forge/_generated/testGraph.json +1 -2
  146. package/src/forge/_generated/testGraph.ts +565 -113
  147. package/src/forge/_generated/testPlanRegistry.json +1 -2
  148. package/src/forge/_generated/testPlanRegistry.ts +2 -2
  149. package/src/forge/_generated/uiRoutes.json +0 -1
  150. package/src/forge/_generated/uiRoutes.ts +1 -1
  151. package/src/forge/_generated/uiScenarios.json +0 -1
  152. package/src/forge/_generated/uiScenarios.ts +1 -1
  153. package/src/forge/_generated/uiTestManifest.json +1 -2
  154. package/src/forge/_generated/uiTestManifest.ts +2 -2
  155. package/src/forge/_generated/workflowRegistry.json +1 -2
  156. package/src/forge/_generated/workflowRegistry.ts +3 -3
  157. package/src/forge/_generated/workflowSubscriptions.json +1 -2
  158. package/src/forge/_generated/workflowSubscriptions.ts +3 -3
  159. package/src/forge/bench.ts +248 -0
  160. package/src/forge/cli/ai.ts +671 -3
  161. package/src/forge/cli/auth.ts +36 -1
  162. package/src/forge/cli/build.ts +1 -1
  163. package/src/forge/cli/commands.ts +1013 -861
  164. package/src/forge/cli/deps.ts +178 -11
  165. package/src/forge/cli/dev.ts +32 -5
  166. package/src/forge/cli/index.ts +7 -7
  167. package/src/forge/cli/main.ts +57 -55
  168. package/src/forge/cli/new.ts +29 -1
  169. package/src/forge/cli/output.ts +97 -97
  170. package/src/forge/cli/parse.ts +867 -677
  171. package/src/forge/cli/query.ts +32 -0
  172. package/src/forge/cli/rls.ts +568 -17
  173. package/src/forge/cli/run.ts +41 -0
  174. package/src/forge/cli/secrets.ts +46 -1
  175. package/src/forge/cli/security.ts +381 -0
  176. package/src/forge/cli/verify.ts +201 -24
  177. package/src/forge/cli/version.ts +1 -1
  178. package/src/forge/compiler/agent-contract/build.ts +435 -12
  179. package/src/forge/compiler/agent-contract/types.ts +88 -0
  180. package/src/forge/compiler/ai-registry/build.ts +62 -1
  181. package/src/forge/compiler/ai-registry/constants.ts +1 -1
  182. package/src/forge/compiler/ai-registry/parse.ts +98 -4
  183. package/src/forge/compiler/api-surface/build.ts +47 -0
  184. package/src/forge/compiler/app-graph/build.ts +141 -113
  185. package/src/forge/compiler/app-graph/classify.ts +10 -10
  186. package/src/forge/compiler/app-graph/dup-symbol.ts +29 -29
  187. package/src/forge/compiler/app-graph/extract.ts +123 -123
  188. package/src/forge/compiler/app-graph/forge-apis.ts +30 -29
  189. package/src/forge/compiler/app-graph/index.ts +11 -11
  190. package/src/forge/compiler/app-graph/module-graph.ts +312 -317
  191. package/src/forge/compiler/app-graph/parser.ts +119 -119
  192. package/src/forge/compiler/app-graph/profile.ts +26 -0
  193. package/src/forge/compiler/app-graph/symbols.ts +48 -48
  194. package/src/forge/compiler/app-graph/tsconfig-hash.ts +62 -62
  195. package/src/forge/compiler/app-graph/types.ts +43 -43
  196. package/src/forge/compiler/app-graph/versions.ts +14 -14
  197. package/src/forge/compiler/cache/index.ts +17 -17
  198. package/src/forge/compiler/cache/key.ts +46 -46
  199. package/src/forge/compiler/cache/scheduler.ts +72 -72
  200. package/src/forge/compiler/cache/store.ts +78 -78
  201. package/src/forge/compiler/classifier/capabilities.ts +79 -78
  202. package/src/forge/compiler/classifier/classify.ts +137 -113
  203. package/src/forge/compiler/classifier/contexts.ts +188 -188
  204. package/src/forge/compiler/classifier/index.ts +18 -18
  205. package/src/forge/compiler/classifier/runtime-matrix.ts +45 -45
  206. package/src/forge/compiler/classifier/secrets.ts +42 -41
  207. package/src/forge/compiler/classifier/signals.ts +219 -129
  208. package/src/forge/compiler/client-sdk/build-manifest.ts +4 -0
  209. package/src/forge/compiler/client-sdk/render-client.ts +105 -0
  210. package/src/forge/compiler/dev-manifest/build.ts +3 -0
  211. package/src/forge/compiler/diagnostics/codes.ts +152 -120
  212. package/src/forge/compiler/diagnostics/create.ts +88 -88
  213. package/src/forge/compiler/diagnostics/index.ts +41 -41
  214. package/src/forge/compiler/emitter/artifact-kind.ts +14 -14
  215. package/src/forge/compiler/emitter/barrel.ts +38 -38
  216. package/src/forge/compiler/emitter/constants.ts +7 -7
  217. package/src/forge/compiler/emitter/emit.ts +234 -237
  218. package/src/forge/compiler/emitter/index.ts +24 -24
  219. package/src/forge/compiler/emitter/lock.ts +61 -61
  220. package/src/forge/compiler/emitter/render.ts +78 -73
  221. package/src/forge/compiler/external-manifest/registry.ts +204 -0
  222. package/src/forge/compiler/external-manifest/types.ts +89 -0
  223. package/src/forge/compiler/external-manifest/validate.ts +335 -0
  224. package/src/forge/compiler/guards/artifacts.ts +96 -96
  225. package/src/forge/compiler/guards/check-import-guards.ts +106 -106
  226. package/src/forge/compiler/guards/index.ts +11 -11
  227. package/src/forge/compiler/guards/propagate-contexts.ts +57 -57
  228. package/src/forge/compiler/index.ts +17 -17
  229. package/src/forge/compiler/integration/add.ts +493 -493
  230. package/src/forge/compiler/integration/index.ts +17 -17
  231. package/src/forge/compiler/integration/plan.ts +279 -279
  232. package/src/forge/compiler/integration/render.ts +189 -189
  233. package/src/forge/compiler/integration/snapshot.ts +52 -52
  234. package/src/forge/compiler/make-registry/build.ts +13 -0
  235. package/src/forge/compiler/orchestrator/discover.ts +214 -214
  236. package/src/forge/compiler/orchestrator/guards.ts +5 -5
  237. package/src/forge/compiler/orchestrator/index.ts +27 -27
  238. package/src/forge/compiler/orchestrator/manifest.ts +69 -69
  239. package/src/forge/compiler/orchestrator/orphans.ts +51 -51
  240. package/src/forge/compiler/orchestrator/plan-profile.ts +23 -0
  241. package/src/forge/compiler/orchestrator/plan.ts +857 -805
  242. package/src/forge/compiler/orchestrator/profile.ts +65 -0
  243. package/src/forge/compiler/orchestrator/run.ts +244 -178
  244. package/src/forge/compiler/orchestrator/serialize.ts +934 -859
  245. package/src/forge/compiler/orchestrator/types.ts +23 -23
  246. package/src/forge/compiler/orchestrator/verify.ts +35 -35
  247. package/src/forge/compiler/package-graph/capabilities-stub.ts +33 -33
  248. package/src/forge/compiler/package-graph/checksum.ts +107 -97
  249. package/src/forge/compiler/package-graph/compiler.ts +454 -363
  250. package/src/forge/compiler/package-graph/constants.ts +4 -4
  251. package/src/forge/compiler/package-graph/exports-discovery.ts +91 -84
  252. package/src/forge/compiler/package-graph/extract-dts.ts +32 -32
  253. package/src/forge/compiler/package-graph/index.ts +24 -24
  254. package/src/forge/compiler/package-graph/jsdoc.ts +50 -50
  255. package/src/forge/compiler/package-graph/oracle.ts +326 -0
  256. package/src/forge/compiler/package-graph/read-file.ts +21 -21
  257. package/src/forge/compiler/package-graph/resolve.ts +131 -127
  258. package/src/forge/compiler/package-manager/adapter.ts +232 -232
  259. package/src/forge/compiler/package-manager/commands.ts +47 -47
  260. package/src/forge/compiler/package-manager/detect.ts +65 -65
  261. package/src/forge/compiler/package-manager/executor.ts +29 -29
  262. package/src/forge/compiler/package-manager/index.ts +22 -22
  263. package/src/forge/compiler/package-manager/parse-spec.ts +16 -16
  264. package/src/forge/compiler/package-manager/version.ts +20 -20
  265. package/src/forge/compiler/policy-registry/build.ts +44 -1
  266. package/src/forge/compiler/primitives/compare.ts +26 -26
  267. package/src/forge/compiler/primitives/hash.ts +42 -33
  268. package/src/forge/compiler/primitives/header.ts +43 -43
  269. package/src/forge/compiler/primitives/index.ts +45 -45
  270. package/src/forge/compiler/primitives/paths.ts +24 -24
  271. package/src/forge/compiler/primitives/serialize.ts +66 -66
  272. package/src/forge/compiler/primitives/sort.ts +87 -87
  273. package/src/forge/compiler/recipes/definitions.ts +269 -269
  274. package/src/forge/compiler/recipes/helpers.ts +37 -37
  275. package/src/forge/compiler/recipes/index.ts +21 -21
  276. package/src/forge/compiler/recipes/registry.ts +87 -87
  277. package/src/forge/compiler/sandbox/artifact-sanitize.ts +26 -26
  278. package/src/forge/compiler/sandbox/backends/child.ts +123 -123
  279. package/src/forge/compiler/sandbox/backends/docker.ts +173 -173
  280. package/src/forge/compiler/sandbox/index.ts +51 -51
  281. package/src/forge/compiler/sandbox/inspect.ts +143 -143
  282. package/src/forge/compiler/sandbox/inspector-entry.ts +115 -115
  283. package/src/forge/compiler/sandbox/limits.ts +31 -31
  284. package/src/forge/compiler/sandbox/scrub-env.ts +60 -60
  285. package/src/forge/compiler/sandbox/secret-scan.ts +54 -54
  286. package/src/forge/compiler/sandbox/serialize.ts +106 -106
  287. package/src/forge/compiler/sandbox/types.ts +7 -7
  288. package/src/forge/compiler/test-graph/build.ts +11 -3
  289. package/src/forge/compiler/types/ai-registry.ts +25 -1
  290. package/src/forge/compiler/types/app-graph.ts +72 -71
  291. package/src/forge/compiler/types/capability.ts +29 -29
  292. package/src/forge/compiler/types/classification.ts +9 -9
  293. package/src/forge/compiler/types/cli.ts +89 -85
  294. package/src/forge/compiler/types/dev-manifest.ts +3 -0
  295. package/src/forge/compiler/types/diagnostic.ts +2 -2
  296. package/src/forge/compiler/types/emit.ts +25 -25
  297. package/src/forge/compiler/types/import-guards.ts +19 -19
  298. package/src/forge/compiler/types/index.ts +98 -98
  299. package/src/forge/compiler/types/integration.ts +25 -25
  300. package/src/forge/compiler/types/json.ts +3 -3
  301. package/src/forge/compiler/types/lock.ts +37 -37
  302. package/src/forge/compiler/types/package-graph.ts +122 -77
  303. package/src/forge/compiler/types/runtime-matrix.ts +16 -16
  304. package/src/forge/compiler/types/runtime.ts +30 -30
  305. package/src/forge/compiler/types/sandbox.ts +24 -24
  306. package/src/forge/dev/server.ts +592 -3
  307. package/src/forge/make/index.ts +126 -3
  308. package/src/forge/make/templates.ts +190 -2
  309. package/src/forge/make/types.ts +1 -0
  310. package/src/forge/refactor/index.ts +10 -2
  311. package/src/forge/refactor/runtime-rename.ts +598 -0
  312. package/src/forge/runtime/ai/context.ts +210 -5
  313. package/src/forge/runtime/ai/types.ts +70 -0
  314. package/src/forge/runtime/auth/claims.ts +32 -0
  315. package/src/forge/runtime/auth/errors.ts +2 -0
  316. package/src/forge/runtime/context/create-context.ts +30 -6
  317. package/src/forge/runtime/db/memory-adapter.ts +2 -2
  318. package/src/forge/runtime/db/postgres-adapter.ts +6 -3
  319. package/src/forge/runtime/executor.ts +3 -2
  320. package/src/forge/runtime/external/bridge.ts +553 -0
  321. package/src/forge/runtime/live/live-query-runner.ts +2 -1
  322. package/src/forge/runtime/outbox/process.ts +2 -1
  323. package/src/forge/runtime/query/run-query.ts +2 -1
  324. package/src/forge/runtime/runner/run-entry.ts +2 -1
  325. package/src/forge/runtime/telemetry/scrubber.ts +56 -5
  326. package/src/forge/runtime/telemetry/sinks/posthog.ts +4 -5
  327. package/src/forge/runtime/telemetry/sinks/sentry.ts +4 -5
  328. package/src/forge/runtime/webhooks/security.ts +184 -0
  329. package/src/forge/runtime/workflows/resolve-step.ts +2 -1
  330. package/src/forge/server.ts +93 -0
  331. package/src/forge/version.ts +3 -0
  332. package/templates/b2b-support-web/package.json +2 -0
  333. package/templates/b2b-support-web/src/actions/captureTicketCreated.ts +7 -2
  334. package/templates/b2b-support-web/src/commands/closeTicket.ts +6 -1
  335. package/templates/b2b-support-web/src/commands/createTicket.ts +8 -2
  336. package/templates/b2b-support-web/src/queries/getTicket.ts +8 -1
  337. package/templates/b2b-support-web/tsconfig.json +4 -1
  338. package/templates/b2b-support-web/web/components/CreateTicketForm.tsx +1 -2
  339. package/templates/b2b-support-web/web/components/PolicyDeniedDemo.tsx +1 -2
  340. package/templates/b2b-support-web/web/components/TicketList.tsx +1 -2
  341. package/templates/b2b-support-web/web/components/TraceDetails.tsx +1 -1
  342. package/templates/b2b-support-web/web/lib/forge.ts +1 -0
  343. package/templates/b2b-support-web/web/package.json +1 -1
  344. package/templates/minimal-web/package.json +2 -1
  345. package/templates/minimal-web/tsconfig.json +3 -1
  346. package/templates/minimal-web/web/package.json +2 -2
package/.npmignore CHANGED
@@ -1 +1,9 @@
1
- # Staged publish copy. Package contents are controlled by package.json files.
1
+ # Package contents are primarily controlled by package.json "files".
2
+ node_modules/
3
+ .git/
4
+ .github/
5
+ .forge/
6
+ tests/
7
+ examples/
8
+ *.tgz
9
+ npm-debug.log*
package/AGENTS.md CHANGED
@@ -1,4 +1,4 @@
1
- // @forge-generated generator=0.0.0 input=6b855b87f2f57fce3e0939076b81cc0263cccfeae7bb969d2662613867b1c8ee content=972ba64a9c3df8fb49f4e4c7cb9892d6449d7833b9a303b748d08c5717d239e3
1
+ // @forge-generated generator=0.1.0-alpha.10 input=9b218d51e45bbb3220f861cec8dcd08f63224475d6356fc73d26c330ddf108e7 content=1611635edf59c122b013ba76c85bd333ab3b30b289aaea04a9074f9438782a50
2
2
  # AGENTS.md
3
3
 
4
4
  <!-- forge-generated:start -->
@@ -69,6 +69,10 @@ forge inspect app --json
69
69
  forge inspect all --json
70
70
  forge inspect frontend --json
71
71
  forge inspect capabilities --json
72
+ forge inspect agent-tools --json
73
+ forge deps inspect <package> --json
74
+ forge deps api <package> <symbol> --json
75
+ forge deps trace <package> --json
72
76
  forge auth check --json
73
77
  forge inspect runtime-matrix --json
74
78
  forge inspect policies --json
@@ -79,6 +83,9 @@ forge doctor
79
83
  forge doctor windows --json
80
84
  forge setup windows --json
81
85
  forge agent print-context --json
86
+ forge ai tools --json
87
+ forge ai agents --json
88
+ forge ai trace <traceId> --json
82
89
  forge verify --smoke
83
90
  forge verify --standard
84
91
  forge verify --strict
@@ -100,6 +107,21 @@ Tenant-scoped tables:
100
107
  - ANTHROPIC_API_KEY (required)
101
108
  - OPENAI_API_KEY (required)
102
109
 
110
+ ## AI Tools And Agents
111
+
112
+ - AI SDK engine: Vercel AI SDK v6.
113
+ - Forge layer: generated registry, runtime rules, telemetry, secrets, tenant/auth context, and agent contract.
114
+ - Use `ctx.agent.run` or `ctx.ai.runAgent` only in actions, workflows, endpoints, and server code.
115
+ - Do not create custom tool loops; use Forge tools and AI SDK `ToolLoopAgent` through the Forge runtime.
116
+
117
+ Tools:
118
+
119
+ - none
120
+
121
+ Agents:
122
+
123
+ - none
124
+
103
125
  ## Auth
104
126
 
105
127
  - Modes: dev-headers, jwt, oidc, disabled
@@ -155,6 +177,7 @@ Use:
155
177
  forge make resource <name> --fields title:text,status:enum(open,closed) --dry-run --json
156
178
  forge make resource <name> --fields title:text,status:enum(open,closed) --with-ui --yes
157
179
  forge make ui --framework vite --dry-run --json
180
+ forge make ai-chat support --dry-run --json
158
181
  ```
159
182
 
160
183
  Review the plan before applying when the resource touches schema or policies.
@@ -191,11 +214,13 @@ Use:
191
214
  ```bash
192
215
  forge refactor rename field tickets.priority tickets.urgency --dry-run --json
193
216
  forge refactor rename field tickets.priority tickets.urgency --yes
217
+ forge refactor rename command createTicket openTicket --dry-run --json
218
+ forge refactor rename command createTicket openTicket --yes
194
219
  ```
195
220
 
196
- These codemods are AST-aware for `extract-action`, `rename field`, and `rename table`. Field renames are scoped to the target table, so `tickets.priority` only rewrites references linked to `tickets`.
221
+ These codemods are AST-aware for `extract-action`, `rename command`, `rename field`, and `rename table`. Command renames update runtime registries, generated client references, frontend hooks, tests, and string references where safe. Field renames are scoped to the target table, so `tickets.priority` only rewrites references linked to `tickets`.
197
222
 
198
- Never edit `src/forge/_generated/**` directly. Review migration hints before applying field or table renames.
223
+ Never edit `src/forge/_generated/**` directly. Review migration hints before applying command, field, or table renames.
199
224
 
200
225
  ### Plan impact-based tests
201
226
 
@@ -221,6 +246,19 @@ forge repair plan --from-last-test-run --write
221
246
 
222
247
  Apply only high-confidence deterministic repairs automatically. Review medium or low confidence repairs before changing code.
223
248
 
249
+ ### Add AI tools or agents
250
+
251
+ Use:
252
+
253
+ ```bash
254
+ forge generate
255
+ forge inspect all --json
256
+ forge ai check --json
257
+ forge ai trace <traceId> --json
258
+ ```
259
+
260
+ Define tools with `aiTool({ inputSchema, outputSchema, risk, needsApproval, handler })` and agents with `agent({ provider, model, instructions, tools, stopWhen })`. Execute agents with `ctx.agent.run` or `ctx.ai.runAgent` only from actions, workflows, endpoints, or server code. In dev, POST `/ai/agents/run` returns JSON for automation and POST `/ai/agents/chat` returns an AI SDK UIMessage stream for React `useChat`; both accept `agent: "<exportedAgentName>"` and use generated auto-tools from `agentTools.json`.
261
+
224
262
  ### Export agent adapters
225
263
 
226
264
  Use:
@@ -250,6 +288,8 @@ Use:
250
288
 
251
289
  ```bash
252
290
  forge deps upgrade-plan <package> --to latest
291
+ forge deps inspect <package> --json
292
+ forge deps api <package> <symbol> --json
253
293
  forge deps upgrade-apply <plan>
254
294
  forge verify --strict
255
295
  ```
package/CHANGELOG.md CHANGED
@@ -1,8 +1,117 @@
1
1
  # forgeos
2
2
 
3
+ ## 0.1.0-alpha.10
4
+
5
+ Launch polish:
6
+
7
+ - Fixed `forge run <external-command> --args ...` so CLI arguments reach the external runtime bridge.
8
+ - Added direct external query CLI support through `forge query <service.query> --args ...`.
9
+ - Emit generated `.json` artifacts as pure JSON while keeping deterministic headers on code/text artifacts.
10
+ - Relaxed the `minimal-web` template verify script to `forge verify --smoke` and added the missing `check` script to `b2b-support-web`.
11
+ - Updated public protocol/changelog docs for the external runtime and Go adapter alpha line.
12
+ - Bumped the create-app wrapper package line to `create-forgeos-app@0.1.0-alpha.4`.
13
+
14
+ ## 0.1.0-alpha.9
15
+
16
+ ### Patch Changes
17
+
18
+ - Added the Forge external runtime protocol bridge for manifest-backed commands and queries.
19
+ - Added the Go adapter MVP with a real `go-billing` conformance example.
20
+ - Emitted external service metadata into inspect/API/agent artifacts, including `needsApproval` for agent tools.
21
+ - Reuse compiler classifier package signals across export classification, dropping repeated package signal scans.
22
+ - Reuse serialized graph JSON when rendering the largest generated TypeScript graph artifacts.
23
+ - Keep generated Forge artifacts aligned with the `0.1.0-alpha.9` compiler/runtime version.
24
+
25
+ ## 0.1.0-alpha.8
26
+
27
+ ### Patch Changes
28
+
29
+ - [`7568756`](https://github.com/Stahldavid/forge/commit/756875688873dd60d3d6cf700a7bb7c211968c69) Thanks [@Stahldavid](https://github.com/Stahldavid)! - Publish prerelease packages through the ForgeOS alpha publisher so npm dist-tags stay aligned.
30
+
31
+ ## 0.1.0-alpha.7
32
+
33
+ ### Patch Changes
34
+
35
+ - [`4ace311`](https://github.com/Stahldavid/forge/commit/4ace3113e3298b5c306000870922fcfbae9c1861) Thanks [@Stahldavid](https://github.com/Stahldavid)! - Keep npm prerelease publishing on the public alpha dist-tag.
36
+
37
+ ## 0.1.0-alpha.6
38
+
39
+ ### Patch Changes
40
+
41
+ - [`c30f906`](https://github.com/Stahldavid/forge/commit/c30f9069c99ac747ce143ab5fbcbf13912ed8760) Thanks [@Stahldavid](https://github.com/Stahldavid)! - Add CLI version output, align create-app help with package metadata, and add release dependency audit evidence.
42
+
43
+ ## 0.1.0-alpha.5
44
+
45
+ Release alignment for the public alpha channel:
46
+
47
+ - Added `forge ai redteam --model-level --json` with deterministic prompt-injection, secret-exfiltration, approval-bypass, cross-tenant, and indirect tool-injection probes.
48
+ - Added `forge security prove --full --json` support for source checkouts, with graceful structural-proof fallback when packaged apps do not include ForgeOS test fixtures.
49
+ - Strengthened npm publish workflows to run `security prove --db postgres --full --json`.
50
+ - Added public registry smoke coverage for `forgeos@alpha` and `create-forgeos-app@alpha`.
51
+ - Bumped the create-app wrapper package line to `create-forgeos-app@0.1.0-alpha.1`.
52
+
53
+ ## 0.1.0-alpha.4
54
+
55
+ Security assurance and release evidence hardening:
56
+
57
+ - Added value-aware telemetry redaction for known secret values in safe-looking fields, messages, details, outputs, and stack traces.
58
+ - Added webhook signature, timestamp, and replay protection helpers with Stripe/GitHub/generic HMAC coverage.
59
+ - Added HTTP tenant-isolation tests that exercise the dev server/API boundary, not only the internal runtime executor.
60
+ - Added `forge rls mutate-test --json` to kill dangerous generated RLS mutations such as missing FORCE RLS, missing policies, unconditional predicates, and `BYPASSRLS`.
61
+ - Extended `forge security prove --json` with RLS mutation proof and invariant-level evidence metadata.
62
+ - Added scripts to split security evidence by invariant and emit basic release supply-chain evidence plus CycloneDX SBOM.
63
+ - Strengthened publish/security workflows so release gates use Postgres-backed security proof, RLS mutation proof, release evidence, and SBOM generation.
64
+
65
+ ## 0.1.0-alpha.3
66
+
67
+ Native Forge AI agents on top of Vercel AI SDK v6:
68
+
69
+ - Added `aiTool` and `agent` primitives with generated `agentTools.json` / `agentTools.md`.
70
+ - Added `ctx.agent.run` and `ctx.ai.runAgent` using AI SDK `ToolLoopAgent`.
71
+ - Added auto-tools for commands, queries, and liveQueries with read-only vs approval-required writes.
72
+ - Added dev agent endpoints: `POST /ai/agents/run` and `POST /ai/agents/chat`.
73
+ - Extended `forge ai` CLI with `tools`, `agents`, and `trace` subcommands.
74
+ - Added `forge inspect agent-tools` and agent tool metadata in `agentContract.json`.
75
+ - Upgraded runtime dependency to AI SDK v6 for tool calling, streaming UI, and MCP compatibility.
76
+
77
+ Documentation:
78
+
79
+ - Added public [AI](https://forgeos.readthedocs.io/en/latest/ai/) page and AST-aware `rename command` codemod docs.
80
+ - Expanded ReadTheDocs to full agent-native coverage: agent workflow (`forge do`), frontend/liveQuery, security/data, authoring, testing/repair, self-host, templates, Material theme, and changelog page.
81
+
82
+ ## 0.1.0-alpha.2
83
+
84
+ Windows and generated-app hardening:
85
+
86
+ - Fixed Node ESM handler loading on Windows by importing generated app modules
87
+ through `file://` URLs across commands, queries, liveQueries, outbox actions,
88
+ workflow steps, mocks, and telemetry adapters.
89
+ - Fixed `forge dev` SSE streaming on the Node HTTP fallback so liveQuery
90
+ snapshots are flushed immediately instead of buffering forever.
91
+ - Hardened generated app scaffolding and web dev spawning on Windows.
92
+ - Updated the B2B support template to route frontend imports through
93
+ `web/lib/forge.ts` and use safer handler input validation.
94
+ - Added focused tests for Node compatibility, template scaffolding, runtime
95
+ imports, and streaming responses.
96
+
97
+ ## 0.1.0-alpha.1
98
+
99
+ Republish alpha with the dependency/API oracle improvements:
100
+
101
+ - Added dependency API inspection commands for agents:
102
+ `forge deps api`, `forge deps trace`, and `forge deps runtime-compat`.
103
+ - Added dependency API summaries to `agentContract.json`.
104
+ - Added package resolution traces, runtime compatibility metadata, and
105
+ runtime/type mismatch diagnostics to `packageGraph`.
106
+ - Reduced package graph warning noise for `package.json` metadata exports,
107
+ declaration-file subpaths, and pattern exports.
108
+
3
109
  ## 0.1.0-alpha.0
4
110
 
5
111
  Initial alpha packaging baseline for ForgeOS.
6
112
 
7
113
  This release line is intended to validate npm installation, the `forge` CLI binary,
8
114
  template creation, generated contracts, and the agent-native local development loop.
115
+
116
+ Added ReadTheDocs-ready public documentation, generator/package version alignment
117
+ checks, and a broad generated-app field-test harness for release hardening.
package/CONTRIBUTING.md CHANGED
@@ -9,8 +9,29 @@ bun run typecheck
9
9
  bun test --timeout 120000
10
10
  node ./bin/forge.mjs verify --standard --script-timeout-ms 120000
11
11
  npm run release:smoke
12
+ npm run field:test -- --dry-run --json
12
13
  ```
13
14
 
15
+ Run a real external-app smoke before release candidates:
16
+
17
+ ```bash
18
+ npm run field:test -- --package-managers npm --templates minimal-web --forge-spec "file:." --install --json
19
+ ```
20
+
21
+ Use the GitHub Actions `Field Tests` workflow for the broader OS, Node, package-manager matrix.
22
+
23
+ ## Documentation
24
+
25
+ Public docs are built with MkDocs on ReadTheDocs. The configuration lives in:
26
+
27
+ ```txt
28
+ .readthedocs.yaml
29
+ mkdocs.yml
30
+ docs/**
31
+ ```
32
+
33
+ Keep `docs/getting-started.md`, `docs/cli.md`, and `docs/field-testing.md` current when changing install, template, or verification behavior.
34
+
14
35
  ## Changesets
15
36
 
16
37
  For changes that should be published, add a changeset:
@@ -36,7 +57,7 @@ Configure the npm package `forgeos` with:
36
57
  | Environment | blank |
37
58
  | Allowed action | `npm publish` |
38
59
 
39
- Do not configure `NPM_TOKEN` for normal releases. The publish workflow uses GitHub OIDC with `id-token: write`, Node 24, npm 11+, and provenance.
60
+ Do not configure `NPM_TOKEN` for normal releases. The publish workflow uses GitHub OIDC with `id-token: write`, Node 24, npm 11+, and provenance. In npm package settings, prefer "Require two-factor authentication and disallow tokens"; Trusted Publishers continue to work with that stricter token setting.
40
61
 
41
62
  ## Manual Publish
42
63
 
package/README.md CHANGED
@@ -2,7 +2,11 @@
2
2
 
3
3
  Agent-native application framework and compiler for building Forge apps without a mandatory dashboard. ForgeOS turns application source into deterministic runtime contracts, generated clients, safety checks, and machine-readable context that humans and AI coding agents can use safely.
4
4
 
5
- **Status:** private MVP, implemented through H42. The core compiler, local runtime, frontend SDK, production auth, RLS compiler, repair/review loops, UI test bridge, guided intent router, full-stack capability map, clean templates, faster generated checks, showcase app, Windows-safe Bun resolution, native Windows diagnostics/setup, Node-compatible CLI/runtime paths, observable verify timeouts, multi-OS Node CI smoke, release packaging smoke, AST-aware codemods for `extract-action`, `rename field`, and `rename table`, and quieter template workspaces are present. Public release still needs deeper semantic codemods and final npm Trusted Publisher activation.
5
+ **Status:** private/public alpha MVP, implemented through H43. ForgeOS already includes the compiler, local runtime, frontend SDK, production auth, RLS compiler, liveQuery, self-host artifacts, generated agent contract, guided dev loop, repair/review/test tooling, AST-aware codemods, package intelligence, native AI tools/agents, npm alpha publishing, and Read the Docs public docs. Public release hardening is still focused on deeper semantic codemods, broader field reports, and more production mileage.
6
+
7
+ Public docs live at [forgeos.readthedocs.io](https://forgeos.readthedocs.io/). The repo builds them with `.readthedocs.yaml`, `mkdocs.yml`, and `docs/index.md`.
8
+
9
+ Start with [Why ForgeOS](https://forgeos.readthedocs.io/en/latest/why-forgeos/) to understand the agent-native design.
6
10
 
7
11
  ## Agent-First Quickstart
8
12
 
@@ -42,6 +46,22 @@ These files describe the app surface, runtime rules, generated files, policies,
42
46
 
43
47
  ## Create a Test App
44
48
 
49
+ Public one-command app creation:
50
+
51
+ ```bash
52
+ npm create forgeos-app@alpha notes-app -- --template minimal-web
53
+ cd notes-app
54
+ npm run dev
55
+ ```
56
+
57
+ Equivalent lower-level command without installing ForgeOS globally:
58
+
59
+ ```bash
60
+ npm exec --package forgeos@alpha -- forge new notes-app --template minimal-web --package-manager npm
61
+ ```
62
+
63
+ If ForgeOS is already installed or you are inside this repository:
64
+
45
65
  ```bash
46
66
  forge new notes-app --template minimal-web --package-manager npm
47
67
  cd notes-app
@@ -56,11 +76,49 @@ Templates also include workspace editor excludes for generated/runtime directori
56
76
  For release or external smoke testing, choose the Forge package source explicitly:
57
77
 
58
78
  ```bash
59
- forge new smoke-app --template minimal-web --package-manager npm --forge-spec "npm:forgeos@^0.1.0-alpha.0"
79
+ forge new smoke-app --template minimal-web --package-manager npm --forge-spec "npm:forgeos@alpha"
60
80
  forge new local-app --template minimal-web --package-manager npm --local-forge
61
81
  ```
62
82
 
63
- `--forge-spec` writes that dependency spec into the generated app, while `--local-forge` keeps the monorepo/local package workflow. The npm package is published as `forgeos`, but generated apps keep the dependency key, CLI binary, and import surface as `forge` (`forge`, `forge/server`, `forge/react`) by using npm alias specs such as `"forge": "npm:forgeos@^0.1.0-alpha.0"`. CI uses both `--forge-spec "file:$GITHUB_WORKSPACE"` and a packed tarball smoke to prove freshly created apps can install ForgeOS and run outside the framework workspace.
83
+ `--forge-spec` writes that dependency spec into the generated app, while `--local-forge` keeps the monorepo/local package workflow. The npm package is published as `forgeos`, but generated apps keep the dependency key, CLI binary, and import surface as `forge` (`forge`, `forge/server`, `forge/react`) by using npm alias specs such as `"forge": "npm:forgeos@alpha"`. CI uses both `--forge-spec "file:$GITHUB_WORKSPACE"` and a packed tarball smoke to prove freshly created apps can install ForgeOS and run outside the framework workspace.
84
+
85
+ For broader field testing:
86
+
87
+ ```bash
88
+ npm run field:test -- --dry-run --json
89
+ npm run field:test -- --package-managers npm --templates minimal-web --forge-spec "file:." --install --json
90
+ ```
91
+
92
+ The scheduled/manual `Field Tests` workflow expands that coverage across Linux, macOS, Windows, Node 22, Node 24, and npm/pnpm/yarn/bun.
93
+
94
+ ## External Runtimes And Go Adapter
95
+
96
+ ForgeOS can import services written outside TypeScript through the Forge Protocol.
97
+ External runtimes publish a `forge.manifest.json` that describes commands, queries,
98
+ transport, policies, risk metadata, tenant scope, and schemas. Forge then emits
99
+ the same machine-readable app/API/agent artifacts and exposes runtime bridge
100
+ endpoints for those entries.
101
+
102
+ The first adapter MVP is Go:
103
+
104
+ ```bash
105
+ cd examples/go-billing
106
+ go run . --manifest --base-url http://127.0.0.1:8787 > forge.manifest.json
107
+ go run . --addr 127.0.0.1:8787 --base-url http://127.0.0.1:8787
108
+ ```
109
+
110
+ In a Forge app:
111
+
112
+ ```bash
113
+ forge manifest validate ./forge.manifest.json --json
114
+ forge manifest import ./forge.manifest.json --json
115
+ forge generate
116
+ forge run billing.createInvoice --args '{"title":"Invoice"}' --user-id u1 --tenant-id tenant-a --role admin
117
+ forge query billing.listInvoices --args '{}' --user-id u1 --tenant-id tenant-a --role admin
118
+ ```
119
+
120
+ See [`docs/forge-protocol.md`](docs/forge-protocol.md), [`schemas/forge-manifest.schema.json`](schemas/forge-manifest.schema.json),
121
+ and [`adapters/go`](adapters/go/README.md).
64
122
 
65
123
  ## What ForgeOS Generates
66
124
 
@@ -111,7 +169,7 @@ forge.lock
111
169
  | Auth | dev headers, JWT, OIDC discovery/JWKS verification via `jose`, production-mode guardrails |
112
170
  | RLS | Postgres RLS SQL compiler/checks for DB-enforced tenant isolation |
113
171
  | Secrets/env | secret registry, env schema, redaction, strict `process.env` checks |
114
- | AI | provider registry, `ctx.ai`, mock mode, telemetry without prompt/output retention by default |
172
+ | AI | Vercel AI SDK v6 engine, provider registry, `ctx.ai`, `ctx.agent.run`, `aiTool`, `agent`, `/ai/agents/run` JSON automation, `/ai/agents/chat` UIMessage streaming, `forge ai trace`, structural and model-level redteam probes, mock mode, telemetry without prompt/output retention by default |
115
173
  | Frontend | generated client SDK, React/Next hooks, template app, liveQuery client support |
116
174
  | LiveQuery | durable invalidation log, reconnect/resume semantics, production hardening checks |
117
175
  | Self-host | compose/deploy artifacts and self-host checks |
@@ -187,6 +245,7 @@ Common command groups:
187
245
  Refactor codemods are AST-aware where safety matters most:
188
246
 
189
247
  - `forge refactor extract-action` is binding-aware and preserves unrelated imports, type-only imports, and shadowed locals.
248
+ - `forge refactor rename command <oldName> <newName>` rewrites command declarations, generated client references, React hook usage, tests, and safe string references while preserving unrelated symbols.
190
249
  - `forge refactor rename field <table.field> <table.field>` rewrites structured TS/JS/JSX/TSX and JSON references, preserves locals, and scopes the field change to files/objects linked to the target table. For example, `tickets.priority -> tickets.urgency` does not rewrite a generic `priority` prop in a component with no `tickets` binding.
191
250
  - `forge refactor rename table <from> <to>` rewrites table definitions, `ctx.db.<table>` access, policy strings, JSON/blueprints, and import/export specifiers while preserving unrelated locals with the same name.
192
251
 
@@ -215,12 +274,23 @@ See [`examples/showcase-forge-app`](examples/showcase-forge-app/README.md).
215
274
 
216
275
  ```bash
217
276
  cd examples/showcase-forge-app
218
- bun install
219
- bun run generate
220
- bun run dev
277
+ npm install
278
+ npm run generate
279
+ npm run dev
280
+ ```
281
+
282
+ For the reproducible public proof path:
283
+
284
+ ```bash
285
+ npm run proof:inspect
286
+ npm run proof:dev
287
+ npm run proof:capabilities
288
+ npm run proof:verify
221
289
  ```
222
290
 
223
- Examples are source-only where practical: generated artifacts, `forge.lock`, package lockfiles, and operational `.forge/**` state are recreated locally. The showcase demonstrates tenant-scoped data, policies, commands, queries, liveQueries, outbox actions, workflows, mock AI, telemetry trace IDs, generated React hooks, `agentContract`, `frontendGraph`, and `capabilityMap`.
291
+ Read [`examples/showcase-forge-app/PUBLIC_PROOF.md`](examples/showcase-forge-app/PUBLIC_PROOF.md) for the full walkthrough.
292
+
293
+ Examples are source-only where practical: generated artifacts, `forge.lock`, package lockfiles, and operational `.forge/**` state are recreated locally. The showcase demonstrates tenant-scoped data, policies, commands, queries, liveQueries, outbox actions, workflows, mock AI, telemetry trace IDs, generated React hooks, `agentContract`, `frontendGraph`, `capabilityMap`, and the standard agent handoff loop.
224
294
 
225
295
  ## Platform Support
226
296
 
@@ -296,7 +366,7 @@ For the first prerelease publish, use the alpha dist-tag explicitly:
296
366
 
297
367
  ```bash
298
368
  npm run release:publish-local-alpha -- --dry-run
299
- npm run release:publish-local-alpha -- --yes
369
+ npm run release:publish-alpha
300
370
  ```
301
371
 
302
372
  The normal path is:
@@ -319,7 +389,7 @@ Configure npm Trusted Publisher for package `forgeos`:
319
389
  | Environment | blank |
320
390
  | Allowed action | `npm publish` |
321
391
 
322
- Do not add `NPM_TOKEN` for normal releases. Alpha releases publish with the `alpha` dist-tag so prerelease builds do not become `latest` accidentally. The first manual package creation uses `release:publish-local-alpha`, which publishes from a temporary hardlink-free staging copy and disables provenance because local shells do not have a GitHub OIDC provider. The workflow uses `id-token: write`, Node 24/npm 11+, and provenance for subsequent releases. `npm run release:smoke` runs `npm pack`, creates a fresh app with the packed tarball, installs dependencies, runs `forge dev --once --json`, and verifies the app smoke path.
392
+ Do not add `NPM_TOKEN` for normal releases. Alpha releases publish with the `alpha` dist-tag so prerelease builds do not become `latest` accidentally. Use `release:publish-local-alpha -- --dry-run` only to validate the staged tarball locally; real npm publishing should go through `release:publish-alpha`, which dispatches `publish.yml` and uses npm OIDC Trusted Publisher. The workflow checks whether the package version already exists before installing dependencies or running tests, then uses `id-token: write`, Node 24/npm 11+, and provenance for the actual publish. `npm run release:smoke` runs `npm pack`, creates a fresh app with the packed tarball, installs dependencies, runs `forge dev --once --json`, and verifies the app smoke path.
323
393
 
324
394
  ## Milestone History
325
395
 
@@ -366,11 +436,12 @@ H39 Showcase app
366
436
  H40 Windows/runtime hardening
367
437
  H41 Node-compatible CLI/runtime
368
438
  H42 Verify observability and quieter app workspaces
439
+ H43 Native AI tools and agent loop
369
440
  ```
370
441
 
371
442
  ## Remaining Hardening Before Public Release
372
443
 
373
- - Keep expanding semantic codemods beyond the current AST-aware `extract-action`, `rename field`, and `rename table` paths.
444
+ - Keep expanding semantic codemods beyond the current AST-aware `extract-action`, `rename command`, `rename field`, and `rename table` paths.
374
445
  - Reduce command-selection risk with more task routers and richer inline diagnostics.
375
446
  - Keep hardening native Windows setup beyond diagnostics and safe automatic environment fixes.
376
447
  - Keep broadening package manager CI from template smoke toward install/build smoke for pnpm and yarn apps.
@@ -0,0 +1,23 @@
1
+ # Forge Go Adapter
2
+
3
+ `adapters/go` is the minimal Go SDK for external Forge runtimes. It registers
4
+ commands and queries, emits `forge.manifest.json`, and exposes a Forge-compatible
5
+ HTTP handler.
6
+
7
+ ```go
8
+ app := forge.New("billing", forge.BaseURL("http://127.0.0.1:8787"))
9
+
10
+ app.Command("createInvoice", forge.Handle(createInvoice),
11
+ forge.Policy("billing.manage"),
12
+ forge.TenantScoped(true),
13
+ forge.NeedsApproval(true),
14
+ )
15
+
16
+ app.Query("listInvoices", forge.Handle(listInvoices),
17
+ forge.Policy("billing.manage"),
18
+ forge.TenantScoped(true),
19
+ )
20
+ ```
21
+
22
+ The HTTP handler accepts Forge runtime envelopes on `/commands/:name` and
23
+ `/queries/:name`, then returns `{ "ok": true, "result": ... }` envelopes.
@@ -0,0 +1,3 @@
1
+ module github.com/Stahldavid/forge/adapters/go
2
+
3
+ go 1.22
@@ -0,0 +1,149 @@
1
+ package forge
2
+
3
+ import (
4
+ "encoding/json"
5
+ "errors"
6
+ "net/http"
7
+ "strings"
8
+ )
9
+
10
+ func (registry *Registry) HTTPHandler() http.Handler {
11
+ mux := http.NewServeMux()
12
+ mux.HandleFunc(registry.service.Health, registry.handleHealth)
13
+ mux.HandleFunc("/manifest", registry.handleManifest)
14
+ mux.HandleFunc("/commands/", registry.handleRuntime(KindCommand, "/commands/"))
15
+ mux.HandleFunc("/queries/", registry.handleRuntime(KindQuery, "/queries/"))
16
+ return mux
17
+ }
18
+
19
+ func (registry *Registry) handleHealth(response http.ResponseWriter, request *http.Request) {
20
+ writeJSON(response, http.StatusOK, map[string]any{
21
+ "ok": true,
22
+ "service": registry.service.Name,
23
+ })
24
+ }
25
+
26
+ func (registry *Registry) handleManifest(response http.ResponseWriter, request *http.Request) {
27
+ baseURL := request.URL.Query().Get("baseUrl")
28
+ if baseURL == "" {
29
+ baseURL = registry.service.BaseURL
30
+ }
31
+ writeJSON(response, http.StatusOK, registry.Manifest(baseURL))
32
+ }
33
+
34
+ func (registry *Registry) handleRuntime(kind EntryKind, prefix string) http.HandlerFunc {
35
+ return func(response http.ResponseWriter, request *http.Request) {
36
+ name := strings.TrimPrefix(request.URL.Path, prefix)
37
+ registered, ok := registry.lookup[lookupKey(kind, name)]
38
+ if !ok {
39
+ writeError(response, http.StatusNotFound, "", "FORGE_GO_ENTRY_NOT_FOUND", "external entry not found")
40
+ return
41
+ }
42
+ if request.Method != http.MethodPost && request.Method != http.MethodGet {
43
+ writeError(response, http.StatusMethodNotAllowed, "", "FORGE_GO_METHOD_NOT_ALLOWED", "external entry only accepts GET or POST")
44
+ return
45
+ }
46
+
47
+ envelope, err := readRequestEnvelope(request)
48
+ traceID := traceIDFrom(request, envelope)
49
+ if err != nil {
50
+ writeError(response, http.StatusBadRequest, traceID, "FORGE_GO_BAD_REQUEST", err.Error())
51
+ return
52
+ }
53
+ if envelope.Forge.Service == "" {
54
+ envelope.Forge.Service = registry.service.Name
55
+ }
56
+ if envelope.Forge.Entry == "" {
57
+ envelope.Forge.Entry = name
58
+ }
59
+ if envelope.Forge.Kind == "" {
60
+ envelope.Forge.Kind = string(kind)
61
+ }
62
+ if envelope.Forge.TraceID == "" {
63
+ envelope.Forge.TraceID = traceID
64
+ }
65
+ if envelope.Auth.Kind == "" {
66
+ envelope.Auth = authFromHeaders(request.Header)
67
+ }
68
+
69
+ call := &Context{
70
+ Auth: envelope.Auth,
71
+ Forge: envelope.Forge,
72
+ Headers: request.Header,
73
+ }
74
+ result, err := registered.handler(request.Context(), call, envelope.Args)
75
+ if err != nil {
76
+ writeError(response, http.StatusInternalServerError, envelope.Forge.TraceID, "FORGE_GO_HANDLER_FAILED", err.Error())
77
+ return
78
+ }
79
+ writeJSON(response, http.StatusOK, ResponseEnvelope{
80
+ OK: true,
81
+ Result: result,
82
+ TraceID: envelope.Forge.TraceID,
83
+ })
84
+ }
85
+ }
86
+
87
+ func readRequestEnvelope(request *http.Request) (RequestEnvelope, error) {
88
+ if request.Method == http.MethodGet {
89
+ args := request.URL.Query().Get("args")
90
+ if args == "" {
91
+ args = "{}"
92
+ }
93
+ return RequestEnvelope{Args: json.RawMessage(args)}, nil
94
+ }
95
+ defer request.Body.Close()
96
+ var envelope RequestEnvelope
97
+ decoder := json.NewDecoder(request.Body)
98
+ if err := decoder.Decode(&envelope); err != nil {
99
+ return envelope, err
100
+ }
101
+ if len(envelope.Args) == 0 {
102
+ envelope.Args = json.RawMessage("{}")
103
+ }
104
+ if !json.Valid(envelope.Args) {
105
+ return envelope, errors.New("request args must be valid JSON")
106
+ }
107
+ return envelope, nil
108
+ }
109
+
110
+ func authFromHeaders(headers http.Header) Auth {
111
+ auth := Auth{Kind: headers.Get("x-forge-auth-kind")}
112
+ if auth.Kind == "" {
113
+ auth.Kind = "anonymous"
114
+ }
115
+ auth.UserID = headers.Get("x-forge-user-id")
116
+ auth.TenantID = headers.Get("x-forge-tenant-id")
117
+ auth.Role = headers.Get("x-forge-role")
118
+ return auth
119
+ }
120
+
121
+ func traceIDFrom(request *http.Request, envelope RequestEnvelope) string {
122
+ if envelope.Forge.TraceID != "" {
123
+ return envelope.Forge.TraceID
124
+ }
125
+ return request.Header.Get("x-forge-trace-id")
126
+ }
127
+
128
+ func writeError(response http.ResponseWriter, status int, traceID string, code string, message string) {
129
+ writeJSON(response, status, ResponseEnvelope{
130
+ OK: false,
131
+ Diagnostics: []Diagnostic{{
132
+ Severity: "error",
133
+ Code: code,
134
+ Message: message,
135
+ Docs: []string{"docs/forge-protocol.md"},
136
+ }},
137
+ Error: &ErrorInfo{
138
+ Code: code,
139
+ Message: message,
140
+ },
141
+ TraceID: traceID,
142
+ })
143
+ }
144
+
145
+ func writeJSON(response http.ResponseWriter, status int, body any) {
146
+ response.Header().Set("content-type", "application/json")
147
+ response.WriteHeader(status)
148
+ _ = json.NewEncoder(response).Encode(body)
149
+ }