@strapi/core 0.0.0-experimental.e3e48deb89bd0a1b6cc69b698696566fa7854a95 → 0.0.0-experimental.e9122b401c96877b6707775c4f893660eab93ae3

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 (782) hide show
  1. package/LICENSE +18 -3
  2. package/dist/Strapi.d.ts +49 -58
  3. package/dist/Strapi.d.ts.map +1 -1
  4. package/dist/Strapi.js +192 -220
  5. package/dist/Strapi.js.map +1 -1
  6. package/dist/Strapi.mjs +161 -209
  7. package/dist/Strapi.mjs.map +1 -1
  8. package/dist/configuration/config-loader.d.ts.map +1 -1
  9. package/dist/configuration/config-loader.js +9 -5
  10. package/dist/configuration/config-loader.js.map +1 -1
  11. package/dist/configuration/config-loader.mjs +9 -5
  12. package/dist/configuration/config-loader.mjs.map +1 -1
  13. package/dist/configuration/get-dirs.d.ts +10 -0
  14. package/dist/configuration/get-dirs.d.ts.map +1 -0
  15. package/dist/{utils → configuration}/get-dirs.js +3 -2
  16. package/dist/configuration/get-dirs.js.map +1 -0
  17. package/dist/{utils → configuration}/get-dirs.mjs +3 -2
  18. package/dist/configuration/get-dirs.mjs.map +1 -0
  19. package/dist/configuration/index.d.ts +4 -7
  20. package/dist/configuration/index.d.ts.map +1 -1
  21. package/dist/configuration/index.js +8 -6
  22. package/dist/configuration/index.js.map +1 -1
  23. package/dist/configuration/index.mjs +5 -4
  24. package/dist/configuration/index.mjs.map +1 -1
  25. package/dist/container.d.ts +2 -2
  26. package/dist/container.d.ts.map +1 -1
  27. package/dist/container.js.map +1 -1
  28. package/dist/container.mjs.map +1 -1
  29. package/dist/core-api/controller/collection-type.d.ts +3 -3
  30. package/dist/core-api/controller/collection-type.d.ts.map +1 -1
  31. package/dist/core-api/controller/collection-type.js +6 -3
  32. package/dist/core-api/controller/collection-type.js.map +1 -1
  33. package/dist/core-api/controller/collection-type.mjs +3 -0
  34. package/dist/core-api/controller/collection-type.mjs.map +1 -1
  35. package/dist/core-api/controller/index.d.ts +3 -3
  36. package/dist/core-api/controller/index.d.ts.map +1 -1
  37. package/dist/core-api/controller/index.js +7 -7
  38. package/dist/core-api/controller/index.js.map +1 -1
  39. package/dist/core-api/controller/index.mjs +6 -6
  40. package/dist/core-api/controller/index.mjs.map +1 -1
  41. package/dist/core-api/controller/single-type.d.ts +3 -3
  42. package/dist/core-api/controller/single-type.d.ts.map +1 -1
  43. package/dist/core-api/controller/single-type.js +3 -2
  44. package/dist/core-api/controller/single-type.js.map +1 -1
  45. package/dist/core-api/controller/single-type.mjs +1 -0
  46. package/dist/core-api/controller/single-type.mjs.map +1 -1
  47. package/dist/core-api/controller/transform.d.ts +2 -2
  48. package/dist/core-api/controller/transform.d.ts.map +1 -1
  49. package/dist/core-api/controller/transform.js +10 -13
  50. package/dist/core-api/controller/transform.js.map +1 -1
  51. package/dist/core-api/controller/transform.mjs +2 -5
  52. package/dist/core-api/controller/transform.mjs.map +1 -1
  53. package/dist/core-api/routes/index.d.ts.map +1 -1
  54. package/dist/core-api/service/collection-type.d.ts +11 -17
  55. package/dist/core-api/service/collection-type.d.ts.map +1 -1
  56. package/dist/core-api/service/collection-type.js +18 -7
  57. package/dist/core-api/service/collection-type.js.map +1 -1
  58. package/dist/core-api/service/collection-type.mjs +19 -8
  59. package/dist/core-api/service/collection-type.mjs.map +1 -1
  60. package/dist/core-api/service/index.d.ts +3 -3
  61. package/dist/core-api/service/index.d.ts.map +1 -1
  62. package/dist/core-api/service/index.js.map +1 -1
  63. package/dist/core-api/service/index.mjs.map +1 -1
  64. package/dist/core-api/service/pagination.d.ts +4 -11
  65. package/dist/core-api/service/pagination.d.ts.map +1 -1
  66. package/dist/core-api/service/pagination.js +18 -44
  67. package/dist/core-api/service/pagination.js.map +1 -1
  68. package/dist/core-api/service/pagination.mjs +16 -42
  69. package/dist/core-api/service/pagination.mjs.map +1 -1
  70. package/dist/core-api/service/single-type.d.ts +4 -4
  71. package/dist/core-api/service/single-type.d.ts.map +1 -1
  72. package/dist/core-api/service/single-type.js +9 -2
  73. package/dist/core-api/service/single-type.js.map +1 -1
  74. package/dist/core-api/service/single-type.mjs +9 -2
  75. package/dist/core-api/service/single-type.mjs.map +1 -1
  76. package/dist/domain/content-type/index.d.ts +1 -1
  77. package/dist/domain/content-type/index.d.ts.map +1 -1
  78. package/dist/domain/content-type/index.js +4 -4
  79. package/dist/domain/content-type/index.js.map +1 -1
  80. package/dist/domain/module/index.d.ts +24 -23
  81. package/dist/domain/module/index.d.ts.map +1 -1
  82. package/dist/domain/module/index.js +2 -1
  83. package/dist/domain/module/index.js.map +1 -1
  84. package/dist/domain/module/index.mjs +3 -2
  85. package/dist/domain/module/index.mjs.map +1 -1
  86. package/dist/ee/index.d.ts +4 -2
  87. package/dist/ee/index.d.ts.map +1 -1
  88. package/dist/ee/index.js +3 -3
  89. package/dist/ee/index.js.map +1 -1
  90. package/dist/ee/index.mjs.map +1 -1
  91. package/dist/ee/license.d.ts +2 -2
  92. package/dist/ee/license.d.ts.map +1 -1
  93. package/dist/ee/license.js +2 -1
  94. package/dist/ee/license.js.map +1 -1
  95. package/dist/ee/license.mjs +2 -1
  96. package/dist/ee/license.mjs.map +1 -1
  97. package/dist/factories.d.ts +10 -10
  98. package/dist/factories.d.ts.map +1 -1
  99. package/dist/factories.js +10 -6
  100. package/dist/factories.js.map +1 -1
  101. package/dist/factories.mjs +6 -2
  102. package/dist/factories.mjs.map +1 -1
  103. package/dist/index.d.ts +18 -2
  104. package/dist/index.d.ts.map +1 -1
  105. package/dist/index.js +25 -1
  106. package/dist/index.js.map +1 -1
  107. package/dist/index.mjs +27 -3
  108. package/dist/index.mjs.map +1 -1
  109. package/dist/loaders/admin.d.ts +2 -2
  110. package/dist/loaders/admin.d.ts.map +1 -1
  111. package/dist/loaders/admin.js +0 -1
  112. package/dist/loaders/admin.js.map +1 -1
  113. package/dist/loaders/admin.mjs +0 -1
  114. package/dist/loaders/admin.mjs.map +1 -1
  115. package/dist/loaders/apis.d.ts +2 -2
  116. package/dist/loaders/apis.d.ts.map +1 -1
  117. package/dist/loaders/apis.js +12 -12
  118. package/dist/loaders/apis.js.map +1 -1
  119. package/dist/loaders/apis.mjs +10 -10
  120. package/dist/loaders/apis.mjs.map +1 -1
  121. package/dist/loaders/components.d.ts +2 -2
  122. package/dist/loaders/components.d.ts.map +1 -1
  123. package/dist/loaders/components.js.map +1 -1
  124. package/dist/loaders/components.mjs.map +1 -1
  125. package/dist/loaders/index.d.ts +2 -2
  126. package/dist/loaders/index.d.ts.map +1 -1
  127. package/dist/loaders/index.js +0 -2
  128. package/dist/loaders/index.js.map +1 -1
  129. package/dist/loaders/index.mjs +0 -2
  130. package/dist/loaders/index.mjs.map +1 -1
  131. package/dist/loaders/middlewares.d.ts +2 -2
  132. package/dist/loaders/middlewares.d.ts.map +1 -1
  133. package/dist/loaders/middlewares.js.map +1 -1
  134. package/dist/loaders/middlewares.mjs.map +1 -1
  135. package/dist/loaders/plugins/get-enabled-plugins.d.ts +2 -2
  136. package/dist/loaders/plugins/get-enabled-plugins.d.ts.map +1 -1
  137. package/dist/loaders/plugins/get-enabled-plugins.js +41 -14
  138. package/dist/loaders/plugins/get-enabled-plugins.js.map +1 -1
  139. package/dist/loaders/plugins/get-enabled-plugins.mjs +11 -6
  140. package/dist/loaders/plugins/get-enabled-plugins.mjs.map +1 -1
  141. package/dist/loaders/plugins/get-user-plugins-config.js +2 -2
  142. package/dist/loaders/plugins/get-user-plugins-config.js.map +1 -1
  143. package/dist/loaders/plugins/index.d.ts +2 -2
  144. package/dist/loaders/plugins/index.d.ts.map +1 -1
  145. package/dist/loaders/plugins/index.js +6 -6
  146. package/dist/loaders/plugins/index.js.map +1 -1
  147. package/dist/loaders/plugins/index.mjs.map +1 -1
  148. package/dist/loaders/policies.d.ts +2 -2
  149. package/dist/loaders/policies.d.ts.map +1 -1
  150. package/dist/loaders/policies.js.map +1 -1
  151. package/dist/loaders/policies.mjs.map +1 -1
  152. package/dist/loaders/sanitizers.d.ts +2 -2
  153. package/dist/loaders/sanitizers.d.ts.map +1 -1
  154. package/dist/loaders/sanitizers.js.map +1 -1
  155. package/dist/loaders/sanitizers.mjs.map +1 -1
  156. package/dist/loaders/src-index.d.ts +2 -2
  157. package/dist/loaders/src-index.d.ts.map +1 -1
  158. package/dist/loaders/src-index.js.map +1 -1
  159. package/dist/loaders/src-index.mjs.map +1 -1
  160. package/dist/loaders/validators.d.ts +2 -2
  161. package/dist/loaders/validators.d.ts.map +1 -1
  162. package/dist/loaders/validators.js.map +1 -1
  163. package/dist/loaders/validators.mjs.map +1 -1
  164. package/dist/middlewares/body.d.ts +4 -4
  165. package/dist/middlewares/body.d.ts.map +1 -1
  166. package/dist/middlewares/body.js +6 -6
  167. package/dist/middlewares/body.js.map +1 -1
  168. package/dist/middlewares/body.mjs +4 -4
  169. package/dist/middlewares/body.mjs.map +1 -1
  170. package/dist/middlewares/compression.d.ts +2 -2
  171. package/dist/middlewares/compression.d.ts.map +1 -1
  172. package/dist/middlewares/compression.js.map +1 -1
  173. package/dist/middlewares/compression.mjs.map +1 -1
  174. package/dist/middlewares/cors.d.ts +2 -2
  175. package/dist/middlewares/cors.d.ts.map +1 -1
  176. package/dist/middlewares/cors.js +9 -7
  177. package/dist/middlewares/cors.js.map +1 -1
  178. package/dist/middlewares/cors.mjs +9 -7
  179. package/dist/middlewares/cors.mjs.map +1 -1
  180. package/dist/middlewares/errors.d.ts +2 -2
  181. package/dist/middlewares/errors.d.ts.map +1 -1
  182. package/dist/middlewares/errors.js.map +1 -1
  183. package/dist/middlewares/errors.mjs.map +1 -1
  184. package/dist/middlewares/favicon.d.ts +2 -2
  185. package/dist/middlewares/favicon.d.ts.map +1 -1
  186. package/dist/middlewares/favicon.js.map +1 -1
  187. package/dist/middlewares/favicon.mjs.map +1 -1
  188. package/dist/middlewares/index.d.ts +2 -2
  189. package/dist/middlewares/index.d.ts.map +1 -1
  190. package/dist/middlewares/index.js.map +1 -1
  191. package/dist/middlewares/index.mjs.map +1 -1
  192. package/dist/middlewares/ip.d.ts +2 -2
  193. package/dist/middlewares/ip.d.ts.map +1 -1
  194. package/dist/middlewares/ip.js.map +1 -1
  195. package/dist/middlewares/ip.mjs.map +1 -1
  196. package/dist/middlewares/logger.d.ts +2 -2
  197. package/dist/middlewares/logger.d.ts.map +1 -1
  198. package/dist/middlewares/logger.js.map +1 -1
  199. package/dist/middlewares/logger.mjs.map +1 -1
  200. package/dist/middlewares/powered-by.d.ts +2 -2
  201. package/dist/middlewares/powered-by.d.ts.map +1 -1
  202. package/dist/middlewares/powered-by.js.map +1 -1
  203. package/dist/middlewares/powered-by.mjs.map +1 -1
  204. package/dist/middlewares/public.d.ts +2 -2
  205. package/dist/middlewares/public.d.ts.map +1 -1
  206. package/dist/middlewares/public.js +3 -3
  207. package/dist/middlewares/public.js.map +1 -1
  208. package/dist/middlewares/public.mjs +1 -1
  209. package/dist/middlewares/public.mjs.map +1 -1
  210. package/dist/middlewares/query.d.ts +2 -2
  211. package/dist/middlewares/query.d.ts.map +1 -1
  212. package/dist/middlewares/query.js.map +1 -1
  213. package/dist/middlewares/query.mjs.map +1 -1
  214. package/dist/middlewares/response-time.d.ts +2 -2
  215. package/dist/middlewares/response-time.d.ts.map +1 -1
  216. package/dist/middlewares/response-time.js.map +1 -1
  217. package/dist/middlewares/response-time.mjs.map +1 -1
  218. package/dist/middlewares/responses.d.ts +3 -3
  219. package/dist/middlewares/responses.d.ts.map +1 -1
  220. package/dist/middlewares/responses.js +2 -2
  221. package/dist/middlewares/responses.js.map +1 -1
  222. package/dist/middlewares/responses.mjs.map +1 -1
  223. package/dist/middlewares/security.d.ts +2 -2
  224. package/dist/middlewares/security.d.ts.map +1 -1
  225. package/dist/middlewares/security.js +12 -5
  226. package/dist/middlewares/security.js.map +1 -1
  227. package/dist/middlewares/security.mjs +11 -4
  228. package/dist/middlewares/security.mjs.map +1 -1
  229. package/dist/middlewares/session.d.ts +2 -2
  230. package/dist/middlewares/session.d.ts.map +1 -1
  231. package/dist/middlewares/session.js +2 -2
  232. package/dist/middlewares/session.js.map +1 -1
  233. package/dist/middlewares/session.mjs.map +1 -1
  234. package/dist/migrations/database/5.0.0-discard-drafts.d.ts +30 -0
  235. package/dist/migrations/database/5.0.0-discard-drafts.d.ts.map +1 -0
  236. package/dist/migrations/database/5.0.0-discard-drafts.js +50 -0
  237. package/dist/migrations/database/5.0.0-discard-drafts.js.map +1 -0
  238. package/dist/migrations/database/5.0.0-discard-drafts.mjs +50 -0
  239. package/dist/migrations/database/5.0.0-discard-drafts.mjs.map +1 -0
  240. package/dist/migrations/draft-publish.d.ts.map +1 -1
  241. package/dist/migrations/draft-publish.js +14 -31
  242. package/dist/migrations/draft-publish.js.map +1 -1
  243. package/dist/migrations/draft-publish.mjs +15 -32
  244. package/dist/migrations/draft-publish.mjs.map +1 -1
  245. package/dist/providers/admin.d.ts +3 -0
  246. package/dist/providers/admin.d.ts.map +1 -0
  247. package/dist/providers/admin.js +20 -0
  248. package/dist/providers/admin.js.map +1 -0
  249. package/dist/providers/admin.mjs +21 -0
  250. package/dist/providers/admin.mjs.map +1 -0
  251. package/dist/providers/coreStore.d.ts +3 -0
  252. package/dist/providers/coreStore.d.ts.map +1 -0
  253. package/dist/providers/coreStore.js +11 -0
  254. package/dist/providers/coreStore.js.map +1 -0
  255. package/dist/providers/coreStore.mjs +12 -0
  256. package/dist/providers/coreStore.mjs.map +1 -0
  257. package/dist/providers/cron.d.ts +3 -0
  258. package/dist/providers/cron.d.ts.map +1 -0
  259. package/dist/providers/cron.js +20 -0
  260. package/dist/providers/cron.js.map +1 -0
  261. package/dist/providers/cron.mjs +21 -0
  262. package/dist/providers/cron.mjs.map +1 -0
  263. package/dist/providers/index.d.ts +3 -0
  264. package/dist/providers/index.d.ts.map +1 -0
  265. package/dist/providers/index.js +11 -0
  266. package/dist/providers/index.js.map +1 -0
  267. package/dist/providers/index.mjs +11 -0
  268. package/dist/providers/index.mjs.map +1 -0
  269. package/dist/providers/provider.d.ts +9 -0
  270. package/dist/providers/provider.d.ts.map +1 -0
  271. package/dist/providers/provider.js +5 -0
  272. package/dist/providers/provider.js.map +1 -0
  273. package/dist/providers/provider.mjs +5 -0
  274. package/dist/providers/provider.mjs.map +1 -0
  275. package/dist/providers/registries.d.ts +3 -0
  276. package/dist/providers/registries.d.ts.map +1 -0
  277. package/dist/providers/registries.js +35 -0
  278. package/dist/providers/registries.js.map +1 -0
  279. package/dist/providers/registries.mjs +36 -0
  280. package/dist/providers/registries.mjs.map +1 -0
  281. package/dist/providers/telemetry.d.ts +3 -0
  282. package/dist/providers/telemetry.d.ts.map +1 -0
  283. package/dist/providers/telemetry.js +19 -0
  284. package/dist/providers/telemetry.js.map +1 -0
  285. package/dist/providers/telemetry.mjs +20 -0
  286. package/dist/providers/telemetry.mjs.map +1 -0
  287. package/dist/providers/webhooks.d.ts +3 -0
  288. package/dist/providers/webhooks.d.ts.map +1 -0
  289. package/dist/providers/webhooks.js +30 -0
  290. package/dist/providers/webhooks.js.map +1 -0
  291. package/dist/providers/webhooks.mjs +31 -0
  292. package/dist/providers/webhooks.mjs.map +1 -0
  293. package/dist/registries/apis.d.ts +2 -2
  294. package/dist/registries/apis.d.ts.map +1 -1
  295. package/dist/registries/apis.js +2 -2
  296. package/dist/registries/apis.js.map +1 -1
  297. package/dist/registries/apis.mjs.map +1 -1
  298. package/dist/registries/components.d.ts +6 -6
  299. package/dist/registries/components.d.ts.map +1 -1
  300. package/dist/registries/components.js +2 -2
  301. package/dist/registries/components.js.map +1 -1
  302. package/dist/registries/components.mjs.map +1 -1
  303. package/dist/registries/content-types.d.ts +5 -5
  304. package/dist/registries/content-types.d.ts.map +1 -1
  305. package/dist/registries/content-types.js +3 -3
  306. package/dist/registries/content-types.js.map +1 -1
  307. package/dist/registries/content-types.mjs.map +1 -1
  308. package/dist/registries/controllers.d.ts +10 -10
  309. package/dist/registries/controllers.d.ts.map +1 -1
  310. package/dist/registries/controllers.js +3 -3
  311. package/dist/registries/controllers.js.map +1 -1
  312. package/dist/registries/controllers.mjs.map +1 -1
  313. package/dist/registries/custom-fields.d.ts +3 -3
  314. package/dist/registries/custom-fields.d.ts.map +1 -1
  315. package/dist/registries/custom-fields.js +4 -4
  316. package/dist/registries/custom-fields.js.map +1 -1
  317. package/dist/registries/custom-fields.mjs.map +1 -1
  318. package/dist/registries/hooks.js +2 -2
  319. package/dist/registries/hooks.js.map +1 -1
  320. package/dist/registries/index.d.ts +0 -1
  321. package/dist/registries/index.d.ts.map +1 -1
  322. package/dist/registries/middlewares.d.ts +6 -6
  323. package/dist/registries/middlewares.d.ts.map +1 -1
  324. package/dist/registries/middlewares.js +3 -3
  325. package/dist/registries/middlewares.js.map +1 -1
  326. package/dist/registries/middlewares.mjs.map +1 -1
  327. package/dist/registries/modules.d.ts +2 -2
  328. package/dist/registries/modules.d.ts.map +1 -1
  329. package/dist/registries/modules.js +3 -3
  330. package/dist/registries/modules.js.map +1 -1
  331. package/dist/registries/modules.mjs.map +1 -1
  332. package/dist/registries/plugins.d.ts +5 -5
  333. package/dist/registries/plugins.d.ts.map +1 -1
  334. package/dist/registries/plugins.js +2 -2
  335. package/dist/registries/plugins.js.map +1 -1
  336. package/dist/registries/plugins.mjs.map +1 -1
  337. package/dist/registries/policies.d.ts +22 -10
  338. package/dist/registries/policies.d.ts.map +1 -1
  339. package/dist/registries/policies.js +66 -20
  340. package/dist/registries/policies.js.map +1 -1
  341. package/dist/registries/policies.mjs +65 -19
  342. package/dist/registries/policies.mjs.map +1 -1
  343. package/dist/registries/services.d.ts +8 -8
  344. package/dist/registries/services.d.ts.map +1 -1
  345. package/dist/registries/services.js +3 -3
  346. package/dist/registries/services.js.map +1 -1
  347. package/dist/registries/services.mjs.map +1 -1
  348. package/dist/services/auth/index.d.ts +4 -4
  349. package/dist/services/auth/index.d.ts.map +1 -1
  350. package/dist/services/auth/index.js +3 -3
  351. package/dist/services/auth/index.js.map +1 -1
  352. package/dist/services/auth/index.mjs.map +1 -1
  353. package/dist/services/config.d.ts +3 -0
  354. package/dist/services/config.d.ts.map +1 -0
  355. package/dist/services/config.js +47 -0
  356. package/dist/services/config.js.map +1 -0
  357. package/dist/services/config.mjs +47 -0
  358. package/dist/services/config.mjs.map +1 -0
  359. package/dist/services/content-api/index.d.ts +31 -15
  360. package/dist/services/content-api/index.d.ts.map +1 -1
  361. package/dist/services/content-api/index.js +28 -2
  362. package/dist/services/content-api/index.js.map +1 -1
  363. package/dist/services/content-api/index.mjs +28 -2
  364. package/dist/services/content-api/index.mjs.map +1 -1
  365. package/dist/services/content-api/permissions/index.d.ts +13 -15
  366. package/dist/services/content-api/permissions/index.d.ts.map +1 -1
  367. package/dist/services/content-api/permissions/index.js +1 -1
  368. package/dist/services/content-api/permissions/index.js.map +1 -1
  369. package/dist/services/content-api/permissions/index.mjs +1 -1
  370. package/dist/services/content-api/permissions/index.mjs.map +1 -1
  371. package/dist/services/content-api/permissions/providers/action.d.ts +5 -6
  372. package/dist/services/content-api/permissions/providers/action.d.ts.map +1 -1
  373. package/dist/services/content-api/permissions/providers/condition.d.ts +5 -6
  374. package/dist/services/content-api/permissions/providers/condition.d.ts.map +1 -1
  375. package/dist/services/core-store.d.ts.map +1 -1
  376. package/dist/services/core-store.js +3 -3
  377. package/dist/services/core-store.js.map +1 -1
  378. package/dist/services/cron.d.ts +5 -5
  379. package/dist/services/cron.d.ts.map +1 -1
  380. package/dist/services/cron.js +3 -3
  381. package/dist/services/cron.js.map +1 -1
  382. package/dist/services/cron.mjs.map +1 -1
  383. package/dist/services/custom-fields.d.ts +2 -2
  384. package/dist/services/custom-fields.d.ts.map +1 -1
  385. package/dist/services/custom-fields.js.map +1 -1
  386. package/dist/services/custom-fields.mjs.map +1 -1
  387. package/dist/services/document-service/attributes/index.d.ts +6 -0
  388. package/dist/services/document-service/attributes/index.d.ts.map +1 -0
  389. package/dist/services/{entity-service → document-service}/attributes/index.js +5 -5
  390. package/dist/services/document-service/attributes/index.js.map +1 -0
  391. package/dist/services/{entity-service → document-service}/attributes/index.mjs +5 -5
  392. package/dist/services/document-service/attributes/index.mjs.map +1 -0
  393. package/dist/services/document-service/attributes/transforms.d.ts +10 -0
  394. package/dist/services/document-service/attributes/transforms.d.ts.map +1 -0
  395. package/dist/services/{entity-service → document-service}/attributes/transforms.js +3 -3
  396. package/dist/services/document-service/attributes/transforms.js.map +1 -0
  397. package/dist/services/document-service/attributes/transforms.mjs.map +1 -0
  398. package/dist/services/document-service/common.d.ts +2 -2
  399. package/dist/services/document-service/common.d.ts.map +1 -1
  400. package/dist/services/document-service/common.js.map +1 -1
  401. package/dist/services/document-service/common.mjs.map +1 -1
  402. package/dist/services/document-service/components.d.ts +25 -1
  403. package/dist/services/document-service/components.d.ts.map +1 -1
  404. package/dist/services/{entity-service → document-service}/components.js +46 -56
  405. package/dist/services/document-service/components.js.map +1 -0
  406. package/dist/services/{entity-service → document-service}/components.mjs +36 -46
  407. package/dist/services/document-service/components.mjs.map +1 -0
  408. package/dist/services/document-service/draft-and-publish.d.ts +7 -7
  409. package/dist/services/document-service/draft-and-publish.d.ts.map +1 -1
  410. package/dist/services/document-service/draft-and-publish.js +16 -16
  411. package/dist/services/document-service/draft-and-publish.js.map +1 -1
  412. package/dist/services/document-service/draft-and-publish.mjs.map +1 -1
  413. package/dist/services/document-service/entries.d.ts +10 -0
  414. package/dist/services/document-service/entries.d.ts.map +1 -0
  415. package/dist/services/document-service/entries.js +96 -0
  416. package/dist/services/document-service/entries.js.map +1 -0
  417. package/dist/services/document-service/entries.mjs +96 -0
  418. package/dist/services/document-service/entries.mjs.map +1 -0
  419. package/dist/services/document-service/events.d.ts +25 -0
  420. package/dist/services/document-service/events.d.ts.map +1 -0
  421. package/dist/services/document-service/events.js +47 -0
  422. package/dist/services/document-service/events.js.map +1 -0
  423. package/dist/services/document-service/events.mjs +47 -0
  424. package/dist/services/document-service/events.mjs.map +1 -0
  425. package/dist/services/document-service/index.d.ts +2 -4
  426. package/dist/services/document-service/index.d.ts.map +1 -1
  427. package/dist/services/document-service/index.js +18 -5
  428. package/dist/services/document-service/index.js.map +1 -1
  429. package/dist/services/document-service/index.mjs +16 -3
  430. package/dist/services/document-service/index.mjs.map +1 -1
  431. package/dist/services/document-service/internationalization.d.ts +5 -5
  432. package/dist/services/document-service/internationalization.d.ts.map +1 -1
  433. package/dist/services/document-service/internationalization.js +21 -12
  434. package/dist/services/document-service/internationalization.js.map +1 -1
  435. package/dist/services/document-service/internationalization.mjs +14 -5
  436. package/dist/services/document-service/internationalization.mjs.map +1 -1
  437. package/dist/services/document-service/middlewares/errors.d.ts +6 -0
  438. package/dist/services/document-service/middlewares/errors.d.ts.map +1 -0
  439. package/dist/services/document-service/middlewares/errors.js +25 -0
  440. package/dist/services/document-service/middlewares/errors.js.map +1 -0
  441. package/dist/services/document-service/middlewares/errors.mjs +25 -0
  442. package/dist/services/document-service/middlewares/errors.mjs.map +1 -0
  443. package/dist/services/document-service/middlewares/index.d.ts +3 -0
  444. package/dist/services/document-service/middlewares/index.d.ts.map +1 -0
  445. package/dist/services/document-service/middlewares/middleware-manager.d.ts +10 -0
  446. package/dist/services/document-service/middlewares/middleware-manager.d.ts.map +1 -0
  447. package/dist/services/document-service/{middlewares.js → middlewares/middleware-manager.js} +9 -6
  448. package/dist/services/document-service/middlewares/middleware-manager.js.map +1 -0
  449. package/dist/services/document-service/{middlewares.mjs → middlewares/middleware-manager.mjs} +9 -6
  450. package/dist/services/document-service/middlewares/middleware-manager.mjs.map +1 -0
  451. package/dist/services/document-service/params.d.ts +3 -1
  452. package/dist/services/document-service/params.d.ts.map +1 -1
  453. package/dist/services/{entity-service → document-service}/params.js +2 -2
  454. package/dist/services/document-service/params.js.map +1 -0
  455. package/dist/services/document-service/params.mjs.map +1 -0
  456. package/dist/services/document-service/repository.d.ts.map +1 -1
  457. package/dist/services/document-service/repository.js +172 -158
  458. package/dist/services/document-service/repository.js.map +1 -1
  459. package/dist/services/document-service/repository.mjs +149 -135
  460. package/dist/services/document-service/repository.mjs.map +1 -1
  461. package/dist/services/document-service/transform/data.d.ts.map +1 -1
  462. package/dist/services/document-service/transform/data.js +4 -2
  463. package/dist/services/document-service/transform/data.js.map +1 -1
  464. package/dist/services/document-service/transform/data.mjs +4 -2
  465. package/dist/services/document-service/transform/data.mjs.map +1 -1
  466. package/dist/services/document-service/transform/fields.d.ts +2 -2
  467. package/dist/services/document-service/transform/fields.d.ts.map +1 -1
  468. package/dist/services/document-service/transform/fields.js.map +1 -1
  469. package/dist/services/document-service/transform/fields.mjs.map +1 -1
  470. package/dist/services/document-service/transform/id-map.d.ts +3 -3
  471. package/dist/services/document-service/transform/id-map.d.ts.map +1 -1
  472. package/dist/services/document-service/transform/id-map.js.map +1 -1
  473. package/dist/services/document-service/transform/id-map.mjs.map +1 -1
  474. package/dist/services/document-service/transform/id-transform.d.ts +2 -2
  475. package/dist/services/document-service/transform/id-transform.d.ts.map +1 -1
  476. package/dist/services/document-service/transform/id-transform.js +2 -2
  477. package/dist/services/document-service/transform/id-transform.js.map +1 -1
  478. package/dist/services/document-service/transform/id-transform.mjs.map +1 -1
  479. package/dist/services/document-service/transform/populate.d.ts +2 -2
  480. package/dist/services/document-service/transform/populate.d.ts.map +1 -1
  481. package/dist/services/document-service/transform/populate.js +1 -1
  482. package/dist/services/document-service/transform/populate.js.map +1 -1
  483. package/dist/services/document-service/transform/populate.mjs +1 -1
  484. package/dist/services/document-service/transform/populate.mjs.map +1 -1
  485. package/dist/services/document-service/transform/query.d.ts +5 -0
  486. package/dist/services/document-service/transform/query.d.ts.map +1 -0
  487. package/dist/services/document-service/transform/query.js +9 -0
  488. package/dist/services/document-service/transform/query.js.map +1 -0
  489. package/dist/services/document-service/transform/query.mjs +9 -0
  490. package/dist/services/document-service/transform/query.mjs.map +1 -0
  491. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +8 -7
  492. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -1
  493. package/dist/services/document-service/transform/relations/extract/data-ids.js +45 -78
  494. package/dist/services/document-service/transform/relations/extract/data-ids.js.map +1 -1
  495. package/dist/services/document-service/transform/relations/extract/data-ids.mjs +44 -77
  496. package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +1 -1
  497. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts +8 -4
  498. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts.map +1 -1
  499. package/dist/services/document-service/transform/relations/transform/data-ids.js +61 -126
  500. package/dist/services/document-service/transform/relations/transform/data-ids.js.map +1 -1
  501. package/dist/services/document-service/transform/relations/transform/data-ids.mjs +61 -126
  502. package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +1 -1
  503. package/dist/services/document-service/transform/relations/transform/default-locale.d.ts +9 -0
  504. package/dist/services/document-service/transform/relations/transform/default-locale.d.ts.map +1 -0
  505. package/dist/services/document-service/transform/relations/transform/default-locale.js +32 -0
  506. package/dist/services/document-service/transform/relations/transform/default-locale.js.map +1 -0
  507. package/dist/services/document-service/transform/relations/transform/default-locale.mjs +32 -0
  508. package/dist/services/document-service/transform/relations/transform/default-locale.mjs.map +1 -0
  509. package/dist/services/document-service/transform/relations/utils/dp.d.ts +3 -3
  510. package/dist/services/document-service/transform/relations/utils/dp.d.ts.map +1 -1
  511. package/dist/services/document-service/transform/relations/utils/dp.js +10 -5
  512. package/dist/services/document-service/transform/relations/utils/dp.js.map +1 -1
  513. package/dist/services/document-service/transform/relations/utils/dp.mjs +9 -4
  514. package/dist/services/document-service/transform/relations/utils/dp.mjs.map +1 -1
  515. package/dist/services/document-service/transform/relations/utils/i18n.d.ts +6 -6
  516. package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -1
  517. package/dist/services/document-service/transform/relations/utils/i18n.js +3 -9
  518. package/dist/services/document-service/transform/relations/utils/i18n.js.map +1 -1
  519. package/dist/services/document-service/transform/relations/utils/i18n.mjs +3 -9
  520. package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +1 -1
  521. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts +6 -0
  522. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts.map +1 -0
  523. package/dist/services/document-service/transform/relations/utils/map-relation.js +91 -0
  524. package/dist/services/document-service/transform/relations/utils/map-relation.js.map +1 -0
  525. package/dist/services/document-service/transform/relations/utils/map-relation.mjs +91 -0
  526. package/dist/services/document-service/transform/relations/utils/map-relation.mjs.map +1 -0
  527. package/dist/services/document-service/transform/relations/utils/types.d.ts +6 -0
  528. package/dist/services/document-service/transform/relations/utils/types.d.ts.map +1 -1
  529. package/dist/services/document-service/transform/types.d.ts +3 -3
  530. package/dist/services/document-service/transform/types.d.ts.map +1 -1
  531. package/dist/services/document-service/utils/populate.d.ts +2 -2
  532. package/dist/services/document-service/utils/populate.d.ts.map +1 -1
  533. package/dist/services/document-service/utils/populate.js +4 -0
  534. package/dist/services/document-service/utils/populate.js.map +1 -1
  535. package/dist/services/document-service/utils/populate.mjs +4 -0
  536. package/dist/services/document-service/utils/populate.mjs.map +1 -1
  537. package/dist/services/entity-service/index.d.ts +4 -4
  538. package/dist/services/entity-service/index.d.ts.map +1 -1
  539. package/dist/services/entity-service/index.js +22 -16
  540. package/dist/services/entity-service/index.js.map +1 -1
  541. package/dist/services/entity-service/index.mjs +23 -17
  542. package/dist/services/entity-service/index.mjs.map +1 -1
  543. package/dist/services/entity-validator/blocks-validator.d.ts +1 -2
  544. package/dist/services/entity-validator/blocks-validator.d.ts.map +1 -1
  545. package/dist/services/entity-validator/blocks-validator.js +4 -3
  546. package/dist/services/entity-validator/blocks-validator.js.map +1 -1
  547. package/dist/services/entity-validator/blocks-validator.mjs +3 -3
  548. package/dist/services/entity-validator/blocks-validator.mjs.map +1 -1
  549. package/dist/services/entity-validator/index.d.ts +16 -2
  550. package/dist/services/entity-validator/index.d.ts.map +1 -1
  551. package/dist/services/entity-validator/index.js +190 -127
  552. package/dist/services/entity-validator/index.js.map +1 -1
  553. package/dist/services/entity-validator/index.mjs +185 -122
  554. package/dist/services/entity-validator/index.mjs.map +1 -1
  555. package/dist/services/entity-validator/validators.d.ts +36 -25
  556. package/dist/services/entity-validator/validators.d.ts.map +1 -1
  557. package/dist/services/entity-validator/validators.js +153 -33
  558. package/dist/services/entity-validator/validators.js.map +1 -1
  559. package/dist/services/entity-validator/validators.mjs +145 -25
  560. package/dist/services/entity-validator/validators.mjs.map +1 -1
  561. package/dist/services/event-hub.d.ts +1 -0
  562. package/dist/services/event-hub.d.ts.map +1 -1
  563. package/dist/services/event-hub.js +9 -4
  564. package/dist/services/event-hub.js.map +1 -1
  565. package/dist/services/event-hub.mjs +9 -4
  566. package/dist/services/event-hub.mjs.map +1 -1
  567. package/dist/services/features.d.ts +3 -3
  568. package/dist/services/features.d.ts.map +1 -1
  569. package/dist/services/features.js.map +1 -1
  570. package/dist/services/features.mjs.map +1 -1
  571. package/dist/services/fs.d.ts +2 -2
  572. package/dist/services/fs.d.ts.map +1 -1
  573. package/dist/services/fs.js.map +1 -1
  574. package/dist/services/fs.mjs.map +1 -1
  575. package/dist/services/metrics/admin-user-hash.d.ts +2 -2
  576. package/dist/services/metrics/admin-user-hash.d.ts.map +1 -1
  577. package/dist/services/metrics/admin-user-hash.js.map +1 -1
  578. package/dist/services/metrics/admin-user-hash.mjs.map +1 -1
  579. package/dist/services/metrics/index.d.ts +2 -2
  580. package/dist/services/metrics/index.d.ts.map +1 -1
  581. package/dist/services/metrics/index.js.map +1 -1
  582. package/dist/services/metrics/index.mjs.map +1 -1
  583. package/dist/services/metrics/middleware.d.ts +2 -2
  584. package/dist/services/metrics/middleware.d.ts.map +1 -1
  585. package/dist/services/metrics/middleware.js.map +1 -1
  586. package/dist/services/metrics/middleware.mjs.map +1 -1
  587. package/dist/services/metrics/rate-limiter.d.ts.map +1 -1
  588. package/dist/services/metrics/rate-limiter.js.map +1 -1
  589. package/dist/services/metrics/rate-limiter.mjs.map +1 -1
  590. package/dist/services/metrics/sender.d.ts +3 -3
  591. package/dist/services/metrics/sender.d.ts.map +1 -1
  592. package/dist/services/metrics/sender.js.map +1 -1
  593. package/dist/services/metrics/sender.mjs.map +1 -1
  594. package/dist/services/query-params.d.ts +7 -0
  595. package/dist/services/query-params.d.ts.map +1 -0
  596. package/dist/services/query-params.js +12 -0
  597. package/dist/services/query-params.js.map +1 -0
  598. package/dist/services/query-params.mjs +13 -0
  599. package/dist/services/query-params.mjs.map +1 -0
  600. package/dist/services/reloader.d.ts +7 -0
  601. package/dist/services/reloader.d.ts.map +1 -0
  602. package/dist/services/reloader.js +36 -0
  603. package/dist/services/reloader.js.map +1 -0
  604. package/dist/services/reloader.mjs +36 -0
  605. package/dist/services/reloader.mjs.map +1 -0
  606. package/dist/services/server/admin-api.d.ts +3 -3
  607. package/dist/services/server/admin-api.d.ts.map +1 -1
  608. package/dist/services/server/admin-api.js.map +1 -1
  609. package/dist/services/server/admin-api.mjs.map +1 -1
  610. package/dist/services/server/api.d.ts +3 -3
  611. package/dist/services/server/api.d.ts.map +1 -1
  612. package/dist/services/server/api.js.map +1 -1
  613. package/dist/services/server/api.mjs.map +1 -1
  614. package/dist/services/server/compose-endpoint.d.ts +2 -2
  615. package/dist/services/server/compose-endpoint.d.ts.map +1 -1
  616. package/dist/services/server/compose-endpoint.js +8 -9
  617. package/dist/services/server/compose-endpoint.js.map +1 -1
  618. package/dist/services/server/compose-endpoint.mjs +2 -3
  619. package/dist/services/server/compose-endpoint.mjs.map +1 -1
  620. package/dist/services/server/content-api.d.ts +3 -3
  621. package/dist/services/server/content-api.d.ts.map +1 -1
  622. package/dist/services/server/content-api.js.map +1 -1
  623. package/dist/services/server/content-api.mjs.map +1 -1
  624. package/dist/services/server/http-server.d.ts +2 -2
  625. package/dist/services/server/http-server.d.ts.map +1 -1
  626. package/dist/services/server/http-server.js.map +1 -1
  627. package/dist/services/server/http-server.mjs.map +1 -1
  628. package/dist/services/server/index.d.ts +2 -2
  629. package/dist/services/server/index.d.ts.map +1 -1
  630. package/dist/services/server/index.js +2 -3
  631. package/dist/services/server/index.js.map +1 -1
  632. package/dist/services/server/index.mjs +2 -3
  633. package/dist/services/server/index.mjs.map +1 -1
  634. package/dist/services/server/koa.d.ts.map +1 -1
  635. package/dist/services/server/koa.js +4 -4
  636. package/dist/services/server/koa.js.map +1 -1
  637. package/dist/services/server/koa.mjs +1 -1
  638. package/dist/services/server/koa.mjs.map +1 -1
  639. package/dist/services/server/middleware.d.ts +4 -4
  640. package/dist/services/server/middleware.d.ts.map +1 -1
  641. package/dist/services/server/middleware.js +3 -3
  642. package/dist/services/server/middleware.js.map +1 -1
  643. package/dist/services/server/middleware.mjs.map +1 -1
  644. package/dist/services/server/policy.d.ts +3 -3
  645. package/dist/services/server/policy.d.ts.map +1 -1
  646. package/dist/services/server/policy.js +4 -4
  647. package/dist/services/server/policy.js.map +1 -1
  648. package/dist/services/server/policy.mjs +4 -4
  649. package/dist/services/server/policy.mjs.map +1 -1
  650. package/dist/services/server/register-middlewares.d.ts +2 -2
  651. package/dist/services/server/register-middlewares.d.ts.map +1 -1
  652. package/dist/services/server/register-middlewares.js.map +1 -1
  653. package/dist/services/server/register-middlewares.mjs.map +1 -1
  654. package/dist/services/server/register-routes.d.ts +2 -2
  655. package/dist/services/server/register-routes.d.ts.map +1 -1
  656. package/dist/services/server/register-routes.js +3 -3
  657. package/dist/services/server/register-routes.js.map +1 -1
  658. package/dist/services/server/register-routes.mjs +3 -3
  659. package/dist/services/server/register-routes.mjs.map +1 -1
  660. package/dist/services/server/routing.d.ts +5 -5
  661. package/dist/services/server/routing.d.ts.map +1 -1
  662. package/dist/services/server/routing.js +2 -2
  663. package/dist/services/server/routing.js.map +1 -1
  664. package/dist/services/server/routing.mjs.map +1 -1
  665. package/dist/services/utils/dynamic-zones.d.ts.map +1 -1
  666. package/dist/services/utils/dynamic-zones.js +7 -6
  667. package/dist/services/utils/dynamic-zones.js.map +1 -1
  668. package/dist/services/utils/dynamic-zones.mjs +2 -1
  669. package/dist/services/utils/dynamic-zones.mjs.map +1 -1
  670. package/dist/services/webhook-runner.d.ts +2 -1
  671. package/dist/services/webhook-runner.d.ts.map +1 -1
  672. package/dist/services/webhook-runner.js.map +1 -1
  673. package/dist/services/webhook-runner.mjs.map +1 -1
  674. package/dist/services/webhook-store.d.ts +2 -8
  675. package/dist/services/webhook-store.d.ts.map +1 -1
  676. package/dist/services/webhook-store.js +14 -8
  677. package/dist/services/webhook-store.js.map +1 -1
  678. package/dist/services/webhook-store.mjs +14 -8
  679. package/dist/services/webhook-store.mjs.map +1 -1
  680. package/dist/utils/convert-custom-field-type.d.ts +2 -2
  681. package/dist/utils/convert-custom-field-type.d.ts.map +1 -1
  682. package/dist/utils/convert-custom-field-type.js.map +1 -1
  683. package/dist/utils/convert-custom-field-type.mjs.map +1 -1
  684. package/dist/utils/cron.js +3 -3
  685. package/dist/utils/cron.js.map +1 -1
  686. package/dist/utils/fetch.d.ts +3 -3
  687. package/dist/utils/fetch.d.ts.map +1 -1
  688. package/dist/utils/fetch.js +4 -3
  689. package/dist/utils/fetch.js.map +1 -1
  690. package/dist/utils/fetch.mjs +4 -3
  691. package/dist/utils/fetch.mjs.map +1 -1
  692. package/dist/utils/filepath-to-prop-path.d.ts +1 -1
  693. package/dist/utils/filepath-to-prop-path.d.ts.map +1 -1
  694. package/dist/utils/filepath-to-prop-path.js +27 -6
  695. package/dist/utils/filepath-to-prop-path.js.map +1 -1
  696. package/dist/utils/filepath-to-prop-path.mjs +25 -5
  697. package/dist/utils/filepath-to-prop-path.mjs.map +1 -1
  698. package/dist/utils/index.d.ts +2 -1
  699. package/dist/utils/index.d.ts.map +1 -1
  700. package/dist/utils/is-initialized.d.ts +2 -2
  701. package/dist/utils/is-initialized.d.ts.map +1 -1
  702. package/dist/utils/is-initialized.js +3 -3
  703. package/dist/utils/is-initialized.js.map +1 -1
  704. package/dist/utils/is-initialized.mjs.map +1 -1
  705. package/dist/utils/load-files.d.ts.map +1 -1
  706. package/dist/utils/open-browser.d.ts +2 -2
  707. package/dist/utils/open-browser.d.ts.map +1 -1
  708. package/dist/utils/open-browser.js.map +1 -1
  709. package/dist/utils/open-browser.mjs.map +1 -1
  710. package/dist/utils/resolve-working-dirs.d.ts +19 -0
  711. package/dist/utils/resolve-working-dirs.d.ts.map +1 -0
  712. package/dist/utils/resolve-working-dirs.js +13 -0
  713. package/dist/utils/resolve-working-dirs.js.map +1 -0
  714. package/dist/utils/resolve-working-dirs.mjs +11 -0
  715. package/dist/utils/resolve-working-dirs.mjs.map +1 -0
  716. package/dist/utils/signals.d.ts +2 -2
  717. package/dist/utils/signals.d.ts.map +1 -1
  718. package/dist/utils/signals.js.map +1 -1
  719. package/dist/utils/signals.mjs.map +1 -1
  720. package/dist/utils/startup-logger.d.ts +2 -2
  721. package/dist/utils/startup-logger.d.ts.map +1 -1
  722. package/dist/utils/startup-logger.js +4 -4
  723. package/dist/utils/startup-logger.js.map +1 -1
  724. package/dist/utils/startup-logger.mjs +3 -3
  725. package/dist/utils/startup-logger.mjs.map +1 -1
  726. package/dist/utils/transform-content-types-to-models.d.ts +54 -99
  727. package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
  728. package/dist/utils/transform-content-types-to-models.js +112 -61
  729. package/dist/utils/transform-content-types-to-models.js.map +1 -1
  730. package/dist/utils/transform-content-types-to-models.mjs +111 -60
  731. package/dist/utils/transform-content-types-to-models.mjs.map +1 -1
  732. package/dist/utils/update-notifier/index.d.ts +2 -7
  733. package/dist/utils/update-notifier/index.d.ts.map +1 -1
  734. package/dist/utils/update-notifier/index.js +11 -14
  735. package/dist/utils/update-notifier/index.js.map +1 -1
  736. package/dist/utils/update-notifier/index.mjs +11 -14
  737. package/dist/utils/update-notifier/index.mjs.map +1 -1
  738. package/package.json +33 -30
  739. package/dist/registries/config.d.ts +0 -4
  740. package/dist/registries/config.d.ts.map +0 -1
  741. package/dist/registries/config.js +0 -31
  742. package/dist/registries/config.js.map +0 -1
  743. package/dist/registries/config.mjs +0 -32
  744. package/dist/registries/config.mjs.map +0 -1
  745. package/dist/services/document-service/middlewares.d.ts +0 -8
  746. package/dist/services/document-service/middlewares.d.ts.map +0 -1
  747. package/dist/services/document-service/middlewares.js.map +0 -1
  748. package/dist/services/document-service/middlewares.mjs.map +0 -1
  749. package/dist/services/document-service/transform/filters.d.ts +0 -3
  750. package/dist/services/document-service/transform/filters.d.ts.map +0 -1
  751. package/dist/services/document-service/transform/relations/transform/output-ids.d.ts +0 -4
  752. package/dist/services/document-service/transform/relations/transform/output-ids.d.ts.map +0 -1
  753. package/dist/services/document-service/transform/relations/utils/data.js +0 -12
  754. package/dist/services/document-service/transform/relations/utils/data.js.map +0 -1
  755. package/dist/services/document-service/transform/relations/utils/data.mjs +0 -12
  756. package/dist/services/document-service/transform/relations/utils/data.mjs.map +0 -1
  757. package/dist/services/document-service/transform/sort.d.ts +0 -5
  758. package/dist/services/document-service/transform/sort.d.ts.map +0 -1
  759. package/dist/services/document-service/transform/utils.d.ts +0 -9
  760. package/dist/services/document-service/transform/utils.d.ts.map +0 -1
  761. package/dist/services/entity-service/attributes/index.d.ts +0 -6
  762. package/dist/services/entity-service/attributes/index.d.ts.map +0 -1
  763. package/dist/services/entity-service/attributes/index.js.map +0 -1
  764. package/dist/services/entity-service/attributes/index.mjs.map +0 -1
  765. package/dist/services/entity-service/attributes/transforms.d.ts +0 -10
  766. package/dist/services/entity-service/attributes/transforms.d.ts.map +0 -1
  767. package/dist/services/entity-service/attributes/transforms.js.map +0 -1
  768. package/dist/services/entity-service/attributes/transforms.mjs.map +0 -1
  769. package/dist/services/entity-service/components.d.ts +0 -20
  770. package/dist/services/entity-service/components.d.ts.map +0 -1
  771. package/dist/services/entity-service/components.js.map +0 -1
  772. package/dist/services/entity-service/components.mjs.map +0 -1
  773. package/dist/services/entity-service/params.d.ts +0 -8
  774. package/dist/services/entity-service/params.d.ts.map +0 -1
  775. package/dist/services/entity-service/params.js.map +0 -1
  776. package/dist/services/entity-service/params.mjs.map +0 -1
  777. package/dist/utils/get-dirs.d.ts +0 -9
  778. package/dist/utils/get-dirs.d.ts.map +0 -1
  779. package/dist/utils/get-dirs.js.map +0 -1
  780. package/dist/utils/get-dirs.mjs.map +0 -1
  781. /package/dist/services/{entity-service → document-service}/attributes/transforms.mjs +0 -0
  782. /package/dist/services/{entity-service → document-service}/params.mjs +0 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"events.d.ts","sourceRoot":"","sources":["../../../src/services/document-service/events.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,KAAK,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAK1D,QAAA,MAAM,MAAM;;;;;;;CAOX,CAAC;AAEF,KAAK,SAAS,GAAG,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,MAAM,CAAC,CAAC;AAEpD;;;;;GAKG;AACH,QAAA,MAAM,kBAAkB,WAAY,KAAK,MAAM,OAAO,IAAI,MAAM;IA2B5D;;;OAGG;yBACkB,SAAS,SAAS,QAAQ,SAAS,CAAC,WAAW;CAMvE,CAAC;AAEF,OAAO,EAAE,kBAAkB,EAAE,CAAC"}
