@carlonicora/nestjs-neo4jsonapi 1.62.7 → 1.64.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (271) hide show
  1. package/dist/agents/agents.modules.d.ts.map +1 -1
  2. package/dist/agents/agents.modules.js +3 -0
  3. package/dist/agents/agents.modules.js.map +1 -1
  4. package/dist/agents/chatbot/chatbot.module.d.ts +3 -0
  5. package/dist/agents/chatbot/chatbot.module.d.ts.map +1 -0
  6. package/dist/agents/chatbot/chatbot.module.js +65 -0
  7. package/dist/agents/chatbot/chatbot.module.js.map +1 -0
  8. package/dist/agents/chatbot/interfaces/chatbot.response.interface.d.ts +25 -0
  9. package/dist/agents/chatbot/interfaces/chatbot.response.interface.d.ts.map +1 -0
  10. package/dist/agents/chatbot/interfaces/chatbot.response.interface.js +3 -0
  11. package/dist/agents/chatbot/interfaces/chatbot.response.interface.js.map +1 -0
  12. package/dist/agents/chatbot/interfaces/graph.catalog.interface.d.ts +50 -0
  13. package/dist/agents/chatbot/interfaces/graph.catalog.interface.d.ts.map +1 -0
  14. package/dist/agents/chatbot/interfaces/graph.catalog.interface.js +3 -0
  15. package/dist/agents/chatbot/interfaces/graph.catalog.interface.js.map +1 -0
  16. package/dist/agents/chatbot/prompts/chatbot.system.prompt.d.ts +3 -0
  17. package/dist/agents/chatbot/prompts/chatbot.system.prompt.d.ts.map +1 -0
  18. package/dist/agents/chatbot/prompts/chatbot.system.prompt.js +60 -0
  19. package/dist/agents/chatbot/prompts/chatbot.system.prompt.js.map +1 -0
  20. package/dist/agents/chatbot/repositories/user-modules.repository.d.ts +28 -0
  21. package/dist/agents/chatbot/repositories/user-modules.repository.d.ts.map +1 -0
  22. package/dist/agents/chatbot/repositories/user-modules.repository.js +76 -0
  23. package/dist/agents/chatbot/repositories/user-modules.repository.js.map +1 -0
  24. package/dist/agents/chatbot/services/chatbot.index.manager.d.ts +17 -0
  25. package/dist/agents/chatbot/services/chatbot.index.manager.d.ts.map +1 -0
  26. package/dist/agents/chatbot/services/chatbot.index.manager.js +84 -0
  27. package/dist/agents/chatbot/services/chatbot.index.manager.js.map +1 -0
  28. package/dist/agents/chatbot/services/chatbot.search.service.d.ts +46 -0
  29. package/dist/agents/chatbot/services/chatbot.search.service.d.ts.map +1 -0
  30. package/dist/agents/chatbot/services/chatbot.search.service.js +148 -0
  31. package/dist/agents/chatbot/services/chatbot.search.service.js.map +1 -0
  32. package/dist/agents/chatbot/services/chatbot.service.d.ts +36 -0
  33. package/dist/agents/chatbot/services/chatbot.service.d.ts.map +1 -0
  34. package/dist/agents/chatbot/services/chatbot.service.js +220 -0
  35. package/dist/agents/chatbot/services/chatbot.service.js.map +1 -0
  36. package/dist/agents/chatbot/services/descriptor.source.d.ts +18 -0
  37. package/dist/agents/chatbot/services/descriptor.source.d.ts.map +1 -0
  38. package/dist/agents/chatbot/services/descriptor.source.js +41 -0
  39. package/dist/agents/chatbot/services/descriptor.source.js.map +1 -0
  40. package/dist/agents/chatbot/services/field-formatting.d.ts +18 -0
  41. package/dist/agents/chatbot/services/field-formatting.d.ts.map +1 -0
  42. package/dist/agents/chatbot/services/field-formatting.js +43 -0
  43. package/dist/agents/chatbot/services/field-formatting.js.map +1 -0
  44. package/dist/agents/chatbot/services/graph.catalog.service.d.ts +60 -0
  45. package/dist/agents/chatbot/services/graph.catalog.service.d.ts.map +1 -0
  46. package/dist/agents/chatbot/services/graph.catalog.service.js +217 -0
  47. package/dist/agents/chatbot/services/graph.catalog.service.js.map +1 -0
  48. package/dist/agents/chatbot/services/humanize-tool.d.ts +9 -0
  49. package/dist/agents/chatbot/services/humanize-tool.d.ts.map +1 -0
  50. package/dist/agents/chatbot/services/humanize-tool.js +35 -0
  51. package/dist/agents/chatbot/services/humanize-tool.js.map +1 -0
  52. package/dist/agents/chatbot/tools/describe-entity.tool.d.ts +14 -0
  53. package/dist/agents/chatbot/tools/describe-entity.tool.d.ts.map +1 -0
  54. package/dist/agents/chatbot/tools/describe-entity.tool.js +63 -0
  55. package/dist/agents/chatbot/tools/describe-entity.tool.js.map +1 -0
  56. package/dist/agents/chatbot/tools/read-entity.tool.d.ts +16 -0
  57. package/dist/agents/chatbot/tools/read-entity.tool.d.ts.map +1 -0
  58. package/dist/agents/chatbot/tools/read-entity.tool.js +102 -0
  59. package/dist/agents/chatbot/tools/read-entity.tool.js.map +1 -0
  60. package/dist/agents/chatbot/tools/resolve-entity.tool.d.ts +16 -0
  61. package/dist/agents/chatbot/tools/resolve-entity.tool.d.ts.map +1 -0
  62. package/dist/agents/chatbot/tools/resolve-entity.tool.js +48 -0
  63. package/dist/agents/chatbot/tools/resolve-entity.tool.js.map +1 -0
  64. package/dist/agents/chatbot/tools/search-entities.tool.d.ts +20 -0
  65. package/dist/agents/chatbot/tools/search-entities.tool.d.ts.map +1 -0
  66. package/dist/agents/chatbot/tools/search-entities.tool.js +122 -0
  67. package/dist/agents/chatbot/tools/search-entities.tool.js.map +1 -0
  68. package/dist/agents/chatbot/tools/tool.factory.d.ts +29 -0
  69. package/dist/agents/chatbot/tools/tool.factory.d.ts.map +1 -0
  70. package/dist/agents/chatbot/tools/tool.factory.js +72 -0
  71. package/dist/agents/chatbot/tools/tool.factory.js.map +1 -0
  72. package/dist/agents/chatbot/tools/traverse.tool.d.ts +58 -0
  73. package/dist/agents/chatbot/tools/traverse.tool.d.ts.map +1 -0
  74. package/dist/agents/chatbot/tools/traverse.tool.js +212 -0
  75. package/dist/agents/chatbot/tools/traverse.tool.js.map +1 -0
  76. package/dist/agents/index.d.ts +9 -0
  77. package/dist/agents/index.d.ts.map +1 -1
  78. package/dist/agents/index.js +17 -1
  79. package/dist/agents/index.js.map +1 -1
  80. package/dist/bootstrap/bootstrap.options.d.ts +7 -0
  81. package/dist/bootstrap/bootstrap.options.d.ts.map +1 -1
  82. package/dist/common/helpers/define-entity.d.ts.map +1 -1
  83. package/dist/common/helpers/define-entity.js +5 -1
  84. package/dist/common/helpers/define-entity.js.map +1 -1
  85. package/dist/common/interfaces/datamodel.interface.d.ts +10 -0
  86. package/dist/common/interfaces/datamodel.interface.d.ts.map +1 -1
  87. package/dist/common/interfaces/datamodel.interface.js.map +1 -1
  88. package/dist/common/interfaces/entity.descriptor.interface.d.ts +1 -1
  89. package/dist/common/interfaces/entity.descriptor.interface.d.ts.map +1 -1
  90. package/dist/common/interfaces/entity.descriptor.interface.js.map +1 -1
  91. package/dist/common/interfaces/entity.schema.interface.d.ts +48 -0
  92. package/dist/common/interfaces/entity.schema.interface.d.ts.map +1 -1
  93. package/dist/common/registries/entity.service.registry.d.ts +13 -0
  94. package/dist/common/registries/entity.service.registry.d.ts.map +1 -0
  95. package/dist/common/registries/entity.service.registry.js +52 -0
  96. package/dist/common/registries/entity.service.registry.js.map +1 -0
  97. package/dist/common/registries/index.d.ts +1 -0
  98. package/dist/common/registries/index.d.ts.map +1 -1
  99. package/dist/common/registries/index.js +1 -0
  100. package/dist/common/registries/index.js.map +1 -1
  101. package/dist/core/core.module.d.ts.map +1 -1
  102. package/dist/core/core.module.js +6 -2
  103. package/dist/core/core.module.js.map +1 -1
  104. package/dist/core/llm/services/llm.service.d.ts.map +1 -1
  105. package/dist/core/llm/services/llm.service.js +8 -0
  106. package/dist/core/llm/services/llm.service.js.map +1 -1
  107. package/dist/core/neo4j/abstracts/abstract.repository.d.ts +48 -1
  108. package/dist/core/neo4j/abstracts/abstract.repository.d.ts.map +1 -1
  109. package/dist/core/neo4j/abstracts/abstract.repository.js +147 -9
  110. package/dist/core/neo4j/abstracts/abstract.repository.js.map +1 -1
  111. package/dist/core/neo4j/abstracts/abstract.service.d.ts +47 -0
  112. package/dist/core/neo4j/abstracts/abstract.service.d.ts.map +1 -1
  113. package/dist/core/neo4j/abstracts/abstract.service.js +57 -0
  114. package/dist/core/neo4j/abstracts/abstract.service.js.map +1 -1
  115. package/dist/core/neo4j/factories/entity.factory.d.ts.map +1 -1
  116. package/dist/core/neo4j/factories/entity.factory.js +27 -6
  117. package/dist/core/neo4j/factories/entity.factory.js.map +1 -1
  118. package/dist/core/neo4j/helpers/build-filter-clauses.d.ts +11 -0
  119. package/dist/core/neo4j/helpers/build-filter-clauses.d.ts.map +1 -0
  120. package/dist/core/neo4j/helpers/build-filter-clauses.js +69 -0
  121. package/dist/core/neo4j/helpers/build-filter-clauses.js.map +1 -0
  122. package/dist/core/neo4j/helpers/build-order-by.d.ts +6 -0
  123. package/dist/core/neo4j/helpers/build-order-by.d.ts.map +1 -0
  124. package/dist/core/neo4j/helpers/build-order-by.js +20 -0
  125. package/dist/core/neo4j/helpers/build-order-by.js.map +1 -0
  126. package/dist/core/neo4j/index.d.ts +1 -0
  127. package/dist/core/neo4j/index.d.ts.map +1 -1
  128. package/dist/core/neo4j/index.js +2 -0
  129. package/dist/core/neo4j/index.js.map +1 -1
  130. package/dist/core/neo4j/types/filter.criterion.d.ts +20 -0
  131. package/dist/core/neo4j/types/filter.criterion.d.ts.map +1 -0
  132. package/dist/core/neo4j/types/filter.criterion.js +3 -0
  133. package/dist/core/neo4j/types/filter.criterion.js.map +1 -0
  134. package/dist/core/neo4j/types/index.d.ts +2 -0
  135. package/dist/core/neo4j/types/index.d.ts.map +1 -0
  136. package/dist/core/neo4j/types/index.js +3 -0
  137. package/dist/core/neo4j/types/index.js.map +1 -0
  138. package/dist/foundations/assistant/assistant.module.d.ts +5 -0
  139. package/dist/foundations/assistant/assistant.module.d.ts.map +1 -0
  140. package/dist/foundations/assistant/assistant.module.js +32 -0
  141. package/dist/foundations/assistant/assistant.module.js.map +1 -0
  142. package/dist/foundations/assistant/controllers/assistant.controller.d.ts +67 -0
  143. package/dist/foundations/assistant/controllers/assistant.controller.d.ts.map +1 -0
  144. package/dist/foundations/assistant/controllers/assistant.controller.js +226 -0
  145. package/dist/foundations/assistant/controllers/assistant.controller.js.map +1 -0
  146. package/dist/foundations/assistant/dtos/assistant-append.dto.d.ts +11 -0
  147. package/dist/foundations/assistant/dtos/assistant-append.dto.d.ts.map +1 -0
  148. package/dist/foundations/assistant/dtos/assistant-append.dto.js +44 -0
  149. package/dist/foundations/assistant/dtos/assistant-append.dto.js.map +1 -0
  150. package/dist/foundations/assistant/dtos/assistant-patch.dto.d.ts +12 -0
  151. package/dist/foundations/assistant/dtos/assistant-patch.dto.d.ts.map +1 -0
  152. package/dist/foundations/assistant/dtos/assistant-patch.dto.js +52 -0
  153. package/dist/foundations/assistant/dtos/assistant-patch.dto.js.map +1 -0
  154. package/dist/foundations/assistant/dtos/assistant-post.dto.d.ts +12 -0
  155. package/dist/foundations/assistant/dtos/assistant-post.dto.d.ts.map +1 -0
  156. package/dist/foundations/assistant/dtos/assistant-post.dto.js +51 -0
  157. package/dist/foundations/assistant/dtos/assistant-post.dto.js.map +1 -0
  158. package/dist/foundations/assistant/entities/assistant.d.ts +48 -0
  159. package/dist/foundations/assistant/entities/assistant.d.ts.map +1 -0
  160. package/dist/foundations/assistant/entities/assistant.js +44 -0
  161. package/dist/foundations/assistant/entities/assistant.js.map +1 -0
  162. package/dist/foundations/assistant/entities/assistant.meta.d.ts +3 -0
  163. package/dist/foundations/assistant/entities/assistant.meta.d.ts.map +1 -0
  164. package/dist/foundations/assistant/entities/assistant.meta.js +10 -0
  165. package/dist/foundations/assistant/entities/assistant.meta.js.map +1 -0
  166. package/dist/foundations/assistant/index.d.ts +7 -0
  167. package/dist/foundations/assistant/index.d.ts.map +1 -0
  168. package/dist/foundations/assistant/index.js +12 -0
  169. package/dist/foundations/assistant/index.js.map +1 -0
  170. package/dist/foundations/assistant/repositories/assistant.repository.d.ts +50 -0
  171. package/dist/foundations/assistant/repositories/assistant.repository.d.ts.map +1 -0
  172. package/dist/foundations/assistant/repositories/assistant.repository.js +65 -0
  173. package/dist/foundations/assistant/repositories/assistant.repository.js.map +1 -0
  174. package/dist/foundations/assistant/services/assistant.service.d.ts +113 -0
  175. package/dist/foundations/assistant/services/assistant.service.d.ts.map +1 -0
  176. package/dist/foundations/assistant/services/assistant.service.js +395 -0
  177. package/dist/foundations/assistant/services/assistant.service.js.map +1 -0
  178. package/dist/foundations/assistant-message/assistant-message.module.d.ts +6 -0
  179. package/dist/foundations/assistant-message/assistant-message.module.d.ts.map +1 -0
  180. package/dist/foundations/assistant-message/assistant-message.module.js +36 -0
  181. package/dist/foundations/assistant-message/assistant-message.module.js.map +1 -0
  182. package/dist/foundations/assistant-message/controllers/assistant-message.controller.d.ts +16 -0
  183. package/dist/foundations/assistant-message/controllers/assistant-message.controller.d.ts.map +1 -0
  184. package/dist/foundations/assistant-message/controllers/assistant-message.controller.js +84 -0
  185. package/dist/foundations/assistant-message/controllers/assistant-message.controller.js.map +1 -0
  186. package/dist/foundations/assistant-message/dtos/assistant-message.dto.d.ts +11 -0
  187. package/dist/foundations/assistant-message/dtos/assistant-message.dto.d.ts.map +1 -0
  188. package/dist/foundations/assistant-message/dtos/assistant-message.dto.js +45 -0
  189. package/dist/foundations/assistant-message/dtos/assistant-message.dto.js.map +1 -0
  190. package/dist/foundations/assistant-message/entities/assistant-message.d.ts +49 -0
  191. package/dist/foundations/assistant-message/entities/assistant-message.d.ts.map +1 -0
  192. package/dist/foundations/assistant-message/entities/assistant-message.js +52 -0
  193. package/dist/foundations/assistant-message/entities/assistant-message.js.map +1 -0
  194. package/dist/foundations/assistant-message/entities/assistant-message.meta.d.ts +3 -0
  195. package/dist/foundations/assistant-message/entities/assistant-message.meta.d.ts.map +1 -0
  196. package/dist/foundations/assistant-message/entities/assistant-message.meta.js +10 -0
  197. package/dist/foundations/assistant-message/entities/assistant-message.meta.js.map +1 -0
  198. package/dist/foundations/assistant-message/index.d.ts +8 -0
  199. package/dist/foundations/assistant-message/index.d.ts.map +1 -0
  200. package/dist/foundations/assistant-message/index.js +24 -0
  201. package/dist/foundations/assistant-message/index.js.map +1 -0
  202. package/dist/foundations/assistant-message/repositories/assistant-message.repository.d.ts +70 -0
  203. package/dist/foundations/assistant-message/repositories/assistant-message.repository.d.ts.map +1 -0
  204. package/dist/foundations/assistant-message/repositories/assistant-message.repository.js +119 -0
  205. package/dist/foundations/assistant-message/repositories/assistant-message.repository.js.map +1 -0
  206. package/dist/foundations/assistant-message/services/assistant-message.service.d.ts +31 -0
  207. package/dist/foundations/assistant-message/services/assistant-message.service.d.ts.map +1 -0
  208. package/dist/foundations/assistant-message/services/assistant-message.service.js +32 -0
  209. package/dist/foundations/assistant-message/services/assistant-message.service.js.map +1 -0
  210. package/dist/foundations/foundations.modules.d.ts.map +1 -1
  211. package/dist/foundations/foundations.modules.js +2 -0
  212. package/dist/foundations/foundations.modules.js.map +1 -1
  213. package/dist/foundations/index.d.ts +2 -0
  214. package/dist/foundations/index.d.ts.map +1 -1
  215. package/dist/foundations/index.js +2 -0
  216. package/dist/foundations/index.js.map +1 -1
  217. package/dist/foundations/rbac/controllers/rbac-dev.controller.d.ts +50 -0
  218. package/dist/foundations/rbac/controllers/rbac-dev.controller.d.ts.map +1 -0
  219. package/dist/foundations/rbac/controllers/rbac-dev.controller.js +172 -0
  220. package/dist/foundations/rbac/controllers/rbac-dev.controller.js.map +1 -0
  221. package/dist/foundations/rbac/dsl/define-rbac.d.ts +15 -0
  222. package/dist/foundations/rbac/dsl/define-rbac.d.ts.map +1 -0
  223. package/dist/foundations/rbac/dsl/define-rbac.js +19 -0
  224. package/dist/foundations/rbac/dsl/define-rbac.js.map +1 -0
  225. package/dist/foundations/rbac/dsl/index.d.ts +6 -0
  226. package/dist/foundations/rbac/dsl/index.d.ts.map +1 -0
  227. package/dist/foundations/rbac/dsl/index.js +30 -0
  228. package/dist/foundations/rbac/dsl/index.js.map +1 -0
  229. package/dist/foundations/rbac/dsl/perm.d.ts +15 -0
  230. package/dist/foundations/rbac/dsl/perm.d.ts.map +1 -0
  231. package/dist/foundations/rbac/dsl/perm.js +24 -0
  232. package/dist/foundations/rbac/dsl/perm.js.map +1 -0
  233. package/dist/foundations/rbac/dsl/resolver.d.ts +24 -0
  234. package/dist/foundations/rbac/dsl/resolver.d.ts.map +1 -0
  235. package/dist/foundations/rbac/dsl/resolver.js +55 -0
  236. package/dist/foundations/rbac/dsl/resolver.js.map +1 -0
  237. package/dist/foundations/rbac/dsl/to-permissions-json.d.ts +13 -0
  238. package/dist/foundations/rbac/dsl/to-permissions-json.d.ts.map +1 -0
  239. package/dist/foundations/rbac/dsl/to-permissions-json.js +43 -0
  240. package/dist/foundations/rbac/dsl/to-permissions-json.js.map +1 -0
  241. package/dist/foundations/rbac/dsl/types.d.ts +55 -0
  242. package/dist/foundations/rbac/dsl/types.d.ts.map +1 -0
  243. package/dist/foundations/rbac/dsl/types.js +6 -0
  244. package/dist/foundations/rbac/dsl/types.js.map +1 -0
  245. package/dist/foundations/rbac/dump.d.ts +116 -0
  246. package/dist/foundations/rbac/dump.d.ts.map +1 -0
  247. package/dist/foundations/rbac/dump.js +154 -0
  248. package/dist/foundations/rbac/dump.js.map +1 -0
  249. package/dist/foundations/rbac/index.d.ts +6 -0
  250. package/dist/foundations/rbac/index.d.ts.map +1 -1
  251. package/dist/foundations/rbac/index.js +23 -1
  252. package/dist/foundations/rbac/index.js.map +1 -1
  253. package/dist/foundations/rbac/rbac.module.d.ts +4 -1
  254. package/dist/foundations/rbac/rbac.module.d.ts.map +1 -1
  255. package/dist/foundations/rbac/rbac.module.js +25 -11
  256. package/dist/foundations/rbac/rbac.module.js.map +1 -1
  257. package/dist/foundations/rbac/rbac.tokens.d.ts +11 -0
  258. package/dist/foundations/rbac/rbac.tokens.d.ts.map +1 -0
  259. package/dist/foundations/rbac/rbac.tokens.js +14 -0
  260. package/dist/foundations/rbac/rbac.tokens.js.map +1 -0
  261. package/dist/foundations/rbac/serializer/matrix-to-ts.d.ts +13 -0
  262. package/dist/foundations/rbac/serializer/matrix-to-ts.d.ts.map +1 -0
  263. package/dist/foundations/rbac/serializer/matrix-to-ts.js +74 -0
  264. package/dist/foundations/rbac/serializer/matrix-to-ts.js.map +1 -0
  265. package/dist/foundations/rbac/services/rbac-reconciler.service.d.ts +30 -0
  266. package/dist/foundations/rbac/services/rbac-reconciler.service.d.ts.map +1 -0
  267. package/dist/foundations/rbac/services/rbac-reconciler.service.js +192 -0
  268. package/dist/foundations/rbac/services/rbac-reconciler.service.js.map +1 -0
  269. package/dist/foundations/stripe/__tests__/mocks/stripe.mock.d.ts +62 -62
  270. package/dist/tools/generate-rbac-paths/index.js +24 -19
  271. package/package.json +1 -1
