@unifiedcommerce/core 0.4.2 → 0.4.4

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 (563) hide show
  1. package/dist/interfaces/rest/index.d.ts.map +1 -1
  2. package/dist/interfaces/rest/index.js +4 -17
  3. package/dist/runtime/server.d.ts.map +1 -1
  4. package/dist/runtime/server.js +33 -0
  5. package/package.json +1 -1
  6. package/src/interfaces/rest/index.ts +4 -18
  7. package/src/runtime/server.ts +33 -0
  8. package/dist/adapters/console-email.d.ts +0 -23
  9. package/dist/adapters/console-email.d.ts.map +0 -1
  10. package/dist/adapters/console-email.js +0 -38
  11. package/dist/auth/access.d.ts +0 -101
  12. package/dist/auth/access.d.ts.map +0 -1
  13. package/dist/auth/access.js +0 -128
  14. package/dist/auth/auth-schema.d.ts +0 -1475
  15. package/dist/auth/auth-schema.d.ts.map +0 -1
  16. package/dist/auth/auth-schema.js +0 -124
  17. package/dist/auth/middleware.d.ts +0 -5
  18. package/dist/auth/middleware.d.ts.map +0 -1
  19. package/dist/auth/middleware.js +0 -141
  20. package/dist/auth/org.d.ts +0 -22
  21. package/dist/auth/org.d.ts.map +0 -1
  22. package/dist/auth/org.js +0 -36
  23. package/dist/auth/permissions.d.ts +0 -4
  24. package/dist/auth/permissions.d.ts.map +0 -1
  25. package/dist/auth/permissions.js +0 -24
  26. package/dist/auth/setup.d.ts +0 -29
  27. package/dist/auth/setup.d.ts.map +0 -1
  28. package/dist/auth/setup.js +0 -117
  29. package/dist/auth/system-actor.d.ts +0 -7
  30. package/dist/auth/system-actor.d.ts.map +0 -1
  31. package/dist/auth/system-actor.js +0 -17
  32. package/dist/auth/types.d.ts +0 -11
  33. package/dist/auth/types.d.ts.map +0 -1
  34. package/dist/auth/types.js +0 -1
  35. package/dist/config/defaults.d.ts +0 -3
  36. package/dist/config/defaults.d.ts.map +0 -1
  37. package/dist/config/defaults.js +0 -80
  38. package/dist/config/define-config.d.ts +0 -9
  39. package/dist/config/define-config.d.ts.map +0 -1
  40. package/dist/config/define-config.js +0 -44
  41. package/dist/config/types.d.ts +0 -327
  42. package/dist/config/types.d.ts.map +0 -1
  43. package/dist/config/types.js +0 -1
  44. package/dist/generated/plugin-manifest.d.ts +0 -48
  45. package/dist/generated/plugin-manifest.d.ts.map +0 -1
  46. package/dist/generated/plugin-manifest.js +0 -20
  47. package/dist/hooks/checkout-completion.d.ts +0 -58
  48. package/dist/hooks/checkout-completion.d.ts.map +0 -1
  49. package/dist/hooks/checkout-completion.js +0 -137
  50. package/dist/hooks/checkout.d.ts +0 -99
  51. package/dist/hooks/checkout.d.ts.map +0 -1
  52. package/dist/hooks/checkout.js +0 -317
  53. package/dist/hooks/order-emails.d.ts +0 -16
  54. package/dist/hooks/order-emails.d.ts.map +0 -1
  55. package/dist/hooks/order-emails.js +0 -44
  56. package/dist/index.d.ts +0 -77
  57. package/dist/index.d.ts.map +0 -1
  58. package/dist/index.js +0 -45
  59. package/dist/interfaces/mcp/agent-prompt.d.ts +0 -16
  60. package/dist/interfaces/mcp/agent-prompt.d.ts.map +0 -1
  61. package/dist/interfaces/mcp/agent-prompt.js +0 -172
  62. package/dist/interfaces/mcp/context-enrichment.d.ts +0 -39
  63. package/dist/interfaces/mcp/context-enrichment.d.ts.map +0 -1
  64. package/dist/interfaces/mcp/context-enrichment.js +0 -119
  65. package/dist/interfaces/mcp/server.d.ts +0 -5
  66. package/dist/interfaces/mcp/server.d.ts.map +0 -1
  67. package/dist/interfaces/mcp/server.js +0 -30
  68. package/dist/interfaces/mcp/tool-builder.d.ts +0 -120
  69. package/dist/interfaces/mcp/tool-builder.d.ts.map +0 -1
  70. package/dist/interfaces/mcp/tool-builder.js +0 -224
  71. package/dist/interfaces/mcp/tools/analytics.d.ts +0 -42
  72. package/dist/interfaces/mcp/tools/analytics.d.ts.map +0 -1
  73. package/dist/interfaces/mcp/tools/analytics.js +0 -70
  74. package/dist/interfaces/mcp/tools/cart.d.ts +0 -14
  75. package/dist/interfaces/mcp/tools/cart.d.ts.map +0 -1
  76. package/dist/interfaces/mcp/tools/cart.js +0 -47
  77. package/dist/interfaces/mcp/tools/catalog.d.ts +0 -53
  78. package/dist/interfaces/mcp/tools/catalog.d.ts.map +0 -1
  79. package/dist/interfaces/mcp/tools/catalog.js +0 -284
  80. package/dist/interfaces/mcp/tools/index.d.ts +0 -3
  81. package/dist/interfaces/mcp/tools/index.d.ts.map +0 -1
  82. package/dist/interfaces/mcp/tools/index.js +0 -20
  83. package/dist/interfaces/mcp/tools/inventory.d.ts +0 -27
  84. package/dist/interfaces/mcp/tools/inventory.d.ts.map +0 -1
  85. package/dist/interfaces/mcp/tools/inventory.js +0 -143
  86. package/dist/interfaces/mcp/tools/orders.d.ts +0 -18
  87. package/dist/interfaces/mcp/tools/orders.d.ts.map +0 -1
  88. package/dist/interfaces/mcp/tools/orders.js +0 -82
  89. package/dist/interfaces/mcp/tools/pricing.d.ts +0 -29
  90. package/dist/interfaces/mcp/tools/pricing.d.ts.map +0 -1
  91. package/dist/interfaces/mcp/tools/pricing.js +0 -90
  92. package/dist/interfaces/mcp/tools/promotions.d.ts +0 -44
  93. package/dist/interfaces/mcp/tools/promotions.d.ts.map +0 -1
  94. package/dist/interfaces/mcp/tools/promotions.js +0 -109
  95. package/dist/interfaces/mcp/tools/registry.d.ts +0 -32
  96. package/dist/interfaces/mcp/tools/registry.d.ts.map +0 -1
  97. package/dist/interfaces/mcp/tools/registry.js +0 -55
  98. package/dist/interfaces/mcp/tools/search.d.ts +0 -14
  99. package/dist/interfaces/mcp/tools/search.d.ts.map +0 -1
  100. package/dist/interfaces/mcp/tools/search.js +0 -39
  101. package/dist/interfaces/mcp/tools/webhooks.d.ts +0 -15
  102. package/dist/interfaces/mcp/tools/webhooks.d.ts.map +0 -1
  103. package/dist/interfaces/mcp/tools/webhooks.js +0 -48
  104. package/dist/interfaces/mcp/transport.d.ts +0 -20
  105. package/dist/interfaces/mcp/transport.d.ts.map +0 -1
  106. package/dist/interfaces/mcp/transport.js +0 -99
  107. package/dist/interfaces/rest/customer-portal.d.ts +0 -5
  108. package/dist/interfaces/rest/customer-portal.d.ts.map +0 -1
  109. package/dist/interfaces/rest/customer-portal.js +0 -206
  110. package/dist/interfaces/rest/router.d.ts +0 -164
  111. package/dist/interfaces/rest/router.d.ts.map +0 -1
  112. package/dist/interfaces/rest/router.js +0 -259
  113. package/dist/interfaces/rest/routes/admin-jobs.d.ts +0 -5
  114. package/dist/interfaces/rest/routes/admin-jobs.d.ts.map +0 -1
  115. package/dist/interfaces/rest/routes/admin-jobs.js +0 -48
  116. package/dist/interfaces/rest/routes/audit.d.ts +0 -5
  117. package/dist/interfaces/rest/routes/audit.d.ts.map +0 -1
  118. package/dist/interfaces/rest/routes/audit.js +0 -43
  119. package/dist/interfaces/rest/routes/carts.d.ts +0 -5
  120. package/dist/interfaces/rest/routes/carts.d.ts.map +0 -1
  121. package/dist/interfaces/rest/routes/carts.js +0 -55
  122. package/dist/interfaces/rest/routes/catalog.d.ts +0 -5
  123. package/dist/interfaces/rest/routes/catalog.d.ts.map +0 -1
  124. package/dist/interfaces/rest/routes/catalog.js +0 -256
  125. package/dist/interfaces/rest/routes/checkout.d.ts +0 -5
  126. package/dist/interfaces/rest/routes/checkout.d.ts.map +0 -1
  127. package/dist/interfaces/rest/routes/checkout.js +0 -216
  128. package/dist/interfaces/rest/routes/customers.d.ts +0 -5
  129. package/dist/interfaces/rest/routes/customers.d.ts.map +0 -1
  130. package/dist/interfaces/rest/routes/customers.js +0 -74
  131. package/dist/interfaces/rest/routes/entity-aliases.d.ts +0 -18
  132. package/dist/interfaces/rest/routes/entity-aliases.d.ts.map +0 -1
  133. package/dist/interfaces/rest/routes/entity-aliases.js +0 -39
  134. package/dist/interfaces/rest/routes/inventory.d.ts +0 -5
  135. package/dist/interfaces/rest/routes/inventory.d.ts.map +0 -1
  136. package/dist/interfaces/rest/routes/inventory.js +0 -72
  137. package/dist/interfaces/rest/routes/media.d.ts +0 -5
  138. package/dist/interfaces/rest/routes/media.d.ts.map +0 -1
  139. package/dist/interfaces/rest/routes/media.js +0 -65
  140. package/dist/interfaces/rest/routes/orders.d.ts +0 -5
  141. package/dist/interfaces/rest/routes/orders.d.ts.map +0 -1
  142. package/dist/interfaces/rest/routes/orders.js +0 -64
  143. package/dist/interfaces/rest/routes/payments.d.ts +0 -5
  144. package/dist/interfaces/rest/routes/payments.d.ts.map +0 -1
  145. package/dist/interfaces/rest/routes/payments.js +0 -45
  146. package/dist/interfaces/rest/routes/pricing.d.ts +0 -5
  147. package/dist/interfaces/rest/routes/pricing.d.ts.map +0 -1
  148. package/dist/interfaces/rest/routes/pricing.js +0 -48
  149. package/dist/interfaces/rest/routes/promotions.d.ts +0 -5
  150. package/dist/interfaces/rest/routes/promotions.d.ts.map +0 -1
  151. package/dist/interfaces/rest/routes/promotions.js +0 -76
  152. package/dist/interfaces/rest/routes/search.d.ts +0 -5
  153. package/dist/interfaces/rest/routes/search.d.ts.map +0 -1
  154. package/dist/interfaces/rest/routes/search.js +0 -60
  155. package/dist/interfaces/rest/routes/webhooks.d.ts +0 -5
  156. package/dist/interfaces/rest/routes/webhooks.d.ts.map +0 -1
  157. package/dist/interfaces/rest/routes/webhooks.js +0 -39
  158. package/dist/interfaces/rest/schemas/admin-jobs.d.ts +0 -327
  159. package/dist/interfaces/rest/schemas/admin-jobs.d.ts.map +0 -1
  160. package/dist/interfaces/rest/schemas/admin-jobs.js +0 -37
  161. package/dist/interfaces/rest/schemas/audit.d.ts +0 -59
  162. package/dist/interfaces/rest/schemas/audit.d.ts.map +0 -1
  163. package/dist/interfaces/rest/schemas/audit.js +0 -43
  164. package/dist/interfaces/rest/schemas/carts.d.ts +0 -1456
  165. package/dist/interfaces/rest/schemas/carts.d.ts.map +0 -1
  166. package/dist/interfaces/rest/schemas/carts.js +0 -109
  167. package/dist/interfaces/rest/schemas/catalog.d.ts +0 -5452
  168. package/dist/interfaces/rest/schemas/catalog.d.ts.map +0 -1
  169. package/dist/interfaces/rest/schemas/catalog.js +0 -397
  170. package/dist/interfaces/rest/schemas/checkout.d.ts +0 -160
  171. package/dist/interfaces/rest/schemas/checkout.d.ts.map +0 -1
  172. package/dist/interfaces/rest/schemas/checkout.js +0 -60
  173. package/dist/interfaces/rest/schemas/customer-portal.d.ts +0 -2203
  174. package/dist/interfaces/rest/schemas/customer-portal.d.ts.map +0 -1
  175. package/dist/interfaces/rest/schemas/customer-portal.js +0 -177
  176. package/dist/interfaces/rest/schemas/customers.d.ts +0 -422
  177. package/dist/interfaces/rest/schemas/customers.d.ts.map +0 -1
  178. package/dist/interfaces/rest/schemas/customers.js +0 -150
  179. package/dist/interfaces/rest/schemas/inventory.d.ts +0 -561
  180. package/dist/interfaces/rest/schemas/inventory.d.ts.map +0 -1
  181. package/dist/interfaces/rest/schemas/inventory.js +0 -148
  182. package/dist/interfaces/rest/schemas/media.d.ts +0 -303
  183. package/dist/interfaces/rest/schemas/media.d.ts.map +0 -1
  184. package/dist/interfaces/rest/schemas/media.js +0 -69
  185. package/dist/interfaces/rest/schemas/orders.d.ts +0 -1792
  186. package/dist/interfaces/rest/schemas/orders.d.ts.map +0 -1
  187. package/dist/interfaces/rest/schemas/orders.js +0 -93
  188. package/dist/interfaces/rest/schemas/pricing.d.ts +0 -256
  189. package/dist/interfaces/rest/schemas/pricing.d.ts.map +0 -1
  190. package/dist/interfaces/rest/schemas/pricing.js +0 -72
  191. package/dist/interfaces/rest/schemas/promotions.d.ts +0 -363
  192. package/dist/interfaces/rest/schemas/promotions.d.ts.map +0 -1
  193. package/dist/interfaces/rest/schemas/promotions.js +0 -98
  194. package/dist/interfaces/rest/schemas/responses.d.ts +0 -4086
  195. package/dist/interfaces/rest/schemas/responses.d.ts.map +0 -1
  196. package/dist/interfaces/rest/schemas/responses.js +0 -74
  197. package/dist/interfaces/rest/schemas/search.d.ts +0 -247
  198. package/dist/interfaces/rest/schemas/search.d.ts.map +0 -1
  199. package/dist/interfaces/rest/schemas/search.js +0 -55
  200. package/dist/interfaces/rest/schemas/shared.d.ts +0 -95
  201. package/dist/interfaces/rest/schemas/shared.d.ts.map +0 -1
  202. package/dist/interfaces/rest/schemas/shared.js +0 -51
  203. package/dist/interfaces/rest/schemas/webhooks.d.ts +0 -221
  204. package/dist/interfaces/rest/schemas/webhooks.d.ts.map +0 -1
  205. package/dist/interfaces/rest/schemas/webhooks.js +0 -62
  206. package/dist/interfaces/rest/utils.d.ts +0 -45
  207. package/dist/interfaces/rest/utils.d.ts.map +0 -1
  208. package/dist/interfaces/rest/utils.js +0 -71
  209. package/dist/interfaces/rest/webhook-router.d.ts +0 -41
  210. package/dist/interfaces/rest/webhook-router.d.ts.map +0 -1
  211. package/dist/interfaces/rest/webhook-router.js +0 -36
  212. package/dist/kernel/compensation/executor.d.ts +0 -21
  213. package/dist/kernel/compensation/executor.d.ts.map +0 -1
  214. package/dist/kernel/compensation/executor.js +0 -36
  215. package/dist/kernel/compensation/types.d.ts +0 -25
  216. package/dist/kernel/compensation/types.d.ts.map +0 -1
  217. package/dist/kernel/compensation/types.js +0 -1
  218. package/dist/kernel/database/adapter.d.ts +0 -18
  219. package/dist/kernel/database/adapter.d.ts.map +0 -1
  220. package/dist/kernel/database/adapter.js +0 -3
  221. package/dist/kernel/database/drizzle-db.d.ts +0 -49
  222. package/dist/kernel/database/drizzle-db.d.ts.map +0 -1
  223. package/dist/kernel/database/drizzle-db.js +0 -20
  224. package/dist/kernel/database/migrate.d.ts +0 -38
  225. package/dist/kernel/database/migrate.d.ts.map +0 -1
  226. package/dist/kernel/database/migrate.js +0 -61
  227. package/dist/kernel/database/plugin-types.d.ts +0 -32
  228. package/dist/kernel/database/plugin-types.d.ts.map +0 -1
  229. package/dist/kernel/database/plugin-types.js +0 -10
  230. package/dist/kernel/database/schema.d.ts +0 -24
  231. package/dist/kernel/database/schema.d.ts.map +0 -1
  232. package/dist/kernel/database/schema.js +0 -36
  233. package/dist/kernel/database/scoped-db.d.ts +0 -20
  234. package/dist/kernel/database/scoped-db.d.ts.map +0 -1
  235. package/dist/kernel/database/scoped-db.js +0 -62
  236. package/dist/kernel/database/tx-context.d.ts +0 -15
  237. package/dist/kernel/database/tx-context.d.ts.map +0 -1
  238. package/dist/kernel/database/tx-context.js +0 -19
  239. package/dist/kernel/error-mapper.d.ts +0 -3
  240. package/dist/kernel/error-mapper.d.ts.map +0 -1
  241. package/dist/kernel/error-mapper.js +0 -12
  242. package/dist/kernel/errors.d.ts +0 -38
  243. package/dist/kernel/errors.d.ts.map +0 -1
  244. package/dist/kernel/errors.js +0 -69
  245. package/dist/kernel/factory/repository-factory.d.ts +0 -71
  246. package/dist/kernel/factory/repository-factory.d.ts.map +0 -1
  247. package/dist/kernel/factory/repository-factory.js +0 -138
  248. package/dist/kernel/hooks/create-context.d.ts +0 -25
  249. package/dist/kernel/hooks/create-context.d.ts.map +0 -1
  250. package/dist/kernel/hooks/create-context.js +0 -22
  251. package/dist/kernel/hooks/executor.d.ts +0 -12
  252. package/dist/kernel/hooks/executor.d.ts.map +0 -1
  253. package/dist/kernel/hooks/executor.js +0 -50
  254. package/dist/kernel/hooks/registry.d.ts +0 -28
  255. package/dist/kernel/hooks/registry.d.ts.map +0 -1
  256. package/dist/kernel/hooks/registry.js +0 -58
  257. package/dist/kernel/hooks/types.d.ts +0 -37
  258. package/dist/kernel/hooks/types.d.ts.map +0 -1
  259. package/dist/kernel/hooks/types.js +0 -1
  260. package/dist/kernel/http-error.d.ts +0 -30
  261. package/dist/kernel/http-error.d.ts.map +0 -1
  262. package/dist/kernel/http-error.js +0 -35
  263. package/dist/kernel/jobs/adapter.d.ts +0 -25
  264. package/dist/kernel/jobs/adapter.d.ts.map +0 -1
  265. package/dist/kernel/jobs/adapter.js +0 -9
  266. package/dist/kernel/jobs/drizzle-adapter.d.ts +0 -15
  267. package/dist/kernel/jobs/drizzle-adapter.d.ts.map +0 -1
  268. package/dist/kernel/jobs/drizzle-adapter.js +0 -42
  269. package/dist/kernel/jobs/runner.d.ts +0 -24
  270. package/dist/kernel/jobs/runner.d.ts.map +0 -1
  271. package/dist/kernel/jobs/runner.js +0 -114
  272. package/dist/kernel/jobs/schema.d.ts +0 -280
  273. package/dist/kernel/jobs/schema.d.ts.map +0 -1
  274. package/dist/kernel/jobs/schema.js +0 -37
  275. package/dist/kernel/jobs/types.d.ts +0 -30
  276. package/dist/kernel/jobs/types.d.ts.map +0 -1
  277. package/dist/kernel/jobs/types.js +0 -1
  278. package/dist/kernel/local-api.d.ts +0 -103
  279. package/dist/kernel/local-api.d.ts.map +0 -1
  280. package/dist/kernel/local-api.js +0 -89
  281. package/dist/kernel/plugin/manifest.d.ts +0 -90
  282. package/dist/kernel/plugin/manifest.d.ts.map +0 -1
  283. package/dist/kernel/plugin/manifest.js +0 -169
  284. package/dist/kernel/query/executor.d.ts +0 -21
  285. package/dist/kernel/query/executor.d.ts.map +0 -1
  286. package/dist/kernel/query/executor.js +0 -128
  287. package/dist/kernel/query/registry.d.ts +0 -33
  288. package/dist/kernel/query/registry.d.ts.map +0 -1
  289. package/dist/kernel/query/registry.js +0 -20
  290. package/dist/kernel/result.d.ts +0 -36
  291. package/dist/kernel/result.d.ts.map +0 -1
  292. package/dist/kernel/result.js +0 -16
  293. package/dist/kernel/schema/extra-columns.d.ts +0 -23
  294. package/dist/kernel/schema/extra-columns.d.ts.map +0 -1
  295. package/dist/kernel/schema/extra-columns.js +0 -10
  296. package/dist/kernel/service-registry.d.ts +0 -109
  297. package/dist/kernel/service-registry.d.ts.map +0 -1
  298. package/dist/kernel/service-registry.js +0 -26
  299. package/dist/kernel/service-timing.d.ts +0 -25
  300. package/dist/kernel/service-timing.d.ts.map +0 -1
  301. package/dist/kernel/service-timing.js +0 -62
  302. package/dist/kernel/state-machine/machine.d.ts +0 -24
  303. package/dist/kernel/state-machine/machine.d.ts.map +0 -1
  304. package/dist/kernel/state-machine/machine.js +0 -70
  305. package/dist/modules/analytics/drizzle-adapter.d.ts +0 -13
  306. package/dist/modules/analytics/drizzle-adapter.d.ts.map +0 -1
  307. package/dist/modules/analytics/drizzle-adapter.js +0 -358
  308. package/dist/modules/analytics/hooks.d.ts +0 -13
  309. package/dist/modules/analytics/hooks.d.ts.map +0 -1
  310. package/dist/modules/analytics/hooks.js +0 -12
  311. package/dist/modules/analytics/models.d.ts +0 -14
  312. package/dist/modules/analytics/models.d.ts.map +0 -1
  313. package/dist/modules/analytics/models.js +0 -118
  314. package/dist/modules/analytics/repository/index.d.ts +0 -5
  315. package/dist/modules/analytics/repository/index.d.ts.map +0 -1
  316. package/dist/modules/analytics/repository/index.js +0 -1
  317. package/dist/modules/analytics/service.d.ts +0 -45
  318. package/dist/modules/analytics/service.d.ts.map +0 -1
  319. package/dist/modules/analytics/service.js +0 -196
  320. package/dist/modules/analytics/types.d.ts +0 -119
  321. package/dist/modules/analytics/types.d.ts.map +0 -1
  322. package/dist/modules/analytics/types.js +0 -25
  323. package/dist/modules/audit/hooks.d.ts +0 -7
  324. package/dist/modules/audit/hooks.d.ts.map +0 -1
  325. package/dist/modules/audit/hooks.js +0 -67
  326. package/dist/modules/audit/schema.d.ts +0 -178
  327. package/dist/modules/audit/schema.d.ts.map +0 -1
  328. package/dist/modules/audit/schema.js +0 -21
  329. package/dist/modules/audit/service.d.ts +0 -38
  330. package/dist/modules/audit/service.d.ts.map +0 -1
  331. package/dist/modules/audit/service.js +0 -109
  332. package/dist/modules/cart/access.d.ts +0 -11
  333. package/dist/modules/cart/access.d.ts.map +0 -1
  334. package/dist/modules/cart/access.js +0 -18
  335. package/dist/modules/cart/matcher.d.ts +0 -20
  336. package/dist/modules/cart/matcher.d.ts.map +0 -1
  337. package/dist/modules/cart/matcher.js +0 -2
  338. package/dist/modules/cart/repository/index.d.ts +0 -45
  339. package/dist/modules/cart/repository/index.d.ts.map +0 -1
  340. package/dist/modules/cart/repository/index.js +0 -158
  341. package/dist/modules/cart/schema.d.ts +0 -359
  342. package/dist/modules/cart/schema.d.ts.map +0 -1
  343. package/dist/modules/cart/schema.js +0 -40
  344. package/dist/modules/cart/schemas.d.ts +0 -29
  345. package/dist/modules/cart/schemas.d.ts.map +0 -1
  346. package/dist/modules/cart/schemas.js +0 -14
  347. package/dist/modules/cart/service.d.ts +0 -63
  348. package/dist/modules/cart/service.d.ts.map +0 -1
  349. package/dist/modules/cart/service.js +0 -339
  350. package/dist/modules/catalog/repository/index.d.ts +0 -106
  351. package/dist/modules/catalog/repository/index.d.ts.map +0 -1
  352. package/dist/modules/catalog/repository/index.js +0 -455
  353. package/dist/modules/catalog/schema.d.ts +0 -1193
  354. package/dist/modules/catalog/schema.d.ts.map +0 -1
  355. package/dist/modules/catalog/schema.js +0 -149
  356. package/dist/modules/catalog/schemas.d.ts +0 -81
  357. package/dist/modules/catalog/schemas.d.ts.map +0 -1
  358. package/dist/modules/catalog/schemas.js +0 -62
  359. package/dist/modules/catalog/service.d.ts +0 -160
  360. package/dist/modules/catalog/service.d.ts.map +0 -1
  361. package/dist/modules/catalog/service.js +0 -759
  362. package/dist/modules/customers/repository/index.d.ts +0 -47
  363. package/dist/modules/customers/repository/index.d.ts.map +0 -1
  364. package/dist/modules/customers/repository/index.js +0 -206
  365. package/dist/modules/customers/schema.d.ts +0 -560
  366. package/dist/modules/customers/schema.d.ts.map +0 -1
  367. package/dist/modules/customers/schema.js +0 -60
  368. package/dist/modules/customers/service.d.ts +0 -27
  369. package/dist/modules/customers/service.d.ts.map +0 -1
  370. package/dist/modules/customers/service.js +0 -106
  371. package/dist/modules/fulfillment/repository/index.d.ts +0 -63
  372. package/dist/modules/fulfillment/repository/index.d.ts.map +0 -1
  373. package/dist/modules/fulfillment/repository/index.js +0 -268
  374. package/dist/modules/fulfillment/schema.d.ts +0 -655
  375. package/dist/modules/fulfillment/schema.d.ts.map +0 -1
  376. package/dist/modules/fulfillment/schema.js +0 -83
  377. package/dist/modules/fulfillment/service.d.ts +0 -58
  378. package/dist/modules/fulfillment/service.d.ts.map +0 -1
  379. package/dist/modules/fulfillment/service.js +0 -338
  380. package/dist/modules/fulfillment/types.d.ts +0 -44
  381. package/dist/modules/fulfillment/types.d.ts.map +0 -1
  382. package/dist/modules/fulfillment/types.js +0 -1
  383. package/dist/modules/inventory/repository/index.d.ts +0 -81
  384. package/dist/modules/inventory/repository/index.d.ts.map +0 -1
  385. package/dist/modules/inventory/repository/index.js +0 -310
  386. package/dist/modules/inventory/schema.d.ts +0 -570
  387. package/dist/modules/inventory/schema.d.ts.map +0 -1
  388. package/dist/modules/inventory/schema.js +0 -69
  389. package/dist/modules/inventory/schemas.d.ts +0 -31
  390. package/dist/modules/inventory/schemas.d.ts.map +0 -1
  391. package/dist/modules/inventory/schemas.js +0 -28
  392. package/dist/modules/inventory/service.d.ts +0 -69
  393. package/dist/modules/inventory/service.d.ts.map +0 -1
  394. package/dist/modules/inventory/service.js +0 -283
  395. package/dist/modules/media/adapter.d.ts +0 -16
  396. package/dist/modules/media/adapter.d.ts.map +0 -1
  397. package/dist/modules/media/adapter.js +0 -1
  398. package/dist/modules/media/repository/index.d.ts +0 -35
  399. package/dist/modules/media/repository/index.d.ts.map +0 -1
  400. package/dist/modules/media/repository/index.js +0 -176
  401. package/dist/modules/media/schema.d.ts +0 -289
  402. package/dist/modules/media/schema.d.ts.map +0 -1
  403. package/dist/modules/media/schema.js +0 -35
  404. package/dist/modules/media/service.d.ts +0 -42
  405. package/dist/modules/media/service.d.ts.map +0 -1
  406. package/dist/modules/media/service.js +0 -89
  407. package/dist/modules/orders/repository/index.d.ts +0 -48
  408. package/dist/modules/orders/repository/index.d.ts.map +0 -1
  409. package/dist/modules/orders/repository/index.js +0 -199
  410. package/dist/modules/orders/schema.d.ts +0 -672
  411. package/dist/modules/orders/schema.d.ts.map +0 -1
  412. package/dist/modules/orders/schema.js +0 -63
  413. package/dist/modules/orders/service.d.ts +0 -85
  414. package/dist/modules/orders/service.d.ts.map +0 -1
  415. package/dist/modules/orders/service.js +0 -313
  416. package/dist/modules/orders/stale-order-cleanup.d.ts +0 -27
  417. package/dist/modules/orders/stale-order-cleanup.d.ts.map +0 -1
  418. package/dist/modules/orders/stale-order-cleanup.js +0 -55
  419. package/dist/modules/organization/service.d.ts +0 -53
  420. package/dist/modules/organization/service.d.ts.map +0 -1
  421. package/dist/modules/organization/service.js +0 -151
  422. package/dist/modules/payments/adapter.d.ts +0 -42
  423. package/dist/modules/payments/adapter.d.ts.map +0 -1
  424. package/dist/modules/payments/adapter.js +0 -1
  425. package/dist/modules/payments/repository/index.d.ts +0 -5
  426. package/dist/modules/payments/repository/index.d.ts.map +0 -1
  427. package/dist/modules/payments/repository/index.js +0 -1
  428. package/dist/modules/payments/service.d.ts +0 -23
  429. package/dist/modules/payments/service.d.ts.map +0 -1
  430. package/dist/modules/payments/service.js +0 -72
  431. package/dist/modules/pricing/repository/index.d.ts +0 -34
  432. package/dist/modules/pricing/repository/index.d.ts.map +0 -1
  433. package/dist/modules/pricing/repository/index.js +0 -176
  434. package/dist/modules/pricing/schema.d.ts +0 -565
  435. package/dist/modules/pricing/schema.d.ts.map +0 -1
  436. package/dist/modules/pricing/schema.js +0 -57
  437. package/dist/modules/pricing/schemas.d.ts +0 -37
  438. package/dist/modules/pricing/schemas.d.ts.map +0 -1
  439. package/dist/modules/pricing/schemas.js +0 -30
  440. package/dist/modules/pricing/service.d.ts +0 -62
  441. package/dist/modules/pricing/service.d.ts.map +0 -1
  442. package/dist/modules/pricing/service.js +0 -308
  443. package/dist/modules/promotions/repository/index.d.ts +0 -41
  444. package/dist/modules/promotions/repository/index.d.ts.map +0 -1
  445. package/dist/modules/promotions/repository/index.js +0 -204
  446. package/dist/modules/promotions/schema.d.ts +0 -427
  447. package/dist/modules/promotions/schema.d.ts.map +0 -1
  448. package/dist/modules/promotions/schema.js +0 -52
  449. package/dist/modules/promotions/schemas.d.ts +0 -33
  450. package/dist/modules/promotions/schemas.d.ts.map +0 -1
  451. package/dist/modules/promotions/schemas.js +0 -32
  452. package/dist/modules/promotions/service.d.ts +0 -80
  453. package/dist/modules/promotions/service.d.ts.map +0 -1
  454. package/dist/modules/promotions/service.js +0 -347
  455. package/dist/modules/search/adapter.d.ts +0 -51
  456. package/dist/modules/search/adapter.d.ts.map +0 -1
  457. package/dist/modules/search/adapter.js +0 -1
  458. package/dist/modules/search/hooks.d.ts +0 -8
  459. package/dist/modules/search/hooks.d.ts.map +0 -1
  460. package/dist/modules/search/hooks.js +0 -6
  461. package/dist/modules/search/repository/index.d.ts +0 -5
  462. package/dist/modules/search/repository/index.d.ts.map +0 -1
  463. package/dist/modules/search/repository/index.js +0 -1
  464. package/dist/modules/search/service.d.ts +0 -24
  465. package/dist/modules/search/service.d.ts.map +0 -1
  466. package/dist/modules/search/service.js +0 -217
  467. package/dist/modules/shipping/calculator.d.ts +0 -42
  468. package/dist/modules/shipping/calculator.d.ts.map +0 -1
  469. package/dist/modules/shipping/calculator.js +0 -91
  470. package/dist/modules/shipping/repository/index.d.ts +0 -5
  471. package/dist/modules/shipping/repository/index.d.ts.map +0 -1
  472. package/dist/modules/shipping/repository/index.js +0 -1
  473. package/dist/modules/shipping/service.d.ts +0 -28
  474. package/dist/modules/shipping/service.d.ts.map +0 -1
  475. package/dist/modules/shipping/service.js +0 -20
  476. package/dist/modules/tax/adapter.d.ts +0 -58
  477. package/dist/modules/tax/adapter.d.ts.map +0 -1
  478. package/dist/modules/tax/adapter.js +0 -1
  479. package/dist/modules/tax/repository/index.d.ts +0 -5
  480. package/dist/modules/tax/repository/index.d.ts.map +0 -1
  481. package/dist/modules/tax/repository/index.js +0 -1
  482. package/dist/modules/tax/service.d.ts +0 -19
  483. package/dist/modules/tax/service.d.ts.map +0 -1
  484. package/dist/modules/tax/service.js +0 -34
  485. package/dist/modules/webhooks/hook.d.ts +0 -13
  486. package/dist/modules/webhooks/hook.d.ts.map +0 -1
  487. package/dist/modules/webhooks/hook.js +0 -29
  488. package/dist/modules/webhooks/repository/index.d.ts +0 -40
  489. package/dist/modules/webhooks/repository/index.d.ts.map +0 -1
  490. package/dist/modules/webhooks/repository/index.js +0 -175
  491. package/dist/modules/webhooks/schema.d.ts +0 -404
  492. package/dist/modules/webhooks/schema.d.ts.map +0 -1
  493. package/dist/modules/webhooks/schema.js +0 -40
  494. package/dist/modules/webhooks/service.d.ts +0 -23
  495. package/dist/modules/webhooks/service.d.ts.map +0 -1
  496. package/dist/modules/webhooks/service.js +0 -92
  497. package/dist/modules/webhooks/signing.d.ts +0 -2
  498. package/dist/modules/webhooks/signing.d.ts.map +0 -1
  499. package/dist/modules/webhooks/signing.js +0 -5
  500. package/dist/modules/webhooks/ssrf-guard.d.ts +0 -19
  501. package/dist/modules/webhooks/ssrf-guard.d.ts.map +0 -1
  502. package/dist/modules/webhooks/ssrf-guard.js +0 -79
  503. package/dist/modules/webhooks/tasks.d.ts +0 -16
  504. package/dist/modules/webhooks/tasks.d.ts.map +0 -1
  505. package/dist/modules/webhooks/tasks.js +0 -35
  506. package/dist/modules/webhooks/worker.d.ts +0 -21
  507. package/dist/modules/webhooks/worker.d.ts.map +0 -1
  508. package/dist/modules/webhooks/worker.js +0 -113
  509. package/dist/runtime/commerce.d.ts +0 -110
  510. package/dist/runtime/commerce.d.ts.map +0 -1
  511. package/dist/runtime/commerce.js +0 -37
  512. package/dist/runtime/kernel.d.ts +0 -71
  513. package/dist/runtime/kernel.d.ts.map +0 -1
  514. package/dist/runtime/kernel.js +0 -306
  515. package/dist/runtime/logger.d.ts +0 -11
  516. package/dist/runtime/logger.d.ts.map +0 -1
  517. package/dist/runtime/logger.js +0 -32
  518. package/dist/runtime/shutdown.d.ts +0 -15
  519. package/dist/runtime/shutdown.d.ts.map +0 -1
  520. package/dist/runtime/shutdown.js +0 -34
  521. package/dist/test-utils/create-pglite-adapter.d.ts +0 -32
  522. package/dist/test-utils/create-pglite-adapter.d.ts.map +0 -1
  523. package/dist/test-utils/create-pglite-adapter.js +0 -107
  524. package/dist/test-utils/create-plugin-test-app.d.ts +0 -50
  525. package/dist/test-utils/create-plugin-test-app.d.ts.map +0 -1
  526. package/dist/test-utils/create-plugin-test-app.js +0 -74
  527. package/dist/test-utils/create-repository-test-harness.d.ts +0 -8
  528. package/dist/test-utils/create-repository-test-harness.d.ts.map +0 -1
  529. package/dist/test-utils/create-repository-test-harness.js +0 -7
  530. package/dist/test-utils/create-test-config.d.ts +0 -18
  531. package/dist/test-utils/create-test-config.d.ts.map +0 -1
  532. package/dist/test-utils/create-test-config.js +0 -172
  533. package/dist/test-utils/create-test-kernel.d.ts +0 -3
  534. package/dist/test-utils/create-test-kernel.d.ts.map +0 -1
  535. package/dist/test-utils/create-test-kernel.js +0 -5
  536. package/dist/test-utils/create-test-plugin-context.d.ts +0 -42
  537. package/dist/test-utils/create-test-plugin-context.d.ts.map +0 -1
  538. package/dist/test-utils/create-test-plugin-context.js +0 -46
  539. package/dist/test-utils/rest-api-test-utils.d.ts +0 -64
  540. package/dist/test-utils/rest-api-test-utils.d.ts.map +0 -1
  541. package/dist/test-utils/rest-api-test-utils.js +0 -207
  542. package/dist/test-utils/test-actors.d.ts +0 -15
  543. package/dist/test-utils/test-actors.d.ts.map +0 -1
  544. package/dist/test-utils/test-actors.js +0 -57
  545. package/dist/test-utils/typed-hooks.d.ts +0 -43
  546. package/dist/test-utils/typed-hooks.d.ts.map +0 -1
  547. package/dist/test-utils/typed-hooks.js +0 -35
  548. package/dist/testing.d.ts +0 -14
  549. package/dist/testing.d.ts.map +0 -1
  550. package/dist/testing.js +0 -13
  551. package/dist/tsconfig.tsbuildinfo +0 -1
  552. package/dist/types/commerce-types.d.ts +0 -34
  553. package/dist/types/commerce-types.d.ts.map +0 -1
  554. package/dist/types/commerce-types.js +0 -1
  555. package/dist/utils/id.d.ts +0 -2
  556. package/dist/utils/id.d.ts.map +0 -1
  557. package/dist/utils/id.js +0 -3
  558. package/dist/utils/logger.d.ts +0 -3
  559. package/dist/utils/logger.d.ts.map +0 -1
  560. package/dist/utils/logger.js +0 -16
  561. package/dist/utils/pagination.d.ts +0 -11
  562. package/dist/utils/pagination.d.ts.map +0 -1
  563. package/dist/utils/pagination.js +0 -15
