@plures/praxis 0.2.1 → 1.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (486) hide show
  1. package/README.md +191 -64
  2. package/core/codegen/docs-generator.ts +808 -0
  3. package/core/codegen/index.ts +27 -0
  4. package/core/codegen/ts-generator.ts +15 -0
  5. package/core/db-adapter/index.ts +52 -0
  6. package/core/db-adapter/sync-engine.ts +450 -0
  7. package/core/logic-engine/engine.ts +12 -0
  8. package/core/logic-engine/index.ts +16 -0
  9. package/core/logic-engine/protocol.ts +16 -0
  10. package/core/logic-engine/psf-adapter.ts +269 -0
  11. package/core/logic-engine/rules.ts +16 -0
  12. package/core/schema-engine/compiler.ts +431 -0
  13. package/core/schema-engine/generator.ts +635 -0
  14. package/core/schema-engine/index.ts +18 -0
  15. package/core/schema-engine/psf.ts +664 -0
  16. package/core/schema-engine/types.ts +63 -0
  17. package/core/schema-engine/validator.ts +541 -0
  18. package/dist/core/codegen/docs-generator.d.ts +123 -0
  19. package/dist/core/codegen/docs-generator.d.ts.map +1 -0
  20. package/dist/core/codegen/docs-generator.js +674 -0
  21. package/dist/core/codegen/docs-generator.js.map +1 -0
  22. package/dist/core/codegen/index.d.ts +11 -0
  23. package/dist/core/codegen/index.d.ts.map +1 -0
  24. package/dist/core/codegen/index.js +13 -0
  25. package/dist/core/codegen/index.js.map +1 -0
  26. package/dist/core/codegen/ts-generator.d.ts +8 -0
  27. package/dist/core/codegen/ts-generator.d.ts.map +1 -0
  28. package/dist/core/codegen/ts-generator.js +8 -0
  29. package/dist/core/codegen/ts-generator.js.map +1 -0
  30. package/dist/core/db-adapter/index.d.ts +18 -0
  31. package/dist/core/db-adapter/index.d.ts.map +1 -0
  32. package/dist/core/db-adapter/index.js +23 -0
  33. package/dist/core/db-adapter/index.js.map +1 -0
  34. package/dist/core/db-adapter/sync-engine.d.ts +180 -0
  35. package/dist/core/db-adapter/sync-engine.d.ts.map +1 -0
  36. package/dist/core/db-adapter/sync-engine.js +342 -0
  37. package/dist/core/db-adapter/sync-engine.js.map +1 -0
  38. package/dist/core/logic-engine/engine.d.ts +8 -0
  39. package/dist/core/logic-engine/engine.d.ts.map +1 -0
  40. package/dist/core/logic-engine/engine.js +8 -0
  41. package/dist/core/logic-engine/engine.js.map +1 -0
  42. package/dist/core/logic-engine/index.d.ts +16 -0
  43. package/dist/core/logic-engine/index.d.ts.map +1 -0
  44. package/dist/core/logic-engine/index.js +16 -0
  45. package/dist/core/logic-engine/index.js.map +1 -0
  46. package/dist/core/logic-engine/protocol.d.ts +7 -0
  47. package/dist/core/logic-engine/protocol.d.ts.map +1 -0
  48. package/dist/core/logic-engine/protocol.js +7 -0
  49. package/dist/core/logic-engine/protocol.js.map +1 -0
  50. package/dist/core/logic-engine/psf-adapter.d.ts +88 -0
  51. package/dist/core/logic-engine/psf-adapter.d.ts.map +1 -0
  52. package/dist/core/logic-engine/psf-adapter.js +207 -0
  53. package/dist/core/logic-engine/psf-adapter.js.map +1 -0
  54. package/dist/core/logic-engine/rules.d.ts +7 -0
  55. package/dist/core/logic-engine/rules.d.ts.map +1 -0
  56. package/dist/core/logic-engine/rules.js +7 -0
  57. package/dist/core/logic-engine/rules.js.map +1 -0
  58. package/dist/core/schema-engine/compiler.d.ts +198 -0
  59. package/dist/core/schema-engine/compiler.d.ts.map +1 -0
  60. package/dist/core/schema-engine/compiler.js +262 -0
  61. package/dist/core/schema-engine/compiler.js.map +1 -0
  62. package/dist/core/schema-engine/generator.d.ts +115 -0
  63. package/dist/core/schema-engine/generator.d.ts.map +1 -0
  64. package/dist/core/schema-engine/generator.js +506 -0
  65. package/dist/core/schema-engine/generator.js.map +1 -0
  66. package/dist/core/schema-engine/index.d.ts +18 -0
  67. package/dist/core/schema-engine/index.d.ts.map +1 -0
  68. package/dist/core/schema-engine/index.js +18 -0
  69. package/dist/core/schema-engine/index.js.map +1 -0
  70. package/dist/core/schema-engine/psf.d.ts +612 -0
  71. package/dist/core/schema-engine/psf.d.ts.map +1 -0
  72. package/dist/core/schema-engine/psf.js +45 -0
  73. package/dist/core/schema-engine/psf.js.map +1 -0
  74. package/dist/core/schema-engine/types.d.ts +10 -0
  75. package/dist/core/schema-engine/types.d.ts.map +1 -0
  76. package/dist/core/schema-engine/types.js +7 -0
  77. package/dist/core/schema-engine/types.js.map +1 -0
  78. package/dist/core/schema-engine/validator.d.ts +140 -0
  79. package/dist/core/schema-engine/validator.d.ts.map +1 -0
  80. package/dist/core/schema-engine/validator.js +407 -0
  81. package/dist/core/schema-engine/validator.js.map +1 -0
  82. package/dist/src/adapters/cli.d.ts.map +1 -0
  83. package/dist/src/adapters/cli.js.map +1 -0
  84. package/dist/src/cli/commands/auth.d.ts.map +1 -0
  85. package/dist/src/cli/commands/auth.js.map +1 -0
  86. package/dist/src/cli/commands/build.d.ts +23 -0
  87. package/dist/src/cli/commands/build.d.ts.map +1 -0
  88. package/dist/src/cli/commands/build.js +162 -0
  89. package/dist/src/cli/commands/build.js.map +1 -0
  90. package/dist/src/cli/commands/canvas.d.ts +23 -0
  91. package/dist/src/cli/commands/canvas.d.ts.map +1 -0
  92. package/dist/src/cli/commands/canvas.js +215 -0
  93. package/dist/src/cli/commands/canvas.js.map +1 -0
  94. package/dist/src/cli/commands/cloud.d.ts.map +1 -0
  95. package/dist/src/cli/commands/cloud.js.map +1 -0
  96. package/dist/src/cli/commands/create.d.ts +21 -0
  97. package/dist/src/cli/commands/create.d.ts.map +1 -0
  98. package/dist/src/cli/commands/create.js +621 -0
  99. package/dist/src/cli/commands/create.js.map +1 -0
  100. package/dist/src/cli/commands/dev.d.ts +21 -0
  101. package/dist/src/cli/commands/dev.d.ts.map +1 -0
  102. package/dist/src/cli/commands/dev.js +71 -0
  103. package/dist/src/cli/commands/dev.js.map +1 -0
  104. package/dist/src/cli/commands/generate.d.ts.map +1 -0
  105. package/dist/src/cli/commands/generate.js.map +1 -0
  106. package/dist/src/cli/commands/orchestrate.d.ts +44 -0
  107. package/dist/src/cli/commands/orchestrate.d.ts.map +1 -0
  108. package/dist/src/cli/commands/orchestrate.js +150 -0
  109. package/dist/src/cli/commands/orchestrate.js.map +1 -0
  110. package/dist/{cli → src/cli}/index.d.ts.map +1 -1
  111. package/dist/{cli → src/cli}/index.js +53 -21
  112. package/dist/src/cli/index.js.map +1 -0
  113. package/dist/src/cloud/auth.d.ts.map +1 -0
  114. package/dist/src/cloud/auth.js.map +1 -0
  115. package/dist/src/cloud/billing.d.ts.map +1 -0
  116. package/dist/src/cloud/billing.js.map +1 -0
  117. package/dist/src/cloud/client.d.ts.map +1 -0
  118. package/dist/src/cloud/client.js.map +1 -0
  119. package/dist/src/cloud/index.d.ts.map +1 -0
  120. package/dist/src/cloud/index.js.map +1 -0
  121. package/dist/src/cloud/marketplace.d.ts.map +1 -0
  122. package/dist/src/cloud/marketplace.js.map +1 -0
  123. package/dist/src/cloud/provisioning.d.ts.map +1 -0
  124. package/dist/src/cloud/provisioning.js.map +1 -0
  125. package/dist/src/cloud/relay/endpoints.d.ts.map +1 -0
  126. package/dist/src/cloud/relay/endpoints.js.map +1 -0
  127. package/dist/src/cloud/relay/health/index.d.ts.map +1 -0
  128. package/dist/src/cloud/relay/health/index.js.map +1 -0
  129. package/dist/src/cloud/relay/stats/index.d.ts.map +1 -0
  130. package/dist/src/cloud/relay/stats/index.js.map +1 -0
  131. package/dist/src/cloud/relay/sync/index.d.ts.map +1 -0
  132. package/dist/src/cloud/relay/sync/index.js.map +1 -0
  133. package/dist/src/cloud/relay/usage/index.d.ts.map +1 -0
  134. package/dist/src/cloud/relay/usage/index.js.map +1 -0
  135. package/dist/src/cloud/sponsors.d.ts.map +1 -0
  136. package/dist/src/cloud/sponsors.js.map +1 -0
  137. package/dist/src/cloud/types.d.ts.map +1 -0
  138. package/dist/src/cloud/types.js.map +1 -0
  139. package/dist/src/components/index.d.ts.map +1 -0
  140. package/dist/src/components/index.js.map +1 -0
  141. package/dist/src/core/actors.d.ts.map +1 -0
  142. package/dist/src/core/actors.js.map +1 -0
  143. package/dist/src/core/component/generator.d.ts.map +1 -0
  144. package/dist/{core → src/core}/component/generator.js +45 -3
  145. package/dist/src/core/component/generator.js.map +1 -0
  146. package/dist/src/core/engine.d.ts.map +1 -0
  147. package/dist/src/core/engine.js.map +1 -0
  148. package/dist/src/core/introspection.d.ts.map +1 -0
  149. package/dist/src/core/introspection.js.map +1 -0
  150. package/dist/src/core/logic/generator.d.ts.map +1 -0
  151. package/dist/{core → src/core}/logic/generator.js +35 -4
  152. package/dist/src/core/logic/generator.js.map +1 -0
  153. package/dist/src/core/pluresdb/adapter.d.ts +72 -0
  154. package/dist/src/core/pluresdb/adapter.d.ts.map +1 -0
  155. package/dist/src/core/pluresdb/adapter.js +73 -0
  156. package/dist/src/core/pluresdb/adapter.js.map +1 -0
  157. package/dist/src/core/pluresdb/generator.d.ts.map +1 -0
  158. package/dist/{core → src/core}/pluresdb/generator.js +33 -4
  159. package/dist/src/core/pluresdb/generator.js.map +1 -0
  160. package/dist/src/core/pluresdb/index.d.ts +15 -0
  161. package/dist/src/core/pluresdb/index.d.ts.map +1 -0
  162. package/dist/src/core/pluresdb/index.js +11 -0
  163. package/dist/src/core/pluresdb/index.js.map +1 -0
  164. package/dist/src/core/pluresdb/schema-registry.d.ts +104 -0
  165. package/dist/src/core/pluresdb/schema-registry.d.ts.map +1 -0
  166. package/dist/src/core/pluresdb/schema-registry.js +130 -0
  167. package/dist/src/core/pluresdb/schema-registry.js.map +1 -0
  168. package/dist/src/core/pluresdb/store.d.ts +199 -0
  169. package/dist/src/core/pluresdb/store.d.ts.map +1 -0
  170. package/dist/src/core/pluresdb/store.js +344 -0
  171. package/dist/src/core/pluresdb/store.js.map +1 -0
  172. package/dist/src/core/protocol.d.ts.map +1 -0
  173. package/dist/src/core/protocol.js.map +1 -0
  174. package/dist/src/core/rules.d.ts.map +1 -0
  175. package/dist/src/core/rules.js.map +1 -0
  176. package/dist/src/core/schema/loader.d.ts.map +1 -0
  177. package/dist/src/core/schema/loader.js.map +1 -0
  178. package/dist/src/core/schema/normalize.d.ts.map +1 -0
  179. package/dist/src/core/schema/normalize.js.map +1 -0
  180. package/dist/src/core/schema/types.d.ts.map +1 -0
  181. package/dist/src/core/schema/types.js.map +1 -0
  182. package/dist/src/dsl/index.d.ts.map +1 -0
  183. package/dist/src/dsl/index.js.map +1 -0
  184. package/dist/src/dsl.d.ts.map +1 -0
  185. package/dist/src/dsl.js.map +1 -0
  186. package/dist/src/examples/advanced-todo/index.d.ts.map +1 -0
  187. package/dist/src/examples/advanced-todo/index.js.map +1 -0
  188. package/dist/src/examples/auth-basic/index.d.ts.map +1 -0
  189. package/dist/src/examples/auth-basic/index.js.map +1 -0
  190. package/dist/src/examples/cart/index.d.ts.map +1 -0
  191. package/dist/src/examples/cart/index.js.map +1 -0
  192. package/dist/src/examples/hero-ecommerce/index.d.ts.map +1 -0
  193. package/dist/src/examples/hero-ecommerce/index.js.map +1 -0
  194. package/dist/src/examples/svelte-counter/index.d.ts.map +1 -0
  195. package/dist/src/examples/svelte-counter/index.js.map +1 -0
  196. package/dist/src/flows.d.ts.map +1 -0
  197. package/dist/src/flows.js.map +1 -0
  198. package/dist/{index.d.ts → src/index.d.ts} +12 -2
  199. package/dist/src/index.d.ts.map +1 -0
  200. package/dist/{index.js → src/index.js} +6 -1
  201. package/dist/src/index.js.map +1 -0
  202. package/dist/src/integrations/code-canvas.d.ts +265 -0
  203. package/dist/src/integrations/code-canvas.d.ts.map +1 -0
  204. package/dist/src/integrations/code-canvas.js +451 -0
  205. package/dist/src/integrations/code-canvas.js.map +1 -0
  206. package/dist/src/integrations/pluresdb.d.ts +117 -0
  207. package/dist/src/integrations/pluresdb.d.ts.map +1 -0
  208. package/dist/src/integrations/pluresdb.js +117 -0
  209. package/dist/src/integrations/pluresdb.js.map +1 -0
  210. package/dist/src/integrations/state-docs.d.ts +191 -0
  211. package/dist/src/integrations/state-docs.d.ts.map +1 -0
  212. package/dist/src/integrations/state-docs.js +515 -0
  213. package/dist/src/integrations/state-docs.js.map +1 -0
  214. package/dist/src/integrations/svelte.d.ts.map +1 -0
  215. package/dist/src/integrations/svelte.js.map +1 -0
  216. package/dist/src/integrations/tauri.d.ts +360 -0
  217. package/dist/src/integrations/tauri.d.ts.map +1 -0
  218. package/dist/src/integrations/tauri.js +278 -0
  219. package/dist/src/integrations/tauri.js.map +1 -0
  220. package/dist/src/integrations/unum.d.ts +159 -0
  221. package/dist/src/integrations/unum.d.ts.map +1 -0
  222. package/dist/src/integrations/unum.js +240 -0
  223. package/dist/src/integrations/unum.js.map +1 -0
  224. package/dist/src/registry.d.ts.map +1 -0
  225. package/dist/src/registry.js.map +1 -0
  226. package/dist/{runtime → src/runtime}/terminal-adapter.d.ts +58 -7
  227. package/dist/src/runtime/terminal-adapter.d.ts.map +1 -0
  228. package/dist/src/runtime/terminal-adapter.js +239 -0
  229. package/dist/src/runtime/terminal-adapter.js.map +1 -0
  230. package/dist/src/step.d.ts.map +1 -0
  231. package/dist/src/step.js.map +1 -0
  232. package/dist/src/types.d.ts.map +1 -0
  233. package/dist/{cloud → src}/types.js.map +1 -1
  234. package/dist/tools/cli/commands/index.d.ts +7 -0
  235. package/dist/tools/cli/commands/index.d.ts.map +1 -0
  236. package/dist/tools/cli/commands/index.js +7 -0
  237. package/dist/tools/cli/commands/index.js.map +1 -0
  238. package/dist/tools/cli/index.d.ts +8 -0
  239. package/dist/tools/cli/index.d.ts.map +1 -0
  240. package/dist/tools/cli/index.js +9 -0
  241. package/dist/tools/cli/index.js.map +1 -0
  242. package/dist/tools/watcher/index.d.ts +105 -0
  243. package/dist/tools/watcher/index.d.ts.map +1 -0
  244. package/dist/tools/watcher/index.js +213 -0
  245. package/dist/tools/watcher/index.js.map +1 -0
  246. package/dist/ui/canvas/canvas-projection.d.ts +78 -0
  247. package/dist/ui/canvas/canvas-projection.d.ts.map +1 -0
  248. package/dist/ui/canvas/canvas-projection.js +416 -0
  249. package/dist/ui/canvas/canvas-projection.js.map +1 -0
  250. package/dist/ui/canvas/canvas-state.d.ts +200 -0
  251. package/dist/ui/canvas/canvas-state.d.ts.map +1 -0
  252. package/dist/ui/canvas/canvas-state.js +464 -0
  253. package/dist/ui/canvas/canvas-state.js.map +1 -0
  254. package/dist/ui/canvas/components/index.d.ts +95 -0
  255. package/dist/ui/canvas/components/index.d.ts.map +1 -0
  256. package/dist/ui/canvas/components/index.js +19 -0
  257. package/dist/ui/canvas/components/index.js.map +1 -0
  258. package/dist/ui/canvas/index.d.ts +32 -0
  259. package/dist/ui/canvas/index.d.ts.map +1 -0
  260. package/dist/ui/canvas/index.js +32 -0
  261. package/dist/ui/canvas/index.js.map +1 -0
  262. package/dist/ui/svelte-generator/index.d.ts +9 -0
  263. package/dist/ui/svelte-generator/index.d.ts.map +1 -0
  264. package/dist/ui/svelte-generator/index.js +11 -0
  265. package/dist/ui/svelte-generator/index.js.map +1 -0
  266. package/dist/ui/svelte-generator/psf-generator.d.ts +128 -0
  267. package/dist/ui/svelte-generator/psf-generator.d.ts.map +1 -0
  268. package/dist/ui/svelte-generator/psf-generator.js +506 -0
  269. package/dist/ui/svelte-generator/psf-generator.js.map +1 -0
  270. package/docs/README.md +155 -0
  271. package/docs/core/building-extensions.md +553 -0
  272. package/docs/core/cli-usage.md +498 -0
  273. package/docs/core/code-canvas-sync.md +468 -0
  274. package/docs/core/logic-engine.md +566 -0
  275. package/docs/core/pluresdb-integration.md +646 -0
  276. package/docs/core/schema-model.md +414 -0
  277. package/docs/core/ui-generation.md +580 -0
  278. package/docs/core/what-is-praxis.md +240 -0
  279. package/docs/tutorials/README.md +84 -0
  280. package/docs/tutorials/ecommerce-cart.md +631 -0
  281. package/docs/tutorials/first-app.md +529 -0
  282. package/docs/tutorials/form-builder.md +620 -0
  283. package/docs/tutorials/todo-pluresdb.md +589 -0
  284. package/package.json +16 -16
  285. package/src/__tests__/canvas-components.test.ts +450 -0
  286. package/src/__tests__/cli-create.test.ts +178 -0
  287. package/src/__tests__/code-canvas-integration.test.ts +277 -0
  288. package/src/__tests__/docs-generator.test.ts +181 -0
  289. package/src/__tests__/generators.test.ts +3 -2
  290. package/src/__tests__/pluresdb.test.ts +457 -0
  291. package/src/__tests__/psf-schema-engine.test.ts +450 -0
  292. package/src/__tests__/state-docs-integration.test.ts +297 -0
  293. package/src/__tests__/tauri-integration.test.ts +298 -0
  294. package/src/__tests__/terminal-node.test.ts +1 -1
  295. package/src/__tests__/unum-integration.test.ts +142 -0
  296. package/src/cli/commands/build.ts +203 -0
  297. package/src/cli/commands/canvas.ts +246 -0
  298. package/src/cli/commands/create.ts +666 -0
  299. package/src/cli/commands/dev.ts +95 -0
  300. package/src/cli/commands/orchestrate.ts +212 -0
  301. package/src/cli/index.ts +48 -21
  302. package/src/core/component/generator.ts +45 -3
  303. package/src/core/logic/generator.ts +39 -4
  304. package/src/core/pluresdb/adapter.ts +117 -0
  305. package/src/core/pluresdb/generator.ts +33 -4
  306. package/src/core/pluresdb/index.ts +37 -0
  307. package/src/core/pluresdb/schema-registry.ts +162 -0
  308. package/src/core/pluresdb/store.ts +446 -0
  309. package/src/index.ts +109 -0
  310. package/src/integrations/code-canvas.ts +717 -0
  311. package/src/integrations/pluresdb.ts +140 -29
  312. package/src/integrations/state-docs.ts +710 -0
  313. package/src/integrations/tauri.ts +638 -0
  314. package/src/integrations/unum.ts +395 -0
  315. package/src/runtime/terminal-adapter.ts +184 -23
  316. package/dist/adapters/cli.d.ts.map +0 -1
  317. package/dist/adapters/cli.js.map +0 -1
  318. package/dist/cli/commands/auth.d.ts.map +0 -1
  319. package/dist/cli/commands/auth.js.map +0 -1
  320. package/dist/cli/commands/cloud.d.ts.map +0 -1
  321. package/dist/cli/commands/cloud.js.map +0 -1
  322. package/dist/cli/commands/generate.d.ts.map +0 -1
  323. package/dist/cli/commands/generate.js.map +0 -1
  324. package/dist/cli/index.js.map +0 -1
  325. package/dist/cloud/auth.d.ts.map +0 -1
  326. package/dist/cloud/auth.js.map +0 -1
  327. package/dist/cloud/billing.d.ts.map +0 -1
  328. package/dist/cloud/billing.js.map +0 -1
  329. package/dist/cloud/client.d.ts.map +0 -1
  330. package/dist/cloud/client.js.map +0 -1
  331. package/dist/cloud/index.d.ts.map +0 -1
  332. package/dist/cloud/index.js.map +0 -1
  333. package/dist/cloud/marketplace.d.ts.map +0 -1
  334. package/dist/cloud/marketplace.js.map +0 -1
  335. package/dist/cloud/provisioning.d.ts.map +0 -1
  336. package/dist/cloud/provisioning.js.map +0 -1
  337. package/dist/cloud/relay/endpoints.d.ts.map +0 -1
  338. package/dist/cloud/relay/endpoints.js.map +0 -1
  339. package/dist/cloud/relay/health/index.d.ts.map +0 -1
  340. package/dist/cloud/relay/health/index.js.map +0 -1
  341. package/dist/cloud/relay/stats/index.d.ts.map +0 -1
  342. package/dist/cloud/relay/stats/index.js.map +0 -1
  343. package/dist/cloud/relay/sync/index.d.ts.map +0 -1
  344. package/dist/cloud/relay/sync/index.js.map +0 -1
  345. package/dist/cloud/relay/usage/index.d.ts.map +0 -1
  346. package/dist/cloud/relay/usage/index.js.map +0 -1
  347. package/dist/cloud/sponsors.d.ts.map +0 -1
  348. package/dist/cloud/sponsors.js.map +0 -1
  349. package/dist/cloud/types.d.ts.map +0 -1
  350. package/dist/components/index.d.ts.map +0 -1
  351. package/dist/components/index.js.map +0 -1
  352. package/dist/core/actors.d.ts.map +0 -1
  353. package/dist/core/actors.js.map +0 -1
  354. package/dist/core/component/generator.d.ts.map +0 -1
  355. package/dist/core/component/generator.js.map +0 -1
  356. package/dist/core/engine.d.ts.map +0 -1
  357. package/dist/core/engine.js.map +0 -1
  358. package/dist/core/introspection.d.ts.map +0 -1
  359. package/dist/core/introspection.js.map +0 -1
  360. package/dist/core/logic/generator.d.ts.map +0 -1
  361. package/dist/core/logic/generator.js.map +0 -1
  362. package/dist/core/pluresdb/generator.d.ts.map +0 -1
  363. package/dist/core/pluresdb/generator.js.map +0 -1
  364. package/dist/core/protocol.d.ts.map +0 -1
  365. package/dist/core/protocol.js.map +0 -1
  366. package/dist/core/rules.d.ts.map +0 -1
  367. package/dist/core/rules.js.map +0 -1
  368. package/dist/core/schema/loader.d.ts.map +0 -1
  369. package/dist/core/schema/loader.js.map +0 -1
  370. package/dist/core/schema/normalize.d.ts.map +0 -1
  371. package/dist/core/schema/normalize.js.map +0 -1
  372. package/dist/core/schema/types.d.ts.map +0 -1
  373. package/dist/core/schema/types.js.map +0 -1
  374. package/dist/dsl/index.d.ts.map +0 -1
  375. package/dist/dsl/index.js.map +0 -1
  376. package/dist/dsl.d.ts.map +0 -1
  377. package/dist/dsl.js.map +0 -1
  378. package/dist/examples/advanced-todo/index.d.ts.map +0 -1
  379. package/dist/examples/advanced-todo/index.js.map +0 -1
  380. package/dist/examples/auth-basic/index.d.ts.map +0 -1
  381. package/dist/examples/auth-basic/index.js.map +0 -1
  382. package/dist/examples/cart/index.d.ts.map +0 -1
  383. package/dist/examples/cart/index.js.map +0 -1
  384. package/dist/examples/hero-ecommerce/index.d.ts.map +0 -1
  385. package/dist/examples/hero-ecommerce/index.js.map +0 -1
  386. package/dist/examples/svelte-counter/index.d.ts.map +0 -1
  387. package/dist/examples/svelte-counter/index.js.map +0 -1
  388. package/dist/flows.d.ts.map +0 -1
  389. package/dist/flows.js.map +0 -1
  390. package/dist/index.d.ts.map +0 -1
  391. package/dist/index.js.map +0 -1
  392. package/dist/integrations/pluresdb.d.ts +0 -56
  393. package/dist/integrations/pluresdb.d.ts.map +0 -1
  394. package/dist/integrations/pluresdb.js +0 -46
  395. package/dist/integrations/pluresdb.js.map +0 -1
  396. package/dist/integrations/svelte.d.ts.map +0 -1
  397. package/dist/integrations/svelte.js.map +0 -1
  398. package/dist/registry.d.ts.map +0 -1
  399. package/dist/registry.js.map +0 -1
  400. package/dist/runtime/terminal-adapter.d.ts.map +0 -1
  401. package/dist/runtime/terminal-adapter.js +0 -113
  402. package/dist/runtime/terminal-adapter.js.map +0 -1
  403. package/dist/step.d.ts.map +0 -1
  404. package/dist/step.js.map +0 -1
  405. package/dist/types.d.ts.map +0 -1
  406. package/dist/types.js.map +0 -1
  407. /package/dist/{adapters → src/adapters}/cli.d.ts +0 -0
  408. /package/dist/{adapters → src/adapters}/cli.js +0 -0
  409. /package/dist/{cli → src/cli}/commands/auth.d.ts +0 -0
  410. /package/dist/{cli → src/cli}/commands/auth.js +0 -0
  411. /package/dist/{cli → src/cli}/commands/cloud.d.ts +0 -0
  412. /package/dist/{cli → src/cli}/commands/cloud.js +0 -0
  413. /package/dist/{cli → src/cli}/commands/generate.d.ts +0 -0
  414. /package/dist/{cli → src/cli}/commands/generate.js +0 -0
  415. /package/dist/{cli → src/cli}/index.d.ts +0 -0
  416. /package/dist/{cloud → src/cloud}/auth.d.ts +0 -0
  417. /package/dist/{cloud → src/cloud}/auth.js +0 -0
  418. /package/dist/{cloud → src/cloud}/billing.d.ts +0 -0
  419. /package/dist/{cloud → src/cloud}/billing.js +0 -0
  420. /package/dist/{cloud → src/cloud}/client.d.ts +0 -0
  421. /package/dist/{cloud → src/cloud}/client.js +0 -0
  422. /package/dist/{cloud → src/cloud}/index.d.ts +0 -0
  423. /package/dist/{cloud → src/cloud}/index.js +0 -0
  424. /package/dist/{cloud → src/cloud}/marketplace.d.ts +0 -0
  425. /package/dist/{cloud → src/cloud}/marketplace.js +0 -0
  426. /package/dist/{cloud → src/cloud}/provisioning.d.ts +0 -0
  427. /package/dist/{cloud → src/cloud}/provisioning.js +0 -0
  428. /package/dist/{cloud → src/cloud}/relay/endpoints.d.ts +0 -0
  429. /package/dist/{cloud → src/cloud}/relay/endpoints.js +0 -0
  430. /package/dist/{cloud → src/cloud}/relay/health/index.d.ts +0 -0
  431. /package/dist/{cloud → src/cloud}/relay/health/index.js +0 -0
  432. /package/dist/{cloud → src/cloud}/relay/stats/index.d.ts +0 -0
  433. /package/dist/{cloud → src/cloud}/relay/stats/index.js +0 -0
  434. /package/dist/{cloud → src/cloud}/relay/sync/index.d.ts +0 -0
  435. /package/dist/{cloud → src/cloud}/relay/sync/index.js +0 -0
  436. /package/dist/{cloud → src/cloud}/relay/usage/index.d.ts +0 -0
  437. /package/dist/{cloud → src/cloud}/relay/usage/index.js +0 -0
  438. /package/dist/{cloud → src/cloud}/sponsors.d.ts +0 -0
  439. /package/dist/{cloud → src/cloud}/sponsors.js +0 -0
  440. /package/dist/{cloud → src/cloud}/types.d.ts +0 -0
  441. /package/dist/{cloud → src/cloud}/types.js +0 -0
  442. /package/dist/{components → src/components}/index.d.ts +0 -0
  443. /package/dist/{components → src/components}/index.js +0 -0
  444. /package/dist/{core → src/core}/actors.d.ts +0 -0
  445. /package/dist/{core → src/core}/actors.js +0 -0
  446. /package/dist/{core → src/core}/component/generator.d.ts +0 -0
  447. /package/dist/{core → src/core}/engine.d.ts +0 -0
  448. /package/dist/{core → src/core}/engine.js +0 -0
  449. /package/dist/{core → src/core}/introspection.d.ts +0 -0
  450. /package/dist/{core → src/core}/introspection.js +0 -0
  451. /package/dist/{core → src/core}/logic/generator.d.ts +0 -0
  452. /package/dist/{core → src/core}/pluresdb/generator.d.ts +0 -0
  453. /package/dist/{core → src/core}/protocol.d.ts +0 -0
  454. /package/dist/{core → src/core}/protocol.js +0 -0
  455. /package/dist/{core → src/core}/rules.d.ts +0 -0
  456. /package/dist/{core → src/core}/rules.js +0 -0
  457. /package/dist/{core → src/core}/schema/loader.d.ts +0 -0
  458. /package/dist/{core → src/core}/schema/loader.js +0 -0
  459. /package/dist/{core → src/core}/schema/normalize.d.ts +0 -0
  460. /package/dist/{core → src/core}/schema/normalize.js +0 -0
  461. /package/dist/{core → src/core}/schema/types.d.ts +0 -0
  462. /package/dist/{core → src/core}/schema/types.js +0 -0
  463. /package/dist/{dsl → src/dsl}/index.d.ts +0 -0
  464. /package/dist/{dsl → src/dsl}/index.js +0 -0
  465. /package/dist/{dsl.d.ts → src/dsl.d.ts} +0 -0
  466. /package/dist/{dsl.js → src/dsl.js} +0 -0
  467. /package/dist/{examples → src/examples}/advanced-todo/index.d.ts +0 -0
  468. /package/dist/{examples → src/examples}/advanced-todo/index.js +0 -0
  469. /package/dist/{examples → src/examples}/auth-basic/index.d.ts +0 -0
  470. /package/dist/{examples → src/examples}/auth-basic/index.js +0 -0
  471. /package/dist/{examples → src/examples}/cart/index.d.ts +0 -0
  472. /package/dist/{examples → src/examples}/cart/index.js +0 -0
  473. /package/dist/{examples → src/examples}/hero-ecommerce/index.d.ts +0 -0
  474. /package/dist/{examples → src/examples}/hero-ecommerce/index.js +0 -0
  475. /package/dist/{examples → src/examples}/svelte-counter/index.d.ts +0 -0
  476. /package/dist/{examples → src/examples}/svelte-counter/index.js +0 -0
  477. /package/dist/{flows.d.ts → src/flows.d.ts} +0 -0
  478. /package/dist/{flows.js → src/flows.js} +0 -0
  479. /package/dist/{integrations → src/integrations}/svelte.d.ts +0 -0
  480. /package/dist/{integrations → src/integrations}/svelte.js +0 -0
  481. /package/dist/{registry.d.ts → src/registry.d.ts} +0 -0
  482. /package/dist/{registry.js → src/registry.js} +0 -0
  483. /package/dist/{step.d.ts → src/step.d.ts} +0 -0
  484. /package/dist/{step.js → src/step.js} +0 -0
  485. /package/dist/{types.d.ts → src/types.d.ts} +0 -0
  486. /package/dist/{types.js → src/types.js} +0 -0