@@ -0,0 +1,47 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const strapiUtils = require("@strapi/utils");
4
+ const populate = require("./utils/populate.js");
5
+ const EVENTS = {
6
+ ENTRY_CREATE: "entry.create",
7
+ ENTRY_UPDATE: "entry.update",
8
+ ENTRY_DELETE: "entry.delete",
9
+ ENTRY_PUBLISH: "entry.publish",
10
+ ENTRY_UNPUBLISH: "entry.unpublish",
11
+ ENTRY_DRAFT_DISCARD: "entry.draft-discard"
12
+ };
13
+ const createEventManager = (strapi, uid) => {
14
+ const populate$1 = populate.getDeepPopulate(uid, {});
15
+ const model = strapi.getModel(uid);
16
+ const emitEvent = async (eventName, entry) => {
17
+ let populatedEntry = entry;
18
+ if (![EVENTS.ENTRY_DELETE, EVENTS.ENTRY_UNPUBLISH].includes(eventName)) {
19
+ populatedEntry = await strapi.db.query(uid).findOne({ where: { id: entry.id }, populate: populate$1 });
20
+ }
21
+ const sanitizedEntry = await strapiUtils.sanitize.sanitizers.defaultSanitizeOutput(
22
+ {
23
+ schema: model,
24
+ getModel: (uid2) => strapi.getModel(uid2)
25
+ },
26
+ populatedEntry
27
+ );
28
+ await strapi.eventHub.emit(eventName, {
29
+ model: model.modelName,
30
+ uid: model.uid,
31
+ entry: sanitizedEntry
32
+ });
33
+ };
34
+ return {
35
+ /**
36
+ * strapi.db.query might reuse the transaction used in the doc service request,
37
+ * so this is executed after that transaction is committed.
38
+ */
39
+ emitEvent(eventName, entry) {
40
+ strapi.db.transaction(({ onCommit }) => {
41
+ onCommit(() => emitEvent(eventName, entry));
42
+ });
43
+ }
44
+ };
45
+ };
46
+ exports.createEventManager = createEventManager;
47
+ //# sourceMappingURL=events.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"events.js","sources":["../../../src/services/document-service/events.ts"],"sourcesContent":["import { UID, Utils, Modules, Core } from '@strapi/types';\nimport { sanitize } from '@strapi/utils';\n\nimport { getDeepPopulate } from './utils/populate';\n\nconst EVENTS = {\n ENTRY_CREATE: 'entry.create',\n ENTRY_UPDATE: 'entry.update',\n ENTRY_DELETE: 'entry.delete',\n ENTRY_PUBLISH: 'entry.publish',\n ENTRY_UNPUBLISH: 'entry.unpublish',\n ENTRY_DRAFT_DISCARD: 'entry.draft-discard',\n};\n\ntype EventName = Utils.Object.Values<typeof EVENTS>;\n\n/**\n * Manager to trigger entry related events\n *\n * It will populate the entry if it is not a delete event.\n * So the event payload will contain the full entry.\n */\nconst createEventManager = (strapi: Core.Strapi, uid: UID.Schema) => {\n const populate = getDeepPopulate(uid, {});\n const model = strapi.getModel(uid);\n\n const emitEvent = async (eventName: EventName, entry: Modules.Documents.AnyDocument) => {\n // There is no need to populate the entry if it has been deleted\n let populatedEntry = entry;\n if (![EVENTS.ENTRY_DELETE, EVENTS.ENTRY_UNPUBLISH].includes(eventName)) {\n populatedEntry = await strapi.db.query(uid).findOne({ where: { id: entry.id }, populate });\n }\n\n const sanitizedEntry = await sanitize.sanitizers.defaultSanitizeOutput(\n {\n schema: model,\n getModel: (uid) => strapi.getModel(uid as UID.Schema),\n },\n populatedEntry\n );\n\n await strapi.eventHub.emit(eventName, {\n model: model.modelName,\n uid: model.uid,\n entry: sanitizedEntry,\n });\n };\n\n return {\n /**\n * strapi.db.query might reuse the transaction used in the doc service request,\n * so this is executed after that transaction is committed.\n */\n emitEvent(eventName: EventName, entry: Modules.Documents.AnyDocument) {\n strapi.db.transaction(({ onCommit }) => {\n onCommit(() => emitEvent(eventName, entry));\n });\n },\n };\n};\n\nexport { createEventManager };\n"],"names":["populate","getDeepPopulate","sanitize","uid"],"mappings":";;;;AAKA,MAAM,SAAS;AAAA,EACb,cAAc;AAAA,EACd,cAAc;AAAA,EACd,cAAc;AAAA,EACd,eAAe;AAAA,EACf,iBAAiB;AAAA,EACjB,qBAAqB;AACvB;AAUM,MAAA,qBAAqB,CAAC,QAAqB,QAAoB;AACnE,QAAMA,aAAWC,SAAAA,gBAAgB,KAAK,CAAE,CAAA;AAClC,QAAA,QAAQ,OAAO,SAAS,GAAG;AAE3B,QAAA,YAAY,OAAO,WAAsB,UAAyC;AAEtF,QAAI,iBAAiB;AACjB,QAAA,CAAC,CAAC,OAAO,cAAc,OAAO,eAAe,EAAE,SAAS,SAAS,GAAG;AACtE,uBAAiB,MAAM,OAAO,GAAG,MAAM,GAAG,EAAE,QAAQ,EAAE,OAAO,EAAE,IAAI,MAAM,GAAG,GAAGD,UAAAA,WAAU,CAAA;AAAA,IAC3F;AAEM,UAAA,iBAAiB,MAAME,qBAAS,WAAW;AAAA,MAC/C;AAAA,QACE,QAAQ;AAAA,QACR,UAAU,CAACC,SAAQ,OAAO,SAASA,IAAiB;AAAA,MACtD;AAAA,MACA;AAAA,IAAA;AAGI,UAAA,OAAO,SAAS,KAAK,WAAW;AAAA,MACpC,OAAO,MAAM;AAAA,MACb,KAAK,MAAM;AAAA,MACX,OAAO;AAAA,IAAA,CACR;AAAA,EAAA;AAGI,SAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAKL,UAAU,WAAsB,OAAsC;AACpE,aAAO,GAAG,YAAY,CAAC,EAAE,eAAe;AACtC,iBAAS,MAAM,UAAU,WAAW,KAAK,CAAC;AAAA,MAAA,CAC3C;AAAA,IACH;AAAA,EAAA;AAEJ;;"}
@@ -0,0 +1,47 @@
1
+ import { sanitize } from "@strapi/utils";
2
+ import { getDeepPopulate } from "./utils/populate.mjs";
3
+ const EVENTS = {
4
+ ENTRY_CREATE: "entry.create",
5
+ ENTRY_UPDATE: "entry.update",
6
+ ENTRY_DELETE: "entry.delete",
7
+ ENTRY_PUBLISH: "entry.publish",
8
+ ENTRY_UNPUBLISH: "entry.unpublish",
9
+ ENTRY_DRAFT_DISCARD: "entry.draft-discard"
10
+ };
11
+ const createEventManager = (strapi, uid) => {
12
+ const populate = getDeepPopulate(uid, {});
13
+ const model = strapi.getModel(uid);
14
+ const emitEvent = async (eventName, entry) => {
15
+ let populatedEntry = entry;
16
+ if (![EVENTS.ENTRY_DELETE, EVENTS.ENTRY_UNPUBLISH].includes(eventName)) {
17
+ populatedEntry = await strapi.db.query(uid).findOne({ where: { id: entry.id }, populate });
18
+ }
19
+ const sanitizedEntry = await sanitize.sanitizers.defaultSanitizeOutput(
20
+ {
21
+ schema: model,
22
+ getModel: (uid2) => strapi.getModel(uid2)
23
+ },
24
+ populatedEntry
25
+ );
26
+ await strapi.eventHub.emit(eventName, {
27
+ model: model.modelName,
28
+ uid: model.uid,
29
+ entry: sanitizedEntry
30
+ });
31
+ };
32
+ return {
33
+ /**
34
+ * strapi.db.query might reuse the transaction used in the doc service request,
35
+ * so this is executed after that transaction is committed.
36
+ */
37
+ emitEvent(eventName, entry) {
38
+ strapi.db.transaction(({ onCommit }) => {
39
+ onCommit(() => emitEvent(eventName, entry));
40
+ });
41
+ }
42
+ };
43
+ };
44
+ export {
45
+ createEventManager
46
+ };
47
+ //# sourceMappingURL=events.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"events.mjs","sources":["../../../src/services/document-service/events.ts"],"sourcesContent":["import { UID, Utils, Modules, Core } from '@strapi/types';\nimport { sanitize } from '@strapi/utils';\n\nimport { getDeepPopulate } from './utils/populate';\n\nconst EVENTS = {\n ENTRY_CREATE: 'entry.create',\n ENTRY_UPDATE: 'entry.update',\n ENTRY_DELETE: 'entry.delete',\n ENTRY_PUBLISH: 'entry.publish',\n ENTRY_UNPUBLISH: 'entry.unpublish',\n ENTRY_DRAFT_DISCARD: 'entry.draft-discard',\n};\n\ntype EventName = Utils.Object.Values<typeof EVENTS>;\n\n/**\n * Manager to trigger entry related events\n *\n * It will populate the entry if it is not a delete event.\n * So the event payload will contain the full entry.\n */\nconst createEventManager = (strapi: Core.Strapi, uid: UID.Schema) => {\n const populate = getDeepPopulate(uid, {});\n const model = strapi.getModel(uid);\n\n const emitEvent = async (eventName: EventName, entry: Modules.Documents.AnyDocument) => {\n // There is no need to populate the entry if it has been deleted\n let populatedEntry = entry;\n if (![EVENTS.ENTRY_DELETE, EVENTS.ENTRY_UNPUBLISH].includes(eventName)) {\n populatedEntry = await strapi.db.query(uid).findOne({ where: { id: entry.id }, populate });\n }\n\n const sanitizedEntry = await sanitize.sanitizers.defaultSanitizeOutput(\n {\n schema: model,\n getModel: (uid) => strapi.getModel(uid as UID.Schema),\n },\n populatedEntry\n );\n\n await strapi.eventHub.emit(eventName, {\n model: model.modelName,\n uid: model.uid,\n entry: sanitizedEntry,\n });\n };\n\n return {\n /**\n * strapi.db.query might reuse the transaction used in the doc service request,\n * so this is executed after that transaction is committed.\n */\n emitEvent(eventName: EventName, entry: Modules.Documents.AnyDocument) {\n strapi.db.transaction(({ onCommit }) => {\n onCommit(() => emitEvent(eventName, entry));\n });\n },\n };\n};\n\nexport { createEventManager };\n"],"names":["uid"],"mappings":";;AAKA,MAAM,SAAS;AAAA,EACb,cAAc;AAAA,EACd,cAAc;AAAA,EACd,cAAc;AAAA,EACd,eAAe;AAAA,EACf,iBAAiB;AAAA,EACjB,qBAAqB;AACvB;AAUM,MAAA,qBAAqB,CAAC,QAAqB,QAAoB;AACnE,QAAM,WAAW,gBAAgB,KAAK,CAAE,CAAA;AAClC,QAAA,QAAQ,OAAO,SAAS,GAAG;AAE3B,QAAA,YAAY,OAAO,WAAsB,UAAyC;AAEtF,QAAI,iBAAiB;AACjB,QAAA,CAAC,CAAC,OAAO,cAAc,OAAO,eAAe,EAAE,SAAS,SAAS,GAAG;AACtE,uBAAiB,MAAM,OAAO,GAAG,MAAM,GAAG,EAAE,QAAQ,EAAE,OAAO,EAAE,IAAI,MAAM,GAAG,GAAG,SAAU,CAAA;AAAA,IAC3F;AAEM,UAAA,iBAAiB,MAAM,SAAS,WAAW;AAAA,MAC/C;AAAA,QACE,QAAQ;AAAA,QACR,UAAU,CAACA,SAAQ,OAAO,SAASA,IAAiB;AAAA,MACtD;AAAA,MACA;AAAA,IAAA;AAGI,UAAA,OAAO,SAAS,KAAK,WAAW;AAAA,MACpC,OAAO,MAAM;AAAA,MACb,KAAK,MAAM;AAAA,MACX,OAAO;AAAA,IAAA,CACR;AAAA,EAAA;AAGI,SAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAKL,UAAU,WAAsB,OAAsC;AACpE,aAAO,GAAG,YAAY,CAAC,EAAE,eAAe;AACtC,iBAAS,MAAM,UAAU,WAAW,KAAK,CAAC;AAAA,MAAA,CAC3C;AAAA,IACH;AAAA,EAAA;AAEJ;"}
@@ -1,4 +1,4 @@
1
- import { Strapi, Documents } from '@strapi/types';
1
+ import type { Core, Modules } from '@strapi/types';
2
2
  /**
3
3
  * Repository to :
4
4
  * - Access documents via actions (findMany, findOne, create, update, delete, ...)
@@ -6,8 +6,6 @@ import { Strapi, Documents } from '@strapi/types';
6
6
  * - Apply default parameters to document actions
7
7
  *
8
8
  * @param strapi
9
- * @param options.defaults - Default parameters to apply to all actions
10
- * @param options.parent - Parent repository, used when creating a new repository with .with()
11
9
  * @returns DocumentService
12
10
  *
13
11
  * @example Access documents
@@ -15,5 +13,5 @@ import { Strapi, Documents } from '@strapi/types';
15
13
  * const allArticles = strapi.documents('api::article.article').findMany(params)
16
14
  *
17
15
  */