@@ -1,759 +0,0 @@
1
- import { resolveOrgId } from "../../auth/org.js";
2
- import { assertPermission } from "../../auth/permissions.js";
3
- import { CommerceConflictError, CommerceNotFoundError, CommerceValidationError, toCommerceError, } from "../../kernel/errors.js";
4
- import { runAfterHooks, runBeforeHooks } from "../../kernel/hooks/executor.js";
5
- import { createHookContext } from "../../kernel/hooks/create-context.js";
6
- import { Err, Ok } from "../../kernel/result.js";
7
- import { createLogger } from "../../utils/logger.js";
8
- import { paginate } from "../../utils/pagination.js";
9
- function cartesian(arrays) {
10
- return arrays.reduce((acc, values) => acc.flatMap((entry) => values.map((value) => [...entry, value])), [[]]);
11
- }
12
- /**
13
- * Helper to extract the value from a SellableCustomField based on its type.
14
- */
15
- function getCustomFieldValue(field) {
16
- switch (field.fieldType) {
17
- case "text":
18
- case "relation":
19
- return field.textValue;
20
- case "number":
21
- return field.numberValue;
22
- case "boolean":
23
- return field.booleanValue;
24
- case "date":
25
- return field.dateValue;
26
- case "json":
27
- return field.jsonValue;
28
- default:
29
- return null;
30
- }
31
- }
32
- export class CatalogServiceImpl {
33
- deps;
34
- repo;
35
- constructor(deps) {
36
- this.deps = deps;
37
- this.repo = deps.repository;
38
- }
39
- async validateAndCreateCustomFields(entityId, entityType, customFields, ctx) {
40
- if (!customFields)
41
- return Ok(undefined);
42
- const entityConfig = this.deps.config.entities?.[entityType];
43
- if (!entityConfig)
44
- return Ok(undefined);
45
- const definitionMap = new Map(entityConfig.fields.map((f) => [f.name, f]));
46
- for (const [name, value] of Object.entries(customFields)) {
47
- const def = definitionMap.get(name);
48
- if (!def) {
49
- return Err(new CommerceValidationError(`Unknown custom field: ${name}`));
50
- }
51
- const type = def.type;
52
- let valid = false;
53
- switch (type) {
54
- case "text":
55
- case "relation":
56
- case "select":
57
- valid = typeof value === "string";
58
- break;
59
- case "number":
60
- valid = typeof value === "number";
61
- break;
62
- case "boolean":
63
- valid = typeof value === "boolean";
64
- break;
65
- case "date":
66
- valid = typeof value === "string" || value instanceof Date;
67
- break;
68
- case "json":
69
- valid = typeof value === "object";
70
- break;
71
- default:
72
- valid = false;
73
- }
74
- if (!valid) {
75
- return Err(new CommerceValidationError(`Custom field ${name} expected type ${type}.`));
76
- }
77
- const fieldType = (type === "select" ? "text" : type);
78
- const insertData = {
79
- entityId,
80
- fieldName: name,
81
- fieldType,
82
- };
83
- switch (fieldType) {
84
- case "text":
85
- case "relation":
86
- insertData.textValue = value;
87
- break;
88
- case "number":
89
- insertData.numberValue = value;
90
- break;
91
- case "boolean":
92
- insertData.booleanValue = value;
93
- break;
94
- case "date":
95
- insertData.dateValue =
96
- value instanceof Date ? value : new Date(value);
97
- break;
98
- case "json":
99
- insertData.jsonValue = value;
100
- break;
101
- }
102
- await this.repo.createCustomField(insertData, ctx);
103
- }
104
- return Ok(undefined);
105
- }
106
- async hydrateEntity(entity, options, ctx) {
107
- const hydrated = { ...entity };
108
- if (options?.includeAttributes) {
109
- const attrs = await this.repo.findAttributesByEntityId(entity.id, ctx);
110
- if (typeof options.includeAttributes === "object") {
111
- hydrated.attributes = attrs.filter((a) => options.includeAttributes &&
112
- typeof options.includeAttributes === "object" &&
113
- options.includeAttributes.locales.includes(a.locale));
114
- }
115
- else {
116
- hydrated.attributes = attrs;
117
- }
118
- }
119
- if (options?.includeVariants) {
120
- const entityVariants = await this.repo.findVariantsByEntityId(entity.id, ctx);
121
- const variantsWithOptions = await Promise.all(entityVariants.map(async (variant) => {
122
- const optionValues = await this.repo.findVariantOptionValues(variant.id, ctx);
123
- return {
124
- ...variant,
125
- optionValueIds: optionValues.map((vov) => vov.optionValueId),
126
- };
127
- }));
128
- hydrated.variants = variantsWithOptions;
129
- }
130
- if (options?.includeOptionTypes) {
131
- const entityOptionTypes = await this.repo.findOptionTypesByEntityId(entity.id, ctx);
132
- hydrated.optionTypes = await Promise.all(entityOptionTypes.map(async (ot) => {
133
- const values = await this.repo.findOptionValuesByTypeId(ot.id, ctx);
134
- return { ...ot, values };
135
- }));
136
- }
137
- if (options?.includeCategories) {
138
- hydrated.categories = await this.repo.findEntityCategories(entity.id, ctx);
139
- }
140
- if (options?.includeBrands) {
141
- hydrated.brands = await this.repo.findEntityBrands(entity.id, ctx);
142
- }
143
- if (options?.includeMedia) {
144
- // TODO: integrate with MediaRepository when media service is refactored
145
- hydrated.media = [];
146
- }
147
- return hydrated;
148
- }
149
- async create(input, actor, ctx) {
150
- try {
151
- assertPermission(actor, "catalog:create");
152
- const orgId = resolveOrgId(actor);
153
- const existingBySlug = await this.repo.findEntityBySlug(orgId, input.slug, ctx);
154
- if (existingBySlug) {
155
- return Err(new CommerceConflictError(`Entity with slug ${input.slug} already exists.`));
156
- }
157
- const beforeHooks = this.deps.hooks.resolve("catalog.beforeCreate");
158
- const afterHooks = this.deps.hooks.resolve("catalog.afterCreate");
159
- const logger = createLogger("catalog.create");
160
- const context = createHookContext({
161
- actor,
162
- tx: ctx?.tx ?? null,
163
- logger,
164
- services: this.deps.services,
165
- });
166
- const processedInput = await runBeforeHooks(beforeHooks, input, "create", context);
167
- const entity = await this.repo.createEntity({
168
- organizationId: orgId,
169
- type: processedInput.type,
170
- slug: processedInput.slug,
171
- status: "draft",
172
- isVisible: false,
173
- metadata: processedInput.metadata ?? {},
174
- }, ctx);
175
- if (processedInput.attributes) {
176
- await this.repo.createAttribute({
177
- entityId: entity.id,
178
- locale: processedInput.attributes.locale ?? "en",
179
- title: processedInput.attributes.title,
180
- subtitle: processedInput.attributes.subtitle,
181
- description: processedInput.attributes.description,
182
- richDescription: processedInput.attributes.richDescription,
183
- seoTitle: processedInput.attributes.seoTitle,
184
- seoDescription: processedInput.attributes.seoDescription,
185
- }, ctx);
186
- }
187
- const customFieldsResult = await this.validateAndCreateCustomFields(entity.id, entity.type, processedInput.customFields, ctx);
188
- if (!customFieldsResult.ok)
189
- return customFieldsResult;
190
- const hookReport = await runAfterHooks(afterHooks, null, entity, "create", context);
191
- const hydrated = await this.hydrateEntity(entity, undefined, ctx);
192
- return Ok(hydrated, hookReport.hasErrors ? { hookErrors: hookReport.errors } : undefined);
193
- }
194
- catch (error) {
195
- return Err(toCommerceError(error));
196
- }
197
- }
198
- async update(id, input, actor, ctx) {
199
- try {
200
- assertPermission(actor, "catalog:update");
201
- const existing = await this.repo.findEntityById(id, ctx);
202
- if (!existing)
203
- return Err(new CommerceNotFoundError("Entity not found."));
204
- const beforeHooks = this.deps.hooks.resolve("catalog.beforeUpdate");
205
- const afterHooks = this.deps.hooks.resolve("catalog.afterUpdate");
206
- const context = createHookContext({
207
- actor,
208
- tx: ctx?.tx ?? null,
209
- logger: createLogger("catalog.update"),
210
- services: this.deps.services,
211
- });
212
- const processed = await runBeforeHooks(beforeHooks, input, "update", context);
213
- const updated = await this.repo.updateEntity(id, {
214
- ...(processed.slug !== undefined ? { slug: processed.slug } : {}),
215
- ...(processed.status !== undefined
216
- ? { status: processed.status }
217
- : {}),
218
- ...(processed.metadata !== undefined
219
- ? { metadata: processed.metadata }
220
- : {}),
221
- ...(processed.isVisible !== undefined
222
- ? { isVisible: processed.isVisible }
223
- : {}),
224
- }, ctx);
225
- if (!updated)
226
- return Err(new CommerceNotFoundError("Entity not found."));
227
- const hookReport = await runAfterHooks(afterHooks, existing, updated, "update", context);
228
- const hydrated = await this.hydrateEntity(updated, undefined, ctx);
229
- return Ok(hydrated, hookReport.hasErrors ? { hookErrors: hookReport.errors } : undefined);
230
- }
231
- catch (error) {
232
- return Err(toCommerceError(error));
233
- }
234
- }
235
- async delete(id, actor, ctx) {
236
- try {
237
- assertPermission(actor, "catalog:delete");
238
- const existing = await this.repo.findEntityById(id, ctx);
239
- if (!existing)
240
- return Err(new CommerceNotFoundError("Entity not found."));
241
- // Clean up related data (cascade handles most, but be explicit)
242
- await this.repo.deleteAttributesByEntityId(id, ctx);
243
- await this.repo.deleteCustomFieldsByEntityId(id, ctx);
244
- await this.repo.deleteEntityCategoriesByEntityId(id, ctx);
245
- await this.repo.deleteEntityBrandsByEntityId(id, ctx);
246
- await this.repo.deleteVariantOptionValuesByEntityId(id, ctx);
247
- await this.repo.deleteVariantsByEntityId(id, ctx);
248
- await this.repo.deleteEntity(id, ctx);
249
- return Ok(undefined);
250
- }
251
- catch (error) {
252
- return Err(toCommerceError(error));
253
- }
254
- }
255
- async getById(id, options, actor, ctx) {
256
- const context = createHookContext({
257
- actor: actor ?? null,
258
- tx: ctx?.tx ?? null,
259
- logger: createLogger("catalog.read"),
260
- services: this.deps.services,
261
- });
262
- const beforeHooks = this.deps.hooks.resolve("catalog.beforeRead");
263
- const afterHooks = this.deps.hooks.resolve("catalog.afterRead");
264
- const readInput = {
265
- id,
266
- ...(options !== undefined ? { options } : {}),
267
- };
268
- const processed = await runBeforeHooks(beforeHooks, readInput, "read", context);
269
- const entity = await this.repo.findEntityById(processed.id ?? id, ctx);
270
- if (!entity)
271
- return Err(new CommerceNotFoundError("Entity not found."));
272
- // Org boundary check — prevent cross-org access
273
- if (actor && entity.organizationId) {
274
- const orgId = resolveOrgId(actor);
275
- if (entity.organizationId !== orgId) {
276
- return Err(new CommerceNotFoundError("Entity not found."));
277
- }
278
- }
279
- const result = await this.hydrateEntity(entity, processed.options ?? options, ctx);
280
- const report = await runAfterHooks(afterHooks, null, result, "read", context);
281
- return Ok(result, report.hasErrors ? { hookErrors: report.errors } : undefined);
282
- }
283
- async getBySlug(slug, options, actor, ctx) {
284
- const context = createHookContext({
285
- actor: actor ?? null,
286
- tx: ctx?.tx ?? null,
287
- logger: createLogger("catalog.read"),
288
- services: this.deps.services,
289
- });
290
- const beforeHooks = this.deps.hooks.resolve("catalog.beforeRead");
291
- const afterHooks = this.deps.hooks.resolve("catalog.afterRead");
292
- const readInput = {
293
- slug,
294
- ...(options !== undefined ? { options } : {}),
295
- };
296
- const processed = await runBeforeHooks(beforeHooks, readInput, "read", context);
297
- const resolvedSlug = processed.slug ?? slug;
298
- const orgId = resolveOrgId(actor ?? null);
299
- const entity = await this.repo.findEntityBySlug(orgId, resolvedSlug, ctx);
300
- if (!entity)
301
- return Err(new CommerceNotFoundError("Entity not found."));
302
- const result = await this.hydrateEntity(entity, processed.options ?? options, ctx);
303
- const report = await runAfterHooks(afterHooks, null, result, "read", context);
304
- return Ok(result, report.hasErrors ? { hookErrors: report.errors } : undefined);
305
- }
306
- async list(params, actor, ctx) {
307
- const resolvedActor = actor ?? ctx?.actor ?? null;
308
- const context = createHookContext({
309
- actor: resolvedActor,
310
- tx: ctx?.tx ?? null,
311
- logger: createLogger("catalog.list"),
312
- services: this.deps.services,
313
- });
314
- const beforeHooks = this.deps.hooks.resolve("catalog.beforeList");
315
- const afterHooks = this.deps.hooks.resolve("catalog.afterList");
316
- const processed = await runBeforeHooks(beforeHooks, params, "list", context);
317
- const listOrgId = resolveOrgId(resolvedActor);
318
- let entities = await this.repo.findEntities(listOrgId, {
319
- ...(processed.filter?.type ? { type: processed.filter.type } : {}),
320
- ...(processed.filter?.status
321
- ? { status: processed.filter.status }
322
- : {}),
323
- }, ctx);
324
- // Category filter (M1 fix: validate input format, return error if not found)
325
- if (processed.filter?.category) {
326
- const catInput = processed.filter.category;
327
- const isUUID = /^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i;
328
- let category = await this.repo.findCategoryBySlug(listOrgId, catInput, ctx);
329
- if (!category && isUUID.test(catInput)) {
330
- category = await this.repo.findCategoryById(catInput, ctx);
331
- }
332
- if (!category) {
333
- return Err(new CommerceValidationError(`Category not found: "${catInput}".`));
334
- }
335
- const entityIds = await this.repo.findEntitiesByCategory(category.id, ctx);
336
- const entityIdSet = new Set(entityIds);
337
- entities = entities.filter((e) => entityIdSet.has(e.id));
338
- }
339
- // Brand filter
340
- if (processed.filter?.brand) {
341
- let brand = await this.repo.findBrandBySlug(listOrgId, processed.filter.brand, ctx);
342
- if (!brand) {
343
- brand = await this.repo.findBrandById(processed.filter.brand, ctx);
344
- }
345
- if (brand) {
346
- const brandEntityIds = [];
347
- for (const entity of entities) {
348
- const entityBrands = await this.repo.findEntityBrands(entity.id, ctx);
349
- if (entityBrands.some((eb) => eb.brandId === brand.id)) {
350
- brandEntityIds.push(entity.id);
351
- }
352
- }
353
- const brandEntitySet = new Set(brandEntityIds);
354
- entities = entities.filter((e) => brandEntitySet.has(e.id));
355
- }
356
- }
357
- // Custom field filter
358
- if (processed.filter?.customField) {
359
- const filteredIds = [];
360
- for (const entity of entities) {
361
- const fields = await this.repo.findCustomFieldsByEntityId(entity.id, ctx);
362
- const matches = fields.some((field) => {
363
- if (field.fieldName !== processed.filter?.customField?.fieldName)
364
- return false;
365
- return (getCustomFieldValue(field) === processed.filter.customField.value);
366
- });
367
- if (matches)
368
- filteredIds.push(entity.id);
369
- }
370
- const filteredSet = new Set(filteredIds);
371
- entities = entities.filter((e) => filteredSet.has(e.id));
372
- }
373
- // Sorting
374
- if (processed.sort) {
375
- const direction = processed.sort.direction === "asc" ? 1 : -1;
376
- entities.sort((a, b) => {
377
- const first = a[processed.sort.field];
378
- const second = b[processed.sort.field];
379
- if (first instanceof Date && second instanceof Date) {
380
- return (first.getTime() - second.getTime()) * direction;
381
- }
382
- return String(first).localeCompare(String(second)) * direction;
383
- });
384
- }
385
- const page = processed.pagination?.page ?? 1;
386
- const limit = processed.pagination?.limit ?? 20;
387
- const paged = paginate(entities, page, limit);
388
- const hydratedItems = await Promise.all(paged.items.map((entity) => this.hydrateEntity(entity, undefined, ctx)));
389
- const result = { items: hydratedItems, pagination: paged.pagination };
390
- const report = await runAfterHooks(afterHooks, null, result, "list", context);
391
- return Ok(result, report.hasErrors ? { hookErrors: report.errors } : undefined);
392
- }
393
- async changeStatus(id, status, actor, ctx) {
394
- const entity = await this.repo.findEntityById(id, ctx);
395
- if (!entity)
396
- return Err(new CommerceNotFoundError("Entity not found."));
397
- assertPermission(actor, "catalog:update");
398
- const updateData = { status };
399
- if (status === "active") {
400
- updateData.publishedAt = new Date();
401
- updateData.isVisible = true;
402
- }
403
- const updated = await this.repo.updateEntity(id, updateData, ctx);
404
- if (!updated)
405
- return Err(new CommerceNotFoundError("Entity not found."));
406
- return Ok(await this.hydrateEntity(updated, undefined, ctx));
407
- }
408
- publish(id, actor, ctx) {
409
- return this.changeStatus(id, "active", actor, ctx);
410
- }
411
- archive(id, actor, ctx) {
412
- return this.changeStatus(id, "archived", actor, ctx);
413
- }
414
- discontinue(id, actor, ctx) {
415
- return this.changeStatus(id, "discontinued", actor, ctx);
416
- }
417
- async setAttributes(entityId, locale, attrs, ctx) {
418
- const entity = await this.repo.findEntityById(entityId, ctx);
419
- if (!entity)
420
- return Err(new CommerceNotFoundError("Entity not found."));
421
- await this.repo.upsertAttribute(entityId, locale, {
422
- title: attrs.title,
423
- subtitle: attrs.subtitle,
424
- description: attrs.description,
425
- richDescription: attrs.richDescription,
426
- seoTitle: attrs.seoTitle,
427
- seoDescription: attrs.seoDescription,
428
- }, ctx);
429
- return Ok(undefined);
430
- }
431
- async getAttributes(entityId, locale, ctx) {
432
- const attr = await this.repo.findAttributeByLocale(entityId, locale, ctx);
433
- if (!attr)
434
- return Err(new CommerceNotFoundError(`Attributes for locale ${locale} not found.`));
435
- return Ok(attr);
436
- }
437
- async listCategories(ctx) {
438
- const allCategories = await this.repo.findAllCategories(resolveOrgId(ctx?.actor ?? null), ctx);
439
- const sorted = allCategories.sort((a, b) => a.sortOrder - b.sortOrder || a.slug.localeCompare(b.slug));
440
- return Ok(sorted.map((c) => ({
441
- id: c.id,
442
- parentId: c.parentId,
443
- slug: c.slug,
444
- sortOrder: c.sortOrder,
445
- metadata: c.metadata ?? {},
446
- })));
447
- }
448
- async createCategory(input, actor, ctx) {
449
- assertPermission(actor, "catalog:update");
450
- if (input.id) {
451
- const existingById = await this.repo.findCategoryById(input.id, ctx);
452
- if (existingById) {
453
- return Err(new CommerceConflictError(`Category with id ${input.id} already exists.`));
454
- }
455
- }
456
- const orgId = resolveOrgId(actor);
457
- const existingBySlug = await this.repo.findCategoryBySlug(orgId, input.slug, ctx);
458
- if (existingBySlug) {
459
- return Err(new CommerceConflictError(`Category with slug ${input.slug} already exists.`));
460
- }
461
- const category = await this.repo.createCategory({
462
- organizationId: orgId,
463
- ...(input.id ? { id: input.id } : {}),
464
- slug: input.slug,
465
- sortOrder: input.sortOrder ?? 0,
466
- metadata: input.metadata ?? {},
467
- ...(input.parentId !== undefined ? { parentId: input.parentId } : {}),
468
- }, ctx);
469
- return Ok({
470
- id: category.id,
471
- parentId: category.parentId,
472
- slug: category.slug,
473
- sortOrder: category.sortOrder,
474
- metadata: category.metadata ?? {},
475
- });
476
- }
477
- async updateCategory(id, input, actor, ctx) {
478
- assertPermission(actor, "catalog:update");
479
- const existing = await this.repo.findCategoryById(id, ctx);
480
- if (!existing)
481
- return Err(new CommerceNotFoundError("Category not found."));
482
- if (input.slug) {
483
- const catOrgId = resolveOrgId(actor);
484
- const existingBySlug = await this.repo.findCategoryBySlug(catOrgId, input.slug, ctx);
485
- if (existingBySlug && existingBySlug.id !== id) {
486
- return Err(new CommerceConflictError(`Category with slug ${input.slug} already exists.`));
487
- }
488
- }
489
- const updated = await this.repo.updateCategory(id, {
490
- ...(input.slug !== undefined ? { slug: input.slug } : {}),
491
- ...(input.sortOrder !== undefined
492
- ? { sortOrder: input.sortOrder }
493
- : {}),
494
- ...(input.metadata !== undefined ? { metadata: input.metadata } : {}),
495
- ...(input.parentId !== undefined ? { parentId: input.parentId } : {}),
496
- }, ctx);
497
- if (!updated)
498
- return Err(new CommerceNotFoundError("Category not found."));
499
- return Ok({
500
- id: updated.id,
501
- parentId: updated.parentId,
502
- slug: updated.slug,
503
- sortOrder: updated.sortOrder,
504
- metadata: updated.metadata ?? {},
505
- });
506
- }
507
- async deleteCategory(id, actor, ctx) {
508
- assertPermission(actor, "catalog:update");
509
- const existing = await this.repo.findCategoryById(id, ctx);
510
- if (!existing)
511
- return Err(new CommerceNotFoundError("Category not found."));
512
- await this.repo.deleteEntityCategoriesByCategoryId(id, ctx);
513
- await this.repo.deleteCategory(id, ctx);
514
- return Ok(undefined);
515
- }
516
- async addToCategory(entityId, categoryId, ctx) {
517
- const entity = await this.repo.findEntityById(entityId, ctx);
518
- if (!entity)
519
- return Err(new CommerceNotFoundError("Entity not found."));
520
- const addCatOrgId = resolveOrgId(ctx?.actor ?? null);
521
- const isUuid = /^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i.test(categoryId);
522
- let category = isUuid ? await this.repo.findCategoryById(categoryId, ctx) : null;
523
- if (!category) {
524
- category = await this.repo.findCategoryBySlug(addCatOrgId, categoryId, ctx);
525
- }
526
- if (!category) {
527
- category = await this.repo.createCategory({
528
- organizationId: addCatOrgId,
529
- slug: categoryId,
530
- sortOrder: 0,
531
- metadata: {},
532
- }, ctx);
533
- }
534
- await this.repo.addEntityToCategory(entityId, category.id, 0, ctx);
535
- return Ok(undefined);
536
- }
537
- async removeFromCategory(entityId, categoryId, ctx) {
538
- const isCatUuid = /^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i.test(categoryId);
539
- let category = isCatUuid ? await this.repo.findCategoryById(categoryId, ctx) : null;
540
- if (!category) {
541
- category = await this.repo.findCategoryBySlug(resolveOrgId(ctx?.actor ?? null), categoryId, ctx);
542
- }
543
- const resolvedCategoryId = category?.id ?? categoryId;
544
- const removed = await this.repo.removeEntityFromCategory(entityId, resolvedCategoryId, ctx);
545
- if (!removed)
546
- return Err(new CommerceNotFoundError("Category assignment not found."));
547
- return Ok(undefined);
548
- }
549
- async listBrands(ctx) {
550
- const allBrands = await this.repo.findAllBrands(resolveOrgId(ctx?.actor ?? null), ctx);
551
- return Ok(allBrands.sort((a, b) => a.displayName.localeCompare(b.displayName)));
552
- }
553
- async createBrand(input, actor, ctx) {
554
- assertPermission(actor, "catalog:update");
555
- if (input.id) {
556
- const existingById = await this.repo.findBrandById(input.id, ctx);
557
- if (existingById) {
558
- return Err(new CommerceConflictError(`Brand with id ${input.id} already exists.`));
559
- }
560
- }
561
- const orgId = resolveOrgId(actor);
562
- const existingBySlug = await this.repo.findBrandBySlug(orgId, input.slug, ctx);
563
- if (existingBySlug) {
564
- return Err(new CommerceConflictError(`Brand with slug ${input.slug} already exists.`));
565
- }
566
- return Ok(await this.repo.createBrand({
567
- organizationId: orgId,
568
- ...(input.id ? { id: input.id } : {}),
569
- slug: input.slug,
570
- displayName: input.displayName,
571
- metadata: input.metadata ?? {},
572
- }, ctx));
573
- }
574
- async updateBrand(id, input, actor, ctx) {
575
- assertPermission(actor, "catalog:update");
576
- const existing = await this.repo.findBrandById(id, ctx);
577
- if (!existing)
578
- return Err(new CommerceNotFoundError("Brand not found."));
579
- if (input.slug) {
580
- const brandOrgId = resolveOrgId(actor);
581
- const existingBySlug = await this.repo.findBrandBySlug(brandOrgId, input.slug, ctx);
582
- if (existingBySlug && existingBySlug.id !== id) {
583
- return Err(new CommerceConflictError(`Brand with slug ${input.slug} already exists.`));
584
- }
585
- }
586
- const updated = await this.repo.updateBrand(id, {
587
- ...(input.slug !== undefined ? { slug: input.slug } : {}),
588
- ...(input.displayName !== undefined
589
- ? { displayName: input.displayName }
590
- : {}),
591
- ...(input.metadata !== undefined ? { metadata: input.metadata } : {}),
592
- }, ctx);
593
- if (!updated)
594
- return Err(new CommerceNotFoundError("Brand not found."));
595
- return Ok(updated);
596
- }
597
- async deleteBrand(id, actor, ctx) {
598
- assertPermission(actor, "catalog:update");
599
- const existing = await this.repo.findBrandById(id, ctx);
600
- if (!existing)
601
- return Err(new CommerceNotFoundError("Brand not found."));
602
- await this.repo.deleteEntityBrandsByBrandId(id, ctx);
603
- await this.repo.deleteBrand(id, ctx);
604
- return Ok(undefined);
605
- }
606
- async addToBrand(entityId, brandId, ctx) {
607
- const entity = await this.repo.findEntityById(entityId, ctx);
608
- if (!entity)
609
- return Err(new CommerceNotFoundError("Entity not found."));
610
- const addBrandOrgId = resolveOrgId(ctx?.actor ?? null);
611
- const isBrandUuid = /^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i.test(brandId);
612
- let brand = isBrandUuid ? await this.repo.findBrandById(brandId, ctx) : null;
613
- if (!brand) {
614
- brand = await this.repo.findBrandBySlug(addBrandOrgId, brandId, ctx);
615
- }
616
- if (!brand) {
617
- brand = await this.repo.createBrand({
618
- organizationId: addBrandOrgId,
619
- slug: brandId,
620
- displayName: brandId,
621
- metadata: {},
622
- }, ctx);
623
- }
624
- await this.repo.addEntityToBrand(entityId, brand.id, 0, ctx);
625
- return Ok(undefined);
626
- }
627
- async removeFromBrand(entityId, brandId, ctx) {
628
- const isBrUuid = /^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i.test(brandId);
629
- let brand = isBrUuid ? await this.repo.findBrandById(brandId, ctx) : null;
630
- if (!brand) {
631
- brand = await this.repo.findBrandBySlug(resolveOrgId(ctx?.actor ?? null), brandId, ctx);
632
- }
633
- const resolvedBrandId = brand?.id ?? brandId;
634
- const removed = await this.repo.removeEntityFromBrand(entityId, resolvedBrandId, ctx);
635
- if (!removed)
636
- return Err(new CommerceNotFoundError("Brand assignment not found."));
637
- return Ok(undefined);
638
- }
639
- async createOptionType(input, actor, ctx) {
640
- assertPermission(actor, "catalog:update");
641
- const entity = await this.repo.findEntityById(input.entityId, ctx);
642
- if (!entity)
643
- return Err(new CommerceNotFoundError("Entity not found."));
644
- const optionType = await this.repo.createOptionType({
645
- entityId: input.entityId,
646
- name: input.name,
647
- displayName: input.name,
648
- sortOrder: 0,
649
- }, ctx);
650
- // Create initial option values if provided
651
- if (input.values) {
652
- for (const value of input.values) {
653
- await this.repo.createOptionValue({
654
- optionTypeId: optionType.id,
655
- value,
656
- displayValue: value,
657
- sortOrder: 0,
658
- metadata: {},
659
- }, ctx);
660
- }
661
- }
662
- return Ok(optionType);
663
- }
664
- async createOptionValue(input, actor, ctx) {
665
- assertPermission(actor, "catalog:update");
666
- const optionType = await this.repo.findOptionTypeById(input.optionTypeId, ctx);
667
- if (!optionType)
668
- return Err(new CommerceNotFoundError("Option type not found."));
669
- return Ok(await this.repo.createOptionValue({
670
- optionTypeId: input.optionTypeId,
671
- value: input.value,
672
- displayValue: input.value,
673
- sortOrder: 0,
674
- metadata: {},
675
- }, ctx));
676
- }
677
- async createVariant(input, actor, ctx) {
678
- assertPermission(actor, "catalog:update");
679
- const entity = await this.repo.findEntityById(input.entityId, ctx);
680
- if (!entity)
681
- return Err(new CommerceNotFoundError("Entity not found."));
682
- // Resolve options record (e.g. { Color: "Red" }) into option value IDs
683
- const entityOptionTypes = await this.repo.findOptionTypesByEntityId(input.entityId, ctx);
684
- const optionValueIds = [];
685
- for (const [optName, optVal] of Object.entries(input.options)) {
686
- const ot = entityOptionTypes.find((t) => t.name === optName);
687
- if (!ot) {
688
- return Err(new CommerceValidationError(`Option type "${optName}" does not exist on this entity.`));
689
- }
690
- const typeValues = await this.repo.findOptionValuesByTypeId(ot.id, ctx);
691
- const ov = typeValues.find((v) => v.value === optVal);
692
- if (!ov) {
693
- return Err(new CommerceValidationError(`Option value "${optVal}" does not exist for option type "${optName}".`));
694
- }
695
- optionValueIds.push(ov.id);
696
- }
697
- const variant = await this.repo.createVariant({
698
- entityId: input.entityId,
699
- status: "active",
700
- sortOrder: 0,
701
- metadata: {},
702
- ...(input.sku !== undefined ? { sku: input.sku } : {}),
703
- }, ctx);
704
- await this.repo.createVariantOptionValues(optionValueIds.map((optionValueId) => ({
705
- variantId: variant.id,
706
- optionValueId,
707
- })), ctx);
708
- return Ok(variant);
709
- }
710
- async generateVariants(entityId, strategy, actor, ctx) {
711
- assertPermission(actor, "catalog:update");
712
- const entity = await this.repo.findEntityById(entityId, ctx);
713
- if (!entity)
714
- return Err(new CommerceNotFoundError("Entity not found."));
715
- const entityOptionTypes = await this.repo.findOptionTypesByEntityId(entityId, ctx);
716
- const sortedOptionTypes = entityOptionTypes.sort((a, b) => a.sortOrder - b.sortOrder);
717
- const optionValueGroups = [];
718
- for (const optionType of sortedOptionTypes) {
719
- const values = await this.repo.findOptionValuesByTypeId(optionType.id, ctx);
720
- const sortedValues = values.sort((a, b) => a.sortOrder - b.sortOrder);
721
- optionValueGroups.push(sortedValues.map((v) => v.id));
722
- }
723
- let combinations = [];
724
- if (strategy.mode === "all") {
725
- combinations = cartesian(optionValueGroups);
726
- }
727
- else if (strategy.mode === "manual") {
728
- combinations = strategy.combinations;
729
- }
730
- else {
731
- const base = cartesian(optionValueGroups);
732
- const include = strategy.matrix.include;
733
- const exclude = strategy.matrix.exclude;
734
- combinations = base.filter((combo) => {
735
- const isExcluded = (exclude ?? []).some((pattern) => pattern.every((val) => combo.includes(val)));
736
- if (isExcluded)
737
- return false;
738
- if (!include || include.length === 0)
739
- return true;
740
- return include.some((pattern) => pattern.every((val) => combo.includes(val)));
741
- });
742
- }
743
- const created = [];
744
- for (const combo of combinations) {
745
- const variant = await this.repo.createVariant({
746
- entityId,
747
- status: "active",
748
- sortOrder: 0,
749
- metadata: { generatedBy: strategy.mode },
750
- }, ctx);
751
- await this.repo.createVariantOptionValues(combo.map((optionValueId) => ({
752
- variantId: variant.id,
753
- optionValueId,
754
- })), ctx);
755
- created.push(variant);
756
- }
757
- return Ok(created);
758
- }
759
- }