spine-framework 0.2.1 → 1.0.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 (425) hide show
  1. package/LICENSE.md +213 -8
  2. package/README.md +327 -0
  3. package/package.json +107 -217
  4. package/src/cli/commands/init.ts +192 -0
  5. package/src/cli/commands/install.ts +25 -0
  6. package/src/cli/commands/list.ts +33 -0
  7. package/src/cli/commands/migrate.ts +24 -0
  8. package/src/cli/index.ts +46 -0
  9. package/src/components/AppLayout.tsx +21 -0
  10. package/src/components/AuthGuard.tsx +21 -0
  11. package/src/components/RoleGuard.tsx +23 -0
  12. package/src/components/index.ts +3 -0
  13. package/src/contexts/AppContext.tsx +122 -0
  14. package/src/contexts/AuthContext.tsx +87 -0
  15. package/src/contexts/SpineContext.tsx +46 -0
  16. package/src/contexts/index.ts +3 -0
  17. package/src/hooks/index.ts +4 -0
  18. package/src/hooks/useItems.ts +78 -0
  19. package/src/hooks/useThreads.ts +73 -0
  20. package/src/hooks/useWebSocket.ts +97 -0
  21. package/src/index.ts +22 -0
  22. package/src/types/index.ts +163 -0
  23. package/src/utils/api.ts +88 -0
  24. package/src/utils/client.ts +146 -0
  25. package/src/utils/config.ts +20 -0
  26. package/src/utils/index.ts +3 -0
  27. package/.framework/README.md +0 -129
  28. package/.framework/cli/bin.cjs +0 -14
  29. package/.framework/cli/commands/agents.ts +0 -153
  30. package/.framework/cli/commands/auth.ts +0 -94
  31. package/.framework/cli/commands/create-app.ts +0 -185
  32. package/.framework/cli/commands/dev.ts +0 -113
  33. package/.framework/cli/commands/doctor.ts +0 -442
  34. package/.framework/cli/commands/generate.ts +0 -332
  35. package/.framework/cli/commands/init.ts +0 -186
  36. package/.framework/cli/commands/install-app.ts +0 -565
  37. package/.framework/cli/commands/items.ts +0 -253
  38. package/.framework/cli/commands/migrate.ts +0 -139
  39. package/.framework/cli/commands/migrations.ts +0 -141
  40. package/.framework/cli/commands/pipelines.ts +0 -166
  41. package/.framework/cli/commands/status.ts +0 -197
  42. package/.framework/cli/commands/system.ts +0 -184
  43. package/.framework/cli/commands/test.ts +0 -227
  44. package/.framework/cli/commands/uninstall-app.ts +0 -166
  45. package/.framework/cli/context.ts +0 -268
  46. package/.framework/cli/env-loader.ts +0 -36
  47. package/.framework/cli/index.ts +0 -116
  48. package/.framework/cli/welcome.cjs +0 -45
  49. package/.framework/docs/API.md +0 -384
  50. package/.framework/docs/STABILITY.md +0 -52
  51. package/.framework/docs/admin-routes.md +0 -76
  52. package/.framework/docs/api-docs-progress.md +0 -38
  53. package/.framework/docs/api-governance.md +0 -146
  54. package/.framework/docs/api-testing-results.md +0 -212
  55. package/.framework/docs/apis/admin-configs.md +0 -567
  56. package/.framework/docs/apis/admin-data.md +0 -272
  57. package/.framework/docs/apis/index.md +0 -231
  58. package/.framework/docs/apis/internal.md +0 -295
  59. package/.framework/docs/apis/runtime.md +0 -537
  60. package/.framework/docs/assembly-launch-guide.md +0 -138
  61. package/.framework/docs/audit-results.md +0 -590
  62. package/.framework/docs/authorization-model.md +0 -170
  63. package/.framework/docs/db-api-inventory.md +0 -95
  64. package/.framework/docs/examples/custom-app/README.md +0 -77
  65. package/.framework/docs/examples/custom-function/README.md +0 -27
  66. package/.framework/docs/examples/custom-function/handler.ts +0 -48
  67. package/.framework/docs/examples/custom-webhook/README.md +0 -68
  68. package/.framework/docs/gap-remediation-backlog.md +0 -103
  69. package/.framework/docs/guides/cli-guide.md +0 -224
  70. package/.framework/docs/guides/getting-started.md +0 -103
  71. package/.framework/docs/guides/import-guide.md +0 -193
  72. package/.framework/docs/guides/testing-guide.md +0 -229
  73. package/.framework/docs/permission-examples.md +0 -326
  74. package/.framework/docs/ui-adoption-verification.md +0 -111
  75. package/.framework/docs/ui-api-coverage.md +0 -84
  76. package/.framework/docs/v2-compatibility-audit.md +0 -228
  77. package/.framework/functions/.gitkeep +0 -1
  78. package/.framework/functions/_shared/agent-runner.ts +0 -1097
  79. package/.framework/functions/_shared/app-manifest.ts +0 -184
  80. package/.framework/functions/_shared/audit.ts +0 -150
  81. package/.framework/functions/_shared/db.ts +0 -178
  82. package/.framework/functions/_shared/index.ts +0 -391
  83. package/.framework/functions/_shared/middleware.ts +0 -490
  84. package/.framework/functions/_shared/permissions.ts +0 -1325
  85. package/.framework/functions/_shared/pipeline-runner.ts +0 -731
  86. package/.framework/functions/_shared/principal.ts +0 -818
  87. package/.framework/functions/_shared/resolve-ids.ts +0 -106
  88. package/.framework/functions/_shared/schema-utils.ts +0 -967
  89. package/.framework/functions/_shared/testing.ts +0 -258
  90. package/.framework/functions/_shared/trigger-engine.ts +0 -425
  91. package/.framework/functions/_shared/webhook-registration.ts +0 -168
  92. package/.framework/functions/_shared/webhook-registry.ts +0 -129
  93. package/.framework/functions/account-nodes.ts +0 -111
  94. package/.framework/functions/admin-data.ts +0 -606
  95. package/.framework/functions/ai-agents.ts +0 -323
  96. package/.framework/functions/api-keys.ts +0 -376
  97. package/.framework/functions/apps.ts +0 -483
  98. package/.framework/functions/auth.ts +0 -196
  99. package/.framework/functions/debug-auth.ts +0 -107
  100. package/.framework/functions/embeddings.ts +0 -556
  101. package/.framework/functions/integration-routes.ts +0 -523
  102. package/.framework/functions/integrations.ts +0 -319
  103. package/.framework/functions/item-progress.ts +0 -272
  104. package/.framework/functions/logs.ts +0 -438
  105. package/.framework/functions/observability.ts +0 -275
  106. package/.framework/functions/pipeline-executions.ts +0 -494
  107. package/.framework/functions/pipelines.ts +0 -485
  108. package/.framework/functions/prompt-configs.ts +0 -339
  109. package/.framework/functions/roles.ts +0 -387
  110. package/.framework/functions/system-cron.ts +0 -742
  111. package/.framework/functions/system.ts +0 -323
  112. package/.framework/functions/tests.ts +0 -119
  113. package/.framework/functions/timers.ts +0 -357
  114. package/.framework/functions/triggers.ts +0 -563
  115. package/.framework/functions/types.ts +0 -604
  116. package/.framework/index.html +0 -16
  117. package/.framework/migrations/000_foundation.sql +0 -1266
  118. package/.framework/migrations/001_seed.sql +0 -163
  119. package/.framework/migrations/002_seed_constraints.sql +0 -19
  120. package/.framework/migrations/003_auth_user_trigger.sql +0 -67
  121. package/.framework/src/App.tsx +0 -133
  122. package/.framework/src/apps/admin/index.tsx +0 -173
  123. package/.framework/src/components/AppWrapper.tsx +0 -56
  124. package/.framework/src/components/CustomAppLoader.tsx +0 -116
  125. package/.framework/src/components/admin/AdminListPage.tsx +0 -151
  126. package/.framework/src/components/admin/AdminSidebar.tsx +0 -166
  127. package/.framework/src/components/admin/AdminStatsCard.tsx +0 -62
  128. package/.framework/src/components/admin/SortableTableHeader.tsx +0 -42
  129. package/.framework/src/components/app-shell/GenericAppShell.tsx +0 -181
  130. package/.framework/src/components/app-shell/GenericDetailPage.tsx +0 -200
  131. package/.framework/src/components/app-shell/GenericListPage.tsx +0 -116
  132. package/.framework/src/components/app-sidebar.tsx +0 -228
  133. package/.framework/src/components/auth/ProtectedRoute.tsx +0 -88
  134. package/.framework/src/components/layout/AppShell.tsx +0 -91
  135. package/.framework/src/components/layout/Header.tsx +0 -88
  136. package/.framework/src/components/layout/Layout.tsx +0 -95
  137. package/.framework/src/components/layout/Sidebar.tsx +0 -329
  138. package/.framework/src/components/runtime/DataDetailHeader.tsx +0 -77
  139. package/.framework/src/components/runtime/DataDetailPage.tsx +0 -171
  140. package/.framework/src/components/runtime/DataFilters.tsx +0 -91
  141. package/.framework/src/components/runtime/DataHeader.tsx +0 -68
  142. package/.framework/src/components/runtime/DataListPage.tsx +0 -124
  143. package/.framework/src/components/runtime/DataStats.tsx +0 -70
  144. package/.framework/src/components/runtime/DataTable.tsx +0 -174
  145. package/.framework/src/components/runtime/SchemaDetailForm.tsx +0 -134
  146. package/.framework/src/components/runtime/index.ts +0 -18
  147. package/.framework/src/components/search-form.tsx +0 -29
  148. package/.framework/src/components/shared/AgentView.tsx +0 -213
  149. package/.framework/src/components/shared/FieldRenderer.tsx +0 -478
  150. package/.framework/src/components/shared/SchemaFields.tsx +0 -226
  151. package/.framework/src/components/ui/DataTable.tsx +0 -343
  152. package/.framework/src/components/ui/Form.tsx +0 -281
  153. package/.framework/src/components/ui/ItemCard.tsx +0 -296
  154. package/.framework/src/components/ui/ItemListView.tsx +0 -308
  155. package/.framework/src/components/ui/LoadingSpinner.tsx +0 -52
  156. package/.framework/src/components/ui/Modal.tsx +0 -61
  157. package/.framework/src/components/ui/RichTextEditor.tsx +0 -210
  158. package/.framework/src/components/ui/accordion.tsx +0 -82
  159. package/.framework/src/components/ui/alert-dialog.tsx +0 -197
  160. package/.framework/src/components/ui/alert.tsx +0 -76
  161. package/.framework/src/components/ui/aspect-ratio.tsx +0 -11
  162. package/.framework/src/components/ui/avatar.tsx +0 -110
  163. package/.framework/src/components/ui/badge.tsx +0 -49
  164. package/.framework/src/components/ui/breadcrumb.tsx +0 -122
  165. package/.framework/src/components/ui/button-group.tsx +0 -83
  166. package/.framework/src/components/ui/button.tsx +0 -65
  167. package/.framework/src/components/ui/calendar.tsx +0 -222
  168. package/.framework/src/components/ui/card.tsx +0 -100
  169. package/.framework/src/components/ui/carousel.tsx +0 -240
  170. package/.framework/src/components/ui/chart.tsx +0 -368
  171. package/.framework/src/components/ui/checkbox.tsx +0 -31
  172. package/.framework/src/components/ui/collapsible.tsx +0 -33
  173. package/.framework/src/components/ui/combobox.tsx +0 -299
  174. package/.framework/src/components/ui/command.tsx +0 -193
  175. package/.framework/src/components/ui/context-menu.tsx +0 -261
  176. package/.framework/src/components/ui/dialog.tsx +0 -165
  177. package/.framework/src/components/ui/direction.tsx +0 -6
  178. package/.framework/src/components/ui/drawer.tsx +0 -132
  179. package/.framework/src/components/ui/dropdown-menu.tsx +0 -269
  180. package/.framework/src/components/ui/empty.tsx +0 -104
  181. package/.framework/src/components/ui/field.tsx +0 -238
  182. package/.framework/src/components/ui/hover-card.tsx +0 -42
  183. package/.framework/src/components/ui/input-group.tsx +0 -153
  184. package/.framework/src/components/ui/input-otp.tsx +0 -87
  185. package/.framework/src/components/ui/input.tsx +0 -19
  186. package/.framework/src/components/ui/item.tsx +0 -196
  187. package/.framework/src/components/ui/kbd.tsx +0 -26
  188. package/.framework/src/components/ui/label.tsx +0 -22
  189. package/.framework/src/components/ui/menubar.tsx +0 -277
  190. package/.framework/src/components/ui/native-select.tsx +0 -61
  191. package/.framework/src/components/ui/navigation-menu.tsx +0 -164
  192. package/.framework/src/components/ui/pagination.tsx +0 -129
  193. package/.framework/src/components/ui/popover.tsx +0 -87
  194. package/.framework/src/components/ui/progress.tsx +0 -31
  195. package/.framework/src/components/ui/radio-group.tsx +0 -42
  196. package/.framework/src/components/ui/resizable.tsx +0 -50
  197. package/.framework/src/components/ui/scroll-area.tsx +0 -53
  198. package/.framework/src/components/ui/select.tsx +0 -195
  199. package/.framework/src/components/ui/separator.tsx +0 -26
  200. package/.framework/src/components/ui/sheet.tsx +0 -145
  201. package/.framework/src/components/ui/sidebar.tsx +0 -706
  202. package/.framework/src/components/ui/skeleton.tsx +0 -13
  203. package/.framework/src/components/ui/slider.tsx +0 -59
  204. package/.framework/src/components/ui/sonner.tsx +0 -47
  205. package/.framework/src/components/ui/spinner.tsx +0 -10
  206. package/.framework/src/components/ui/switch.tsx +0 -33
  207. package/.framework/src/components/ui/table-primitives.tsx +0 -141
  208. package/.framework/src/components/ui/table.tsx +0 -114
  209. package/.framework/src/components/ui/tabs.tsx +0 -90
  210. package/.framework/src/components/ui/textarea.tsx +0 -18
  211. package/.framework/src/components/ui/toggle-group.tsx +0 -89
  212. package/.framework/src/components/ui/toggle.tsx +0 -45
  213. package/.framework/src/components/ui/tooltip.tsx +0 -57
  214. package/.framework/src/contexts/AppContext.tsx +0 -133
  215. package/.framework/src/contexts/AuthContext.tsx +0 -371
  216. package/.framework/src/hooks/use-mobile.ts +0 -19
  217. package/.framework/src/hooks/useApi.ts +0 -526
  218. package/.framework/src/hooks/useApps.ts +0 -114
  219. package/.framework/src/hooks/useEntityList.ts +0 -190
  220. package/.framework/src/hooks/useEntityRecord.ts +0 -308
  221. package/.framework/src/hooks/useForm.ts +0 -307
  222. package/.framework/src/hooks/useListSchema.ts +0 -264
  223. package/.framework/src/hooks/useSchemaRecord.ts +0 -223
  224. package/.framework/src/index.css +0 -128
  225. package/.framework/src/lib/api.ts +0 -156
  226. package/.framework/src/lib/supabase.ts +0 -94
  227. package/.framework/src/lib/utils.ts +0 -317
  228. package/.framework/src/main.tsx +0 -27
  229. package/.framework/src/pages/DashboardPage.tsx +0 -181
  230. package/.framework/src/pages/NotFoundPage.tsx +0 -39
  231. package/.framework/src/pages/admin/AIAgentDetailPage.tsx +0 -161
  232. package/.framework/src/pages/admin/AIAgentsPage.tsx +0 -318
  233. package/.framework/src/pages/admin/APIKeyDetailPage.tsx +0 -199
  234. package/.framework/src/pages/admin/APIKeysPage.tsx +0 -303
  235. package/.framework/src/pages/admin/AlertsConfigPage.tsx +0 -523
  236. package/.framework/src/pages/admin/AppDetailPage.tsx +0 -493
  237. package/.framework/src/pages/admin/AppsPage.tsx +0 -355
  238. package/.framework/src/pages/admin/DesignedPage.tsx +0 -491
  239. package/.framework/src/pages/admin/EmbeddingDetailPage.tsx +0 -534
  240. package/.framework/src/pages/admin/EmbeddingsPage.tsx +0 -424
  241. package/.framework/src/pages/admin/ExtendedShadcnTestPage.tsx +0 -176
  242. package/.framework/src/pages/admin/IncrementalShadcnTestPage.tsx +0 -109
  243. package/.framework/src/pages/admin/IntegratedDashboard.tsx +0 -402
  244. package/.framework/src/pages/admin/IntegrationDetailPage.tsx +0 -187
  245. package/.framework/src/pages/admin/IntegrationsPage.tsx +0 -301
  246. package/.framework/src/pages/admin/LogsPage.tsx +0 -283
  247. package/.framework/src/pages/admin/MinimalShadcnTestPage.tsx +0 -85
  248. package/.framework/src/pages/admin/ObservabilityDashboard.tsx +0 -470
  249. package/.framework/src/pages/admin/PipelineDetailPage.tsx +0 -183
  250. package/.framework/src/pages/admin/PipelineExecutionsPage.tsx +0 -279
  251. package/.framework/src/pages/admin/PipelinesPage.tsx +0 -390
  252. package/.framework/src/pages/admin/PromptConfigDetailPage.tsx +0 -299
  253. package/.framework/src/pages/admin/PromptConfigsPage.tsx +0 -292
  254. package/.framework/src/pages/admin/ProperlyDesignedPage.tsx +0 -434
  255. package/.framework/src/pages/admin/RoleDetailPage.tsx +0 -273
  256. package/.framework/src/pages/admin/RolesPage.tsx +0 -292
  257. package/.framework/src/pages/admin/SelectTestPage.tsx +0 -61
  258. package/.framework/src/pages/admin/ShadcnTestPage.tsx +0 -588
  259. package/.framework/src/pages/admin/SimpleDashboard.tsx +0 -387
  260. package/.framework/src/pages/admin/TestRunDetailPage.tsx +0 -172
  261. package/.framework/src/pages/admin/TestingDashboard.tsx +0 -257
  262. package/.framework/src/pages/admin/TimerDetailPage.tsx +0 -151
  263. package/.framework/src/pages/admin/TimersPage.tsx +0 -376
  264. package/.framework/src/pages/admin/TriggerDetailPage.tsx +0 -149
  265. package/.framework/src/pages/admin/TriggersPage.tsx +0 -381
  266. package/.framework/src/pages/admin/TypeDetailPage.tsx +0 -694
  267. package/.framework/src/pages/admin/TypesPage.tsx +0 -295
  268. package/.framework/src/pages/auth/LoginPage.tsx +0 -187
  269. package/.framework/src/pages/auth/RegisterPage.tsx +0 -163
  270. package/.framework/src/pages/spine-framework/APIPage.tsx +0 -17
  271. package/.framework/src/pages/spine-framework/CLIPage.tsx +0 -25
  272. package/.framework/src/types/auth.ts +0 -125
  273. package/.framework/src/types/types.ts +0 -407
  274. package/STRUCTURE.md +0 -150
  275. package/bin/spine-framework.cjs +0 -62
  276. package/bin/welcome.cjs +0 -45
  277. package/bin/ws-shim.cjs +0 -8
  278. package/bin/ws-shim.ts +0 -10
  279. package/config/components.json +0 -25
  280. package/config/deno.lock +0 -108
  281. package/config/package-lock.json +0 -17183
  282. package/config/postcss.config.cjs +0 -10
  283. package/config/tailwind.config.cjs +0 -78
  284. package/config/tsconfig.build.json +0 -32
  285. package/config/tsconfig.cli.json +0 -18
  286. package/config/tsconfig.json +0 -41
  287. package/config/tsconfig.node.json +0 -17
  288. package/config/tsconfig.node.tsbuildinfo +0 -1
  289. package/config/tsconfig.tsbuildinfo +0 -1
  290. package/config/typedoc.json +0 -16
  291. package/config/vite.config.d.ts +0 -2
  292. package/config/vite.config.ts +0 -71
  293. package/dist/cli/commands/agents.d.ts +0 -39
  294. package/dist/cli/commands/agents.d.ts.map +0 -1
  295. package/dist/cli/commands/auth.d.ts +0 -36
  296. package/dist/cli/commands/auth.d.ts.map +0 -1
  297. package/dist/cli/commands/create-app.d.ts +0 -23
  298. package/dist/cli/commands/create-app.d.ts.map +0 -1
  299. package/dist/cli/commands/dev.d.ts +0 -24
  300. package/dist/cli/commands/dev.d.ts.map +0 -1
  301. package/dist/cli/commands/doctor.d.ts +0 -42
  302. package/dist/cli/commands/doctor.d.ts.map +0 -1
  303. package/dist/cli/commands/generate.d.ts +0 -36
  304. package/dist/cli/commands/generate.d.ts.map +0 -1
  305. package/dist/cli/commands/init.d.ts +0 -20
  306. package/dist/cli/commands/init.d.ts.map +0 -1
  307. package/dist/cli/commands/install-app.d.ts +0 -30
  308. package/dist/cli/commands/install-app.d.ts.map +0 -1
  309. package/dist/cli/commands/items.d.ts +0 -45
  310. package/dist/cli/commands/items.d.ts.map +0 -1
  311. package/dist/cli/commands/migrate.d.ts +0 -21
  312. package/dist/cli/commands/migrate.d.ts.map +0 -1
  313. package/dist/cli/commands/migrations.d.ts +0 -41
  314. package/dist/cli/commands/migrations.d.ts.map +0 -1
  315. package/dist/cli/commands/pipelines.d.ts +0 -40
  316. package/dist/cli/commands/pipelines.d.ts.map +0 -1
  317. package/dist/cli/commands/status.d.ts +0 -23
  318. package/dist/cli/commands/status.d.ts.map +0 -1
  319. package/dist/cli/commands/system.d.ts +0 -29
  320. package/dist/cli/commands/system.d.ts.map +0 -1
  321. package/dist/cli/commands/test.d.ts +0 -46
  322. package/dist/cli/commands/test.d.ts.map +0 -1
  323. package/dist/cli/commands/uninstall-app.d.ts +0 -23
  324. package/dist/cli/commands/uninstall-app.d.ts.map +0 -1
  325. package/dist/cli/context.d.ts +0 -88
  326. package/dist/cli/context.d.ts.map +0 -1
  327. package/dist/cli/env-loader.d.ts +0 -14
  328. package/dist/cli/env-loader.d.ts.map +0 -1
  329. package/dist/cli/index.d.ts +0 -41
  330. package/dist/cli/index.d.ts.map +0 -1
  331. package/dist/functions/_shared/agent-runner.d.ts +0 -156
  332. package/dist/functions/_shared/agent-runner.d.ts.map +0 -1
  333. package/dist/functions/_shared/app-manifest.d.ts +0 -68
  334. package/dist/functions/_shared/app-manifest.d.ts.map +0 -1
  335. package/dist/functions/_shared/audit.d.ts +0 -91
  336. package/dist/functions/_shared/audit.d.ts.map +0 -1
  337. package/dist/functions/_shared/db.d.ts +0 -125
  338. package/dist/functions/_shared/db.d.ts.map +0 -1
  339. package/dist/functions/_shared/index.d.ts +0 -299
  340. package/dist/functions/_shared/index.d.ts.map +0 -1
  341. package/dist/functions/_shared/middleware.d.ts +0 -315
  342. package/dist/functions/_shared/middleware.d.ts.map +0 -1
  343. package/dist/functions/_shared/permissions.d.ts +0 -626
  344. package/dist/functions/_shared/permissions.d.ts.map +0 -1
  345. package/dist/functions/_shared/pipeline-runner.d.ts +0 -124
  346. package/dist/functions/_shared/pipeline-runner.d.ts.map +0 -1
  347. package/dist/functions/_shared/principal.d.ts +0 -284
  348. package/dist/functions/_shared/principal.d.ts.map +0 -1
  349. package/dist/functions/_shared/resolve-ids.d.ts +0 -10
  350. package/dist/functions/_shared/resolve-ids.d.ts.map +0 -1
  351. package/dist/functions/_shared/schema-utils.d.ts +0 -181
  352. package/dist/functions/_shared/schema-utils.d.ts.map +0 -1
  353. package/dist/functions/_shared/testing.d.ts +0 -172
  354. package/dist/functions/_shared/testing.d.ts.map +0 -1
  355. package/dist/functions/_shared/trigger-engine.d.ts +0 -140
  356. package/dist/functions/_shared/trigger-engine.d.ts.map +0 -1
  357. package/dist/functions/_shared/webhook-registration.d.ts +0 -81
  358. package/dist/functions/_shared/webhook-registration.d.ts.map +0 -1
  359. package/dist/functions/_shared/webhook-registry.d.ts +0 -57
  360. package/dist/functions/_shared/webhook-registry.d.ts.map +0 -1
  361. package/dist/functions/account-nodes.d.ts +0 -48
  362. package/dist/functions/account-nodes.d.ts.map +0 -1
  363. package/dist/functions/admin-data.d.ts +0 -178
  364. package/dist/functions/admin-data.d.ts.map +0 -1
  365. package/dist/functions/ai-agents.d.ts +0 -125
  366. package/dist/functions/ai-agents.d.ts.map +0 -1
  367. package/dist/functions/api-keys.d.ts +0 -140
  368. package/dist/functions/api-keys.d.ts.map +0 -1
  369. package/dist/functions/apps.d.ts +0 -163
  370. package/dist/functions/apps.d.ts.map +0 -1
  371. package/dist/functions/auth.d.ts +0 -74
  372. package/dist/functions/auth.d.ts.map +0 -1
  373. package/dist/functions/debug-auth.d.ts +0 -33
  374. package/dist/functions/debug-auth.d.ts.map +0 -1
  375. package/dist/functions/embeddings.d.ts +0 -205
  376. package/dist/functions/embeddings.d.ts.map +0 -1
  377. package/dist/functions/integration-routes.d.ts +0 -45
  378. package/dist/functions/integration-routes.d.ts.map +0 -1
  379. package/dist/functions/integrations.d.ts +0 -124
  380. package/dist/functions/integrations.d.ts.map +0 -1
  381. package/dist/functions/item-progress.d.ts +0 -41
  382. package/dist/functions/item-progress.d.ts.map +0 -1
  383. package/dist/functions/logs.d.ts +0 -162
  384. package/dist/functions/logs.d.ts.map +0 -1
  385. package/dist/functions/observability.d.ts +0 -123
  386. package/dist/functions/observability.d.ts.map +0 -1
  387. package/dist/functions/pipeline-executions.d.ts +0 -190
  388. package/dist/functions/pipeline-executions.d.ts.map +0 -1
  389. package/dist/functions/pipelines.d.ts +0 -171
  390. package/dist/functions/pipelines.d.ts.map +0 -1
  391. package/dist/functions/prompt-configs.d.ts +0 -125
  392. package/dist/functions/prompt-configs.d.ts.map +0 -1
  393. package/dist/functions/roles.d.ts +0 -118
  394. package/dist/functions/roles.d.ts.map +0 -1
  395. package/dist/functions/system-cron.d.ts +0 -65
  396. package/dist/functions/system-cron.d.ts.map +0 -1
  397. package/dist/functions/system.d.ts +0 -29
  398. package/dist/functions/system.d.ts.map +0 -1
  399. package/dist/functions/tests.d.ts +0 -28
  400. package/dist/functions/tests.d.ts.map +0 -1
  401. package/dist/functions/timers.d.ts +0 -139
  402. package/dist/functions/timers.d.ts.map +0 -1
  403. package/dist/functions/triggers.d.ts +0 -203
  404. package/dist/functions/triggers.d.ts.map +0 -1
  405. package/dist/functions/types.d.ts +0 -151
  406. package/dist/functions/types.d.ts.map +0 -1
  407. package/dist/src/types/types.d.ts +0 -364
  408. package/dist/src/types/types.d.ts.map +0 -1
  409. package/index.html +0 -13
  410. package/netlify.toml +0 -36
  411. package/package-project.json +0 -71
  412. package/scripts/app-install-cli.ts +0 -286
  413. package/scripts/assemble-frontend.sh +0 -76
  414. package/scripts/assemble-functions.sh +0 -62
  415. package/scripts/assemble.sh +0 -41
  416. package/scripts/boundary-check.sh +0 -106
  417. package/scripts/build-manifest.sh +0 -80
  418. package/scripts/check-core-integrity.sh +0 -82
  419. package/scripts/ingest-chunks.cjs +0 -202
  420. package/scripts/kb-chunk-parser.cjs +0 -312
  421. package/scripts/kb-chunk-parser.ts +0 -330
  422. package/scripts/load-test-app-install.ts +0 -484
  423. package/scripts/netlify-dev-wrapper.sh +0 -22
  424. package/scripts/verify-integrity.sh +0 -69
  425. package/vitest.config.ts +0 -45