18
- export declare const createDocumentService: (strapi: Strapi) => Documents.Service;
16
+ export declare const createDocumentService: (strapi: Core.Strapi) => Modules.Documents.Service;
19
17
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/services/document-service/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAKlD;;;;;;;;;;;;;;;GAeG;AAEH,eAAO,MAAM,qBAAqB,WAAY,MAAM,KAAG,UAAU,OAoBhE,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/services/document-service/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,OAAO,EAAO,MAAM,eAAe,CAAC;AAMxD;;;;;;;;;;;;;GAaG;AACH,eAAO,MAAM,qBAAqB,WAAY,KAAK,MAAM,KAAG,QAAQ,SAAS,CAAC,OAmC7E,CAAC"}
@@ -1,21 +1,34 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const middlewares = require("./middlewares.js");
3
+ const errors = require("./middlewares/errors.js");
4
+ const middlewareManager = require("./middlewares/middleware-manager.js");
4
5
  const repository = require("./repository.js");
6
+ const data = require("./transform/data.js");
5
7
  const createDocumentService = (strapi) => {
6
8
  const repositories = /* @__PURE__ */ new Map();
7
- const middlewares$1 = middlewares.createMiddlewareManager();
9
+ const middlewares = middlewareManager.createMiddlewareManager();
10
+ middlewares.use(errors.databaseErrorsMiddleware);
8
11
  const factory = function factory2(uid) {
9
12
  if (repositories.has(uid)) {
10
13
  return repositories.get(uid);
11
14
  }
12
15
  const contentType = strapi.contentType(uid);
13
16
  const repository$1 = repository.createContentTypeRepository(uid);
14
- repositories.set(uid, middlewares$1.wrapObject(repository$1, { contentType }));
15
- return repository$1;
17
+ const instance = middlewares.wrapObject(
18
+ repository$1,
19
+ { uid, contentType },
20
+ {
21
+ exclude: ["updateComponents", "omitComponentData"]
22
+ }
23
+ );
24
+ repositories.set(uid, instance);
25
+ return instance;
16
26
  };
17
27
  return Object.assign(factory, {
18
- use: middlewares$1.use.bind(middlewares$1)
28
+ utils: {
29
+ transformData: data.transformData
30
+ },
31
+ use: middlewares.use.bind(middlewares)
19
32
  });
20
33
  };
