@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,28 +0,0 @@
1
- import { z } from "@hono/zod-openapi";
2
- // ─── Zod Body Schemas (single source of truth) ─────────────────────────────
3
- export const InventoryAdjustBodySchema = z.object({
4
- entityId: z.string().openapi({ example: "550e8400-e29b-41d4-a716-446655440000" }),
5
- variantId: z.string().optional().openapi({ example: "variant-uuid" }),
6
- warehouseId: z.string().optional().openapi({ example: "warehouse-uuid" }),
7
- adjustment: z.number().int().refine((v) => v !== 0, { message: "Adjustment cannot be zero" }).openapi({ example: 10 }),
8
- reason: z.string().openapi({ example: "Restock from supplier" }),
9
- performedBy: z.string().optional(),
10
- referenceType: z.string().optional(),
11
- referenceId: z.string().optional(),
12
- }).openapi("InventoryAdjustRequest");
13
- export const InventoryReserveBodySchema = z.object({
14
- entityId: z.string().openapi({ example: "550e8400-e29b-41d4-a716-446655440000" }),
15
- variantId: z.string().optional(),
16
- warehouseId: z.string().optional(),
17
- quantity: z.number().int().min(1).openapi({ example: 2 }),
18
- orderId: z.string().openapi({ example: "order-uuid" }),
19
- performedBy: z.string().optional(),
20
- }).openapi("InventoryReserveRequest");
21
- export const InventoryReleaseBodySchema = z.object({
22
- entityId: z.string().openapi({ example: "550e8400-e29b-41d4-a716-446655440000" }),
23
- variantId: z.string().optional(),
24
- warehouseId: z.string().optional(),
25
- quantity: z.number().int().min(1).openapi({ example: 2 }),
26
- orderId: z.string().openapi({ example: "order-uuid" }),
27
- performedBy: z.string().optional(),
28
- }).openapi("InventoryReleaseRequest");
@@ -1,69 +0,0 @@
1
- import type { Actor } from "../../auth/types.js";
2
- import type { CommerceConfig } from "../../config/types.js";
3
- import type { HookRegistry } from "../../kernel/hooks/registry.js";
4
- import { type Result } from "../../kernel/result.js";
5
- import type { DatabaseAdapter } from "../../kernel/database/adapter.js";
6
- import { type TxContext } from "../../kernel/database/tx-context.js";
7
- import { InventoryRepository, type Warehouse, type InventoryLevel } from "./repository/index.js";
8
- export type { InventoryAdjustInput, InventoryReserveInput, InventoryReleaseInput } from "./schemas.js";
9
- import type { InventoryAdjustInput, InventoryReserveInput, InventoryReleaseInput } from "./schemas.js";
10
- export interface InventoryServiceDeps {
11
- repository: InventoryRepository;
12
- hooks: HookRegistry;
13
- config: CommerceConfig;
14
- services: Record<string, unknown>;
15
- database: DatabaseAdapter;
16
- }
17
- export declare class InventoryService {
18
- private deps;
19
- private readonly repo;
20
- constructor(deps: InventoryServiceDeps);
21
- private pickWarehouse;
22
- createWarehouse(input: Partial<Warehouse>, actor?: Actor | null, ctx?: TxContext): Promise<Result<Warehouse>>;
23
- listWarehouses(actor?: Actor | null, ctx?: TxContext): Promise<Result<Warehouse[]>>;
24
- getAvailable(entityId: string, variantId?: string, ctx?: TxContext): Promise<Result<number>>;
25
- listLevels(params?: {
26
- warehouseId?: string;
27
- entityId?: string;
28
- }, actor?: Actor | null, ctx?: TxContext): Promise<Result<InventoryLevel[]>>;
29
- checkMultiple(entityIds: string[], ctx?: TxContext): Promise<Result<Record<string, number>>>;
30
- getLevelsByEntityId(entityId: string, ctx?: TxContext): Promise<Result<InventoryLevel[]>>;
31
- reserve(input: InventoryReserveInput, actor?: Actor | null, ctx?: TxContext): Promise<Result<void>>;
32
- release(input: InventoryReleaseInput, actor?: Actor | null, ctx?: TxContext): Promise<Result<void>>;
33
- adjust(input: InventoryAdjustInput, actor?: Actor | null, ctx?: TxContext): Promise<Result<InventoryLevel>>;
34
- /**
35
- * Set inventory to an absolute quantity (not a delta).
36
- *
37
- * Used by external store webhooks where the source system reports
38
- * the current stock level (e.g., Shopify sends `{ available: 6 }`).
39
- * Computes the delta internally so audit movements stay correct.
40
- */
41
- setAbsolute(input: {
42
- entityId: string;
43
- quantity: number;
44
- warehouseId?: string;
45
- variantId?: string;
46
- reason?: string;
47
- }, actor?: Actor | null, ctx?: TxContext): Promise<Result<InventoryLevel>>;
48
- /**
49
- * Deduct inventory on fulfillment (system-level, no permission check).
50
- *
51
- * Decrements quantityOnHand for fulfilled items. This is a system
52
- * operation triggered by order status → fulfilled, not a manual
53
- * stock adjustment. Creates a "fulfillment" type movement for audit.
54
- *
55
- * Net effect when paired with release():
56
- * Before: on_hand=100, reserved=5, available=95
57
- * After deduct+release: on_hand=95, reserved=0, available=95
58
- */
59
- deductForFulfillment(input: {
60
- entityId: string;
61
- variantId?: string;
62
- warehouseId?: string;
63
- quantity: number;
64
- orderId: string;
65
- orgId?: string;
66
- }, ctx?: TxContext): Promise<Result<void>>;
67
- setUnitCost(entityId: string, warehouseId: string, unitCost: number, variantId?: string, ctx?: TxContext): Promise<Result<InventoryLevel>>;
68
- }
69
- //# sourceMappingURL=service.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"service.d.ts","sourceRoot":"","sources":["../../../src/modules/inventory/service.ts"],"names":[],"mappings":"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"}
@@ -1,283 +0,0 @@
1
- import { resolveOrgId } from "../../auth/org.js";
2
- import { assertPermission } from "../../auth/permissions.js";
3
- import { CommerceNotFoundError, CommerceValidationError, toCommerceError, } from "../../kernel/errors.js";
4
- import { runAfterHooks } 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 { createTxContext } from "../../kernel/database/tx-context.js";
9
- export class InventoryService {
10
- deps;
11
- repo;
12
- constructor(deps) {
13
- this.deps = deps;
14
- this.repo = deps.repository;
15
- }
16
- async pickWarehouse(actor, ctx) {
17
- const orgId = resolveOrgId(actor ?? ctx?.actor ?? null);
18
- const warehouses = await this.repo.findAllWarehouses(orgId, ctx);
19
- const sorted = warehouses.sort((a, b) => a.priority - b.priority);
20
- if (sorted.length > 0) {
21
- return sorted[0].id;
22
- }
23
- // Create default warehouse if none exists
24
- const defaultWarehouse = await this.repo.createWarehouse({
25
- organizationId: orgId,
26
- name: "Default Warehouse",
27
- code: "DEFAULT",
28
- isActive: true,
29
- priority: 0,
30
- metadata: {},
31
- }, ctx);
32
- return defaultWarehouse.id;
33
- }
34
- async createWarehouse(input, actor, ctx) {
35
- if (!input.name || !input.code) {
36
- return Err(new CommerceValidationError("Warehouse name and code are required."));
37
- }
38
- const orgId = resolveOrgId(actor ?? ctx?.actor ?? null);
39
- const warehouse = await this.repo.createWarehouse({
40
- organizationId: orgId,
41
- name: input.name,
42
- code: input.code,
43
- isActive: input.isActive ?? true,
44
- priority: input.priority ?? 0,
45
- metadata: input.metadata ?? {},
46
- ...(input.address !== undefined ? { address: input.address } : {}),
47
- }, ctx);
48
- return Ok(warehouse);
49
- }
50
- async listWarehouses(actor, ctx) {
51
- const orgId = resolveOrgId(actor ?? ctx?.actor ?? null);
52
- const warehouses = await this.repo.findAllWarehouses(orgId, ctx);
53
- return Ok(warehouses.sort((a, b) => a.priority - b.priority));
54
- }
55
- async getAvailable(entityId, variantId, ctx) {
56
- const available = await this.repo.getAvailableQuantity(entityId, variantId, ctx);
57
- return Ok(available);
58
- }
59
- async listLevels(params, actor, ctx) {
60
- if (params?.entityId) {
61
- const levels = await this.repo.findLevelsByEntityId(params.entityId, ctx);
62
- return Ok(levels);
63
- }
64
- if (params?.warehouseId) {
65
- const levels = await this.repo.findLevelsByWarehouseId(params.warehouseId, ctx);
66
- return Ok(levels);
67
- }
68
- const levels = await this.repo.findAllLevels(ctx);
69
- return Ok(levels);
70
- }
71
- async checkMultiple(entityIds, ctx) {
72
- const data = await this.repo.getAvailableQuantities(entityIds, ctx);
73
- return Ok(data);
74
- }
75
- async getLevelsByEntityId(entityId, ctx) {
76
- const levels = await this.repo.findLevelsByEntityId(entityId, ctx);
77
- return Ok(levels);
78
- }
79
- async reserve(input, actor, ctx) {
80
- if (input.quantity <= 0) {
81
- return Err(new CommerceValidationError("Reservation quantity must be greater than zero."));
82
- }
83
- const warehouseId = input.warehouseId ?? (await this.pickWarehouse(actor, ctx));
84
- const performedBy = input.performedBy ?? actor?.userId ?? "system";
85
- const variantId = input.variantId ?? null;
86
- // If we have a transaction context, use the concurrency-safe
87
- // reserveWithLock (SELECT FOR UPDATE). This is the correct path
88
- // for checkout — it prevents two concurrent requests from both
89
- // reserving the last unit.
90
- if (ctx?.tx) {
91
- const reserveResult = await this.repo.reserveWithLock(input.entityId, variantId, warehouseId, input.quantity, ctx);
92
- if (!reserveResult.ok) {
93
- return Err(new CommerceValidationError(reserveResult.reason));
94
- }
95
- await this.repo.createMovement({
96
- entityId: input.entityId,
97
- warehouseId,
98
- type: "reservation",
99
- quantity: input.quantity,
100
- performedBy,
101
- referenceType: "order",
102
- referenceId: input.orderId,
103
- ...(input.variantId != null
104
- ? { variantId: input.variantId }
105
- : {}),
106
- }, ctx);
107
- return Ok(undefined);
108
- }
109
- // Fallback: no transaction provided. Wrap in a transaction so we can
110
- // use reserveWithLock (SELECT FOR UPDATE) for concurrency safety.
111
- const result = await this.deps.database.transaction(async (tx) => {
112
- const txCtx = createTxContext(tx, { actor: actor ?? null });
113
- const reserveResult = await this.repo.reserveWithLock(input.entityId, variantId, warehouseId, input.quantity, txCtx);
114
- if (!reserveResult.ok) {
115
- return Err(new CommerceValidationError(reserveResult.reason));
116
- }
117
- await this.repo.createMovement({
118
- entityId: input.entityId,
119
- warehouseId,
120
- type: "reservation",
121
- quantity: input.quantity,
122
- performedBy,
123
- referenceType: "order",
124
- referenceId: input.orderId,
125
- ...(input.variantId != null
126
- ? { variantId: input.variantId }
127
- : {}),
128
- }, txCtx);
129
- return Ok(undefined);
130
- });
131
- return result;
132
- }
133
- async release(input, actor, ctx) {
134
- const warehouseId = input.warehouseId ?? (await this.pickWarehouse(actor, ctx));
135
- const performedBy = input.performedBy ?? actor?.userId ?? "system";
136
- const variantId = input.variantId ?? null;
137
- const doRelease = async (txCtx) => {
138
- const releaseResult = await this.repo.releaseWithLock(input.entityId, variantId, warehouseId, input.quantity, txCtx);
139
- if (!releaseResult.ok) {
140
- return Err(new CommerceValidationError(releaseResult.reason));
141
- }
142
- await this.repo.createMovement({
143
- entityId: input.entityId,
144
- warehouseId,
145
- type: "release",
146
- quantity: input.quantity,
147
- performedBy,
148
- referenceType: "order",
149
- referenceId: input.orderId,
150
- ...(input.variantId != null
151
- ? { variantId: input.variantId }
152
- : {}),
153
- }, txCtx);
154
- return Ok(undefined);
155
- };
156
- // If we already have a transaction, use it directly
157
- if (ctx?.tx) {
158
- return doRelease(ctx);
159
- }
160
- // Otherwise wrap in a new transaction for locking safety
161
- return this.deps.database.transaction(async (tx) => {
162
- return doRelease(createTxContext(tx, { actor: actor ?? null }));
163
- });
164
- }
165
- async adjust(input, actor, ctx) {
166
- try {
167
- assertPermission(actor ?? null, "inventory:adjust");
168
- }
169
- catch (error) {
170
- return Err(toCommerceError(error));
171
- }
172
- const warehouseId = input.warehouseId ?? (await this.pickWarehouse(actor, ctx));
173
- // Use upsertLevel to create or update
174
- const existingLevel = await this.repo.findLevelByKey(input.entityId, warehouseId, input.variantId, ctx);
175
- let level;
176
- if (existingLevel) {
177
- const newQuantity = Math.max(0, existingLevel.quantityOnHand + input.adjustment);
178
- const updated = await this.repo.updateLevel(existingLevel.id, { quantityOnHand: newQuantity }, ctx);
179
- level = updated;
180
- }
181
- else {
182
- level = await this.repo.createLevel({
183
- entityId: input.entityId,
184
- warehouseId,
185
- quantityOnHand: Math.max(0, input.adjustment),
186
- quantityReserved: 0,
187
- quantityIncoming: 0,
188
- ...(input.variantId !== undefined
189
- ? { variantId: input.variantId }
190
- : {}),
191
- }, ctx);
192
- }
193
- await this.repo.createMovement({
194
- entityId: input.entityId,
195
- warehouseId,
196
- type: "adjustment",
197
- quantity: input.adjustment,
198
- reason: input.reason,
199
- performedBy: input.performedBy ?? actor?.userId ?? "system",
200
- ...(input.variantId !== undefined
201
- ? { variantId: input.variantId }
202
- : {}),
203
- ...(input.referenceType !== undefined
204
- ? { referenceType: input.referenceType }
205
- : {}),
206
- ...(input.referenceId !== undefined
207
- ? { referenceId: input.referenceId }
208
- : {}),
209
- }, ctx);
210
- const context = createHookContext({
211
- actor: actor ?? null,
212
- tx: ctx?.tx ?? null,
213
- logger: createLogger("inventory.adjust"),
214
- services: this.deps.services,
215
- context: { moduleName: "inventory" },
216
- });
217
- const afterHooks = this.deps.hooks.resolve("inventory.afterAdjust");
218
- await runAfterHooks(afterHooks, null, level, "update", context);
219
- return Ok(level);
220
- }
221
- /**
222
- * Set inventory to an absolute quantity (not a delta).
223
- *
224
- * Used by external store webhooks where the source system reports
225
- * the current stock level (e.g., Shopify sends `{ available: 6 }`).
226
- * Computes the delta internally so audit movements stay correct.
227
- */
228
- async setAbsolute(input, actor, ctx) {
229
- const warehouseId = input.warehouseId ?? (await this.pickWarehouse(actor, ctx));
230
- const existingLevel = await this.repo.findLevelByKey(input.entityId, warehouseId, input.variantId, ctx);
231
- const currentOnHand = existingLevel?.quantityOnHand ?? 0;
232
- const delta = input.quantity - currentOnHand;
233
- // Delegate to adjust() so hooks, movements, and permission checks are consistent
234
- return this.adjust({
235
- entityId: input.entityId,
236
- warehouseId,
237
- adjustment: delta,
238
- reason: input.reason ?? "External store absolute inventory sync",
239
- ...(input.variantId !== undefined ? { variantId: input.variantId } : {}),
240
- }, actor, ctx);
241
- }
242
- /**
243
- * Deduct inventory on fulfillment (system-level, no permission check).
244
- *
245
- * Decrements quantityOnHand for fulfilled items. This is a system
246
- * operation triggered by order status → fulfilled, not a manual
247
- * stock adjustment. Creates a "fulfillment" type movement for audit.
248
- *
249
- * Net effect when paired with release():
250
- * Before: on_hand=100, reserved=5, available=95
251
- * After deduct+release: on_hand=95, reserved=0, available=95
252
- */
253
- async deductForFulfillment(input, ctx) {
254
- const warehouseId = input.warehouseId ?? (await this.pickWarehouse(null, ctx));
255
- const variantId = input.variantId ?? null;
256
- const level = await this.repo.findLevelByKey(input.entityId, warehouseId, variantId != null ? variantId : undefined, ctx);
257
- if (!level) {
258
- // No inventory record — nothing to deduct
259
- return Ok(undefined);
260
- }
261
- const newOnHand = Math.max(0, level.quantityOnHand - input.quantity);
262
- await this.repo.updateLevel(level.id, { quantityOnHand: newOnHand }, ctx);
263
- await this.repo.createMovement({
264
- entityId: input.entityId,
265
- warehouseId,
266
- type: "fulfillment",
267
- quantity: -input.quantity,
268
- performedBy: "system",
269
- referenceType: "order",
270
- referenceId: input.orderId,
271
- ...(variantId != null ? { variantId } : {}),
272
- }, ctx);
273
- return Ok(undefined);
274
- }
275
- async setUnitCost(entityId, warehouseId, unitCost, variantId, ctx) {
276
- const level = await this.repo.findLevelByKey(entityId, warehouseId, variantId, ctx);
277
- if (!level) {
278
- return Err(new CommerceNotFoundError(`Inventory level not found for entity ${entityId} at warehouse ${warehouseId}.`));
279
- }
280
- const updated = await this.repo.updateLevel(level.id, { unitCost }, ctx);
281
- return Ok(updated);
282
- }
283
- }
@@ -1,16 +0,0 @@
1
- import type { Result } from "../../kernel/result.js";
2
- export interface StoredFile {
3
- key: string;
4
- url: string;
5
- contentType: string;
6
- size?: number;
7
- }
8
- export interface StorageAdapter {
9
- readonly providerId: string;
10
- upload(key: string, data: ArrayBuffer | ReadableStream, contentType: string): Promise<Result<StoredFile>>;
11
- getUrl(key: string): Promise<Result<string>>;
12
- getSignedUrl(key: string, expiresIn: number): Promise<Result<string>>;
13
- delete(key: string): Promise<Result<void>>;
14
- list(prefix: string): Promise<Result<StoredFile[]>>;
15
- }
16
- //# sourceMappingURL=adapter.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"adapter.d.ts","sourceRoot":"","sources":["../../../src/modules/media/adapter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AAErD,MAAM,WAAW,UAAU;IACzB,GAAG,EAAE,MAAM,CAAC;IACZ,GAAG,EAAE,MAAM,CAAC;IACZ,WAAW,EAAE,MAAM,CAAC;IACpB,IAAI,CAAC,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,cAAc;IAC7B,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;IAC5B,MAAM,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,WAAW,GAAG,cAAc,EAAE,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC;IAC1G,MAAM,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC;IAC7C,YAAY,CAAC,GAAG,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC;IACtE,MAAM,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;IAC3C,IAAI,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC;CACrD"}
@@ -1 +0,0 @@
1
- export {};
@@ -1,35 +0,0 @@
1
- import type { TxContext } from "../../../kernel/database/tx-context.js";
2
- import type { DrizzleDatabase } from "../../../kernel/database/drizzle-db.js";
3
- import { mediaAssets, entityMedia } from "../schema.js";
4
- export type MediaAsset = typeof mediaAssets.$inferSelect;
5
- export type MediaAssetInsert = typeof mediaAssets.$inferInsert;
6
- export type EntityMedia = typeof entityMedia.$inferSelect;
7
- export type EntityMediaInsert = typeof entityMedia.$inferInsert;
8
- /**
9
- * MediaRepository provides type-safe database operations for media assets.
10
- *
11
- * This repository manages media assets and their associations with entities.
12
- * All methods support an optional TxContext parameter for transaction participation.
13
- */
14
- export declare class MediaRepository {
15
- private readonly db;
16
- constructor(db: DrizzleDatabase);
17
- private getDb;
18
- findAssetById(id: string, ctx?: TxContext, orgId?: string): Promise<MediaAsset | undefined>;
19
- findAssetByStorageKey(storageKey: string, ctx?: TxContext): Promise<MediaAsset | undefined>;
20
- findAssetsByIds(ids: string[], ctx?: TxContext): Promise<MediaAsset[]>;
21
- createAsset(data: MediaAssetInsert, ctx?: TxContext): Promise<MediaAsset>;
22
- updateAsset(id: string, data: Partial<Omit<MediaAssetInsert, "id">>, ctx?: TxContext): Promise<MediaAsset | undefined>;
23
- deleteAsset(id: string, ctx?: TxContext): Promise<boolean>;
24
- findEntityMedia(entityId: string, variantId?: string, ctx?: TxContext): Promise<EntityMedia[]>;
25
- findEntityMediaByRole(entityId: string, role: EntityMedia["role"], variantId?: string, ctx?: TxContext): Promise<EntityMedia[]>;
26
- findPrimaryMedia(entityId: string, variantId?: string, ctx?: TxContext): Promise<EntityMedia | undefined>;
27
- createEntityMedia(data: EntityMediaInsert, ctx?: TxContext): Promise<EntityMedia>;
28
- createEntityMediaBatch(data: EntityMediaInsert[], ctx?: TxContext): Promise<EntityMedia[]>;
29
- updateEntityMediaSortOrder(entityId: string, mediaAssetId: string, sortOrder: number, variantId?: string, ctx?: TxContext): Promise<EntityMedia | undefined>;
30
- removeEntityMedia(entityId: string, mediaAssetId: string, variantId?: string, ctx?: TxContext): Promise<boolean>;
31
- removeAllEntityMedia(entityId: string, ctx?: TxContext): Promise<void>;
32
- removeAllMediaByAssetId(mediaAssetId: string, ctx?: TxContext): Promise<void>;
33
- findAssetsForEntity(entityId: string, variantId?: string, ctx?: TxContext): Promise<MediaAsset[]>;
34
- }
35
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/modules/media/repository/index.ts"],"names":[],"mappings":"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"}
@@ -1,176 +0,0 @@
1
- import { eq, and, inArray } from "drizzle-orm";
2
- import { mediaAssets, entityMedia } from "../schema.js";
3
- /**
4
- * MediaRepository provides type-safe database operations for media assets.
5
- *
6
- * This repository manages media assets and their associations with entities.
7
- * All methods support an optional TxContext parameter for transaction participation.
8
- */
9
- export class MediaRepository {
10
- db;
11
- constructor(db) {
12
- this.db = db;
13
- }
14
- getDb(ctx) {
15
- return ctx?.tx ?? this.db;
16
- }
17
- // ─────────────────────────────────────────────────────────────────────────────
18
- // Media Assets
19
- // ─────────────────────────────────────────────────────────────────────────────
20
- async findAssetById(id, ctx, orgId) {
21
- const db = this.getDb(ctx);
22
- const conditions = [eq(mediaAssets.id, id)];
23
- if (orgId) {
24
- conditions.push(eq(mediaAssets.organizationId, orgId));
25
- }
26
- const rows = await db
27
- .select()
28
- .from(mediaAssets)
29
- .where(and(...conditions));
30
- return rows[0];
31
- }
32
- async findAssetByStorageKey(storageKey, ctx) {
33
- const db = this.getDb(ctx);
34
- const rows = await db
35
- .select()
36
- .from(mediaAssets)
37
- .where(eq(mediaAssets.storageKey, storageKey));
38
- return rows[0];
39
- }
40
- async findAssetsByIds(ids, ctx) {
41
- if (ids.length === 0)
42
- return [];
43
- const db = this.getDb(ctx);
44
- return db.select().from(mediaAssets).where(inArray(mediaAssets.id, ids));
45
- }
46
- async createAsset(data, ctx) {
47
- const db = this.getDb(ctx);
48
- const rows = await db.insert(mediaAssets).values(data).returning();
49
- return rows[0];
50
- }
51
- async updateAsset(id, data, ctx) {
52
- const db = this.getDb(ctx);
53
- const rows = await db
54
- .update(mediaAssets)
55
- .set(data)
56
- .where(eq(mediaAssets.id, id))
57
- .returning();
58
- return rows[0];
59
- }
60
- async deleteAsset(id, ctx) {
61
- const db = this.getDb(ctx);
62
- const result = await db
63
- .delete(mediaAssets)
64
- .where(eq(mediaAssets.id, id))
65
- .returning();
66
- return result.length > 0;
67
- }
68
- // ─────────────────────────────────────────────────────────────────────────────
69
- // Entity Media (Associations)
70
- // ─────────────────────────────────────────────────────────────────────────────
71
- async findEntityMedia(entityId, variantId, ctx) {
72
- const db = this.getDb(ctx);
73
- if (variantId === undefined) {
74
- // Find media for entity only (not variant-specific)
75
- const rows = await db
76
- .select()
77
- .from(entityMedia)
78
- .where(eq(entityMedia.entityId, entityId));
79
- return rows.filter((r) => r.variantId === null);
80
- }
81
- return db
82
- .select()
83
- .from(entityMedia)
84
- .where(and(eq(entityMedia.entityId, entityId), eq(entityMedia.variantId, variantId)));
85
- }
86
- async findEntityMediaByRole(entityId, role, variantId, ctx) {
87
- const db = this.getDb(ctx);
88
- const conditions = [
89
- eq(entityMedia.entityId, entityId),
90
- eq(entityMedia.role, role),
91
- ];
92
- if (variantId !== undefined) {
93
- conditions.push(eq(entityMedia.variantId, variantId));
94
- }
95
- const rows = await db
96
- .select()
97
- .from(entityMedia)
98
- .where(and(...conditions));
99
- if (variantId === undefined) {
100
- return rows.filter((r) => r.variantId === null);
101
- }
102
- return rows;
103
- }
104
- async findPrimaryMedia(entityId, variantId, ctx) {
105
- const media = await this.findEntityMediaByRole(entityId, "primary", variantId, ctx);
106
- return media[0];
107
- }
108
- async createEntityMedia(data, ctx) {
109
- const db = this.getDb(ctx);
110
- const rows = await db.insert(entityMedia).values(data).returning();
111
- return rows[0];
112
- }
113
- async createEntityMediaBatch(data, ctx) {
114
- if (data.length === 0)
115
- return [];
116
- const db = this.getDb(ctx);
117
- return db.insert(entityMedia).values(data).returning();
118
- }
119
- async updateEntityMediaSortOrder(entityId, mediaAssetId, sortOrder, variantId, ctx) {
120
- const db = this.getDb(ctx);
121
- const conditions = [
122
- eq(entityMedia.entityId, entityId),
123
- eq(entityMedia.mediaAssetId, mediaAssetId),
124
- ];
125
- if (variantId !== undefined) {
126
- conditions.push(eq(entityMedia.variantId, variantId));
127
- }
128
- const rows = await db
129
- .update(entityMedia)
130
- .set({ sortOrder })
131
- .where(and(...conditions))
132
- .returning();
133
- if (variantId === undefined) {
134
- return rows.find((r) => r.variantId === null);
135
- }
136
- return rows[0];
137
- }
138
- async removeEntityMedia(entityId, mediaAssetId, variantId, ctx) {
139
- const db = this.getDb(ctx);
140
- const conditions = [
141
- eq(entityMedia.entityId, entityId),
142
- eq(entityMedia.mediaAssetId, mediaAssetId),
143
- ];
144
- if (variantId !== undefined) {
145
- conditions.push(eq(entityMedia.variantId, variantId));
146
- }
147
- const result = await db
148
- .delete(entityMedia)
149
- .where(and(...conditions))
150
- .returning();
151
- if (variantId === undefined) {
152
- return result.some((r) => r.variantId === null);
153
- }
154
- return result.length > 0;
155
- }
156
- async removeAllEntityMedia(entityId, ctx) {
157
- const db = this.getDb(ctx);
158
- await db.delete(entityMedia).where(eq(entityMedia.entityId, entityId));
159
- }
160
- async removeAllMediaByAssetId(mediaAssetId, ctx) {
161
- const db = this.getDb(ctx);
162
- await db
163
- .delete(entityMedia)
164
- .where(eq(entityMedia.mediaAssetId, mediaAssetId));
165
- }
166
- // ─────────────────────────────────────────────────────────────────────────────
167
- // Aggregates
168
- // ─────────────────────────────────────────────────────────────────────────────
169
- async findAssetsForEntity(entityId, variantId, ctx) {
170
- const associations = await this.findEntityMedia(entityId, variantId, ctx);
171
- const assetIds = associations.map((a) => a.mediaAssetId);
172
- if (assetIds.length === 0)
173
- return [];
174
- return this.findAssetsByIds(assetIds, ctx);
175
- }
176
- }