@@ -1,731 +0,0 @@
1
- /**
2
- * @module pipeline-runner
3
- * @audience both
4
- * @layer shared-core
5
- * @stability stable
6
- *
7
- * Sequential pipeline execution engine. A pipeline is a named list of stages
8
- * (`PipelineStage[]`) stored in `pipelines.stages`. Each stage references an
9
- * `action` record by `stage_type` slug. Stages run sequentially; a failed stage
10
- * halts execution unless `stage.continue_on_error` is set.
11
- *
12
- * Every execution creates a `pipeline_executions` row (status: running →
13
- * completed | failed) and emits an audit log on completion or failure.
14
- *
15
- * Built-in stage handlers (no external config required):
16
- * - `update_item` — update a record by ID
17
- * - `create_record` — insert a new record
18
- * - `http_request` — fetch any HTTP endpoint
19
- * - `send_notification`— insert watchers notification rows
20
- * - `run_pipeline` — trigger a nested pipeline (self-recursion blocked)
21
- * - `search_knowledge` — full-text + fallback search on embeddings table
22
- * - `query_items` — filtered query on any table
23
- * - `agent_inference` — call an external LLM webhook or return a mock
24
- *
25
- * INVARIANT: `adminDb` (service role) is used for all DB writes — stage
26
- * execution runs as the pipeline's machine principal, not the end user.
27
- * INVARIANT: `run_pipeline` handler blocks self-referential execution
28
- * (`config._pipelineId === pipeline_id`) to prevent infinite loops.
29
- * INVARIANT: `runPipeline` never throws — failures are captured in the
30
- * returned `ExecutionResult` with `status: 'failed'`.
31
- *
32
- * @seeAlso trigger-engine.ts (calls runPipeline when a trigger fires)
33
- * @seeAlso agent-runner.ts (calls runPipeline for agentic tool calls)
34
- * @seeAlso audit.ts (emitAudit called on pipeline.completed / pipeline.failed)
35
- * @seeAlso index.ts (runPipeline re-exported for v2-custom/ and CLI)
36
- */
37
-
38
- import { CoreContext } from './middleware'
39
- import { adminDb } from './db'
40
- import { emitAudit } from './audit'
41
-
42
- const UUID_RE = /^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i
43
- function isUuid(v: string | undefined | null): v is string { return !!v && UUID_RE.test(v) }
44
-
45
- // ─── TYPES ──────────────────────────────────────────────────────────────
46
-
47
- /**
48
- * Result of a single pipeline stage execution.
49
- *
50
- * @outputSpec stageIndex: number — 0-based position in the pipeline's stages array
51
- * @outputSpec stageType: string — action slug (e.g. 'update_item', 'http_request')
52
- * @outputSpec status: 'success' | 'failed' | 'skipped'
53
- * @outputSpec output: any | undefined — handler return value on success
54
- * @outputSpec error: string | undefined — error message on failure
55
- * @outputSpec durationMs: number — wall-clock time for this stage
56
- */
57
- export interface StageResult {
58
- stageIndex: number
59
- stageType: string
60
- status: 'success' | 'failed' | 'skipped'
61
- output?: any
62
- error?: string
63
- durationMs: number
64
- }
65
-
66
- /**
67
- * Top-level result of a `runPipeline` call. Stored in `pipeline_executions.result`.
68
- *
69
- * @outputSpec executionId: string — UUID of the pipeline_executions row
70
- * @outputSpec pipelineId: string — UUID of the pipeline that was run
71
- * @outputSpec status: 'completed' | 'failed' | 'cancelled'
72
- * @outputSpec stages: StageResult[] — per-stage results in execution order
73
- * @outputSpec durationMs: number — total wall-clock time
74
- * @outputSpec error: string | undefined — top-level error message on failure
75
- */
76
- export interface ExecutionResult {
77
- executionId: string
78
- pipelineId: string
79
- status: 'completed' | 'failed' | 'cancelled'
80
- stages: StageResult[]
81
- durationMs: number
82
- error?: string
83
- }
84
-
85
- /**
86
- * Single stage definition as stored in `pipelines.stages` JSONB array.
87
- *
88
- * @inputSpec stage_type: string — action.slug to look up the handler
89
- * @inputSpec config: Record<string, any> | undefined — merged with action defaults
90
- * @inputSpec continue_on_error: boolean | undefined — if true, failure doesn’t halt
91
- */
92
- interface PipelineStage {
93
- stage_type: string
94
- config?: Record<string, any>
95
- continue_on_error?: boolean
96
- }
97
-
98
- // ─── PRIMARY EXPORT ────────────────────────────────────────────────────────────
99
-
100
- /**
101
- * Executes a pipeline by ID, running its stages sequentially.
102
- *
103
- * Execution lifecycle:
104
- * 1. Load pipeline record (`pipelines` table, `is_active = true`)
105
- * 2. Insert `pipeline_executions` row with `status: 'running'`
106
- * 3. For each stage: load action → merge config → call `executeStage`
107
- * 4. On stage failure: push failed StageResult; stop unless `continue_on_error`
108
- * 5. Update `pipeline_executions` to `completed` or `failed`
109
- * 6. Emit `pipeline.completed` or `pipeline.failed` audit log
110
- * 7. Return `ExecutionResult` (never throws; failures are in result.status)
111
- *
112
- * @param pipelineId - UUID of the pipeline to run (must be active)
113
- * @param triggerData - Arbitrary context passed to each stage as `_triggerData`
114
- * @param ctx - CoreContext with principal and accountId for audit and stage writes
115
- * @returns Promise<ExecutionResult> — always resolves; never throws
116
- * @throws Error('Pipeline not found or inactive') — only if pipeline lookup fails
117
- * before execution begins (throws before creating the execution row)
118
- * @throws Error('Failed to create execution') — if execution row insert fails
119
- * @inputSpec pipelineId: string — valid UUID of a pipeline in pipelines table
120
- * @inputSpec triggerData: any — JSON-serializable; stored in trigger_data column
121
- * @inputSpec ctx.accountId: string | null — stamped on execution row
122
- * @inputSpec ctx.principal.id: string — stamped as created_by on execution row
123
- * @outputSpec ExecutionResult with status, stages, durationMs
124
- * @sideEffects DB write: inserts pipeline_executions row; updates it on completion
125
- * @sideEffects DB write: emitAudit to logs table
126
- * @calledBy trigger-engine.ts (on trigger fire)
127
- * @calledBy agent-runner.ts (tool call dispatch)
128
- * @calledBy stageHandlers.run_pipeline (nested execution)
129
- * @calledBy v2-custom/ import callers and CLI
130
- * @calls executeStage, adminDb, emitAudit
131
- * @testUnit tests/unit/pipeline-runner.test.ts
132
- * @testIntegration tests/integration/pipeline-runner.test.ts
133
- *
134
- * @example API handler trigger
135
- * ```ts
136
- * import { runPipeline } from './_shared/index'
137
- * const result = await runPipeline(body.pipeline_id, body.data, ctx)
138
- * if (result.status === 'failed') return error(result.error!, 500)
139
- * return result
140
- * ```
141
- *
142
- * @example Import usage (v2-custom/)
143
- * ```ts
144
- * import { runPipeline, SYSTEM_PRINCIPAL, adminDb, CoreContext } from '../_shared/index'
145
- * const ctx: CoreContext = { principal: SYSTEM_PRINCIPAL, accountId: MY_ACCOUNT, db: adminDb, requestId: crypto.randomUUID() }
146
- * const result = await runPipeline('pipeline-uuid', { source: 'import' }, ctx)
147
- * ```
148
- */
149
- export async function runPipeline(
150
- pipelineId: string,
151
- triggerData: any,
152
- ctx: CoreContext
153
- ): Promise<ExecutionResult> {
154
- const startTime = Date.now()
155
-
156
- // Load pipeline definition
157
- const { data: pipeline, error: pipelineError } = await adminDb
158
- .from('pipelines')
159
- .select('*')
160
- .eq('id', pipelineId)
161
- .eq('is_active', true)
162
- .single()
163
-
164
- if (pipelineError || !pipeline) {
165
- throw new Error(`Pipeline not found or inactive: ${pipelineId}`)
166
- }
167
-
168
- // Create execution record
169
- const { data: execution, error: execError } = await adminDb
170
- .from('pipeline_executions')
171
- .insert({
172
- pipeline_id: pipelineId,
173
- status: 'running',
174
- trigger_data: triggerData || {},
175
- account_id: ctx.accountId,
176
- created_by: isUuid(ctx.principal?.id) ? ctx.principal?.id : null,
177
- started_at: new Date().toISOString()
178
- })
179
- .select()
180
- .single()
181
-
182
- if (execError || !execution) {
183
- throw new Error(`Failed to create execution: ${execError?.message}`)
184
- }
185
-
186
- const executionId = execution.id
187
- const stageResults: StageResult[] = []
188
- const stages: PipelineStage[] = pipeline.stages || []
189
-
190
- try {
191
- // Execute each stage sequentially
192
- for (let i = 0; i < stages.length; i++) {
193
- const stage = stages[i]
194
- const stageStartTime = Date.now()
195
-
196
- try {
197
- // Load action for this stage type
198
- const { data: action, error: actionError } = await adminDb
199
- .from('actions')
200
- .select('*')
201
- .eq('slug', stage.stage_type)
202
- .eq('is_active', true)
203
- .single()
204
-
205
- if (actionError || !action) {
206
- throw new Error(`Action not found for stage type: ${stage.stage_type}`)
207
- }
208
-
209
- // Merge stage config with action defaults
210
- const mergedConfig = {
211
- ...action.config,
212
- ...stage.config,
213
- _pipelineId: pipelineId,
214
- _executionId: executionId,
215
- _stageIndex: i,
216
- _triggerData: triggerData
217
- }
218
-
219
- // Execute the stage
220
- const output = await executeStage(ctx, action, mergedConfig)
221
-
222
- stageResults.push({
223
- stageIndex: i,
224
- stageType: stage.stage_type,
225
- status: 'success',
226
- output,
227
- durationMs: Date.now() - stageStartTime
228
- })
229
-
230
- } catch (stageError: any) {
231
- const errorMessage = stageError.message || 'Stage execution failed'
232
-
233
- stageResults.push({
234
- stageIndex: i,
235
- stageType: stage.stage_type,
236
- status: 'failed',
237
- error: errorMessage,
238
- durationMs: Date.now() - stageStartTime
239
- })
240
-
241
- // Stop unless continue_on_error is set
242
- if (!stage.continue_on_error) {
243
- throw new Error(`Stage ${i} (${stage.stage_type}) failed: ${errorMessage}`)
244
- }
245
- }
246
- }
247
-
248
- // Complete successfully
249
- const durationMs = Date.now() - startTime
250
-
251
- await adminDb
252
- .from('pipeline_executions')
253
- .update({
254
- status: 'completed',
255
- result: { stages: stageResults },
256
- completed_at: new Date().toISOString(),
257
- duration_ms: durationMs
258
- })
259
- .eq('id', executionId)
260
-
261
- await emitAudit(ctx, 'pipeline.completed', {
262
- type: 'pipeline_execution',
263
- id: executionId,
264
- account_id: ctx.accountId ?? undefined
265
- }, {
266
- pipeline_id: pipelineId,
267
- duration_ms: durationMs,
268
- stages_completed: stageResults.length
269
- })
270
-
271
- return {
272
- executionId,
273
- pipelineId,
274
- status: 'completed',
275
- stages: stageResults,
276
- durationMs
277
- }
278
-
279
- } catch (error: any) {
280
- // Complete with failure
281
- const durationMs = Date.now() - startTime
282
-
283
- await adminDb
284
- .from('pipeline_executions')
285
- .update({
286
- status: 'failed',
287
- result: { stages: stageResults },
288
- error_message: error.message,
289
- completed_at: new Date().toISOString(),
290
- duration_ms: durationMs
291
- })
292
- .eq('id', executionId)
293
-
294
- await emitAudit(ctx, 'pipeline.failed', {
295
- type: 'pipeline_execution',
296
- id: executionId,
297
- account_id: ctx.accountId ?? undefined
298
- }, {
299
- pipeline_id: pipelineId,
300
- error: error.message,
301
- stages_completed: stageResults.length
302
- })
303
-
304
- return {
305
- executionId,
306
- pipelineId,
307
- status: 'failed',
308
- stages: stageResults,
309
- durationMs,
310
- error: error.message
311
- }
312
- }
313
- }
314
-
315
- // ─── STAGE DISPATCH ────────────────────────────────────────────────────────────
316
-
317
- /**
318
- * Dispatches a single stage to the correct handler module.
319
- *
320
- * Routes based on `action.handler_module`:
321
- * - `'functions'` → `executeFunctionHandler` (built-in stageHandlers)
322
- * - `'integrations'` → `executeIntegrationHandler` (loads integration by slug)
323
- * - `'webhook'` → `executeWebhookHandler` (calls action.config.url)
324
- *
325
- * @param ctx - CoreContext
326
- * @param action - Action record from the `actions` table
327
- * @param config - Merged stage + action config with `_pipelineId`, `_executionId`,
328
- * `_stageIndex`, `_triggerData` injected by runPipeline
329
- * @returns Promise<any> — handler output
330
- * @throws Error('Unknown handler module') on unrecognised module string
331
- * @inputSpec action.handler_module: 'functions' | 'integrations' | 'webhook'
332
- * @inputSpec action.handler: string — handler name or integration slug
333
- * @sideEffects depends on handler module (DB writes, HTTP calls)
334
- * @calledBy runPipeline (per-stage loop)
335
- * @calls executeFunctionHandler | executeIntegrationHandler | executeWebhookHandler
336
- */
337
- async function executeStage(
338
- ctx: CoreContext,
339
- action: any,
340
- config: any
341
- ): Promise<any> {
342
- const handlerModule = action.handler_module || 'functions'
343
- const handlerName = action.handler
344
-
345
- switch (handlerModule) {
346
- case 'functions':
347
- return await executeFunctionHandler(ctx, handlerName, config)
348
-
349
- case 'integrations':
350
- return await executeIntegrationHandler(ctx, handlerName, config)
351
-
352
- case 'webhook':
353
- return await executeWebhookHandler(ctx, action, config)
354
-
355
- default:
356
- throw new Error(`Unknown handler module: ${handlerModule}`)
357
- }
358
- }
359
-
360
- // ─── BUILT-IN STAGE HANDLERS ─────────────────────────────────────────────────────────
361
-
362
- /**
363
- * Map of built-in stage handler functions keyed by action slug.
364
- *
365
- * Each handler receives `(ctx: CoreContext, config: any)` and returns a
366
- * JSON-serializable result or throws on failure. Registered handlers:
367
- *
368
- * | Slug | Required config keys | Returns |
369
- * |---------------------|-----------------------------------|--------------------------------|
370
- * | `update_item` | `entity`, `record_id`, `data` | `{ success, record }` |
371
- * | `create_record` | `entity`, `data` | `{ success, record }` |
372
- * | `http_request` | `url` | `{ success, status, body }` |
373
- * | `send_notification` | `message`, `recipients[]` | `{ success, notified_count }` |
374
- * | `run_pipeline` | `pipeline_id` | `{ success, nested_result }` |
375
- * | `search_knowledge` | `query` | `{ results[], count, method }` |
376
- * | `query_items` | `entity` | `{ items[], count }` |
377
- * | `agent_inference` | `context` | `{ content, confidence, ... }` |
378
- *
379
- * @sideEffects DB writes for update_item, create_record, send_notification
380
- * @sideEffects HTTP calls for http_request, agent_inference (webhook_url)
381
- * @calledBy executeFunctionHandler
382
- */
383
- const stageHandlers: Record<string, Function> = {
384
- 'update_item': async (ctx: CoreContext, config: any) => {
385
- const { entity, record_id, data } = config
386
-
387
- if (!entity || !record_id) {
388
- throw new Error('entity and record_id are required for update_item')
389
- }
390
-
391
- const { data: result, error } = await adminDb
392
- .from(entity)
393
- .update({
394
- ...data,
395
- updated_at: new Date().toISOString(),
396
- updated_by: ctx.principal?.id
397
- })
398
- .eq('id', record_id)
399
- .select()
400
- .single()
401
-
402
- if (error) throw new Error(`Update failed: ${error.message}`)
403
- return { success: true, record: result }
404
- },
405
-
406
- 'create_record': async (ctx: CoreContext, config: any) => {
407
- const { entity, data } = config
408
-
409
- if (!entity || !data) {
410
- throw new Error('entity and data are required for create_record')
411
- }
412
-
413
- const { data: result, error } = await adminDb
414
- .from(entity)
415
- .insert({
416
- ...data,
417
- account_id: ctx.accountId,
418
- created_by: isUuid(ctx.principal?.id) ? ctx.principal?.id : null,
419
- created_at: new Date().toISOString(),
420
- updated_at: new Date().toISOString()
421
- })
422
- .select()
423
- .single()
424
-
425
- if (error) throw new Error(`Create failed: ${error.message}`)
426
- return { success: true, record: result }
427
- },
428
-
429
- 'http_request': async (ctx: CoreContext, config: any) => {
430
- const { method = 'GET', url, headers = {}, body } = config
431
-
432
- if (!url) {
433
- throw new Error('url is required for http_request')
434
- }
435
-
436
- const fetchOptions: RequestInit = {
437
- method,
438
- headers: {
439
- 'Content-Type': 'application/json',
440
- ...headers
441
- }
442
- }
443
-
444
- if (body && ['POST', 'PUT', 'PATCH'].includes(method)) {
445
- fetchOptions.body = JSON.stringify(body)
446
- }
447
-
448
- const response = await fetch(url, fetchOptions)
449
- const responseBody = await response.json().catch(() => null)
450
-
451
- return {
452
- success: response.ok,
453
- status: response.status,
454
- statusText: response.statusText,
455
- body: responseBody
456
- }
457
- },
458
-
459
- 'send_notification': async (ctx: CoreContext, config: any) => {
460
- const { message, entity_type, entity_id, recipients = [] } = config
461
-
462
- // Create watcher notifications
463
- const notifications = recipients.map((recipientId: string) => ({
464
- account_id: ctx.accountId,
465
- person_id: recipientId,
466
- message,
467
- entity_type: entity_type || 'pipeline_execution',
468
- entity_id: entity_id || ctx.requestId,
469
- is_read: false,
470
- created_at: new Date().toISOString()
471
- }))
472
-
473
- if (notifications.length > 0) {
474
- const { error } = await adminDb
475
- .from('watchers')
476
- .insert(notifications)
477
-
478
- if (error) throw new Error(`Notification failed: ${error.message}`)
479
- }
480
-
481
- return { success: true, notified_count: notifications.length }
482
- },
483
-
484
- 'run_pipeline': async (ctx: CoreContext, config: any) => {
485
- const { pipeline_id, trigger_data = {} } = config
486
-
487
- if (!pipeline_id) {
488
- throw new Error('pipeline_id is required for run_pipeline')
489
- }
490
-
491
- // Prevent infinite recursion
492
- if (config._pipelineId === pipeline_id) {
493
- throw new Error('Recursive pipeline execution prevented')
494
- }
495
-
496
- const result = await runPipeline(pipeline_id, trigger_data, ctx)
497
- return {
498
- success: result.status === 'completed',
499
- execution_id: result.executionId,
500
- nested_result: result
501
- }
502
- },
503
-
504
- 'search_knowledge': async (ctx: CoreContext, config: any) => {
505
- const { query, knowledge_sources, model_id, limit = 5, threshold = 0.7 } = config
506
-
507
- if (!query) {
508
- throw new Error('query is required for search_knowledge')
509
- }
510
-
511
- // Text search fallback (when no embedding provided)
512
- let dbQuery = adminDb
513
- .from('embeddings')
514
- .select('*')
515
- .eq('account_id', ctx.accountId)
516
- .limit(limit)
517
-
518
- if (knowledge_sources && knowledge_sources.length > 0) {
519
- dbQuery = dbQuery.in('document_id', knowledge_sources)
520
- }
521
-
522
- if (model_id) {
523
- dbQuery = dbQuery.eq('model_id', model_id)
524
- }
525
-
526
- // Try text search first
527
- const { data: textResults, error: textError } = await dbQuery
528
- .textSearch('content', query, { type: 'websearch', config: 'english' })
529
-
530
- if (!textError && textResults && textResults.length > 0) {
531
- return {
532
- results: textResults,
533
- count: textResults.length,
534
- method: 'text_search',
535
- query
536
- }
537
- }
538
-
539
- // Fallback to ilike search
540
- const { data: fallbackResults, error: fallbackError } = await dbQuery
541
- .ilike('content', `%${query}%`)
542
-
543
- if (fallbackError) {
544
- throw new Error(`Knowledge search failed: ${fallbackError.message}`)
545
- }
546
-
547
- return {
548
- results: fallbackResults || [],
549
- count: fallbackResults?.length || 0,
550
- method: 'fallback_ilike',
551
- query
552
- }
553
- },
554
-
555
- 'query_items': async (ctx: CoreContext, config: any) => {
556
- const { entity, filters = {}, query, limit = 10 } = config
557
-
558
- if (!entity) {
559
- throw new Error('entity is required for query_items')
560
- }
561
-
562
- let dbQuery = adminDb
563
- .from(entity)
564
- .select('*')
565
- .eq('account_id', ctx.accountId)
566
- .limit(parseInt(limit.toString()))
567
-
568
- // Apply filters
569
- Object.entries(filters).forEach(([key, value]) => {
570
- dbQuery = dbQuery.eq(key, value)
571
- })
572
-
573
- // Add text search if query provided
574
- if (query) {
575
- dbQuery = dbQuery.textSearch('data', query, { type: 'websearch', config: 'english' })
576
- }
577
-
578
- const { data, error } = await dbQuery
579
-
580
- if (error) throw new Error(`Query failed: ${error.message}`)
581
- return { items: data || [], count: data?.length || 0 }
582
- },
583
-
584
- 'agent_inference': async (ctx: CoreContext, config: any) => {
585
- const { context, model, temperature, max_tokens, webhook_url, headers = {} } = config
586
-
587
- if (!context) {
588
- throw new Error('context is required for agent_inference')
589
- }
590
-
591
- // If webhook_url provided, call external LLM service
592
- if (webhook_url) {
593
- const response = await fetch(webhook_url, {
594
- method: 'POST',
595
- headers: {
596
- 'Content-Type': 'application/json',
597
- ...headers
598
- },
599
- body: JSON.stringify({
600
- context,
601
- model: model || 'gpt-4o',
602
- temperature: temperature ?? 0.7,
603
- max_tokens: max_tokens ?? 4000
604
- })
605
- })
606
-
607
- if (!response.ok) {
608
- throw new Error(`Inference failed: ${response.status} ${response.statusText}`)
609
- }
610
-
611
- const result: any = await response.json()
612
- return {
613
- content: result.content || result.message || '',
614
- confidence: result.confidence || 0.8,
615
- tool_calls: result.tool_calls,
616
- metadata: result.metadata,
617
- model: model || 'gpt-4o'
618
- }
619
- }
620
-
621
- // Fallback: return mock for development/testing
622
- return {
623
- content: `[Mock Response] Received ${context.length} chars of context. In production, configure webhook_url in action config.`,
624
- confidence: 0.9,
625
- tool_calls: null,
626
- metadata: { mock: true },
627
- model: model || 'gpt-4o'
628
- }
629
- }
630
- }
631
-
632
- // ─── MODULE DISPATCHERS ────────────────────────────────────────────────────────────
633
-
634
- /**
635
- * Looks up a built-in handler by name and calls it.
636
- *
637
- * @throws Error('Unknown function handler: <name>') if not in stageHandlers map
638
- * @calledBy executeStage (functions module)
639
- * @calls stageHandlers[handlerName]
640
- */
641
- async function executeFunctionHandler(
642
- ctx: CoreContext,
643
- handlerName: string,
644
- config: any
645
- ): Promise<any> {
646
- const handler = stageHandlers[handlerName]
647
-
648
- if (!handler) {
649
- throw new Error(`Unknown function handler: ${handlerName}`)
650
- }
651
-
652
- return await handler(ctx, config)
653
- }
654
-
655
- /**
656
- * Loads an integration record by slug and executes it.
657
- *
658
- * Currently a stub — logs the call and returns the integration ID.
659
- * Future: delegate to integration-specific executor based on integration type.
660
- *
661
- * @throws Error('Integration not found') if no active integration matches slug
662
- * @sideEffects DB read: integrations table
663
- * @calledBy executeStage (integrations module)
664
- */
665
- async function executeIntegrationHandler(
666
- ctx: CoreContext,
667
- handlerName: string,
668
- config: any
669
- ): Promise<any> {
670
- // Load integration configuration
671
- const { data: integration, error } = await adminDb
672
- .from('integrations')
673
- .select('*')
674
- .eq('slug', handlerName)
675
- .eq('is_active', true)
676
- .single()
677
-
678
- if (error || !integration) {
679
- throw new Error(`Integration not found: ${handlerName}`)
680
- }
681
-
682
- // Execute based on integration type
683
- // This is a placeholder for actual integration logic
684
- console.log(`[${ctx.requestId}] Integration handler: ${handlerName}`, config)
685
-
686
- return {
687
- success: true,
688
- handler: handlerName,
689
- integration_id: integration.id
690
- }
691
- }
692
-
693
- /**
694
- * POSTs the merged stage config as JSON to the webhook URL from action.config.url.
695
- *
696
- * Returns `{ success, status, body }` based on the HTTP response. Does not
697
- * throw on non-2xx responses — `success: false` is returned instead.
698
- *
699
- * @throws Error('Webhook URL not configured') if action.config.url is missing
700
- * @sideEffects HTTP call to action.config.url
701
- * @calledBy executeStage (webhook module)
702
- */
703
- async function executeWebhookHandler(
704
- ctx: CoreContext,
705
- action: any,
706
- config: any
707
- ): Promise<any> {
708
- const { url, method = 'POST', headers = {} } = action.config || {}
709
-
710
- if (!url) {
711
- throw new Error('Webhook URL not configured in action')
712
- }
713
-
714
- const fetchOptions: RequestInit = {
715
- method,
716
- headers: {
717
- 'Content-Type': 'application/json',
718
- ...headers
719
- },
720
- body: JSON.stringify(config)
721
- }
722
-
723
- const response = await fetch(url, fetchOptions)
724
- const body = await response.json().catch(() => null)
725
-
726
- return {
727
- success: response.ok,
728
- status: response.status,
729
- body
730
- }
731
- }