21
34
  exports.createDocumentService = createDocumentService;
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../../src/services/document-service/index.ts"],"sourcesContent":["import { Strapi, Documents } from '@strapi/types';\n\nimport { createMiddlewareManager } from './middlewares';\nimport { createContentTypeRepository } from './repository';\n\n/**\n * Repository to :\n * - Access documents via actions (findMany, findOne, create, update, delete, ...)\n * - Execute middlewares on document actions\n * - Apply default parameters to document actions\n *\n * @param strapi\n * @param options.defaults - Default parameters to apply to all actions\n * @param options.parent - Parent repository, used when creating a new repository with .with()\n * @returns DocumentService\n *\n * @example Access documents\n * const article = strapi.documents('api::article.article').create(params)\n * const allArticles = strapi.documents('api::article.article').findMany(params)\n *\n */\n// TODO: support global document service middleware & per repo middlewares\nexport const createDocumentService = (strapi: Strapi): Documents.Service => {\n const repositories = new Map<string, Documents.ServiceInstance>();\n const middlewares = createMiddlewareManager();\n\n const factory = function factory(uid) {\n if (repositories.has(uid)) {\n return repositories.get(uid)!;\n }\n\n const contentType = strapi.contentType(uid);\n const repository = createContentTypeRepository(uid);\n\n repositories.set(uid, middlewares.wrapObject(repository, { contentType }));\n\n return repository;\n } as Documents.Service;\n\n return Object.assign(factory, {\n use: middlewares.use.bind(middlewares),\n });\n};\n"],"names":["middlewares","createMiddlewareManager","factory","repository","createContentTypeRepository"],"mappings":";;;;AAsBa,MAAA,wBAAwB,CAAC,WAAsC;AACpE,QAAA,mCAAmB;AACzB,QAAMA,gBAAcC,YAAAA;AAEd,QAAA,UAAU,SAASC,SAAQ,KAAK;AAChC,QAAA,aAAa,IAAI,GAAG,GAAG;AAClB,aAAA,aAAa,IAAI,GAAG;AAAA,IAC7B;AAEM,UAAA,cAAc,OAAO,YAAY,GAAG;AACpC,UAAAC,eAAaC,uCAA4B,GAAG;AAErC,iBAAA,IAAI,KAAKJ,cAAY,WAAWG,cAAY,EAAE,YAAa,CAAA,CAAC;AAElE,WAAAA;AAAAA,EAAA;AAGF,SAAA,OAAO,OAAO,SAAS;AAAA,IAC5B,KAAKH,cAAY,IAAI,KAAKA,aAAW;AAAA,EAAA,CACtC;AACH;;"}
1
+ {"version":3,"file":"index.js","sources":["../../../src/services/document-service/index.ts"],"sourcesContent":["import type { Core, Modules, UID } from '@strapi/types';\n\nimport { createMiddlewareManager, databaseErrorsMiddleware } from './middlewares';\nimport { createContentTypeRepository } from './repository';\nimport { transformData } from './transform/data';\n\n/**\n * Repository to :\n * - Access documents via actions (findMany, findOne, create, update, delete, ...)\n * - Execute middlewares on document actions\n * - Apply default parameters to document actions\n *\n * @param strapi\n * @returns DocumentService\n *\n * @example Access documents\n * const article = strapi.documents('api::article.article').create(params)\n * const allArticles = strapi.documents('api::article.article').findMany(params)\n *\n */\nexport const createDocumentService = (strapi: Core.Strapi): Modules.Documents.Service => {\n // Cache the repositories (one per content type)\n const repositories = new Map<string, Modules.Documents.ServiceInstance>();\n\n // Manager to handle document service middlewares\n const middlewares = createMiddlewareManager();\n middlewares.use(databaseErrorsMiddleware);\n\n const factory = function factory(uid: UID.ContentType) {\n if (repositories.has(uid)) {\n return repositories.get(uid)!;\n }\n\n const contentType = strapi.contentType(uid);\n const repository = createContentTypeRepository(uid);\n\n const instance = middlewares.wrapObject(\n repository,\n { uid, contentType },\n {\n exclude: ['updateComponents', 'omitComponentData'],\n }\n );\n\n repositories.set(uid, instance);\n\n return instance;\n } as Modules.Documents.Service;\n\n return Object.assign(factory, {\n utils: {\n transformData,\n },\n use: middlewares.use.bind(middlewares),\n });\n};\n"],"names":["createMiddlewareManager","databaseErrorsMiddleware","factory","repository","createContentTypeRepository","transformData"],"mappings":";;;;;;AAoBa,MAAA,wBAAwB,CAAC,WAAmD;AAEjF,QAAA,mCAAmB;AAGzB,QAAM,cAAcA,kBAAAA;AACpB,cAAY,IAAIC,OAAAA,wBAAwB;AAElC,QAAA,UAAU,SAASC,SAAQ,KAAsB;AACjD,QAAA,aAAa,IAAI,GAAG,GAAG;AAClB,aAAA,aAAa,IAAI,GAAG;AAAA,IAC7B;AAEM,UAAA,cAAc,OAAO,YAAY,GAAG;AACpC,UAAAC,eAAaC,uCAA4B,GAAG;AAElD,UAAM,WAAW,YAAY;AAAA,MAC3BD;AAAAA,MACA,EAAE,KAAK,YAAY;AAAA,MACnB;AAAA,QACE,SAAS,CAAC,oBAAoB,mBAAmB;AAAA,MACnD;AAAA,IAAA;AAGW,iBAAA,IAAI,KAAK,QAAQ;AAEvB,WAAA;AAAA,EAAA;AAGF,SAAA,OAAO,OAAO,SAAS;AAAA,IAC5B,OAAO;AAAA,MAAA,eACLE,KAAA;AAAA,IACF;AAAA,IACA,KAAK,YAAY,IAAI,KAAK,WAAW;AAAA,EAAA,CACtC;AACH;;"}
@@ -1,18 +1,31 @@
1
- import { createMiddlewareManager } from "./middlewares.mjs";
1
+ import { databaseErrorsMiddleware } from "./middlewares/errors.mjs";
2
+ import { createMiddlewareManager } from "./middlewares/middleware-manager.mjs";
2
3
  import { createContentTypeRepository } from "./repository.mjs";