@@ -0,0 +1,450 @@
1
+ /**
2
+ * PSF Schema Engine Tests
3
+ */
4
+
5
+ import { describe, it, expect } from 'vitest';
6
+ import {
7
+ PSF_VERSION,
8
+ createEmptyPSFSchema,
9
+ generatePSFId,
10
+ type PSFSchema,
11
+ } from '../../core/schema-engine/psf.js';
12
+ import {
13
+ PSFCompiler,
14
+ createPSFCompiler,
15
+ compileToPSF,
16
+ type DSLSchema,
17
+ } from '../../core/schema-engine/compiler.js';
18
+ import {
19
+ PSFGenerator,
20
+ createPSFGenerator,
21
+ generateFromPSF,
22
+ } from '../../core/schema-engine/generator.js';
23
+ import {
24
+ PSFValidator,
25
+ createPSFValidator,
26
+ validatePSFSchema,
27
+ } from '../../core/schema-engine/validator.js';
28
+
29
+ describe('PSF Schema Engine', () => {
30
+ describe('PSF Types', () => {
31
+ it('should have correct version', () => {
32
+ expect(PSF_VERSION).toBe('1.0.0');
33
+ });
34
+
35
+ it('should create empty schema', () => {
36
+ const schema = createEmptyPSFSchema('test-id', 'Test Schema');
37
+
38
+ expect(schema.$version).toBe(PSF_VERSION);
39
+ expect(schema.id).toBe('test-id');
40
+ expect(schema.name).toBe('Test Schema');
41
+ expect(schema.facts).toEqual([]);
42
+ expect(schema.events).toEqual([]);
43
+ expect(schema.rules).toEqual([]);
44
+ expect(schema.constraints).toEqual([]);
45
+ expect(schema.models).toEqual([]);
46
+ expect(schema.components).toEqual([]);
47
+ expect(schema.flows).toEqual([]);
48
+ });
49
+
50
+ it('should generate unique IDs', () => {
51
+ const id1 = generatePSFId('fact');
52
+ const id2 = generatePSFId('fact');
53
+
54
+ expect(id1).not.toBe(id2);
55
+ expect(id1).toMatch(/^fact_/);
56
+ expect(id2).toMatch(/^fact_/);
57
+ });
58
+ });
59
+
60
+ describe('PSF Compiler', () => {
61
+ it('should compile empty schema', () => {
62
+ const input: DSLSchema = {
63
+ name: 'Test App',
64
+ };
65
+
66
+ const result = compileToPSF(input);
67
+
68
+ expect(result.success).toBe(true);
69
+ expect(result.schema).toBeDefined();
70
+ expect(result.schema?.name).toBe('Test App');
71
+ expect(result.errors).toHaveLength(0);
72
+ });
73
+
74
+ it('should compile facts', () => {
75
+ const input: DSLSchema = {
76
+ name: 'Test App',
77
+ facts: [
78
+ {
79
+ tag: 'UserCreated',
80
+ description: 'User was created',
81
+ payload: { userId: 'string', name: 'string' },
82
+ },
83
+ ],
84
+ };
85
+
86
+ const result = compileToPSF(input);
87
+
88
+ expect(result.success).toBe(true);
89
+ expect(result.schema?.facts).toHaveLength(1);
90
+ expect(result.schema?.facts[0].tag).toBe('UserCreated');
91
+ expect(result.schema?.facts[0].payload.properties.userId.type).toBe('string');
92
+ });
93
+
94
+ it('should compile events', () => {
95
+ const input: DSLSchema = {
96
+ name: 'Test App',
97
+ events: [
98
+ {
99
+ tag: 'CreateUser',
100
+ description: 'Create a new user',
101
+ payload: { name: 'string', email: 'string' },
102
+ },
103
+ ],
104
+ };
105
+
106
+ const result = compileToPSF(input);
107
+
108
+ expect(result.success).toBe(true);
109
+ expect(result.schema?.events).toHaveLength(1);
110
+ expect(result.schema?.events[0].tag).toBe('CreateUser');
111
+ });
112
+
113
+ it('should compile rules', () => {
114
+ const input: DSLSchema = {
115
+ name: 'Test App',
116
+ rules: [
117
+ {
118
+ id: 'user.create',
119
+ description: 'Create user on event',
120
+ triggers: ['CreateUser'],
121
+ then: 'return []',
122
+ },
123
+ ],
124
+ };
125
+
126
+ const result = compileToPSF(input);
127
+
128
+ expect(result.success).toBe(true);
129
+ expect(result.schema?.rules).toHaveLength(1);
130
+ expect(result.schema?.rules[0].id).toBe('user.create');
131
+ expect(result.schema?.rules[0].triggers).toContain('CreateUser');
132
+ });
133
+
134
+ it('should compile constraints', () => {
135
+ const input: DSLSchema = {
136
+ name: 'Test App',
137
+ constraints: [
138
+ {
139
+ id: 'positive.count',
140
+ description: 'Count must be positive',
141
+ check: 'state.context.count >= 0',
142
+ errorMessage: 'Count cannot be negative',
143
+ },
144
+ ],
145
+ };
146
+
147
+ const result = compileToPSF(input);
148
+
149
+ expect(result.success).toBe(true);
150
+ expect(result.schema?.constraints).toHaveLength(1);
151
+ expect(result.schema?.constraints[0].id).toBe('positive.count');
152
+ });
153
+
154
+ it('should compile models', () => {
155
+ const input: DSLSchema = {
156
+ name: 'Test App',
157
+ models: [
158
+ {
159
+ name: 'User',
160
+ description: 'A user entity',
161
+ fields: [
162
+ { name: 'id', type: 'uuid' },
163
+ { name: 'name', type: 'string' },
164
+ { name: 'email', type: 'string' },
165
+ { name: 'createdAt', type: 'datetime', optional: true },
166
+ ],
167
+ },
168
+ ],
169
+ };
170
+
171
+ const result = compileToPSF(input);
172
+
173
+ expect(result.success).toBe(true);
174
+ expect(result.schema?.models).toHaveLength(1);
175
+ expect(result.schema?.models[0].name).toBe('User');
176
+ expect(result.schema?.models[0].fields).toHaveLength(4);
177
+ });
178
+
179
+ it('should report errors for invalid identifiers', () => {
180
+ const input: DSLSchema = {
181
+ name: 'Test App',
182
+ facts: [
183
+ {
184
+ tag: '123Invalid', // Invalid - starts with number
185
+ payload: {},
186
+ },
187
+ ],
188
+ };
189
+
190
+ const result = compileToPSF(input);
191
+
192
+ expect(result.success).toBe(false);
193
+ expect(result.errors.length).toBeGreaterThan(0);
194
+ expect(result.errors[0].code).toBe('invalid-identifier');
195
+ });
196
+ });
197
+
198
+ describe('PSF Generator', () => {
199
+ it('should generate code from schema', () => {
200
+ const schema = createEmptyPSFSchema('test', 'Test App');
201
+ schema.facts = [
202
+ {
203
+ id: 'fact_1',
204
+ tag: 'UserCreated',
205
+ description: 'User was created',
206
+ payload: {
207
+ type: 'object',
208
+ properties: {
209
+ userId: { type: 'string' },
210
+ },
211
+ },
212
+ },
213
+ ];
214
+ schema.events = [
215
+ {
216
+ id: 'event_1',
217
+ tag: 'CreateUser',
218
+ description: 'Create a new user',
219
+ payload: {
220
+ type: 'object',
221
+ properties: {
222
+ name: { type: 'string' },
223
+ },
224
+ },
225
+ },
226
+ ];
227
+
228
+ const result = generateFromPSF(schema);
229
+
230
+ expect(result.success).toBe(true);
231
+ expect(result.files.length).toBeGreaterThan(0);
232
+
233
+ const factsFile = result.files.find((f) => f.type === 'facts');
234
+ expect(factsFile).toBeDefined();
235
+ expect(factsFile?.content).toContain('UserCreated');
236
+ expect(factsFile?.content).toContain('defineFact');
237
+
238
+ const eventsFile = result.files.find((f) => f.type === 'events');
239
+ expect(eventsFile).toBeDefined();
240
+ expect(eventsFile?.content).toContain('CreateUser');
241
+ expect(eventsFile?.content).toContain('defineEvent');
242
+ });
243
+
244
+ it('should generate rules file', () => {
245
+ const schema = createEmptyPSFSchema('test', 'Test App');
246
+ schema.rules = [
247
+ {
248
+ id: 'user.create',
249
+ description: 'Create user rule',
250
+ triggers: ['CreateUser'],
251
+ then: { inline: 'return []' },
252
+ },
253
+ ];
254
+
255
+ const result = generateFromPSF(schema);
256
+
257
+ const rulesFile = result.files.find((f) => f.type === 'rules');
258
+ expect(rulesFile).toBeDefined();
259
+ expect(rulesFile?.content).toContain('user_createRule');
260
+ expect(rulesFile?.content).toContain('defineRule');
261
+ });
262
+
263
+ it('should generate models file', () => {
264
+ const schema = createEmptyPSFSchema('test', 'Test App');
265
+ schema.models = [
266
+ {
267
+ id: 'model_1',
268
+ name: 'User',
269
+ description: 'User model',
270
+ fields: [
271
+ { name: 'id', type: 'uuid' },
272
+ { name: 'name', type: 'string' },
273
+ ],
274
+ },
275
+ ];
276
+
277
+ const result = generateFromPSF(schema);
278
+
279
+ const modelsFile = result.files.find((f) => f.type === 'models');
280
+ expect(modelsFile).toBeDefined();
281
+ expect(modelsFile?.content).toContain('interface User');
282
+ expect(modelsFile?.content).toContain('id: string');
283
+ expect(modelsFile?.content).toContain('name: string');
284
+ });
285
+
286
+ it('should generate index file', () => {
287
+ const schema = createEmptyPSFSchema('test', 'Test App');
288
+ schema.facts = [{ id: 'f1', tag: 'TestFact', payload: { type: 'object', properties: {} } }];
289
+
290
+ const result = generateFromPSF(schema, { generateIndex: true });
291
+
292
+ const indexFile = result.files.find((f) => f.type === 'index');
293
+ expect(indexFile).toBeDefined();
294
+ expect(indexFile?.content).toContain("export * from './facts.js'");
295
+ });
296
+ });
297
+
298
+ describe('PSF Validator', () => {
299
+ it('should validate correct schema', () => {
300
+ const schema = createEmptyPSFSchema('test', 'Test App');
301
+
302
+ const result = validatePSFSchema(schema);
303
+
304
+ expect(result.valid).toBe(true);
305
+ expect(result.errors).toHaveLength(0);
306
+ });
307
+
308
+ it('should report missing required fields', () => {
309
+ const schema = {} as PSFSchema;
310
+
311
+ const result = validatePSFSchema(schema);
312
+
313
+ expect(result.valid).toBe(false);
314
+ expect(result.errors.some((e) => e.code === 'missing-version')).toBe(true);
315
+ expect(result.errors.some((e) => e.code === 'missing-id')).toBe(true);
316
+ expect(result.errors.some((e) => e.code === 'missing-name')).toBe(true);
317
+ });
318
+
319
+ it('should report invalid fact tags', () => {
320
+ const schema = createEmptyPSFSchema('test', 'Test App');
321
+ schema.facts = [
322
+ {
323
+ id: 'fact_1',
324
+ tag: 'class', // Reserved keyword
325
+ payload: { type: 'object', properties: {} },
326
+ },
327
+ ];
328
+
329
+ const result = validatePSFSchema(schema);
330
+
331
+ expect(result.valid).toBe(false);
332
+ expect(result.errors.some((e) => e.code === 'invalid-identifier')).toBe(true);
333
+ });
334
+
335
+ it('should report missing rule action', () => {
336
+ const schema = createEmptyPSFSchema('test', 'Test App');
337
+ schema.rules = [
338
+ {
339
+ id: 'rule_1',
340
+ description: 'Test rule',
341
+ then: undefined as any, // Missing required field
342
+ },
343
+ ];
344
+
345
+ const result = validatePSFSchema(schema);
346
+
347
+ expect(result.valid).toBe(false);
348
+ expect(result.errors.some((e) => e.code === 'missing-action')).toBe(true);
349
+ });
350
+
351
+ it('should detect duplicate IDs', () => {
352
+ const schema = createEmptyPSFSchema('test', 'Test App');
353
+ schema.facts = [
354
+ { id: 'duplicate_id', tag: 'Fact1', payload: { type: 'object', properties: {} } },
355
+ ];
356
+ schema.events = [
357
+ { id: 'duplicate_id', tag: 'Event1', payload: { type: 'object', properties: {} } },
358
+ ];
359
+
360
+ const result = validatePSFSchema(schema, { checkDuplicates: true });
361
+
362
+ expect(result.valid).toBe(false);
363
+ expect(result.errors.some((e) => e.code === 'duplicate-id')).toBe(true);
364
+ });
365
+
366
+ it('should warn about unknown model references', () => {
367
+ const schema = createEmptyPSFSchema('test', 'Test App');
368
+ schema.components = [
369
+ {
370
+ id: 'comp_1',
371
+ name: 'UserForm',
372
+ type: 'form',
373
+ model: 'NonExistentModel',
374
+ props: [],
375
+ events: [],
376
+ },
377
+ ];
378
+
379
+ const result = validatePSFSchema(schema, { checkReferences: true });
380
+
381
+ expect(result.warnings.some((w) => w.code === 'unknown-model')).toBe(true);
382
+ });
383
+ });
384
+
385
+ describe('Round-trip (Compile → Generate)', () => {
386
+ it('should preserve schema through compile and generate', () => {
387
+ const input: DSLSchema = {
388
+ name: 'Round Trip App',
389
+ description: 'Testing round-trip',
390
+ facts: [
391
+ {
392
+ tag: 'ItemAdded',
393
+ description: 'Item was added',
394
+ payload: { itemId: 'string', name: 'string' },
395
+ },
396
+ ],
397
+ events: [
398
+ {
399
+ tag: 'AddItem',
400
+ description: 'Add an item',
401
+ payload: { name: 'string', quantity: 'number' },
402
+ },
403
+ ],
404
+ rules: [
405
+ {
406
+ id: 'item.add',
407
+ description: 'Add item on event',
408
+ triggers: ['AddItem'],
409
+ then: 'return []',
410
+ },
411
+ ],
412
+ models: [
413
+ {
414
+ name: 'Item',
415
+ fields: [
416
+ { name: 'id', type: 'uuid' },
417
+ { name: 'name', type: 'string' },
418
+ { name: 'quantity', type: 'number' },
419
+ ],
420
+ },
421
+ ],
422
+ };
423
+
424
+ // Compile DSL to PSF
425
+ const compileResult = compileToPSF(input);
426
+ expect(compileResult.success).toBe(true);
427
+
428
+ // Validate compiled schema
429
+ const validationResult = validatePSFSchema(compileResult.schema!);
430
+ expect(validationResult.valid).toBe(true);
431
+
432
+ // Generate code from PSF
433
+ const generateResult = generateFromPSF(compileResult.schema!);
434
+ expect(generateResult.success).toBe(true);
435
+
436
+ // Verify generated files contain expected content
437
+ const factsFile = generateResult.files.find((f) => f.type === 'facts');
438
+ expect(factsFile?.content).toContain('ItemAdded');
439
+
440
+ const eventsFile = generateResult.files.find((f) => f.type === 'events');
441
+ expect(eventsFile?.content).toContain('AddItem');
442
+
443
+ const rulesFile = generateResult.files.find((f) => f.type === 'rules');
444
+ expect(rulesFile?.content).toContain('item_addRule');
445
+
446
+ const modelsFile = generateResult.files.find((f) => f.type === 'models');
447
+ expect(modelsFile?.content).toContain('interface Item');
448
+ });
449
+ });
450
+ });