@@ -1 +1 @@
1
- {"version":3,"file":"rbac.module.js","sourceRoot":"","sources":["../../../src/foundations/rbac/rbac.module.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,2CAAuD;AACvD,mEAA+D;AAC/D,6FAAuF;AACvF,oEAAgE;AAChE,0DAAsD;AACtD,+FAA0F;AAC1F,mFAA8E;AAC9E,qDAA2D;AAGpD,IAAM,UAAU,kBAAhB,MAAM,UAAU;IACrB,MAAM,CAAC,QAAQ,CAAC,OAAsD;QACpE,OAAO;YACL,MAAM,EAAE,YAAU;YAClB,WAAW,EAAE,CAAC,gCAAc,EAAE,wDAAyB,CAAC;YACxD,SAAS,EAAE;gBACT,gCAAc;gBACd,0BAAW;gBACX,2DAA2B;gBAC3B,+CAAqB;gBACrB;oBACE,OAAO,EAAE,wCAAuB;oBAChC,QAAQ,EAAE,OAAO,CAAC,eAAe;iBAClC;aACF;YACD,OAAO,EAAE,CAAC,0BAAW,CAAC;SACvB,CAAC;IACJ,CAAC;CACF,CAAA;AAlBY,gCAAU;qBAAV,UAAU;IADtB,IAAA,eAAM,EAAC,EAAE,CAAC;GACE,UAAU,CAkBtB"}
1
+ {"version":3,"file":"rbac.module.js","sourceRoot":"","sources":["../../../src/foundations/rbac/rbac.module.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,2CAAuE;AACvE,mEAA+D;AAC/D,6FAAuF;AACvF,oEAAgE;AAChE,0DAAsD;AACtD,gFAA2E;AAC3E,+FAA0F;AAC1F,mFAA8E;AAC9E,qDAA2D;AAC3D,+CAAkD;AAElD,2EAAsE;AACtE,yGAA6F;AAGtF,IAAM,UAAU,kBAAhB,MAAM,UAAU;IACrB,MAAM,CAAC,QAAQ,CAAC,OAIf;QACC,MAAM,SAAS,GAAe;YAC5B,gCAAc;YACd,0BAAW;YACX,2DAA2B;YAC3B,+CAAqB;YACrB,IAAA,oDAAoB,EAAC,+CAAqB,CAAC;YAC3C;gBACE,OAAO,EAAE,wCAAuB;gBAChC,QAAQ,EAAE,OAAO,CAAC,eAAe;aAClC;YACD;gBACE,OAAO,EAAE,+BAAiB;gBAC1B,QAAQ,EAAE,OAAO,CAAC,IAAI,IAAI,IAAI;aAC/B;SACF,CAAC;QAEF,MAAM,WAAW,GAAgB,CAAC,gCAAc,EAAE,wDAAyB,CAAC,CAAC;QAC7E,IAAI,OAAO,CAAC,OAAO,EAAE,CAAC;YACpB,WAAW,CAAC,IAAI,CAAC,uCAAiB,CAAC,CAAC;QACtC,CAAC;QAED,OAAO;YACL,MAAM,EAAE,YAAU;YAClB,WAAW;YACX,SAAS;YACT,OAAO,EAAE,CAAC,0BAAW,CAAC;SACvB,CAAC;IACJ,CAAC;CACF,CAAA;AAlCY,gCAAU;qBAAV,UAAU;IADtB,IAAA,eAAM,EAAC,EAAE,CAAC;GACE,UAAU,CAkCtB"}
@@ -0,0 +1,11 @@
1
+ /**
2
+ * DI token for the declarative RBAC matrix.
3
+ *
4
+ * Applications provide an `RbacMatrix` under this token; `RbacReconcilerService`
5
+ * reads it at bootstrap and reconciles Neo4j against it.
6
+ *
7
+ * Note: `MODULE_USER_PATHS_TOKEN` already lives in `rbac.constants.ts` — import
8
+ * it from there rather than duplicating it here.
9
+ */
10
+ export declare const RBAC_MATRIX_TOKEN: unique symbol;
11
+ //# sourceMappingURL=rbac.tokens.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rbac.tokens.d.ts","sourceRoot":"","sources":["../../../src/foundations/rbac/rbac.tokens.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AACH,eAAO,MAAM,iBAAiB,eAA8B,CAAC"}
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.RBAC_MATRIX_TOKEN = void 0;
4
+ /**
5
+ * DI token for the declarative RBAC matrix.
6
+ *
7
+ * Applications provide an `RbacMatrix` under this token; `RbacReconcilerService`
8
+ * reads it at bootstrap and reconciles Neo4j against it.
9
+ *
10
+ * Note: `MODULE_USER_PATHS_TOKEN` already lives in `rbac.constants.ts` — import
11
+ * it from there rather than duplicating it here.
12
+ */
13
+ exports.RBAC_MATRIX_TOKEN = Symbol("RBAC_MATRIX_TOKEN");
14
+ //# sourceMappingURL=rbac.tokens.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rbac.tokens.js","sourceRoot":"","sources":["../../../src/foundations/rbac/rbac.tokens.ts"],"names":[],"mappings":";;;AAAA;;;;;;;;GAQG;AACU,QAAA,iBAAiB,GAAG,MAAM,CAAC,mBAAmB,CAAC,CAAC"}
@@ -0,0 +1,13 @@
1
+ import type { RbacMatrix } from "../dsl/types";
2
+ interface Options {
3
+ roleNames: Record<string, string>;
4
+ moduleNames: Record<string, string>;
5
+ }
6
+ /**
7
+ * Serialise an RbacMatrix to formatted TypeScript source.
8
+ * Deterministic: module and role keys are sorted by UUID; tokens are
9
+ * normalised per action.
10
+ */
11
+ export declare function serializeMatrixToTs(matrix: RbacMatrix, opts: Options): Promise<string>;
12
+ export {};
13
+ //# sourceMappingURL=matrix-to-ts.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"matrix-to-ts.d.ts","sourceRoot":"","sources":["../../../../src/foundations/rbac/serializer/matrix-to-ts.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,UAAU,EAAa,MAAM,cAAc,CAAC;AAE1D,UAAU,OAAO;IACf,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAClC,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CACrC;AAED;;;;GAIG;AACH,wBAAsB,mBAAmB,CAAC,MAAM,EAAE,UAAU,EAAE,IAAI,EAAE,OAAO,GAAG,OAAO,CAAC,MAAM,CAAC,CAmC5F"}
@@ -0,0 +1,74 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.serializeMatrixToTs = serializeMatrixToTs;
7
+ // packages/nestjs-neo4jsonapi/src/foundations/rbac/serializer/matrix-to-ts.ts
8
+ const prettier_1 = __importDefault(require("prettier"));
9
+ /**
10
+ * Serialise an RbacMatrix to formatted TypeScript source.
11
+ * Deterministic: module and role keys are sorted by UUID; tokens are
12
+ * normalised per action.
13
+ */
14
+ async function serializeMatrixToTs(matrix, opts) {
15
+ const moduleIds = Object.keys(matrix).sort();
16
+ const lines = [];
17
+ lines.push(`// Auto-maintained by the RBAC UI. Edit via \`pnpm dev\` + UI, or by hand.`);
18
+ lines.push(``);
19
+ lines.push(`import { RoleId, ModuleId } from "@neural-erp/shared";`);
20
+ lines.push(`import { perm, defineRbac } from "@carlonicora/nestjs-neo4jsonapi";`);
21
+ lines.push(`import { MODULE_USER_PATHS } from "../features/rbac/module-relationships.map";`);
22
+ lines.push(``);
23
+ lines.push(`export const rbac = defineRbac<typeof MODULE_USER_PATHS>({`);
24
+ for (const moduleId of moduleIds) {
25
+ const block = matrix[moduleId];
26
+ if (!block)
27
+ continue;
28
+ const moduleName = opts.moduleNames[moduleId];
29
+ if (!moduleName) {
30
+ throw new Error(`Unknown module UUID: ${moduleId}. Check module-id.map.json.`);
31
+ }
32
+ lines.push(` [ModuleId.${moduleName}]: {`);
33
+ lines.push(` default: ${renderTokens(block.default)},`);
34
+ const roleIds = Object.keys(block)
35
+ .filter((k) => k !== "default")
36
+ .sort();
37
+ for (const roleId of roleIds) {
38
+ const roleName = opts.roleNames[roleId];
39
+ if (!roleName)
40
+ throw new Error(`Unknown role UUID: ${roleId}`);
41
+ lines.push(` [RoleId.${roleName}]: ${renderTokens(block[roleId])},`);
42
+ }
43
+ lines.push(` },`);
44
+ }
45
+ lines.push(`});`);
46
+ lines.push(``);
47
+ const raw = lines.join("\n");
48
+ return prettier_1.default.format(raw, { parser: "typescript" });
49
+ }
50
+ function renderTokens(tokens) {
51
+ // `scope === false` has no emission (absence of a token is the "deny"
52
+ // semantics). Drop defensively before any shape-checking so malformed state
53
+ // never leaks to disk as `perm.X("false")`.
54
+ const valid = tokens.filter((t) => t.scope === true || (typeof t.scope === "string" && t.scope.length > 0));
55
+ // perm.full collapse
56
+ const isFull = valid.length === 4 && valid.every((t) => t.scope === true) && new Set(valid.map((t) => t.action)).size === 4;
57
+ if (isFull)
58
+ return "perm.full";
59
+ if (valid.length === 0)
60
+ return "[]";
61
+ // Render each token
62
+ const parts = [...valid]
63
+ .sort((a, b) => {
64
+ const order = { read: 0, create: 1, update: 2, delete: 3 };
65
+ return order[a.action] - order[b.action];
66
+ })
67
+ .map((t) => {
68
+ if (t.scope === true)
69
+ return `perm.${t.action}`;
70
+ return `perm.${t.action}("${t.scope}")`;
71
+ });
72
+ return `[${parts.join(", ")}]`;
73
+ }
74
+ //# sourceMappingURL=matrix-to-ts.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"matrix-to-ts.js","sourceRoot":"","sources":["../../../../src/foundations/rbac/serializer/matrix-to-ts.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,30 @@
1
+ import { OnApplicationBootstrap } from "@nestjs/common";
2
+ import { Neo4jService } from "../../../core/neo4j/services/neo4j.service";
3
+ import { AppLoggingService } from "../../../core/logging/services/logging.service";
4
+ import type { RbacMatrix } from "../dsl/types";
5
+ /**
6
+ * Applies the declared `RbacMatrix` to Neo4j at application bootstrap.
7
+ *
8
+ * Behaviour (per spec §6.3):
9
+ * - Administrator role is never written as an HAS_PERMISSIONS edge — the
10
+ * security layer short-circuits for it.
11
+ * - Module defaults are stored on `Module.permissions`.
12
+ * - Role-specific permissions are stored on `(Role)-[:HAS_PERMISSIONS]->(Module)`.
13
+ * - Deletions are scoped to modules declared in the matrix: edges for
14
+ * undeclared modules are left untouched.
15
+ * - Preflight aborts with a clear error if any referenced role or module is
16
+ * missing from the DB (seed migrations must run first).
17
+ */
18
+ export declare class RbacReconcilerService implements OnApplicationBootstrap {
19
+ private readonly neo4j;
20
+ private readonly matrix;
21
+ private readonly logger;
22
+ constructor(neo4j: Neo4jService, matrix: RbacMatrix | null, logger: AppLoggingService);
23
+ onApplicationBootstrap(): Promise<void>;
24
+ private preflight;
25
+ private findMissing;
26
+ private readActualState;
27
+ private computeDiff;
28
+ private apply;
29
+ }
30
+ //# sourceMappingURL=rbac-reconciler.service.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rbac-reconciler.service.d.ts","sourceRoot":"","sources":["../../../../src/foundations/rbac/services/rbac-reconciler.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgC,sBAAsB,EAAE,MAAM,gBAAgB,CAAC;AACtF,OAAO,EAAE,YAAY,EAAE,MAAM,4CAA4C,CAAC;AAC1E,OAAO,EAAE,iBAAiB,EAAE,MAAM,gDAAgD,CAAC;AAGnF,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAe/C;;;;;;;;;;;;GAYG;AACH,qBACa,qBAAsB,YAAW,sBAAsB;IAEhE,OAAO,CAAC,QAAQ,CAAC,KAAK;IACiB,OAAO,CAAC,QAAQ,CAAC,MAAM;IAC9D,OAAO,CAAC,QAAQ,CAAC,MAAM;gBAFN,KAAK,EAAE,YAAY,EACoB,MAAM,EAAE,UAAU,GAAG,IAAI,EAChE,MAAM,EAAE,iBAAiB;IAGtC,sBAAsB,IAAI,OAAO,CAAC,IAAI,CAAC;YAsB/B,SAAS;YAyBT,WAAW;YAOX,eAAe;IAsB7B,OAAO,CAAC,WAAW;YAkEL,KAAK;CA4BpB"}
@@ -0,0 +1,192 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ var __param = (this && this.__param) || function (paramIndex, decorator) {
12
+ return function (target, key) { decorator(target, key, paramIndex); }
13
+ };
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.RbacReconcilerService = void 0;
16
+ const common_1 = require("@nestjs/common");
17
+ const neo4j_service_1 = require("../../../core/neo4j/services/neo4j.service");
18
+ const logging_service_1 = require("../../../core/logging/services/logging.service");
19
+ const system_roles_1 = require("../../../common/constants/system.roles");
20
+ const rbac_tokens_1 = require("../rbac.tokens");
21
+ const resolver_1 = require("../dsl/resolver");
22
+ const ADMINISTRATOR_ID = system_roles_1.SystemRoles.Administrator;
23
+ /**
24
+ * Applies the declared `RbacMatrix` to Neo4j at application bootstrap.
25
+ *
26
+ * Behaviour (per spec §6.3):
27
+ * - Administrator role is never written as an HAS_PERMISSIONS edge — the
28
+ * security layer short-circuits for it.
29
+ * - Module defaults are stored on `Module.permissions`.
30
+ * - Role-specific permissions are stored on `(Role)-[:HAS_PERMISSIONS]->(Module)`.
31
+ * - Deletions are scoped to modules declared in the matrix: edges for
32
+ * undeclared modules are left untouched.
33
+ * - Preflight aborts with a clear error if any referenced role or module is
34
+ * missing from the DB (seed migrations must run first).
35
+ */
36
+ let RbacReconcilerService = class RbacReconcilerService {
37
+ constructor(neo4j, matrix, logger) {
38
+ this.neo4j = neo4j;
39
+ this.matrix = matrix;
40
+ this.logger = logger;
41
+ }
42
+ async onApplicationBootstrap() {
43
+ if (!this.matrix) {
44
+ this.logger.log("RBAC reconciler: no matrix configured, skipping");
45
+ return;
46
+ }
47
+ await this.preflight();
48
+ const actual = await this.readActualState();
49
+ const diff = this.computeDiff(actual);
50
+ if (diff.operations.length === 0) {
51
+ this.logger.log("RBAC reconcile: no changes");
52
+ return;
53
+ }
54
+ await this.apply(diff.operations);
55
+ this.logger.log(`RBAC reconcile: ${diff.defaultsChanged} defaults changed, ${diff.edgesUpserted} edges upserted, ${diff.edgesRemoved} edges removed`);
56
+ }
57
+ async preflight() {
58
+ const moduleIds = new Set();
59
+ const roleIds = new Set();
60
+ for (const moduleId of (0, resolver_1.iterateDeclaredModules)(this.matrix)) {
61
+ moduleIds.add(moduleId);
62
+ }
63
+ for (const { roleId } of (0, resolver_1.iterateDeclaredEdges)(this.matrix)) {
64
+ if (roleId === ADMINISTRATOR_ID)
65
+ continue;
66
+ roleIds.add(roleId);
67
+ }
68
+ const missingRoles = await this.findMissing("Role", Array.from(roleIds));
69
+ const missingModules = await this.findMissing("Module", Array.from(moduleIds));
70
+ if (missingRoles.length > 0 || missingModules.length > 0) {
71
+ throw new Error(`RBAC reconcile aborted - referenced entities not found in DB. ` +
72
+ `Roles missing: ${missingRoles.join(", ") || "none"}. ` +
73
+ `Modules missing: ${missingModules.join(", ") || "none"}. ` +
74
+ `Apply seed migrations before declaring these in the matrix.`);
75
+ }
76
+ }
77
+ async findMissing(label, ids) {
78
+ if (ids.length === 0)
79
+ return [];
80
+ const result = await this.neo4j.read(`MATCH (n:${label}) WHERE n.id IN $ids RETURN n.id AS id`, { ids });
81
+ const found = new Set(result.records.map((r) => r.get("id")));
82
+ return ids.filter((id) => !found.has(id));
83
+ }
84
+ async readActualState() {
85
+ const modulesResult = await this.neo4j.read(`MATCH (m:Module) RETURN m.id AS id, m.permissions AS permissions`, {});
86
+ const edgesResult = await this.neo4j.read(`MATCH (r:Role)-[p:HAS_PERMISSIONS]->(m:Module) RETURN r.id AS roleId, m.id AS moduleId, p.permissions AS permissions`, {});
87
+ const moduleDefaults = {};
88
+ for (const rec of modulesResult.records) {
89
+ moduleDefaults[rec.get("id")] = rec.get("permissions");
90
+ }
91
+ const edges = [];
92
+ for (const rec of edgesResult.records) {
93
+ edges.push({
94
+ roleId: rec.get("roleId"),
95
+ moduleId: rec.get("moduleId"),
96
+ permissions: rec.get("permissions"),
97
+ });
98
+ }
99
+ return { moduleDefaults, edges };
100
+ }
101
+ computeDiff(actual) {
102
+ const operations = [];
103
+ let defaultsChanged = 0;
104
+ let edgesUpserted = 0;
105
+ let edgesRemoved = 0;
106
+ const declaredModules = new Set(Array.from((0, resolver_1.iterateDeclaredModules)(this.matrix)));
107
+ const sortedModules = Array.from(declaredModules).sort();
108
+ // Defaults
109
+ for (const moduleId of sortedModules) {
110
+ const expected = (0, resolver_1.resolveDefault)(this.matrix, moduleId);
111
+ if (expected === undefined)
112
+ continue;
113
+ if (actual.moduleDefaults[moduleId] !== expected) {
114
+ operations.push({ kind: "setDefault", params: { moduleId, permissions: expected } });
115
+ defaultsChanged++;
116
+ }
117
+ }
118
+ // Edges — expected (Administrator excluded)
119
+ const expectedEdgeKeys = new Set();
120
+ const sortedEdges = Array.from((0, resolver_1.iterateDeclaredEdges)(this.matrix))
121
+ .filter((e) => e.roleId !== ADMINISTRATOR_ID)
122
+ .sort((a, b) => (a.moduleId + a.roleId).localeCompare(b.moduleId + b.roleId));
123
+ const actualByKey = new Map();
124
+ for (const edge of actual.edges) {
125
+ actualByKey.set(`${edge.roleId}|${edge.moduleId}`, edge.permissions);
126
+ }
127
+ for (const { roleId, moduleId } of sortedEdges) {
128
+ const expected = (0, resolver_1.resolveForRole)(this.matrix, roleId, moduleId);
129
+ if (expected === undefined)
130
+ continue;
131
+ const key = `${roleId}|${moduleId}`;
132
+ expectedEdgeKeys.add(key);
133
+ if (actualByKey.get(key) !== expected) {
134
+ operations.push({
135
+ kind: "upsertEdge",
136
+ params: { roleId, moduleId, permissions: expected },
137
+ });
138
+ edgesUpserted++;
139
+ }
140
+ }
141
+ // Edges — to delete (scoped to declared modules only; Administrator never managed)
142
+ for (const edge of actual.edges) {
143
+ if (!declaredModules.has(edge.moduleId))
144
+ continue;
145
+ if (edge.roleId === ADMINISTRATOR_ID)
146
+ continue;
147
+ const key = `${edge.roleId}|${edge.moduleId}`;
148
+ if (!expectedEdgeKeys.has(key)) {
149
+ operations.push({
150
+ kind: "deleteEdge",
151
+ params: { roleId: edge.roleId, moduleId: edge.moduleId },
152
+ });
153
+ edgesRemoved++;
154
+ }
155
+ }
156
+ return { operations, defaultsChanged, edgesUpserted, edgesRemoved };
157
+ }
158
+ async apply(operations) {
159
+ const queries = operations.map((op) => {
160
+ if (op.kind === "setDefault") {
161
+ return {
162
+ query: `MATCH (m:Module {id: $moduleId}) SET m.permissions = $permissions`,
163
+ params: op.params,
164
+ };
165
+ }
166
+ if (op.kind === "upsertEdge") {
167
+ return {
168
+ query: `MATCH (role:Role {id: $roleId}) ` +
169
+ `MATCH (module:Module {id: $moduleId}) ` +
170
+ `MERGE (role)-[permissions:HAS_PERMISSIONS]->(module) ` +
171
+ `ON CREATE SET permissions.permissions = $permissions ` +
172
+ `ON MATCH SET permissions.permissions = $permissions`,
173
+ params: op.params,
174
+ };
175
+ }
176
+ // deleteEdge
177
+ return {
178
+ query: `MATCH (role:Role {id: $roleId})-[p:HAS_PERMISSIONS]->(module:Module {id: $moduleId}) DELETE p`,
179
+ params: op.params,
180
+ };
181
+ });
182
+ await this.neo4j.executeInTransaction(queries);
183
+ }
184
+ };
185
+ exports.RbacReconcilerService = RbacReconcilerService;
186
+ exports.RbacReconcilerService = RbacReconcilerService = __decorate([
187
+ (0, common_1.Injectable)(),
188
+ __param(1, (0, common_1.Optional)()),
189
+ __param(1, (0, common_1.Inject)(rbac_tokens_1.RBAC_MATRIX_TOKEN)),
190
+ __metadata("design:paramtypes", [neo4j_service_1.Neo4jService, Object, logging_service_1.AppLoggingService])
191
+ ], RbacReconcilerService);
192
+ //# sourceMappingURL=rbac-reconciler.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rbac-reconciler.service.js","sourceRoot":"","sources":["../../../../src/foundations/rbac/services/rbac-reconciler.service.ts"],"names":[],"mappings":"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"}
@@ -6,112 +6,112 @@
6
6
  */
7
7
  export declare const createMockStripeClient: () => {
8
8
  customers: {
9
- create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
10
- retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
11
- update: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
12
- del: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
13
- list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
9
+ create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
10
+ retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
11
+ update: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
12
+ del: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
13
+ list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
14
14
  };
15
15
  subscriptions: {
16
- create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
17
- retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
18
- update: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
19
- cancel: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
20
- pause: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
21
- resume: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
22
- list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
16
+ create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
17
+ retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
18
+ update: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
19
+ cancel: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
20
+ pause: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
21
+ resume: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
22
+ list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
23
23
  };
24
24
  products: {
25
- create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
26
- retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
27
- update: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
28
- list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
25
+ create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
26
+ retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
27
+ update: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
28
+ list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
29
29
  };
30
30
  prices: {
31
- create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
32
- retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
33
- update: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
34
- list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
31
+ create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
32
+ retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
33
+ update: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
34
+ list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
35
35
  };
36
36
  paymentIntents: {
37
- create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
38
- retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
39
- confirm: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
40
- cancel: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
37
+ create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
38
+ retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
39
+ confirm: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
40
+ cancel: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
41
41
  };
42
42
  setupIntents: {
43
- create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
44
- retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
43
+ create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
44
+ retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
45
45
  };
46
46
  paymentMethods: {
47
- retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
48
- list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
49
- attach: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
50
- detach: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
47
+ retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
48
+ list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
49
+ attach: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
50
+ detach: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
51
51
  };
52
52
  invoices: {
53
- retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
54
- list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
55
- pay: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
56
- voidInvoice: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
57
- retrieveUpcoming: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
58
- createPreview: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
53
+ retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
54
+ list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
55
+ pay: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
56
+ voidInvoice: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
57
+ retrieveUpcoming: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
58
+ createPreview: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
59
59
  };
60
60
  billingPortal: {
61
61
  sessions: {
62
- create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
62
+ create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
63
63
  };
64
64
  };
65
65
  webhooks: {
66
- constructEvent: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
66
+ constructEvent: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
67
67
  };
68
68
  v2: {
69
69
  billing: {
70
70
  meterEvents: {
71
- create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
71
+ create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
72
72
  };
73
73
  meterEventSummaries: {
74
- list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
74
+ list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
75
75
  };
76
76
  };
77
77
  };
78
78
  billing: {
79
79
  meters: {
80
- list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
81
- retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
82
- listEventSummaries: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
80
+ list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
81
+ retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
82
+ listEventSummaries: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
83
83
  };
84
84
  };
85
85
  coupons: {
86
- create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
87
- retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
88
- update: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
89
- del: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
90
- list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
86
+ create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
87
+ retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
88
+ update: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
89
+ del: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
90
+ list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
91
91
  };
92
92
  refunds: {
93
- create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
94
- retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
95
- update: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
96
- list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
97
- cancel: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
93
+ create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
94
+ retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
95
+ update: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
96
+ list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
97
+ cancel: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
98
98
  };
99
99
  taxRates: {
100
- create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
101
- retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
102
- update: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
103
- list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
100
+ create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
101
+ retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
102
+ update: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
103
+ list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
104
104
  };
105
105
  tax: {
106
106
  calculations: {
107
- create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
107
+ create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
108
108
  };
109
109
  };
110
110
  disputes: {
111
- retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
112
- update: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
113
- close: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
114
- list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.4/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
111
+ retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
112
+ update: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
113
+ close: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
114
+ list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
115
115
  };
116
116
  };
117
117
  /**