4
+ import { transformData } from "./transform/data.mjs";
3
5
  const createDocumentService = (strapi) => {
4
6
  const repositories = /* @__PURE__ */ new Map();
5
7
  const middlewares = createMiddlewareManager();
8
+ middlewares.use(databaseErrorsMiddleware);
6
9
  const factory = function factory2(uid) {
7
10
  if (repositories.has(uid)) {
8
11
  return repositories.get(uid);
9
12
  }
10
13
  const contentType = strapi.contentType(uid);
11
14
  const repository = createContentTypeRepository(uid);
12
- repositories.set(uid, middlewares.wrapObject(repository, { contentType }));
13
- return repository;
15
+ const instance = middlewares.wrapObject(
16
+ repository,
17
+ { uid, contentType },
18
+ {
19
+ exclude: ["updateComponents", "omitComponentData"]
20
+ }
21
+ );
22
+ repositories.set(uid, instance);
23
+ return instance;
14
24
  };
15
25
  return Object.assign(factory, {
26
+ utils: {
27
+ transformData
28
+ },
16
29
  use: middlewares.use.bind(middlewares)
17
30
  });
18
31
  };
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","sources":["../../../src/services/document-service/index.ts"],"sourcesContent":["import { Strapi, Documents } from '@strapi/types';\n\nimport { createMiddlewareManager } from './middlewares';\nimport { createContentTypeRepository } from './repository';\n\n/**\n * Repository to :\n * - Access documents via actions (findMany, findOne, create, update, delete, ...)\n * - Execute middlewares on document actions\n * - Apply default parameters to document actions\n *\n * @param strapi\n * @param options.defaults - Default parameters to apply to all actions\n * @param options.parent - Parent repository, used when creating a new repository with .with()\n * @returns DocumentService\n *\n * @example Access documents\n * const article = strapi.documents('api::article.article').create(params)\n * const allArticles = strapi.documents('api::article.article').findMany(params)\n *\n */\n// TODO: support global document service middleware & per repo middlewares\nexport const createDocumentService = (strapi: Strapi): Documents.Service => {\n const repositories = new Map<string, Documents.ServiceInstance>();\n const middlewares = createMiddlewareManager();\n\n const factory = function factory(uid) {\n if (repositories.has(uid)) {\n return repositories.get(uid)!;\n }\n\n const contentType = strapi.contentType(uid);\n const repository = createContentTypeRepository(uid);\n\n repositories.set(uid, middlewares.wrapObject(repository, { contentType }));\n\n return repository;\n } as Documents.Service;\n\n return Object.assign(factory, {\n use: middlewares.use.bind(middlewares),\n });\n};\n"],"names":["factory"],"mappings":";;AAsBa,MAAA,wBAAwB,CAAC,WAAsC;AACpE,QAAA,mCAAmB;AACzB,QAAM,cAAc;AAEd,QAAA,UAAU,SAASA,SAAQ,KAAK;AAChC,QAAA,aAAa,IAAI,GAAG,GAAG;AAClB,aAAA,aAAa,IAAI,GAAG;AAAA,IAC7B;AAEM,UAAA,cAAc,OAAO,YAAY,GAAG;AACpC,UAAA,aAAa,4BAA4B,GAAG;AAErC,iBAAA,IAAI,KAAK,YAAY,WAAW,YAAY,EAAE,YAAa,CAAA,CAAC;AAElE,WAAA;AAAA,EAAA;AAGF,SAAA,OAAO,OAAO,SAAS;AAAA,IAC5B,KAAK,YAAY,IAAI,KAAK,WAAW;AAAA,EAAA,CACtC;AACH;"}
1
+ {"version":3,"file":"index.mjs","sources":["../../../src/services/document-service/index.ts"],"sourcesContent":["import type { Core, Modules, UID } from '@strapi/types';\n\nimport { createMiddlewareManager, databaseErrorsMiddleware } from './middlewares';\nimport { createContentTypeRepository } from './repository';\nimport { transformData } from './transform/data';\n\n/**\n * Repository to :\n * - Access documents via actions (findMany, findOne, create, update, delete, ...)\n * - Execute middlewares on document actions\n * - Apply default parameters to document actions\n *\n * @param strapi\n * @returns DocumentService\n *\n * @example Access documents\n * const article = strapi.documents('api::article.article').create(params)\n * const allArticles = strapi.documents('api::article.article').findMany(params)\n *\n */\nexport const createDocumentService = (strapi: Core.Strapi): Modules.Documents.Service => {\n // Cache the repositories (one per content type)\n const repositories = new Map<string, Modules.Documents.ServiceInstance>();\n\n // Manager to handle document service middlewares\n const middlewares = createMiddlewareManager();\n middlewares.use(databaseErrorsMiddleware);\n\n const factory = function factory(uid: UID.ContentType) {\n if (repositories.has(uid)) {\n return repositories.get(uid)!;\n }\n\n const contentType = strapi.contentType(uid);\n const repository = createContentTypeRepository(uid);\n\n const instance = middlewares.wrapObject(\n repository,\n { uid, contentType },\n {\n exclude: ['updateComponents', 'omitComponentData'],\n }\n );\n\n repositories.set(uid, instance);\n\n return instance;\n } as Modules.Documents.Service;\n\n return Object.assign(factory, {\n utils: {\n transformData,\n },\n use: middlewares.use.bind(middlewares),\n });\n};\n"],"names":["factory"],"mappings":";;;;AAoBa,MAAA,wBAAwB,CAAC,WAAmD;AAEjF,QAAA,mCAAmB;AAGzB,QAAM,cAAc;AACpB,cAAY,IAAI,wBAAwB;AAElC,QAAA,UAAU,SAASA,SAAQ,KAAsB;AACjD,QAAA,aAAa,IAAI,GAAG,GAAG;AAClB,aAAA,aAAa,IAAI,GAAG;AAAA,IAC7B;AAEM,UAAA,cAAc,OAAO,YAAY,GAAG;AACpC,UAAA,aAAa,4BAA4B,GAAG;AAElD,UAAM,WAAW,YAAY;AAAA,MAC3B;AAAA,MACA,EAAE,KAAK,YAAY;AAAA,MACnB;AAAA,QACE,SAAS,CAAC,oBAAoB,mBAAmB;AAAA,MACnD;AAAA,IAAA;AAGW,iBAAA,IAAI,KAAK,QAAQ;AAEvB,WAAA;AAAA,EAAA;AAGF,SAAA,OAAO,OAAO,SAAS;AAAA,IAC5B,OAAO;AAAA,MACL;AAAA,IACF;AAAA,IACA,KAAK,YAAY,IAAI,KAAK,WAAW;AAAA,EAAA,CACtC;AACH;"}
@@ -1,8 +1,8 @@
1
1
  /// <reference types="lodash" />
2
- import type { Schema, Documents } from '@strapi/types';
3
- declare const defaultLocaleCurry: import("lodash").CurriedFunction2<Schema.SingleType | Schema.CollectionType, Documents.Params.All, Promise<Documents.Params.All>>;
4
- declare const localeToLookupCurry: import("lodash").CurriedFunction2<Schema.SingleType | Schema.CollectionType, Documents.Params.All, Documents.Params.All>;
5
- declare const multiLocaleToLookupCurry: import("lodash").CurriedFunction2<Schema.SingleType | Schema.CollectionType, Documents.Params.All, Documents.Params.All>;
6
- declare const localeToDataCurry: import("lodash").CurriedFunction2<Schema.SingleType | Schema.CollectionType, Documents.Params.All, Documents.Params.All>;
2
+ import type { Struct, Modules } from '@strapi/types';
3
+ declare const defaultLocaleCurry: import("lodash").CurriedFunction2<Struct.SingleTypeSchema | Struct.CollectionTypeSchema, Modules.Documents.Params.All, Promise<Modules.Documents.Params.All>>;
4
+ declare const localeToLookupCurry: import("lodash").CurriedFunction2<Struct.SingleTypeSchema | Struct.CollectionTypeSchema, Modules.Documents.Params.All, Modules.Documents.Params.All>;
5
+ declare const multiLocaleToLookupCurry: import("lodash").CurriedFunction2<Struct.SingleTypeSchema | Struct.CollectionTypeSchema, Modules.Documents.Params.All, Modules.Documents.Params.All>;
6
+ declare const localeToDataCurry: import("lodash").CurriedFunction2<Struct.SingleTypeSchema | Struct.CollectionTypeSchema, Modules.Documents.Params.All, Modules.Documents.Params.All>;
7
7
  export { defaultLocaleCurry as defaultLocale, localeToLookupCurry as localeToLookup, localeToDataCurry as localeToData, multiLocaleToLookupCurry as multiLocaleToLookup, };
8
8
  //# sourceMappingURL=internationalization.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"internationalization.d.ts","sourceRoot":"","sources":["../../../src/services/document-service/internationalization.ts"],"names":[],"mappings":";AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AA+EvD,QAAA,MAAM,kBAAkB,mIAAuB,CAAC;AAChD,QAAA,MAAM,mBAAmB,0HAAwB,CAAC;AAClD,QAAA,MAAM,wBAAwB,0HAA6B,CAAC;AAC5D,QAAA,MAAM,iBAAiB,0HAAsB,CAAC;AAE9C,OAAO,EACL,kBAAkB,IAAI,aAAa,EACnC,mBAAmB,IAAI,cAAc,EACrC,iBAAiB,IAAI,YAAY,EACjC,wBAAwB,IAAI,mBAAmB,GAChD,CAAC"}
1
+ {"version":3,"file":"internationalization.d.ts","sourceRoot":"","sources":["../../../src/services/document-service/internationalization.ts"],"names":[],"mappings":";AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AA8FrD,QAAA,MAAM,kBAAkB,+JAAuB,CAAC;AAChD,QAAA,MAAM,mBAAmB,sJAAwB,CAAC;AAClD,QAAA,MAAM,wBAAwB,sJAA6B,CAAC;AAC5D,QAAA,MAAM,iBAAiB,sJAAsB,CAAC;AAE9C,OAAO,EACL,kBAAkB,IAAI,aAAa,EACnC,mBAAmB,IAAI,cAAc,EACrC,iBAAiB,IAAI,YAAY,EACjC,wBAAwB,IAAI,mBAAmB,GAChD,CAAC"}
@@ -1,6 +1,7 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const _ = require("lodash/fp");
3
+ const strapiUtils = require("@strapi/utils");
4
+ const fp = require("lodash/fp");
4
5
  const getDefaultLocale = async () => {
5
6
  return strapi.plugin("i18n").service("locales").getDefaultLocale();
6
7
  };
@@ -9,18 +10,20 @@ const defaultLocale = async (contentType, params) => {
9
10
  return params;
10
11
  }
11
12
  if (!params.locale) {
12
- return _.assoc("locale", await getDefaultLocale(), params);
13
+ return fp.assoc("locale", await getDefaultLocale(), params);
13
14
  }
14
15
  return params;
15
16
  };
16
17
  const localeToLookup = (contentType, params) => {
17
- if (!strapi.plugin("i18n").service("content-types").isLocalizedContentType(contentType)) {
18
+ if (!params.locale || !strapi.plugin("i18n").service("content-types").isLocalizedContentType(contentType)) {
18
19
  return params;
19
20
  }
20
- if (params.locale) {
21
- return _.assoc(["lookup", "locale"], params.locale, params);
21
+ if (typeof params.locale !== "string") {
22
+ throw new strapiUtils.errors.ValidationError(
23
+ `Invalid locale param ${String(params.locale)} provided. Document locales must be strings.`
24
+ );
22
25
  }
23
- return params;
26
+ return fp.assoc(["lookup", "locale"], params.locale, params);
24
27
  };
25
28
  const multiLocaleToLookup = (contentType, params) => {
26
29
  if (!strapi.plugin("i18n").service("content-types").isLocalizedContentType(contentType)) {
@@ -30,7 +33,7 @@ const multiLocaleToLookup = (contentType, params) => {
30
33
  if (params.locale === "*") {
31
34
  return params;
32
35
  }
33
- return _.assoc(["lookup", "locale"], params.locale, params);
36
+ return fp.assoc(["lookup", "locale"], params.locale, params);
34
37
  }
35
38
  return params;
36
39
  };
@@ -39,14 +42,20 @@ const localeToData = (contentType, params) => {
39
42
  return params;
40
43
  }
41
44
  if (params.locale) {
42
- return _.assoc(["data", "locale"], params.locale, params);
45
+ const isValidLocale = typeof params.locale === "string" && params.locale !== "*";
46
+ if (isValidLocale) {
47
+ return fp.assoc(["data", "locale"], params.locale, params);
48
+ }
49
+ throw new strapiUtils.errors.ValidationError(
50
+ `Invalid locale param ${params.locale} provided. Document locales must be strings.`
51
+ );
43
52
  }
44
53
  return params;
45
54
  };
46
- const defaultLocaleCurry = _.curry(defaultLocale);
47
- const localeToLookupCurry = _.curry(localeToLookup);
48
- const multiLocaleToLookupCurry = _.curry(multiLocaleToLookup);
49
- const localeToDataCurry = _.curry(localeToData);
55
+ const defaultLocaleCurry = fp.curry(defaultLocale);
56
+ const localeToLookupCurry = fp.curry(localeToLookup);
57
+ const multiLocaleToLookupCurry = fp.curry(multiLocaleToLookup);
58
+ const localeToDataCurry = fp.curry(localeToData);
50
59
  exports.defaultLocale = defaultLocaleCurry;
51
60
  exports.localeToData = localeToDataCurry;
52
61
  exports.localeToLookup = localeToLookupCurry;
@@ -1 +1 @@
1
- {"version":3,"file":"internationalization.js","sources":["../../../src/services/document-service/internationalization.ts"],"sourcesContent":["import type { Schema, Documents } from '@strapi/types';\nimport { curry, assoc } from 'lodash/fp';\n\ntype Transform = (\n contentType: Schema.SingleType | Schema.CollectionType,\n params: Documents.Params.All\n) => Documents.Params.All;\n\ntype AsyncTransform = (\n contentType: Schema.SingleType | Schema.CollectionType,\n params: Documents.Params.All\n) => Promise<Documents.Params.All>;\n\nconst getDefaultLocale = async (): Promise<string> => {\n return strapi.plugin('i18n').service('locales').getDefaultLocale();\n};\n\nconst defaultLocale: AsyncTransform = async (contentType, params) => {\n if (!strapi.plugin('i18n').service('content-types').isLocalizedContentType(contentType)) {\n return params;\n }\n\n if (!params.locale) {\n // TODO: Load default locale from db in i18n\n return assoc('locale', await getDefaultLocale(), params);\n }\n\n return params;\n};\n\n/**\n * Add locale lookup query to the params\n */\nconst localeToLookup: Transform = (contentType, params) => {\n if (!strapi.plugin('i18n').service('content-types').isLocalizedContentType(contentType)) {\n return params;\n }\n\n if (params.locale) {\n return assoc(['lookup', 'locale'], params.locale, params);\n }\n\n return params;\n};\n\n/**\n * Add locale lookup query to the params\n */\nconst multiLocaleToLookup: Transform = (contentType, params) => {\n if (!strapi.plugin('i18n').service('content-types').isLocalizedContentType(contentType)) {\n return params;\n }\n\n if (params.locale) {\n if (params.locale === '*') {\n return params;\n }\n\n return assoc(['lookup', 'locale'], params.locale, params);\n }\n\n return params;\n};\n\n/**\n * Translate locale status parameter into the data that will be saved\n */\nconst localeToData: Transform = (contentType, params) => {\n if (!strapi.plugin('i18n').service('content-types').isLocalizedContentType(contentType)) {\n return params;\n }\n\n if (params.locale) {\n return assoc(['data', 'locale'], params.locale, params);\n }\n\n return params;\n};\n\nconst defaultLocaleCurry = curry(defaultLocale);\nconst localeToLookupCurry = curry(localeToLookup);\nconst multiLocaleToLookupCurry = curry(multiLocaleToLookup);\nconst localeToDataCurry = curry(localeToData);\n\nexport {\n defaultLocaleCurry as defaultLocale,\n localeToLookupCurry as localeToLookup,\n localeToDataCurry as localeToData,\n multiLocaleToLookupCurry as multiLocaleToLookup,\n};\n"],"names":["assoc","curry"],"mappings":";;;AAaA,MAAM,mBAAmB,YAA6B;AACpD,SAAO,OAAO,OAAO,MAAM,EAAE,QAAQ,SAAS,EAAE;AAClD;AAEA,MAAM,gBAAgC,OAAO,aAAa,WAAW;AAC/D,MAAA,CAAC,OAAO,OAAO,MAAM,EAAE,QAAQ,eAAe,EAAE,uBAAuB,WAAW,GAAG;AAChF,WAAA;AAAA,EACT;AAEI,MAAA,CAAC,OAAO,QAAQ;AAElB,WAAOA,EAAM,MAAA,UAAU,MAAM,oBAAoB,MAAM;AAAA,EACzD;AAEO,SAAA;AACT;AAKA,MAAM,iBAA4B,CAAC,aAAa,WAAW;AACrD,MAAA,CAAC,OAAO,OAAO,MAAM,EAAE,QAAQ,eAAe,EAAE,uBAAuB,WAAW,GAAG;AAChF,WAAA;AAAA,EACT;AAEA,MAAI,OAAO,QAAQ;AACjB,WAAOA,EAAAA,MAAM,CAAC,UAAU,QAAQ,GAAG,OAAO,QAAQ,MAAM;AAAA,EAC1D;AAEO,SAAA;AACT;AAKA,MAAM,sBAAiC,CAAC,aAAa,WAAW;AAC1D,MAAA,CAAC,OAAO,OAAO,MAAM,EAAE,QAAQ,eAAe,EAAE,uBAAuB,WAAW,GAAG;AAChF,WAAA;AAAA,EACT;AAEA,MAAI,OAAO,QAAQ;AACb,QAAA,OAAO,WAAW,KAAK;AAClB,aAAA;AAAA,IACT;AAEA,WAAOA,EAAAA,MAAM,CAAC,UAAU,QAAQ,GAAG,OAAO,QAAQ,MAAM;AAAA,EAC1D;AAEO,SAAA;AACT;AAKA,MAAM,eAA0B,CAAC,aAAa,WAAW;AACnD,MAAA,CAAC,OAAO,OAAO,MAAM,EAAE,QAAQ,eAAe,EAAE,uBAAuB,WAAW,GAAG;AAChF,WAAA;AAAA,EACT;AAEA,MAAI,OAAO,QAAQ;AACjB,WAAOA,EAAAA,MAAM,CAAC,QAAQ,QAAQ,GAAG,OAAO,QAAQ,MAAM;AAAA,EACxD;AAEO,SAAA;AACT;AAEM,MAAA,qBAAqBC,QAAM,aAAa;AACxC,MAAA,sBAAsBA,QAAM,cAAc;AAC1C,MAAA,2BAA2BA,QAAM,mBAAmB;AACpD,MAAA,oBAAoBA,QAAM,YAAY;;;;;"}
1
+ {"version":3,"file":"internationalization.js","sources":["../../../src/services/document-service/internationalization.ts"],"sourcesContent":["import type { Struct, Modules } from '@strapi/types';\nimport { errors } from '@strapi/utils';\nimport { curry, assoc } from 'lodash/fp';\n\ntype Transform = (\n contentType: Struct.SingleTypeSchema | Struct.CollectionTypeSchema,\n params: Modules.Documents.Params.All\n) => Modules.Documents.Params.All;\n\ntype AsyncTransform = (\n contentType: Struct.SingleTypeSchema | Struct.CollectionTypeSchema,\n params: Modules.Documents.Params.All\n) => Promise<Modules.Documents.Params.All>;\n\nconst getDefaultLocale = async (): Promise<string> => {\n return strapi.plugin('i18n').service('locales').getDefaultLocale();\n};\n\nconst defaultLocale: AsyncTransform = async (contentType, params) => {\n if (!strapi.plugin('i18n').service('content-types').isLocalizedContentType(contentType)) {\n return params;\n }\n\n if (!params.locale) {\n return assoc('locale', await getDefaultLocale(), params);\n }\n\n return params;\n};\n\n/**\n * Add locale lookup query to the params\n */\nconst localeToLookup: Transform = (contentType, params) => {\n if (\n !params.locale ||\n !strapi.plugin('i18n').service('content-types').isLocalizedContentType(contentType)\n ) {\n return params;\n }\n\n if (typeof params.locale !== 'string') {\n // localeToLookup accepts locales of '*'. This is because the document\n // service functions that use this transform work with the '*' locale\n // to return all locales.\n throw new errors.ValidationError(\n `Invalid locale param ${String(params.locale)} provided. Document locales must be strings.`\n );\n }\n\n return assoc(['lookup', 'locale'], params.locale, params);\n};\n\n/**\n * Add locale lookup query to the params\n */\nconst multiLocaleToLookup: Transform = (contentType, params) => {\n if (!strapi.plugin('i18n').service('content-types').isLocalizedContentType(contentType)) {\n return params;\n }\n\n if (params.locale) {\n if (params.locale === '*') {\n return params;\n }\n\n return assoc(['lookup', 'locale'], params.locale, params);\n }\n\n return params;\n};\n\n/**\n * Translate locale status parameter into the data that will be saved\n */\nconst localeToData: Transform = (contentType, params) => {\n if (!strapi.plugin('i18n').service('content-types').isLocalizedContentType(contentType)) {\n return params;\n }\n\n if (params.locale) {\n const isValidLocale = typeof params.locale === 'string' && params.locale !== '*';\n if (isValidLocale) {\n return assoc(['data', 'locale'], params.locale, params);\n }\n\n throw new errors.ValidationError(\n `Invalid locale param ${params.locale} provided. Document locales must be strings.`\n );\n }\n\n return params;\n};\n\nconst defaultLocaleCurry = curry(defaultLocale);\nconst localeToLookupCurry = curry(localeToLookup);\nconst multiLocaleToLookupCurry = curry(multiLocaleToLookup);\nconst localeToDataCurry = curry(localeToData);\n\nexport {\n defaultLocaleCurry as defaultLocale,\n localeToLookupCurry as localeToLookup,\n localeToDataCurry as localeToData,\n multiLocaleToLookupCurry as multiLocaleToLookup,\n};\n"],"names":["assoc","errors","curry"],"mappings":";;;;AAcA,MAAM,mBAAmB,YAA6B;AACpD,SAAO,OAAO,OAAO,MAAM,EAAE,QAAQ,SAAS,EAAE;AAClD;AAEA,MAAM,gBAAgC,OAAO,aAAa,WAAW;AAC/D,MAAA,CAAC,OAAO,OAAO,MAAM,EAAE,QAAQ,eAAe,EAAE,uBAAuB,WAAW,GAAG;AAChF,WAAA;AAAA,EACT;AAEI,MAAA,CAAC,OAAO,QAAQ;AAClB,WAAOA,GAAM,MAAA,UAAU,MAAM,oBAAoB,MAAM;AAAA,EACzD;AAEO,SAAA;AACT;AAKA,MAAM,iBAA4B,CAAC,aAAa,WAAW;AACzD,MACE,CAAC,OAAO,UACR,CAAC,OAAO,OAAO,MAAM,EAAE,QAAQ,eAAe,EAAE,uBAAuB,WAAW,GAClF;AACO,WAAA;AAAA,EACT;AAEI,MAAA,OAAO,OAAO,WAAW,UAAU;AAIrC,UAAM,IAAIC,YAAO,OAAA;AAAA,MACf,wBAAwB,OAAO,OAAO,MAAM,CAAC;AAAA,IAAA;AAAA,EAEjD;AAEA,SAAOD,GAAAA,MAAM,CAAC,UAAU,QAAQ,GAAG,OAAO,QAAQ,MAAM;AAC1D;AAKA,MAAM,sBAAiC,CAAC,aAAa,WAAW;AAC1D,MAAA,CAAC,OAAO,OAAO,MAAM,EAAE,QAAQ,eAAe,EAAE,uBAAuB,WAAW,GAAG;AAChF,WAAA;AAAA,EACT;AAEA,MAAI,OAAO,QAAQ;AACb,QAAA,OAAO,WAAW,KAAK;AAClB,aAAA;AAAA,IACT;AAEA,WAAOA,GAAAA,MAAM,CAAC,UAAU,QAAQ,GAAG,OAAO,QAAQ,MAAM;AAAA,EAC1D;AAEO,SAAA;AACT;AAKA,MAAM,eAA0B,CAAC,aAAa,WAAW;AACnD,MAAA,CAAC,OAAO,OAAO,MAAM,EAAE,QAAQ,eAAe,EAAE,uBAAuB,WAAW,GAAG;AAChF,WAAA;AAAA,EACT;AAEA,MAAI,OAAO,QAAQ;AACjB,UAAM,gBAAgB,OAAO,OAAO,WAAW,YAAY,OAAO,WAAW;AAC7E,QAAI,eAAe;AACjB,aAAOA,GAAAA,MAAM,CAAC,QAAQ,QAAQ,GAAG,OAAO,QAAQ,MAAM;AAAA,IACxD;AAEA,UAAM,IAAIC,YAAO,OAAA;AAAA,MACf,wBAAwB,OAAO,MAAM;AAAA,IAAA;AAAA,EAEzC;AAEO,SAAA;AACT;AAEM,MAAA,qBAAqBC,SAAM,aAAa;AACxC,MAAA,sBAAsBA,SAAM,cAAc;AAC1C,MAAA,2BAA2BA,SAAM,mBAAmB;AACpD,MAAA,oBAAoBA,SAAM,YAAY;;;;;"}
@@ -1,3 +1,4 @@
1
+ import { errors } from "@strapi/utils";
1
2
  import { curry, assoc } from "lodash/fp";
2
3
  const getDefaultLocale = async () => {
3
4
  return strapi.plugin("i18n").service("locales").getDefaultLocale();
@@ -12,13 +13,15 @@ const defaultLocale = async (contentType, params) => {
12
13
  return params;
13
14
  };
14
15
  const localeToLookup = (contentType, params) => {
15
- if (!strapi.plugin("i18n").service("content-types").isLocalizedContentType(contentType)) {
16
+ if (!params.locale || !strapi.plugin("i18n").service("content-types").isLocalizedContentType(contentType)) {
16
17
  return params;
17
18
  }
18
- if (params.locale) {
19
- return assoc(["lookup", "locale"], params.locale, params);
19
+ if (typeof params.locale !== "string") {
20
+ throw new errors.ValidationError(
21
+ `Invalid locale param ${String(params.locale)} provided. Document locales must be strings.`
22
+ );
20
23
  }
21
- return params;
24
+ return assoc(["lookup", "locale"], params.locale, params);
22
25
  };
23
26
  const multiLocaleToLookup = (contentType, params) => {
24
27
  if (!strapi.plugin("i18n").service("content-types").isLocalizedContentType(contentType)) {
@@ -37,7 +40,13 @@ const localeToData = (contentType, params) => {
37
40
  return params;
38
41
  }
39
42
  if (params.locale) {
40
- return assoc(["data", "locale"], params.locale, params);
43
+ const isValidLocale = typeof params.locale === "string" && params.locale !== "*";
44
+ if (isValidLocale) {
45
+ return assoc(["data", "locale"], params.locale, params);
46
+ }
47
+ throw new errors.ValidationError(
48
+ `Invalid locale param ${params.locale} provided. Document locales must be strings.`
49
+ );
41
50
  }
42
51
  return params;
43
52
  };
@@ -1 +1 @@
1
- {"version":3,"file":"internationalization.mjs","sources":["../../../src/services/document-service/internationalization.ts"],"sourcesContent":["import type { Schema, Documents } from '@strapi/types';\nimport { curry, assoc } from 'lodash/fp';\n\ntype Transform = (\n contentType: Schema.SingleType | Schema.CollectionType,\n params: Documents.Params.All\n) => Documents.Params.All;\n\ntype AsyncTransform = (\n contentType: Schema.SingleType | Schema.CollectionType,\n params: Documents.Params.All\n) => Promise<Documents.Params.All>;\n\nconst getDefaultLocale = async (): Promise<string> => {\n return strapi.plugin('i18n').service('locales').getDefaultLocale();\n};\n\nconst defaultLocale: AsyncTransform = async (contentType, params) => {\n if (!strapi.plugin('i18n').service('content-types').isLocalizedContentType(contentType)) {\n return params;\n }\n\n if (!params.locale) {\n // TODO: Load default locale from db in i18n\n return assoc('locale', await getDefaultLocale(), params);\n }\n\n return params;\n};\n\n/**\n * Add locale lookup query to the params\n */\nconst localeToLookup: Transform = (contentType, params) => {\n if (!strapi.plugin('i18n').service('content-types').isLocalizedContentType(contentType)) {\n return params;\n }\n\n if (params.locale) {\n return assoc(['lookup', 'locale'], params.locale, params);\n }\n\n return params;\n};\n\n/**\n * Add locale lookup query to the params\n */\nconst multiLocaleToLookup: Transform = (contentType, params) => {\n if (!strapi.plugin('i18n').service('content-types').isLocalizedContentType(contentType)) {\n return params;\n }\n\n if (params.locale) {\n if (params.locale === '*') {\n return params;\n }\n\n return assoc(['lookup', 'locale'], params.locale, params);\n }\n\n return params;\n};\n\n/**\n * Translate locale status parameter into the data that will be saved\n */\nconst localeToData: Transform = (contentType, params) => {\n if (!strapi.plugin('i18n').service('content-types').isLocalizedContentType(contentType)) {\n return params;\n }\n\n if (params.locale) {\n return assoc(['data', 'locale'], params.locale, params);\n }\n\n return params;\n};\n\nconst defaultLocaleCurry = curry(defaultLocale);\nconst localeToLookupCurry = curry(localeToLookup);\nconst multiLocaleToLookupCurry = curry(multiLocaleToLookup);\nconst localeToDataCurry = curry(localeToData);\n\nexport {\n defaultLocaleCurry as defaultLocale,\n localeToLookupCurry as localeToLookup,\n localeToDataCurry as localeToData,\n multiLocaleToLookupCurry as multiLocaleToLookup,\n};\n"],"names":[],"mappings":";AAaA,MAAM,mBAAmB,YAA6B;AACpD,SAAO,OAAO,OAAO,MAAM,EAAE,QAAQ,SAAS,EAAE;AAClD;AAEA,MAAM,gBAAgC,OAAO,aAAa,WAAW;AAC/D,MAAA,CAAC,OAAO,OAAO,MAAM,EAAE,QAAQ,eAAe,EAAE,uBAAuB,WAAW,GAAG;AAChF,WAAA;AAAA,EACT;AAEI,MAAA,CAAC,OAAO,QAAQ;AAElB,WAAO,MAAM,UAAU,MAAM,oBAAoB,MAAM;AAAA,EACzD;AAEO,SAAA;AACT;AAKA,MAAM,iBAA4B,CAAC,aAAa,WAAW;AACrD,MAAA,CAAC,OAAO,OAAO,MAAM,EAAE,QAAQ,eAAe,EAAE,uBAAuB,WAAW,GAAG;AAChF,WAAA;AAAA,EACT;AAEA,MAAI,OAAO,QAAQ;AACjB,WAAO,MAAM,CAAC,UAAU,QAAQ,GAAG,OAAO,QAAQ,MAAM;AAAA,EAC1D;AAEO,SAAA;AACT;AAKA,MAAM,sBAAiC,CAAC,aAAa,WAAW;AAC1D,MAAA,CAAC,OAAO,OAAO,MAAM,EAAE,QAAQ,eAAe,EAAE,uBAAuB,WAAW,GAAG;AAChF,WAAA;AAAA,EACT;AAEA,MAAI,OAAO,QAAQ;AACb,QAAA,OAAO,WAAW,KAAK;AAClB,aAAA;AAAA,IACT;AAEA,WAAO,MAAM,CAAC,UAAU,QAAQ,GAAG,OAAO,QAAQ,MAAM;AAAA,EAC1D;AAEO,SAAA;AACT;AAKA,MAAM,eAA0B,CAAC,aAAa,WAAW;AACnD,MAAA,CAAC,OAAO,OAAO,MAAM,EAAE,QAAQ,eAAe,EAAE,uBAAuB,WAAW,GAAG;AAChF,WAAA;AAAA,EACT;AAEA,MAAI,OAAO,QAAQ;AACjB,WAAO,MAAM,CAAC,QAAQ,QAAQ,GAAG,OAAO,QAAQ,MAAM;AAAA,EACxD;AAEO,SAAA;AACT;AAEM,MAAA,qBAAqB,MAAM,aAAa;AACxC,MAAA,sBAAsB,MAAM,cAAc;AAC1C,MAAA,2BAA2B,MAAM,mBAAmB;AACpD,MAAA,oBAAoB,MAAM,YAAY;"}
1
+ {"version":3,"file":"internationalization.mjs","sources":["../../../src/services/document-service/internationalization.ts"],"sourcesContent":["import type { Struct, Modules } from '@strapi/types';\nimport { errors } from '@strapi/utils';\nimport { curry, assoc } from 'lodash/fp';\n\ntype Transform = (\n contentType: Struct.SingleTypeSchema | Struct.CollectionTypeSchema,\n params: Modules.Documents.Params.All\n) => Modules.Documents.Params.All;\n\ntype AsyncTransform = (\n contentType: Struct.SingleTypeSchema | Struct.CollectionTypeSchema,\n params: Modules.Documents.Params.All\n) => Promise<Modules.Documents.Params.All>;\n\nconst getDefaultLocale = async (): Promise<string> => {\n return strapi.plugin('i18n').service('locales').getDefaultLocale();\n};\n\nconst defaultLocale: AsyncTransform = async (contentType, params) => {\n if (!strapi.plugin('i18n').service('content-types').isLocalizedContentType(contentType)) {\n return params;\n }\n\n if (!params.locale) {\n return assoc('locale', await getDefaultLocale(), params);\n }\n\n return params;\n};\n\n/**\n * Add locale lookup query to the params\n */\nconst localeToLookup: Transform = (contentType, params) => {\n if (\n !params.locale ||\n !strapi.plugin('i18n').service('content-types').isLocalizedContentType(contentType)\n ) {\n return params;\n }\n\n if (typeof params.locale !== 'string') {\n // localeToLookup accepts locales of '*'. This is because the document\n // service functions that use this transform work with the '*' locale\n // to return all locales.\n throw new errors.ValidationError(\n `Invalid locale param ${String(params.locale)} provided. Document locales must be strings.`\n );\n }\n\n return assoc(['lookup', 'locale'], params.locale, params);\n};\n\n/**\n * Add locale lookup query to the params\n */\nconst multiLocaleToLookup: Transform = (contentType, params) => {\n if (!strapi.plugin('i18n').service('content-types').isLocalizedContentType(contentType)) {\n return params;\n }\n\n if (params.locale) {\n if (params.locale === '*') {\n return params;\n }\n\n return assoc(['lookup', 'locale'], params.locale, params);\n }\n\n return params;\n};\n\n/**\n * Translate locale status parameter into the data that will be saved\n */\nconst localeToData: Transform = (contentType, params) => {\n if (!strapi.plugin('i18n').service('content-types').isLocalizedContentType(contentType)) {\n return params;\n }\n\n if (params.locale) {\n const isValidLocale = typeof params.locale === 'string' && params.locale !== '*';\n if (isValidLocale) {\n return assoc(['data', 'locale'], params.locale, params);\n }\n\n throw new errors.ValidationError(\n `Invalid locale param ${params.locale} provided. Document locales must be strings.`\n );\n }\n\n return params;\n};\n\nconst defaultLocaleCurry = curry(defaultLocale);\nconst localeToLookupCurry = curry(localeToLookup);\nconst multiLocaleToLookupCurry = curry(multiLocaleToLookup);\nconst localeToDataCurry = curry(localeToData);\n\nexport {\n defaultLocaleCurry as defaultLocale,\n localeToLookupCurry as localeToLookup,\n localeToDataCurry as localeToData,\n multiLocaleToLookupCurry as multiLocaleToLookup,\n};\n"],"names":[],"mappings":";;AAcA,MAAM,mBAAmB,YAA6B;AACpD,SAAO,OAAO,OAAO,MAAM,EAAE,QAAQ,SAAS,EAAE;AAClD;AAEA,MAAM,gBAAgC,OAAO,aAAa,WAAW;AAC/D,MAAA,CAAC,OAAO,OAAO,MAAM,EAAE,QAAQ,eAAe,EAAE,uBAAuB,WAAW,GAAG;AAChF,WAAA;AAAA,EACT;AAEI,MAAA,CAAC,OAAO,QAAQ;AAClB,WAAO,MAAM,UAAU,MAAM,oBAAoB,MAAM;AAAA,EACzD;AAEO,SAAA;AACT;AAKA,MAAM,iBAA4B,CAAC,aAAa,WAAW;AACzD,MACE,CAAC,OAAO,UACR,CAAC,OAAO,OAAO,MAAM,EAAE,QAAQ,eAAe,EAAE,uBAAuB,WAAW,GAClF;AACO,WAAA;AAAA,EACT;AAEI,MAAA,OAAO,OAAO,WAAW,UAAU;AAIrC,UAAM,IAAI,OAAO;AAAA,MACf,wBAAwB,OAAO,OAAO,MAAM,CAAC;AAAA,IAAA;AAAA,EAEjD;AAEA,SAAO,MAAM,CAAC,UAAU,QAAQ,GAAG,OAAO,QAAQ,MAAM;AAC1D;AAKA,MAAM,sBAAiC,CAAC,aAAa,WAAW;AAC1D,MAAA,CAAC,OAAO,OAAO,MAAM,EAAE,QAAQ,eAAe,EAAE,uBAAuB,WAAW,GAAG;AAChF,WAAA;AAAA,EACT;AAEA,MAAI,OAAO,QAAQ;AACb,QAAA,OAAO,WAAW,KAAK;AAClB,aAAA;AAAA,IACT;AAEA,WAAO,MAAM,CAAC,UAAU,QAAQ,GAAG,OAAO,QAAQ,MAAM;AAAA,EAC1D;AAEO,SAAA;AACT;AAKA,MAAM,eAA0B,CAAC,aAAa,WAAW;AACnD,MAAA,CAAC,OAAO,OAAO,MAAM,EAAE,QAAQ,eAAe,EAAE,uBAAuB,WAAW,GAAG;AAChF,WAAA;AAAA,EACT;AAEA,MAAI,OAAO,QAAQ;AACjB,UAAM,gBAAgB,OAAO,OAAO,WAAW,YAAY,OAAO,WAAW;AAC7E,QAAI,eAAe;AACjB,aAAO,MAAM,CAAC,QAAQ,QAAQ,GAAG,OAAO,QAAQ,MAAM;AAAA,IACxD;AAEA,UAAM,IAAI,OAAO;AAAA,MACf,wBAAwB,OAAO,MAAM;AAAA,IAAA;AAAA,EAEzC;AAEO,SAAA;AACT;AAEM,MAAA,qBAAqB,MAAM,aAAa;AACxC,MAAA,sBAAsB,MAAM,cAAc;AAC1C,MAAA,2BAA2B,MAAM,mBAAmB;AACpD,MAAA,oBAAoB,MAAM,YAAY;"}
@@ -0,0 +1,6 @@
1
+ import type { Middleware } from './middleware-manager';
2
+ /**
3
+ * Handle database errors
4
+ */
5
+ export declare const databaseErrorsMiddleware: Middleware;
6
+ //# sourceMappingURL=errors.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../../../../src/services/document-service/middlewares/errors.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AASvD;;GAEG;AACH,eAAO,MAAM,wBAAwB,EAAE,UAatC,CAAC"}
@@ -0,0 +1,25 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const database = require("@strapi/database");
4
+ const strapiUtils = require("@strapi/utils");
5
+ const databaseErrorsToTransform = [
6
+ database.errors.InvalidTimeError,
7
+ database.errors.InvalidDateTimeError,
8
+ database.errors.InvalidDateError,
9
+ database.errors.InvalidRelationError
10
+ ];
11
+ const databaseErrorsMiddleware = async (ctx, next) => {
12
+ try {
13
+ return await next();
14
+ } catch (error) {
15
+ if (databaseErrorsToTransform.some((errorToTransform) => error instanceof errorToTransform)) {
16
+ if (error instanceof Error) {
17
+ throw new strapiUtils.errors.ValidationError(error.message);
18
+ }
19
+ throw error;
20
+ }
21
+ throw error;
22
+ }
23
+ };
24
+ exports.databaseErrorsMiddleware = databaseErrorsMiddleware;
25
+ //# sourceMappingURL=errors.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"errors.js","sources":["../../../../src/services/document-service/middlewares/errors.ts"],"sourcesContent":["import { errors as databaseErrors } from '@strapi/database';\nimport { errors } from '@strapi/utils';\n\nimport type { Middleware } from './middleware-manager';\n\nconst databaseErrorsToTransform = [\n databaseErrors.InvalidTimeError,\n databaseErrors.InvalidDateTimeError,\n databaseErrors.InvalidDateError,\n databaseErrors.InvalidRelationError,\n];\n\n/**\n * Handle database errors\n */\nexport const databaseErrorsMiddleware: Middleware = async (ctx, next) => {\n try {\n return await next();\n } catch (error) {\n if (databaseErrorsToTransform.some((errorToTransform) => error instanceof errorToTransform)) {\n if (error instanceof Error) {\n throw new errors.ValidationError(error.message);\n }\n\n throw error;\n }\n throw error;\n }\n};\n"],"names":["databaseErrors","errors"],"mappings":";;;;AAKA,MAAM,4BAA4B;AAAA,EAChCA,SAAAA,OAAe;AAAA,EACfA,SAAAA,OAAe;AAAA,EACfA,SAAAA,OAAe;AAAA,EACfA,SAAAA,OAAe;AACjB;AAKa,MAAA,2BAAuC,OAAO,KAAK,SAAS;AACnE,MAAA;AACF,WAAO,MAAM,KAAK;AAAA,WACX,OAAO;AACd,QAAI,0BAA0B,KAAK,CAAC,qBAAqB,iBAAiB,gBAAgB,GAAG;AAC3F,UAAI,iBAAiB,OAAO;AAC1B,cAAM,IAAIC,YAAAA,OAAO,gBAAgB,MAAM,OAAO;AAAA,MAChD;AAEM,YAAA;AAAA,IACR;AACM,UAAA;AAAA,EACR;AACF;;"}
@@ -0,0 +1,25 @@
1
+ import { errors } from "@strapi/database";
2
+ import { errors as errors$1 } from "@strapi/utils";
3
+ const databaseErrorsToTransform = [
4
+ errors.InvalidTimeError,
5
+ errors.InvalidDateTimeError,
6
+ errors.InvalidDateError,
7
+ errors.InvalidRelationError
8
+ ];
9
+ const databaseErrorsMiddleware = async (ctx, next) => {
10
+ try {
11
+ return await next();
12
+ } catch (error) {
13
+ if (databaseErrorsToTransform.some((errorToTransform) => error instanceof errorToTransform)) {
14
+ if (error instanceof Error) {
15
+ throw new errors$1.ValidationError(error.message);
16
+ }
17
+ throw error;
18
+ }
19
+ throw error;
20
+ }
21
+ };
22
+ export {
23
+ databaseErrorsMiddleware
24
+ };
25
+ //# sourceMappingURL=errors.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"errors.mjs","sources":["../../../../src/services/document-service/middlewares/errors.ts"],"sourcesContent":["import { errors as databaseErrors } from '@strapi/database';\nimport { errors } from '@strapi/utils';\n\nimport type { Middleware } from './middleware-manager';\n\nconst databaseErrorsToTransform = [\n databaseErrors.InvalidTimeError,\n databaseErrors.InvalidDateTimeError,\n databaseErrors.InvalidDateError,\n databaseErrors.InvalidRelationError,\n];\n\n/**\n * Handle database errors\n */\nexport const databaseErrorsMiddleware: Middleware = async (ctx, next) => {\n try {\n return await next();\n } catch (error) {\n if (databaseErrorsToTransform.some((errorToTransform) => error instanceof errorToTransform)) {\n if (error instanceof Error) {\n throw new errors.ValidationError(error.message);\n }\n\n throw error;\n }\n throw error;\n }\n};\n"],"names":["databaseErrors","errors"],"mappings":";;AAKA,MAAM,4BAA4B;AAAA,EAChCA,OAAe;AAAA,EACfA,OAAe;AAAA,EACfA,OAAe;AAAA,EACfA,OAAe;AACjB;AAKa,MAAA,2BAAuC,OAAO,KAAK,SAAS;AACnE,MAAA;AACF,WAAO,MAAM,KAAK;AAAA,WACX,OAAO;AACd,QAAI,0BAA0B,KAAK,CAAC,qBAAqB,iBAAiB,gBAAgB,GAAG;AAC3F,UAAI,iBAAiB,OAAO;AAC1B,cAAM,IAAIC,SAAO,gBAAgB,MAAM,OAAO;AAAA,MAChD;AAEM,YAAA;AAAA,IACR;AACM,UAAA;AAAA,EACR;AACF;"}
@@ -0,0 +1,3 @@
1
+ export { databaseErrorsMiddleware } from './errors';
2
+ export { createMiddlewareManager } from './middleware-manager';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/services/document-service/middlewares/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,wBAAwB,EAAE,MAAM,UAAU,CAAC;AACpD,OAAO,EAAE,uBAAuB,EAAE,MAAM,sBAAsB,CAAC"}
@@ -0,0 +1,10 @@
1
+ export type Middleware = (ctx: any, next: () => Promise<void>) => Promise<void> | void;
2
+ export type Options = {
3
+ exclude?: string[];
4
+ };
5
+ export declare const createMiddlewareManager: () => {
6
+ use(middleware: Middleware): () => Middleware[];
7
+ run(ctx: any, cb: () => void): Promise<void>;
8
+ wrapObject<TSource>(source: TSource, ctxDefaults?: {}, opts?: Options): TSource;
9
+ };
10
+ //# sourceMappingURL=middleware-manager.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"middleware-manager.d.ts","sourceRoot":"","sources":["../../../../src/services/document-service/middlewares/middleware-manager.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,UAAU,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,KAAK,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;AAEvF,MAAM,MAAM,OAAO,GAAG;IACpB,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;CACpB,CAAC;AAEF,eAAO,MAAM,uBAAuB;oBAIhB,UAAU;aAMX,GAAG,MAAM,MAAM,IAAI;gCAcN,OAAO,2BAA0B,OAAO,GAAQ,OAAO;CAiCtF,CAAC"}
@@ -17,19 +17,22 @@ const createMiddlewareManager = () => {
17
17
  };
18
18
  return next();
19
19
  },
20
- wrapObject(source, ctxDefaults = {}) {
20
+ wrapObject(source, ctxDefaults = {}, opts = {}) {
21
21
  const facade = {};
22
+ const { exclude = [] } = opts;
22
23
  for (const key in source) {
23
24
  if (Object.hasOwnProperty.call(source, key)) {
24
25
  const prop = source[key];
25
- if (typeof prop === "function") {
26
- const newMethod = async (...args) => {
26
+ if (exclude.includes(key)) {
27
+ facade[key] = prop;
28
+ } else if (typeof prop === "function") {
29
+ const newMethod = async (params = {}) => {
27
30
  const ctx = {
28
31
  ...ctxDefaults,
29
32
  action: key,
30
- args
33
+ params
31
34
  };
32
- return manager.run(ctx, () => prop(...ctx.args));
35
+ return manager.run(ctx, () => prop(ctx.params));
33
36
  };
34
37
  facade[key] = newMethod;
35
38
  } else {
@@ -43,4 +46,4 @@ const createMiddlewareManager = () => {
43
46
  return manager;
44
47
  };
45
48
  exports.createMiddlewareManager = createMiddlewareManager;
46
- //# sourceMappingURL=middlewares.js.map
49
+ //# sourceMappingURL=middleware-manager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"middleware-manager.js","sources":["../../../../src/services/document-service/middlewares/middleware-manager.ts"],"sourcesContent":["export type Middleware = (ctx: any, next: () => Promise<void>) => Promise<void> | void;\n\nexport type Options = {\n exclude?: string[];\n};\n\nexport const createMiddlewareManager = () => {\n const middlewares: Middleware[] = [];\n\n const manager = {\n use(middleware: Middleware) {\n middlewares.push(middleware);\n\n return () => middlewares.splice(middlewares.indexOf(middleware), 1);\n },\n\n async run(ctx: any, cb: () => void) {\n let index = 0;\n const next = async () => {\n if (index < middlewares.length) {\n // eslint-disable-next-line no-plusplus\n return middlewares[index++](ctx, next);\n }\n\n return cb();\n };\n\n return next();\n },\n\n wrapObject<TSource>(source: TSource, ctxDefaults = {}, opts: Options = {}): TSource {\n const facade: TSource = {} as TSource;\n const { exclude = [] } = opts;\n\n for (const key in source) {\n if (Object.hasOwnProperty.call(source, key)) {\n const prop = source[key];\n\n if (exclude.includes(key)) {\n facade[key] = prop;\n } else if (typeof prop === 'function') {\n const newMethod = async (params: any = {}) => {\n const ctx = {\n ...ctxDefaults,\n action: key,\n params,\n };\n\n return manager.run(ctx, () => prop(ctx.params));\n };\n\n facade[key] = newMethod as typeof prop;\n } else {\n facade[key] = prop;\n }\n }\n }\n\n return facade;\n },\n };\n\n return manager;\n};\n"],"names":[],"mappings":";;AAMO,MAAM,0BAA0B,MAAM;AAC3C,QAAM,cAA4B,CAAA;AAElC,QAAM,UAAU;AAAA,IACd,IAAI,YAAwB;AAC1B,kBAAY,KAAK,UAAU;AAE3B,aAAO,MAAM,YAAY,OAAO,YAAY,QAAQ,UAAU,GAAG,CAAC;AAAA,IACpE;AAAA,IAEA,MAAM,IAAI,KAAU,IAAgB;AAClC,UAAI,QAAQ;AACZ,YAAM,OAAO,YAAY;AACnB,YAAA,QAAQ,YAAY,QAAQ;AAE9B,iBAAO,YAAY,OAAO,EAAE,KAAK,IAAI;AAAA,QACvC;AAEA,eAAO,GAAG;AAAA,MAAA;AAGZ,aAAO,KAAK;AAAA,IACd;AAAA,IAEA,WAAoB,QAAiB,cAAc,CAAA,GAAI,OAAgB,CAAA,GAAa;AAClF,YAAM,SAAkB,CAAA;AACxB,YAAM,EAAE,UAAU,GAAO,IAAA;AAEzB,iBAAW,OAAO,QAAQ;AACxB,YAAI,OAAO,eAAe,KAAK,QAAQ,GAAG,GAAG;AACrC,gBAAA,OAAO,OAAO,GAAG;AAEnB,cAAA,QAAQ,SAAS,GAAG,GAAG;AACzB,mBAAO,GAAG,IAAI;AAAA,UAAA,WACL,OAAO,SAAS,YAAY;AACrC,kBAAM,YAAY,OAAO,SAAc,OAAO;AAC5C,oBAAM,MAAM;AAAA,gBACV,GAAG;AAAA,gBACH,QAAQ;AAAA,gBACR;AAAA,cAAA;AAGF,qBAAO,QAAQ,IAAI,KAAK,MAAM,KAAK,IAAI,MAAM,CAAC;AAAA,YAAA;AAGhD,mBAAO,GAAG,IAAI;AAAA,UAAA,OACT;AACL,mBAAO,GAAG,IAAI;AAAA,UAChB;AAAA,QACF;AAAA,MACF;AAEO,aAAA;AAAA,IACT;AAAA,EAAA;AAGK,SAAA;AACT;;"}
@@ -15,19 +15,22 @@ const createMiddlewareManager = () => {
15
15
  };
16
16
  return next();
17
17
  },
18
- wrapObject(source, ctxDefaults = {}) {
18
+ wrapObject(source, ctxDefaults = {}, opts = {}) {
19
19
  const facade = {};
20
+ const { exclude = [] } = opts;
20
21
  for (const key in source) {
21
22
  if (Object.hasOwnProperty.call(source, key)) {
22
23
  const prop = source[key];
23
- if (typeof prop === "function") {
24
- const newMethod = async (...args) => {
24
+ if (exclude.includes(key)) {
25
+ facade[key] = prop;
26
+ } else if (typeof prop === "function") {
27
+ const newMethod = async (params = {}) => {
25
28
  const ctx = {
26
29
  ...ctxDefaults,
27
30
  action: key,
28
- args
31
+ params
29
32
  };
30
- return manager.run(ctx, () => prop(...ctx.args));
33
+ return manager.run(ctx, () => prop(ctx.params));
31
34
  };
32
35
  facade[key] = newMethod;
33
36
  } else {
@@ -43,4 +46,4 @@ const createMiddlewareManager = () => {
43
46
  export {
44
47
  createMiddlewareManager
45
48
  };
46
- //# sourceMappingURL=middlewares.mjs.map
49
+ //# sourceMappingURL=middleware-manager.mjs.map