@strapi/core 5.0.0-beta.0 → 5.0.0-beta.10

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 (707) hide show
  1. package/dist/Strapi.d.ts +46 -57
  2. package/dist/Strapi.d.ts.map +1 -1
  3. package/dist/Strapi.js +145 -220
  4. package/dist/Strapi.js.map +1 -1
  5. package/dist/Strapi.mjs +135 -211
  6. package/dist/Strapi.mjs.map +1 -1
  7. package/dist/configuration/config-loader.d.ts.map +1 -1
  8. package/dist/configuration/config-loader.js +9 -5
  9. package/dist/configuration/config-loader.js.map +1 -1
  10. package/dist/configuration/config-loader.mjs +9 -5
  11. package/dist/configuration/config-loader.mjs.map +1 -1
  12. package/dist/configuration/get-dirs.d.ts +10 -0
  13. package/dist/configuration/get-dirs.d.ts.map +1 -0
  14. package/dist/{utils → configuration}/get-dirs.js +3 -2
  15. package/dist/configuration/get-dirs.js.map +1 -0
  16. package/dist/{utils → configuration}/get-dirs.mjs +3 -2
  17. package/dist/configuration/get-dirs.mjs.map +1 -0
  18. package/dist/configuration/index.d.ts +4 -7
  19. package/dist/configuration/index.d.ts.map +1 -1
  20. package/dist/configuration/index.js +6 -4
  21. package/dist/configuration/index.js.map +1 -1
  22. package/dist/configuration/index.mjs +5 -4
  23. package/dist/configuration/index.mjs.map +1 -1
  24. package/dist/container.d.ts +2 -2
  25. package/dist/container.d.ts.map +1 -1
  26. package/dist/container.js.map +1 -1
  27. package/dist/container.mjs.map +1 -1
  28. package/dist/core-api/controller/collection-type.d.ts +3 -3
  29. package/dist/core-api/controller/collection-type.d.ts.map +1 -1
  30. package/dist/core-api/controller/collection-type.js +3 -0
  31. package/dist/core-api/controller/collection-type.js.map +1 -1
  32. package/dist/core-api/controller/collection-type.mjs +3 -0
  33. package/dist/core-api/controller/collection-type.mjs.map +1 -1
  34. package/dist/core-api/controller/index.d.ts +3 -3
  35. package/dist/core-api/controller/index.d.ts.map +1 -1
  36. package/dist/core-api/controller/index.js +5 -5
  37. package/dist/core-api/controller/index.js.map +1 -1
  38. package/dist/core-api/controller/index.mjs +6 -6
  39. package/dist/core-api/controller/index.mjs.map +1 -1
  40. package/dist/core-api/controller/single-type.d.ts +3 -3
  41. package/dist/core-api/controller/single-type.d.ts.map +1 -1
  42. package/dist/core-api/controller/single-type.js +1 -0
  43. package/dist/core-api/controller/single-type.js.map +1 -1
  44. package/dist/core-api/controller/single-type.mjs +1 -0
  45. package/dist/core-api/controller/single-type.mjs.map +1 -1
  46. package/dist/core-api/controller/transform.d.ts +2 -2
  47. package/dist/core-api/controller/transform.d.ts.map +1 -1
  48. package/dist/core-api/controller/transform.js +2 -5
  49. package/dist/core-api/controller/transform.js.map +1 -1
  50. package/dist/core-api/controller/transform.mjs +2 -5
  51. package/dist/core-api/controller/transform.mjs.map +1 -1
  52. package/dist/core-api/routes/index.d.ts.map +1 -1
  53. package/dist/core-api/service/collection-type.d.ts +11 -17
  54. package/dist/core-api/service/collection-type.d.ts.map +1 -1
  55. package/dist/core-api/service/collection-type.js +18 -7
  56. package/dist/core-api/service/collection-type.js.map +1 -1
  57. package/dist/core-api/service/collection-type.mjs +19 -8
  58. package/dist/core-api/service/collection-type.mjs.map +1 -1
  59. package/dist/core-api/service/index.d.ts +3 -3
  60. package/dist/core-api/service/index.d.ts.map +1 -1
  61. package/dist/core-api/service/index.js.map +1 -1
  62. package/dist/core-api/service/index.mjs.map +1 -1
  63. package/dist/core-api/service/pagination.d.ts +4 -11
  64. package/dist/core-api/service/pagination.d.ts.map +1 -1
  65. package/dist/core-api/service/pagination.js +14 -40
  66. package/dist/core-api/service/pagination.js.map +1 -1
  67. package/dist/core-api/service/pagination.mjs +16 -42
  68. package/dist/core-api/service/pagination.mjs.map +1 -1
  69. package/dist/core-api/service/single-type.d.ts +4 -4
  70. package/dist/core-api/service/single-type.d.ts.map +1 -1
  71. package/dist/core-api/service/single-type.js +9 -2
  72. package/dist/core-api/service/single-type.js.map +1 -1
  73. package/dist/core-api/service/single-type.mjs +9 -2
  74. package/dist/core-api/service/single-type.mjs.map +1 -1
  75. package/dist/domain/content-type/index.d.ts +1 -1
  76. package/dist/domain/content-type/index.d.ts.map +1 -1
  77. package/dist/domain/module/index.d.ts +24 -23
  78. package/dist/domain/module/index.d.ts.map +1 -1
  79. package/dist/domain/module/index.js +2 -1
  80. package/dist/domain/module/index.js.map +1 -1
  81. package/dist/domain/module/index.mjs +3 -2
  82. package/dist/domain/module/index.mjs.map +1 -1
  83. package/dist/ee/index.d.ts +4 -2
  84. package/dist/ee/index.d.ts.map +1 -1
  85. package/dist/ee/index.js.map +1 -1
  86. package/dist/ee/index.mjs.map +1 -1
  87. package/dist/ee/license.d.ts +2 -2
  88. package/dist/ee/license.d.ts.map +1 -1
  89. package/dist/ee/license.js +2 -1
  90. package/dist/ee/license.js.map +1 -1
  91. package/dist/ee/license.mjs +2 -1
  92. package/dist/ee/license.mjs.map +1 -1
  93. package/dist/factories.d.ts +10 -10
  94. package/dist/factories.d.ts.map +1 -1
  95. package/dist/factories.js +6 -2
  96. package/dist/factories.js.map +1 -1
  97. package/dist/factories.mjs +6 -2
  98. package/dist/factories.mjs.map +1 -1
  99. package/dist/index.d.ts +4 -2
  100. package/dist/index.d.ts.map +1 -1
  101. package/dist/index.js +25 -1
  102. package/dist/index.js.map +1 -1
  103. package/dist/index.mjs +27 -3
  104. package/dist/index.mjs.map +1 -1
  105. package/dist/loaders/admin.d.ts +2 -2
  106. package/dist/loaders/admin.d.ts.map +1 -1
  107. package/dist/loaders/admin.js +0 -1
  108. package/dist/loaders/admin.js.map +1 -1
  109. package/dist/loaders/admin.mjs +0 -1
  110. package/dist/loaders/admin.mjs.map +1 -1
  111. package/dist/loaders/apis.d.ts +2 -2
  112. package/dist/loaders/apis.d.ts.map +1 -1
  113. package/dist/loaders/apis.js +10 -10
  114. package/dist/loaders/apis.js.map +1 -1
  115. package/dist/loaders/apis.mjs +10 -10
  116. package/dist/loaders/apis.mjs.map +1 -1
  117. package/dist/loaders/components.d.ts +2 -2
  118. package/dist/loaders/components.d.ts.map +1 -1
  119. package/dist/loaders/components.js.map +1 -1
  120. package/dist/loaders/components.mjs.map +1 -1
  121. package/dist/loaders/index.d.ts +2 -2
  122. package/dist/loaders/index.d.ts.map +1 -1
  123. package/dist/loaders/index.js +0 -2
  124. package/dist/loaders/index.js.map +1 -1
  125. package/dist/loaders/index.mjs +0 -2
  126. package/dist/loaders/index.mjs.map +1 -1
  127. package/dist/loaders/middlewares.d.ts +2 -2
  128. package/dist/loaders/middlewares.d.ts.map +1 -1
  129. package/dist/loaders/middlewares.js.map +1 -1
  130. package/dist/loaders/middlewares.mjs.map +1 -1
  131. package/dist/loaders/plugins/get-enabled-plugins.d.ts +2 -2
  132. package/dist/loaders/plugins/get-enabled-plugins.d.ts.map +1 -1
  133. package/dist/loaders/plugins/get-enabled-plugins.js +7 -6
  134. package/dist/loaders/plugins/get-enabled-plugins.js.map +1 -1
  135. package/dist/loaders/plugins/get-enabled-plugins.mjs +7 -6
  136. package/dist/loaders/plugins/get-enabled-plugins.mjs.map +1 -1
  137. package/dist/loaders/plugins/index.d.ts +2 -2
  138. package/dist/loaders/plugins/index.d.ts.map +1 -1
  139. package/dist/loaders/plugins/index.js.map +1 -1
  140. package/dist/loaders/plugins/index.mjs.map +1 -1
  141. package/dist/loaders/policies.d.ts +2 -2
  142. package/dist/loaders/policies.d.ts.map +1 -1
  143. package/dist/loaders/policies.js.map +1 -1
  144. package/dist/loaders/policies.mjs.map +1 -1
  145. package/dist/loaders/sanitizers.d.ts +2 -2
  146. package/dist/loaders/sanitizers.d.ts.map +1 -1
  147. package/dist/loaders/sanitizers.js.map +1 -1
  148. package/dist/loaders/sanitizers.mjs.map +1 -1
  149. package/dist/loaders/src-index.d.ts +2 -2
  150. package/dist/loaders/src-index.d.ts.map +1 -1
  151. package/dist/loaders/src-index.js.map +1 -1
  152. package/dist/loaders/src-index.mjs.map +1 -1
  153. package/dist/loaders/validators.d.ts +2 -2
  154. package/dist/loaders/validators.d.ts.map +1 -1
  155. package/dist/loaders/validators.js.map +1 -1
  156. package/dist/loaders/validators.mjs.map +1 -1
  157. package/dist/middlewares/body.d.ts +4 -4
  158. package/dist/middlewares/body.d.ts.map +1 -1
  159. package/dist/middlewares/body.js +4 -4
  160. package/dist/middlewares/body.js.map +1 -1
  161. package/dist/middlewares/body.mjs +4 -4
  162. package/dist/middlewares/body.mjs.map +1 -1
  163. package/dist/middlewares/compression.d.ts +2 -2
  164. package/dist/middlewares/compression.d.ts.map +1 -1
  165. package/dist/middlewares/compression.js.map +1 -1
  166. package/dist/middlewares/compression.mjs.map +1 -1
  167. package/dist/middlewares/cors.d.ts +2 -2
  168. package/dist/middlewares/cors.d.ts.map +1 -1
  169. package/dist/middlewares/cors.js +6 -8
  170. package/dist/middlewares/cors.js.map +1 -1
  171. package/dist/middlewares/cors.mjs +6 -8
  172. package/dist/middlewares/cors.mjs.map +1 -1
  173. package/dist/middlewares/errors.d.ts +2 -2
  174. package/dist/middlewares/errors.d.ts.map +1 -1
  175. package/dist/middlewares/errors.js.map +1 -1
  176. package/dist/middlewares/errors.mjs.map +1 -1
  177. package/dist/middlewares/favicon.d.ts +2 -2
  178. package/dist/middlewares/favicon.d.ts.map +1 -1
  179. package/dist/middlewares/favicon.js.map +1 -1
  180. package/dist/middlewares/favicon.mjs.map +1 -1
  181. package/dist/middlewares/index.d.ts +2 -2
  182. package/dist/middlewares/index.d.ts.map +1 -1
  183. package/dist/middlewares/index.js.map +1 -1
  184. package/dist/middlewares/index.mjs.map +1 -1
  185. package/dist/middlewares/ip.d.ts +2 -2
  186. package/dist/middlewares/ip.d.ts.map +1 -1
  187. package/dist/middlewares/ip.js.map +1 -1
  188. package/dist/middlewares/ip.mjs.map +1 -1
  189. package/dist/middlewares/logger.d.ts +2 -2
  190. package/dist/middlewares/logger.d.ts.map +1 -1
  191. package/dist/middlewares/logger.js.map +1 -1
  192. package/dist/middlewares/logger.mjs.map +1 -1
  193. package/dist/middlewares/powered-by.d.ts +2 -2
  194. package/dist/middlewares/powered-by.d.ts.map +1 -1
  195. package/dist/middlewares/powered-by.js.map +1 -1
  196. package/dist/middlewares/powered-by.mjs.map +1 -1
  197. package/dist/middlewares/public.d.ts +2 -2
  198. package/dist/middlewares/public.d.ts.map +1 -1
  199. package/dist/middlewares/public.js +1 -1
  200. package/dist/middlewares/public.js.map +1 -1
  201. package/dist/middlewares/public.mjs +1 -1
  202. package/dist/middlewares/public.mjs.map +1 -1
  203. package/dist/middlewares/query.d.ts +2 -2
  204. package/dist/middlewares/query.d.ts.map +1 -1
  205. package/dist/middlewares/query.js.map +1 -1
  206. package/dist/middlewares/query.mjs.map +1 -1
  207. package/dist/middlewares/response-time.d.ts +2 -2
  208. package/dist/middlewares/response-time.d.ts.map +1 -1
  209. package/dist/middlewares/response-time.js.map +1 -1
  210. package/dist/middlewares/response-time.mjs.map +1 -1
  211. package/dist/middlewares/responses.d.ts +3 -3
  212. package/dist/middlewares/responses.d.ts.map +1 -1
  213. package/dist/middlewares/responses.js.map +1 -1
  214. package/dist/middlewares/responses.mjs.map +1 -1
  215. package/dist/middlewares/security.d.ts +2 -2
  216. package/dist/middlewares/security.d.ts.map +1 -1
  217. package/dist/middlewares/security.js +10 -3
  218. package/dist/middlewares/security.js.map +1 -1
  219. package/dist/middlewares/security.mjs +11 -4
  220. package/dist/middlewares/security.mjs.map +1 -1
  221. package/dist/middlewares/session.d.ts +2 -2
  222. package/dist/middlewares/session.d.ts.map +1 -1
  223. package/dist/middlewares/session.js.map +1 -1
  224. package/dist/middlewares/session.mjs.map +1 -1
  225. package/dist/migrations/database/5.0.0-discard-drafts.d.ts +30 -0
  226. package/dist/migrations/database/5.0.0-discard-drafts.d.ts.map +1 -0
  227. package/dist/migrations/database/5.0.0-discard-drafts.js +50 -0
  228. package/dist/migrations/database/5.0.0-discard-drafts.js.map +1 -0
  229. package/dist/migrations/database/5.0.0-discard-drafts.mjs +50 -0
  230. package/dist/migrations/database/5.0.0-discard-drafts.mjs.map +1 -0
  231. package/dist/migrations/draft-publish.d.ts.map +1 -1
  232. package/dist/migrations/draft-publish.js +14 -31
  233. package/dist/migrations/draft-publish.js.map +1 -1
  234. package/dist/migrations/draft-publish.mjs +15 -32
  235. package/dist/migrations/draft-publish.mjs.map +1 -1
  236. package/dist/providers/admin.d.ts +3 -0
  237. package/dist/providers/admin.d.ts.map +1 -0
  238. package/dist/providers/admin.js +20 -0
  239. package/dist/providers/admin.js.map +1 -0
  240. package/dist/providers/admin.mjs +21 -0
  241. package/dist/providers/admin.mjs.map +1 -0
  242. package/dist/providers/coreStore.d.ts +3 -0
  243. package/dist/providers/coreStore.d.ts.map +1 -0
  244. package/dist/providers/coreStore.js +11 -0
  245. package/dist/providers/coreStore.js.map +1 -0
  246. package/dist/providers/coreStore.mjs +12 -0
  247. package/dist/providers/coreStore.mjs.map +1 -0
  248. package/dist/providers/cron.d.ts +3 -0
  249. package/dist/providers/cron.d.ts.map +1 -0
  250. package/dist/providers/cron.js +20 -0
  251. package/dist/providers/cron.js.map +1 -0
  252. package/dist/providers/cron.mjs +21 -0
  253. package/dist/providers/cron.mjs.map +1 -0
  254. package/dist/providers/index.d.ts +3 -0
  255. package/dist/providers/index.d.ts.map +1 -0
  256. package/dist/providers/index.js +11 -0
  257. package/dist/providers/index.js.map +1 -0
  258. package/dist/providers/index.mjs +11 -0
  259. package/dist/providers/index.mjs.map +1 -0
  260. package/dist/providers/provider.d.ts +9 -0
  261. package/dist/providers/provider.d.ts.map +1 -0
  262. package/dist/providers/provider.js +5 -0
  263. package/dist/providers/provider.js.map +1 -0
  264. package/dist/providers/provider.mjs +5 -0
  265. package/dist/providers/provider.mjs.map +1 -0
  266. package/dist/providers/registries.d.ts +3 -0
  267. package/dist/providers/registries.d.ts.map +1 -0
  268. package/dist/providers/registries.js +35 -0
  269. package/dist/providers/registries.js.map +1 -0
  270. package/dist/providers/registries.mjs +36 -0
  271. package/dist/providers/registries.mjs.map +1 -0
  272. package/dist/providers/telemetry.d.ts +3 -0
  273. package/dist/providers/telemetry.d.ts.map +1 -0
  274. package/dist/providers/telemetry.js +19 -0
  275. package/dist/providers/telemetry.js.map +1 -0
  276. package/dist/providers/telemetry.mjs +20 -0
  277. package/dist/providers/telemetry.mjs.map +1 -0
  278. package/dist/providers/webhooks.d.ts +3 -0
  279. package/dist/providers/webhooks.d.ts.map +1 -0
  280. package/dist/providers/webhooks.js +30 -0
  281. package/dist/providers/webhooks.js.map +1 -0
  282. package/dist/providers/webhooks.mjs +31 -0
  283. package/dist/providers/webhooks.mjs.map +1 -0
  284. package/dist/registries/apis.d.ts +2 -2
  285. package/dist/registries/apis.d.ts.map +1 -1
  286. package/dist/registries/apis.js.map +1 -1
  287. package/dist/registries/apis.mjs.map +1 -1
  288. package/dist/registries/components.d.ts +6 -6
  289. package/dist/registries/components.d.ts.map +1 -1
  290. package/dist/registries/components.js.map +1 -1
  291. package/dist/registries/components.mjs.map +1 -1
  292. package/dist/registries/content-types.d.ts +5 -5
  293. package/dist/registries/content-types.d.ts.map +1 -1
  294. package/dist/registries/content-types.js.map +1 -1
  295. package/dist/registries/content-types.mjs.map +1 -1
  296. package/dist/registries/controllers.d.ts +10 -10
  297. package/dist/registries/controllers.d.ts.map +1 -1
  298. package/dist/registries/controllers.js.map +1 -1
  299. package/dist/registries/controllers.mjs.map +1 -1
  300. package/dist/registries/custom-fields.d.ts +3 -3
  301. package/dist/registries/custom-fields.d.ts.map +1 -1
  302. package/dist/registries/custom-fields.js.map +1 -1
  303. package/dist/registries/custom-fields.mjs.map +1 -1
  304. package/dist/registries/index.d.ts +0 -1
  305. package/dist/registries/index.d.ts.map +1 -1
  306. package/dist/registries/middlewares.d.ts +6 -6
  307. package/dist/registries/middlewares.d.ts.map +1 -1
  308. package/dist/registries/middlewares.js.map +1 -1
  309. package/dist/registries/middlewares.mjs.map +1 -1
  310. package/dist/registries/modules.d.ts +2 -2
  311. package/dist/registries/modules.d.ts.map +1 -1
  312. package/dist/registries/modules.js.map +1 -1
  313. package/dist/registries/modules.mjs.map +1 -1
  314. package/dist/registries/plugins.d.ts +5 -5
  315. package/dist/registries/plugins.d.ts.map +1 -1
  316. package/dist/registries/plugins.js.map +1 -1
  317. package/dist/registries/plugins.mjs.map +1 -1
  318. package/dist/registries/policies.d.ts +23 -11
  319. package/dist/registries/policies.d.ts.map +1 -1
  320. package/dist/registries/policies.js +64 -18
  321. package/dist/registries/policies.js.map +1 -1
  322. package/dist/registries/policies.mjs +65 -19
  323. package/dist/registries/policies.mjs.map +1 -1
  324. package/dist/registries/services.d.ts +8 -8
  325. package/dist/registries/services.d.ts.map +1 -1
  326. package/dist/registries/services.js.map +1 -1
  327. package/dist/registries/services.mjs.map +1 -1
  328. package/dist/services/auth/index.d.ts +4 -4
  329. package/dist/services/auth/index.d.ts.map +1 -1
  330. package/dist/services/auth/index.js.map +1 -1
  331. package/dist/services/auth/index.mjs.map +1 -1
  332. package/dist/services/config.d.ts +3 -0
  333. package/dist/services/config.d.ts.map +1 -0
  334. package/dist/services/config.js +47 -0
  335. package/dist/services/config.js.map +1 -0
  336. package/dist/services/config.mjs +47 -0
  337. package/dist/services/config.mjs.map +1 -0
  338. package/dist/services/content-api/index.d.ts +21 -3
  339. package/dist/services/content-api/index.d.ts.map +1 -1
  340. package/dist/services/content-api/index.js +28 -2
  341. package/dist/services/content-api/index.js.map +1 -1
  342. package/dist/services/content-api/index.mjs +28 -2
  343. package/dist/services/content-api/index.mjs.map +1 -1
  344. package/dist/services/content-api/permissions/index.d.ts +3 -3
  345. package/dist/services/content-api/permissions/index.d.ts.map +1 -1
  346. package/dist/services/content-api/permissions/index.js +1 -1
  347. package/dist/services/content-api/permissions/index.js.map +1 -1
  348. package/dist/services/content-api/permissions/index.mjs +1 -1
  349. package/dist/services/content-api/permissions/index.mjs.map +1 -1
  350. package/dist/services/core-store.d.ts.map +1 -1
  351. package/dist/services/cron.d.ts +2 -2
  352. package/dist/services/cron.d.ts.map +1 -1
  353. package/dist/services/cron.js.map +1 -1
  354. package/dist/services/cron.mjs.map +1 -1
  355. package/dist/services/custom-fields.d.ts +2 -2
  356. package/dist/services/custom-fields.d.ts.map +1 -1
  357. package/dist/services/custom-fields.js.map +1 -1
  358. package/dist/services/custom-fields.mjs.map +1 -1
  359. package/dist/services/document-service/attributes/index.d.ts +6 -0
  360. package/dist/services/document-service/attributes/index.d.ts.map +1 -0
  361. package/dist/services/{entity-service → document-service}/attributes/index.js +5 -5
  362. package/dist/services/document-service/attributes/index.js.map +1 -0
  363. package/dist/services/{entity-service → document-service}/attributes/index.mjs +5 -5
  364. package/dist/services/document-service/attributes/index.mjs.map +1 -0
  365. package/dist/services/document-service/attributes/transforms.d.ts +10 -0
  366. package/dist/services/document-service/attributes/transforms.d.ts.map +1 -0
  367. package/dist/services/document-service/attributes/transforms.js.map +1 -0
  368. package/dist/services/document-service/attributes/transforms.mjs.map +1 -0
  369. package/dist/services/document-service/common.d.ts +2 -2
  370. package/dist/services/document-service/common.d.ts.map +1 -1
  371. package/dist/services/document-service/common.js.map +1 -1
  372. package/dist/services/document-service/common.mjs.map +1 -1
  373. package/dist/services/document-service/components.d.ts +25 -1
  374. package/dist/services/document-service/components.d.ts.map +1 -1
  375. package/dist/services/{entity-service → document-service}/components.js +35 -45
  376. package/dist/services/document-service/components.js.map +1 -0
  377. package/dist/services/{entity-service → document-service}/components.mjs +36 -46
  378. package/dist/services/document-service/components.mjs.map +1 -0
  379. package/dist/services/document-service/draft-and-publish.d.ts +7 -7
  380. package/dist/services/document-service/draft-and-publish.d.ts.map +1 -1
  381. package/dist/services/document-service/draft-and-publish.js.map +1 -1
  382. package/dist/services/document-service/draft-and-publish.mjs.map +1 -1
  383. package/dist/services/document-service/entries.d.ts +10 -0
  384. package/dist/services/document-service/entries.d.ts.map +1 -0
  385. package/dist/services/document-service/entries.js +96 -0
  386. package/dist/services/document-service/entries.js.map +1 -0
  387. package/dist/services/document-service/entries.mjs +96 -0
  388. package/dist/services/document-service/entries.mjs.map +1 -0
  389. package/dist/services/document-service/events.d.ts +25 -0
  390. package/dist/services/document-service/events.d.ts.map +1 -0
  391. package/dist/services/document-service/events.js +47 -0
  392. package/dist/services/document-service/events.js.map +1 -0
  393. package/dist/services/document-service/events.mjs +47 -0
  394. package/dist/services/document-service/events.mjs.map +1 -0
  395. package/dist/services/document-service/index.d.ts +2 -4
  396. package/dist/services/document-service/index.d.ts.map +1 -1
  397. package/dist/services/document-service/index.js +13 -2
  398. package/dist/services/document-service/index.js.map +1 -1
  399. package/dist/services/document-service/index.mjs +13 -2
  400. package/dist/services/document-service/index.mjs.map +1 -1
  401. package/dist/services/document-service/internationalization.d.ts +5 -5
  402. package/dist/services/document-service/internationalization.d.ts.map +1 -1
  403. package/dist/services/document-service/internationalization.js +14 -5
  404. package/dist/services/document-service/internationalization.js.map +1 -1
  405. package/dist/services/document-service/internationalization.mjs +14 -5
  406. package/dist/services/document-service/internationalization.mjs.map +1 -1
  407. package/dist/services/document-service/middlewares/middleware-manager.d.ts +5 -2
  408. package/dist/services/document-service/middlewares/middleware-manager.d.ts.map +1 -1
  409. package/dist/services/document-service/middlewares/middleware-manager.js +8 -5
  410. package/dist/services/document-service/middlewares/middleware-manager.js.map +1 -1
  411. package/dist/services/document-service/middlewares/middleware-manager.mjs +8 -5
  412. package/dist/services/document-service/middlewares/middleware-manager.mjs.map +1 -1
  413. package/dist/services/document-service/params.d.ts +3 -1
  414. package/dist/services/document-service/params.d.ts.map +1 -1
  415. package/dist/services/document-service/params.js.map +1 -0
  416. package/dist/services/document-service/params.mjs.map +1 -0
  417. package/dist/services/document-service/repository.d.ts.map +1 -1
  418. package/dist/services/document-service/repository.js +135 -152
  419. package/dist/services/document-service/repository.js.map +1 -1
  420. package/dist/services/document-service/repository.mjs +118 -135
  421. package/dist/services/document-service/repository.mjs.map +1 -1
  422. package/dist/services/document-service/transform/data.d.ts.map +1 -1
  423. package/dist/services/document-service/transform/data.js +4 -2
  424. package/dist/services/document-service/transform/data.js.map +1 -1
  425. package/dist/services/document-service/transform/data.mjs +4 -2
  426. package/dist/services/document-service/transform/data.mjs.map +1 -1
  427. package/dist/services/document-service/transform/fields.d.ts +2 -2
  428. package/dist/services/document-service/transform/fields.d.ts.map +1 -1
  429. package/dist/services/document-service/transform/fields.js.map +1 -1
  430. package/dist/services/document-service/transform/fields.mjs.map +1 -1
  431. package/dist/services/document-service/transform/id-map.d.ts +3 -3
  432. package/dist/services/document-service/transform/id-map.d.ts.map +1 -1
  433. package/dist/services/document-service/transform/id-map.js.map +1 -1
  434. package/dist/services/document-service/transform/id-map.mjs.map +1 -1
  435. package/dist/services/document-service/transform/id-transform.d.ts +2 -2
  436. package/dist/services/document-service/transform/id-transform.d.ts.map +1 -1
  437. package/dist/services/document-service/transform/id-transform.js.map +1 -1
  438. package/dist/services/document-service/transform/id-transform.mjs.map +1 -1
  439. package/dist/services/document-service/transform/populate.d.ts +2 -2
  440. package/dist/services/document-service/transform/populate.d.ts.map +1 -1
  441. package/dist/services/document-service/transform/populate.js +1 -1
  442. package/dist/services/document-service/transform/populate.js.map +1 -1
  443. package/dist/services/document-service/transform/populate.mjs +1 -1
  444. package/dist/services/document-service/transform/populate.mjs.map +1 -1
  445. package/dist/services/document-service/transform/query.d.ts +5 -0
  446. package/dist/services/document-service/transform/query.d.ts.map +1 -0
  447. package/dist/services/document-service/transform/query.js +9 -0
  448. package/dist/services/document-service/transform/query.js.map +1 -0
  449. package/dist/services/document-service/transform/query.mjs +9 -0
  450. package/dist/services/document-service/transform/query.mjs.map +1 -0
  451. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +8 -7
  452. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -1
  453. package/dist/services/document-service/transform/relations/extract/data-ids.js +44 -77
  454. package/dist/services/document-service/transform/relations/extract/data-ids.js.map +1 -1
  455. package/dist/services/document-service/transform/relations/extract/data-ids.mjs +44 -77
  456. package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +1 -1
  457. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts +8 -4
  458. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts.map +1 -1
  459. package/dist/services/document-service/transform/relations/transform/data-ids.js +60 -125
  460. package/dist/services/document-service/transform/relations/transform/data-ids.js.map +1 -1
  461. package/dist/services/document-service/transform/relations/transform/data-ids.mjs +61 -126
  462. package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +1 -1
  463. package/dist/services/document-service/transform/relations/transform/default-locale.d.ts +9 -0
  464. package/dist/services/document-service/transform/relations/transform/default-locale.d.ts.map +1 -0
  465. package/dist/services/document-service/transform/relations/transform/default-locale.js +32 -0
  466. package/dist/services/document-service/transform/relations/transform/default-locale.js.map +1 -0
  467. package/dist/services/document-service/transform/relations/transform/default-locale.mjs +32 -0
  468. package/dist/services/document-service/transform/relations/transform/default-locale.mjs.map +1 -0
  469. package/dist/services/document-service/transform/relations/utils/dp.d.ts +3 -3
  470. package/dist/services/document-service/transform/relations/utils/dp.d.ts.map +1 -1
  471. package/dist/services/document-service/transform/relations/utils/dp.js.map +1 -1
  472. package/dist/services/document-service/transform/relations/utils/dp.mjs.map +1 -1
  473. package/dist/services/document-service/transform/relations/utils/i18n.d.ts +6 -6
  474. package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -1
  475. package/dist/services/document-service/transform/relations/utils/i18n.js +3 -9
  476. package/dist/services/document-service/transform/relations/utils/i18n.js.map +1 -1
  477. package/dist/services/document-service/transform/relations/utils/i18n.mjs +3 -9
  478. package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +1 -1
  479. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts +6 -0
  480. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts.map +1 -0
  481. package/dist/services/document-service/transform/relations/utils/map-relation.js +91 -0
  482. package/dist/services/document-service/transform/relations/utils/map-relation.js.map +1 -0
  483. package/dist/services/document-service/transform/relations/utils/map-relation.mjs +91 -0
  484. package/dist/services/document-service/transform/relations/utils/map-relation.mjs.map +1 -0
  485. package/dist/services/document-service/transform/relations/utils/types.d.ts +6 -0
  486. package/dist/services/document-service/transform/relations/utils/types.d.ts.map +1 -1
  487. package/dist/services/document-service/transform/types.d.ts +3 -3
  488. package/dist/services/document-service/transform/types.d.ts.map +1 -1
  489. package/dist/services/document-service/utils/populate.d.ts +2 -2
  490. package/dist/services/document-service/utils/populate.d.ts.map +1 -1
  491. package/dist/services/document-service/utils/populate.js.map +1 -1
  492. package/dist/services/document-service/utils/populate.mjs.map +1 -1
  493. package/dist/services/entity-service/index.d.ts +4 -4
  494. package/dist/services/entity-service/index.d.ts.map +1 -1
  495. package/dist/services/entity-service/index.js +22 -16
  496. package/dist/services/entity-service/index.js.map +1 -1
  497. package/dist/services/entity-service/index.mjs +23 -17
  498. package/dist/services/entity-service/index.mjs.map +1 -1
  499. package/dist/services/entity-validator/index.d.ts +2 -2
  500. package/dist/services/entity-validator/index.d.ts.map +1 -1
  501. package/dist/services/entity-validator/index.js +100 -89
  502. package/dist/services/entity-validator/index.js.map +1 -1
  503. package/dist/services/entity-validator/index.mjs +100 -89
  504. package/dist/services/entity-validator/index.mjs.map +1 -1
  505. package/dist/services/entity-validator/validators.d.ts +18 -18
  506. package/dist/services/entity-validator/validators.d.ts.map +1 -1
  507. package/dist/services/entity-validator/validators.js +6 -1
  508. package/dist/services/entity-validator/validators.js.map +1 -1
  509. package/dist/services/entity-validator/validators.mjs +6 -1
  510. package/dist/services/entity-validator/validators.mjs.map +1 -1
  511. package/dist/services/event-hub.d.ts +1 -0
  512. package/dist/services/event-hub.d.ts.map +1 -1
  513. package/dist/services/event-hub.js +9 -4
  514. package/dist/services/event-hub.js.map +1 -1
  515. package/dist/services/event-hub.mjs +9 -4
  516. package/dist/services/event-hub.mjs.map +1 -1
  517. package/dist/services/features.d.ts +3 -3
  518. package/dist/services/features.d.ts.map +1 -1
  519. package/dist/services/features.js.map +1 -1
  520. package/dist/services/features.mjs.map +1 -1
  521. package/dist/services/fs.d.ts +2 -2
  522. package/dist/services/fs.d.ts.map +1 -1
  523. package/dist/services/fs.js.map +1 -1
  524. package/dist/services/fs.mjs.map +1 -1
  525. package/dist/services/metrics/admin-user-hash.d.ts +2 -2
  526. package/dist/services/metrics/admin-user-hash.d.ts.map +1 -1
  527. package/dist/services/metrics/admin-user-hash.js.map +1 -1
  528. package/dist/services/metrics/admin-user-hash.mjs.map +1 -1
  529. package/dist/services/metrics/index.d.ts +2 -2
  530. package/dist/services/metrics/index.d.ts.map +1 -1
  531. package/dist/services/metrics/index.js.map +1 -1
  532. package/dist/services/metrics/index.mjs.map +1 -1
  533. package/dist/services/metrics/middleware.d.ts +2 -2
  534. package/dist/services/metrics/middleware.d.ts.map +1 -1
  535. package/dist/services/metrics/middleware.js.map +1 -1
  536. package/dist/services/metrics/middleware.mjs.map +1 -1
  537. package/dist/services/metrics/rate-limiter.d.ts.map +1 -1
  538. package/dist/services/metrics/rate-limiter.js.map +1 -1
  539. package/dist/services/metrics/rate-limiter.mjs.map +1 -1
  540. package/dist/services/metrics/sender.d.ts +3 -3
  541. package/dist/services/metrics/sender.d.ts.map +1 -1
  542. package/dist/services/metrics/sender.js.map +1 -1
  543. package/dist/services/metrics/sender.mjs.map +1 -1
  544. package/dist/services/query-params.d.ts +7 -0
  545. package/dist/services/query-params.d.ts.map +1 -0
  546. package/dist/services/query-params.js +12 -0
  547. package/dist/services/query-params.js.map +1 -0
  548. package/dist/services/query-params.mjs +13 -0
  549. package/dist/services/query-params.mjs.map +1 -0
  550. package/dist/services/reloader.d.ts +7 -0
  551. package/dist/services/reloader.d.ts.map +1 -0
  552. package/dist/services/reloader.js +36 -0
  553. package/dist/services/reloader.js.map +1 -0
  554. package/dist/services/reloader.mjs +36 -0
  555. package/dist/services/reloader.mjs.map +1 -0
  556. package/dist/services/server/admin-api.d.ts +3 -3
  557. package/dist/services/server/admin-api.d.ts.map +1 -1
  558. package/dist/services/server/admin-api.js.map +1 -1
  559. package/dist/services/server/admin-api.mjs.map +1 -1
  560. package/dist/services/server/api.d.ts +3 -3
  561. package/dist/services/server/api.d.ts.map +1 -1
  562. package/dist/services/server/api.js.map +1 -1
  563. package/dist/services/server/api.mjs.map +1 -1
  564. package/dist/services/server/compose-endpoint.d.ts +2 -2
  565. package/dist/services/server/compose-endpoint.d.ts.map +1 -1
  566. package/dist/services/server/compose-endpoint.js +1 -2
  567. package/dist/services/server/compose-endpoint.js.map +1 -1
  568. package/dist/services/server/compose-endpoint.mjs +2 -3
  569. package/dist/services/server/compose-endpoint.mjs.map +1 -1
  570. package/dist/services/server/content-api.d.ts +3 -3
  571. package/dist/services/server/content-api.d.ts.map +1 -1
  572. package/dist/services/server/content-api.js.map +1 -1
  573. package/dist/services/server/content-api.mjs.map +1 -1
  574. package/dist/services/server/http-server.d.ts +2 -2
  575. package/dist/services/server/http-server.d.ts.map +1 -1
  576. package/dist/services/server/http-server.js.map +1 -1
  577. package/dist/services/server/http-server.mjs.map +1 -1
  578. package/dist/services/server/index.d.ts +2 -2
  579. package/dist/services/server/index.d.ts.map +1 -1
  580. package/dist/services/server/index.js +1 -2
  581. package/dist/services/server/index.js.map +1 -1
  582. package/dist/services/server/index.mjs +1 -2
  583. package/dist/services/server/index.mjs.map +1 -1
  584. package/dist/services/server/koa.d.ts.map +1 -1
  585. package/dist/services/server/koa.js +1 -1
  586. package/dist/services/server/koa.js.map +1 -1
  587. package/dist/services/server/koa.mjs +1 -1
  588. package/dist/services/server/koa.mjs.map +1 -1
  589. package/dist/services/server/middleware.d.ts +4 -4
  590. package/dist/services/server/middleware.d.ts.map +1 -1
  591. package/dist/services/server/middleware.js.map +1 -1
  592. package/dist/services/server/middleware.mjs.map +1 -1
  593. package/dist/services/server/policy.d.ts +3 -3
  594. package/dist/services/server/policy.d.ts.map +1 -1
  595. package/dist/services/server/policy.js +4 -4
  596. package/dist/services/server/policy.js.map +1 -1
  597. package/dist/services/server/policy.mjs +4 -4
  598. package/dist/services/server/policy.mjs.map +1 -1
  599. package/dist/services/server/register-middlewares.d.ts +2 -2
  600. package/dist/services/server/register-middlewares.d.ts.map +1 -1
  601. package/dist/services/server/register-middlewares.js.map +1 -1
  602. package/dist/services/server/register-middlewares.mjs.map +1 -1
  603. package/dist/services/server/register-routes.d.ts +2 -2
  604. package/dist/services/server/register-routes.d.ts.map +1 -1
  605. package/dist/services/server/register-routes.js +3 -3
  606. package/dist/services/server/register-routes.js.map +1 -1
  607. package/dist/services/server/register-routes.mjs +3 -3
  608. package/dist/services/server/register-routes.mjs.map +1 -1
  609. package/dist/services/server/routing.d.ts +5 -5
  610. package/dist/services/server/routing.d.ts.map +1 -1
  611. package/dist/services/server/routing.js.map +1 -1
  612. package/dist/services/server/routing.mjs.map +1 -1
  613. package/dist/services/utils/dynamic-zones.d.ts.map +1 -1
  614. package/dist/services/utils/dynamic-zones.js +2 -1
  615. package/dist/services/utils/dynamic-zones.js.map +1 -1
  616. package/dist/services/utils/dynamic-zones.mjs +2 -1
  617. package/dist/services/utils/dynamic-zones.mjs.map +1 -1
  618. package/dist/services/webhook-runner.d.ts +2 -1
  619. package/dist/services/webhook-runner.d.ts.map +1 -1
  620. package/dist/services/webhook-runner.js.map +1 -1
  621. package/dist/services/webhook-runner.mjs.map +1 -1
  622. package/dist/services/webhook-store.d.ts +2 -8
  623. package/dist/services/webhook-store.d.ts.map +1 -1
  624. package/dist/services/webhook-store.js +14 -8
  625. package/dist/services/webhook-store.js.map +1 -1
  626. package/dist/services/webhook-store.mjs +14 -8
  627. package/dist/services/webhook-store.mjs.map +1 -1
  628. package/dist/utils/convert-custom-field-type.d.ts +2 -2
  629. package/dist/utils/convert-custom-field-type.d.ts.map +1 -1
  630. package/dist/utils/convert-custom-field-type.js.map +1 -1
  631. package/dist/utils/convert-custom-field-type.mjs.map +1 -1
  632. package/dist/utils/fetch.d.ts +3 -3
  633. package/dist/utils/fetch.d.ts.map +1 -1
  634. package/dist/utils/fetch.js.map +1 -1
  635. package/dist/utils/fetch.mjs.map +1 -1
  636. package/dist/utils/index.d.ts +2 -1
  637. package/dist/utils/index.d.ts.map +1 -1
  638. package/dist/utils/is-initialized.d.ts +2 -2
  639. package/dist/utils/is-initialized.d.ts.map +1 -1
  640. package/dist/utils/is-initialized.js.map +1 -1
  641. package/dist/utils/is-initialized.mjs.map +1 -1
  642. package/dist/utils/load-files.d.ts.map +1 -1
  643. package/dist/utils/open-browser.d.ts +2 -2
  644. package/dist/utils/open-browser.d.ts.map +1 -1
  645. package/dist/utils/open-browser.js.map +1 -1
  646. package/dist/utils/open-browser.mjs.map +1 -1
  647. package/dist/utils/resolve-working-dirs.d.ts +19 -0
  648. package/dist/utils/resolve-working-dirs.d.ts.map +1 -0
  649. package/dist/utils/resolve-working-dirs.js +13 -0
  650. package/dist/utils/resolve-working-dirs.js.map +1 -0
  651. package/dist/utils/resolve-working-dirs.mjs +11 -0
  652. package/dist/utils/resolve-working-dirs.mjs.map +1 -0
  653. package/dist/utils/signals.d.ts +2 -2
  654. package/dist/utils/signals.d.ts.map +1 -1
  655. package/dist/utils/signals.js.map +1 -1
  656. package/dist/utils/signals.mjs.map +1 -1
  657. package/dist/utils/startup-logger.d.ts +2 -2
  658. package/dist/utils/startup-logger.d.ts.map +1 -1
  659. package/dist/utils/startup-logger.js.map +1 -1
  660. package/dist/utils/startup-logger.mjs.map +1 -1
  661. package/dist/utils/transform-content-types-to-models.d.ts +54 -99
  662. package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
  663. package/dist/utils/transform-content-types-to-models.js +105 -57
  664. package/dist/utils/transform-content-types-to-models.js.map +1 -1
  665. package/dist/utils/transform-content-types-to-models.mjs +105 -57
  666. package/dist/utils/transform-content-types-to-models.mjs.map +1 -1
  667. package/dist/utils/update-notifier/index.d.ts +2 -7
  668. package/dist/utils/update-notifier/index.d.ts.map +1 -1
  669. package/dist/utils/update-notifier/index.js +11 -14
  670. package/dist/utils/update-notifier/index.js.map +1 -1
  671. package/dist/utils/update-notifier/index.mjs +11 -14
  672. package/dist/utils/update-notifier/index.mjs.map +1 -1
  673. package/package.json +28 -26
  674. package/dist/registries/config.d.ts +0 -4
  675. package/dist/registries/config.d.ts.map +0 -1
  676. package/dist/registries/config.js +0 -31
  677. package/dist/registries/config.js.map +0 -1
  678. package/dist/registries/config.mjs +0 -32
  679. package/dist/registries/config.mjs.map +0 -1
  680. package/dist/services/document-service/transform/relations/utils/data.js +0 -12
  681. package/dist/services/document-service/transform/relations/utils/data.js.map +0 -1
  682. package/dist/services/document-service/transform/relations/utils/data.mjs +0 -12
  683. package/dist/services/document-service/transform/relations/utils/data.mjs.map +0 -1
  684. package/dist/services/entity-service/attributes/index.d.ts +0 -6
  685. package/dist/services/entity-service/attributes/index.d.ts.map +0 -1
  686. package/dist/services/entity-service/attributes/index.js.map +0 -1
  687. package/dist/services/entity-service/attributes/index.mjs.map +0 -1
  688. package/dist/services/entity-service/attributes/transforms.d.ts +0 -10
  689. package/dist/services/entity-service/attributes/transforms.d.ts.map +0 -1
  690. package/dist/services/entity-service/attributes/transforms.js.map +0 -1
  691. package/dist/services/entity-service/attributes/transforms.mjs.map +0 -1
  692. package/dist/services/entity-service/components.d.ts +0 -20
  693. package/dist/services/entity-service/components.d.ts.map +0 -1
  694. package/dist/services/entity-service/components.js.map +0 -1
  695. package/dist/services/entity-service/components.mjs.map +0 -1
  696. package/dist/services/entity-service/params.d.ts +0 -8
  697. package/dist/services/entity-service/params.d.ts.map +0 -1
  698. package/dist/services/entity-service/params.js.map +0 -1
  699. package/dist/services/entity-service/params.mjs.map +0 -1
  700. package/dist/utils/get-dirs.d.ts +0 -9
  701. package/dist/utils/get-dirs.d.ts.map +0 -1
  702. package/dist/utils/get-dirs.js.map +0 -1
  703. package/dist/utils/get-dirs.mjs.map +0 -1
  704. /package/dist/services/{entity-service → document-service}/attributes/transforms.js +0 -0
  705. /package/dist/services/{entity-service → document-service}/attributes/transforms.mjs +0 -0
  706. /package/dist/services/{entity-service → document-service}/params.js +0 -0
  707. /package/dist/services/{entity-service → document-service}/params.mjs +0 -0
@@ -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;"}
@@ -1,7 +1,10 @@
1
- export type Middleware = (ctx: any, next: () => Promise<void>) => Promise<void>;
1
+ export type Middleware = (ctx: any, next: () => Promise<void>) => Promise<void> | void;
2
+ export type Options = {
3
+ exclude?: string[];
4
+ };
2
5
  export declare const createMiddlewareManager: () => {
3
6
  use(middleware: Middleware): () => Middleware[];
4
7
  run(ctx: any, cb: () => void): Promise<void>;
5
- wrapObject<TSource extends Record<string, any>>(source: TSource, ctxDefaults?: {}): TSource;
8
+ wrapObject<TSource>(source: TSource, ctxDefaults?: {}, opts?: Options): TSource;
6
9
  };
7
10
  //# sourceMappingURL=middleware-manager.d.ts.map
@@ -1 +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,CAAC;AAEhF,eAAO,MAAM,uBAAuB;oBAIhB,UAAU;aAMX,GAAG,MAAM,MAAM,IAAI;;CA4CrC,CAAC"}
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 {
@@ -1 +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>;\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 extends Record<string, any>>(source: TSource, ctxDefaults = {}): TSource {\n const facade: TSource = {} as TSource;\n\n for (const key in source) {\n if (Object.hasOwnProperty.call(source, key)) {\n const prop = source[key];\n\n if (typeof prop === 'function') {\n const newMethod = async (...args: any[]) => {\n const ctx = {\n ...ctxDefaults,\n action: key,\n args,\n };\n\n return manager.run(ctx, () => prop(...ctx.args));\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":";;AAEO,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,WAAgD,QAAiB,cAAc,IAAa;AAC1F,YAAM,SAAkB,CAAA;AAExB,iBAAW,OAAO,QAAQ;AACxB,YAAI,OAAO,eAAe,KAAK,QAAQ,GAAG,GAAG;AACrC,gBAAA,OAAO,OAAO,GAAG;AAEnB,cAAA,OAAO,SAAS,YAAY;AACxB,kBAAA,YAAY,UAAU,SAAgB;AAC1C,oBAAM,MAAM;AAAA,gBACV,GAAG;AAAA,gBACH,QAAQ;AAAA,gBACR;AAAA,cAAA;AAGK,qBAAA,QAAQ,IAAI,KAAK,MAAM,KAAK,GAAG,IAAI,IAAI,CAAC;AAAA,YAAA;AAGjD,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;;"}
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 {
@@ -1 +1 @@
1
- {"version":3,"file":"middleware-manager.mjs","sources":["../../../../src/services/document-service/middlewares/middleware-manager.ts"],"sourcesContent":["export type Middleware = (ctx: any, next: () => Promise<void>) => Promise<void>;\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 extends Record<string, any>>(source: TSource, ctxDefaults = {}): TSource {\n const facade: TSource = {} as TSource;\n\n for (const key in source) {\n if (Object.hasOwnProperty.call(source, key)) {\n const prop = source[key];\n\n if (typeof prop === 'function') {\n const newMethod = async (...args: any[]) => {\n const ctx = {\n ...ctxDefaults,\n action: key,\n args,\n };\n\n return manager.run(ctx, () => prop(...ctx.args));\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":"AAEO,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,WAAgD,QAAiB,cAAc,IAAa;AAC1F,YAAM,SAAkB,CAAA;AAExB,iBAAW,OAAO,QAAQ;AACxB,YAAI,OAAO,eAAe,KAAK,QAAQ,GAAG,GAAG;AACrC,gBAAA,OAAO,OAAO,GAAG;AAEnB,cAAA,OAAO,SAAS,YAAY;AACxB,kBAAA,YAAY,UAAU,SAAgB;AAC1C,oBAAM,MAAM;AAAA,gBACV,GAAG;AAAA,gBACH,QAAQ;AAAA,gBACR;AAAA,cAAA;AAGK,qBAAA,QAAQ,IAAI,KAAK,MAAM,KAAK,GAAG,IAAI,IAAI,CAAC;AAAA,YAAA;AAGjD,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;"}
1
+ {"version":3,"file":"middleware-manager.mjs","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;"}
@@ -1,2 +1,4 @@
1
- export * from '../entity-service/params';
1
+ import type { UID, Modules } from '@strapi/types';
2
+ declare const pickSelectionParams: <TUID extends UID.ContentType>(data: unknown) => Modules.Documents.Params.Pick<TUID, 'fields' | 'populate' | 'status'>;
3
+ export { pickSelectionParams };
2
4
  //# sourceMappingURL=params.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"params.d.ts","sourceRoot":"","sources":["../../../src/services/document-service/params.ts"],"names":[],"mappings":"AAAA,cAAc,0BAA0B,CAAC"}
1
+ {"version":3,"file":"params.d.ts","sourceRoot":"","sources":["../../../src/services/document-service/params.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,GAAG,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AAElD,QAAA,MAAM,mBAAmB,uCACjB,OAAO,KACZ,QAAQ,SAAS,CAAC,MAAM,KAAK,CAAC,IAAI,EAAE,QAAQ,GAAG,UAAU,GAAG,QAAQ,CAEtE,CAAC;AAEF,OAAO,EAAE,mBAAmB,EAAE,CAAC"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"params.js","sources":["../../../src/services/document-service/params.ts"],"sourcesContent":["import { pick } from 'lodash/fp';\nimport type { UID, Modules } from '@strapi/types';\n\nconst pickSelectionParams = <TUID extends UID.ContentType>(\n data: unknown\n): Modules.Documents.Params.Pick<TUID, 'fields' | 'populate' | 'status'> => {\n return pick(['fields', 'populate', 'status'], data);\n};\n\nexport { pickSelectionParams };\n"],"names":["pick"],"mappings":";;;AAGM,MAAA,sBAAsB,CAC1B,SAC0E;AAC1E,SAAOA,EAAAA,KAAK,CAAC,UAAU,YAAY,QAAQ,GAAG,IAAI;AACpD;;"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"params.mjs","sources":["../../../src/services/document-service/params.ts"],"sourcesContent":["import { pick } from 'lodash/fp';\nimport type { UID, Modules } from '@strapi/types';\n\nconst pickSelectionParams = <TUID extends UID.ContentType>(\n data: unknown\n): Modules.Documents.Params.Pick<TUID, 'fields' | 'populate' | 'status'> => {\n return pick(['fields', 'populate', 'status'], data);\n};\n\nexport { pickSelectionParams };\n"],"names":[],"mappings":";AAGM,MAAA,sBAAsB,CAC1B,SAC0E;AAC1E,SAAO,KAAK,CAAC,UAAU,YAAY,QAAQ,GAAG,IAAI;AACpD;"}
@@ -1 +1 @@
1
- {"version":3,"file":"repository.d.ts","sourceRoot":"","sources":["../../../src/services/document-service/repository.ts"],"names":[],"mappings":"AAKA,OAAO,EAAqB,KAAK,uBAAuB,EAAE,MAAM,UAAU,CAAC;AA0B3E,eAAO,MAAM,2BAA2B,EAAE,uBAyVzC,CAAC"}
1
+ {"version":3,"file":"repository.d.ts","sourceRoot":"","sources":["../../../src/services/document-service/repository.ts"],"names":[],"mappings":"AAIA,OAAO,EAAqB,KAAK,uBAAuB,EAAE,MAAM,UAAU,CAAC;AAa3E,eAAO,MAAM,2BAA2B,EAAE,uBAyUzC,CAAC"}
@@ -5,95 +5,77 @@ const strapiUtils = require("@strapi/utils");
5
5
  const common = require("./common.js");
6
6
  const draftAndPublish = require("./draft-and-publish.js");
7
7
  const internationalization = require("./internationalization.js");
8
- const idTransform = require("./transform/id-transform.js");
9
- const components = require("../entity-service/components.js");
10
- const params = require("../entity-service/params.js");
11
- const index = require("../entity-validator/index.js");
12
- const index$1 = require("../entity-service/attributes/index.js");
8
+ const components = require("./components.js");
9
+ const entries = require("./entries.js");
10
+ const params = require("./params.js");
13
11
  const transformContentTypesToModels = require("../../utils/transform-content-types-to-models.js");
14
12
  const populate = require("./utils/populate.js");
15
- const data = require("./transform/data.js");
16
- const transformParamsToQuery = _.curry((uid, params2) => {
17
- const query = strapiUtils.convertQueryParams.transformParamsToQuery(uid, params2);
18
- return _.assoc("where", { ...params2?.lookup, ...query.where }, query);
19
- });
13
+ const query = require("./transform/query.js");
14
+ const idTransform = require("./transform/id-transform.js");
15
+ const events = require("./events.js");
20
16
  const createContentTypeRepository = (uid) => {
21
17
  const contentType = strapi.contentType(uid);
22
18
  const hasDraftAndPublish = strapiUtils.contentTypes.hasDraftAndPublish(contentType);
19
+ const entries$1 = entries.createEntriesService(uid);
20
+ const eventManager = events.createEventManager(strapi, uid);
21
+ const emitEvent = _.curry(eventManager.emitEvent);
23
22
  async function findMany(params2 = {}) {
24
- const query = await strapiUtils.async.pipe(
23
+ const query$1 = await strapiUtils.async.pipe(
25
24
  draftAndPublish.defaultToDraft,
26
25
  draftAndPublish.statusToLookup(contentType),
27
26
  internationalization.defaultLocale(contentType),
28
- internationalization.localeToLookup(contentType),
27
+ internationalization.multiLocaleToLookup(contentType),
29
28
  idTransform.transformParamsDocumentId(uid),
30
- transformParamsToQuery(uid)
29
+ query.transformParamsToQuery(uid)
31
30
  )(params2 || {});
32
- return strapi.db.query(uid).findMany(query);
31
+ return strapi.db.query(uid).findMany(query$1);
33
32
  }
34
33
  async function findFirst(params2 = {}) {
35
- const query = await strapiUtils.async.pipe(
34
+ const query$1 = await strapiUtils.async.pipe(
36
35
  draftAndPublish.defaultToDraft,
37
36
  draftAndPublish.statusToLookup(contentType),
38
37
  internationalization.defaultLocale(contentType),
39
38
  internationalization.localeToLookup(contentType),
40
39
  idTransform.transformParamsDocumentId(uid),
41
- transformParamsToQuery(uid)
40
+ query.transformParamsToQuery(uid)
42
41
  )(params2);
43
- return strapi.db.query(uid).findOne(query);
42
+ return strapi.db.query(uid).findOne(query$1);
44
43
  }
45
- async function findOne(documentId, params2 = {}) {
46
- const query = await strapiUtils.async.pipe(
44
+ async function findOne(opts = {}) {
45
+ const { documentId, ...params2 } = opts;
46
+ const query$1 = await strapiUtils.async.pipe(
47
47
  draftAndPublish.defaultToDraft,
48
48
  draftAndPublish.statusToLookup(contentType),
49
49
  internationalization.defaultLocale(contentType),
50
50
  internationalization.localeToLookup(contentType),
51
51
  idTransform.transformParamsDocumentId(uid),
52
- transformParamsToQuery(uid),
52
+ query.transformParamsToQuery(uid),
53
53
  (query2) => _.assoc("where", { ...query2.where, documentId }, query2)
54
54
  )(params2);
55
- return strapi.db.query(uid).findOne(query);
56
- }
57
- async function deleteEntry(id) {
58
- const componentsToDelete = await components.getComponents(uid, { id });
59
- await strapi.db.query(uid).delete({ where: { id } });
60
- await components.deleteComponents(uid, componentsToDelete, { loadComponents: false });
55
+ return strapi.db.query(uid).findOne(query$1);
61
56
  }
62
- async function deleteFn(documentId, params2 = {}) {
63
- const query = await strapiUtils.async.pipe(
57
+ async function deleteDocument(opts = {}) {
58
+ const { documentId, ...params2 } = opts;
59
+ const query$1 = await strapiUtils.async.pipe(
64
60
  _.omit("status"),
65
61
  internationalization.defaultLocale(contentType),
66
62
  internationalization.multiLocaleToLookup(contentType),
67
- transformParamsToQuery(uid),
63
+ query.transformParamsToQuery(uid),
68
64
  (query2) => _.assoc("where", { ...query2.where, documentId }, query2)
69
65
  )(params2);
70
66
  if (params2.status === "draft") {
71
67
  throw new Error("Cannot delete a draft document");
72
68
  }
73
- const entriesToDelete = await strapi.db.query(uid).findMany(query);
74
- await strapiUtils.async.map(entriesToDelete, (entryToDelete) => deleteEntry(entryToDelete.id));
75
- return { deletedEntries: entriesToDelete };
76
- }
77
- async function createEntry(params$1 = {}) {
78
- const { data: data2, ...restParams } = await idTransform.transformParamsDocumentId(uid, params$1);
79
- const query = transformParamsToQuery(uid, params.pickSelectionParams(restParams));
80
- if (!params$1.data) {
81
- throw new Error("Create requires data attribute");
82
- }
83
- const validData = await index.validateEntityCreation(contentType, data2, {
84
- // Note: publishedAt value will always be set when DP is disabled
85
- isDraft: !params$1?.data?.publishedAt,
86
- locale: params$1?.locale
87
- });
88
- const componentData = await components.createComponents(uid, validData);
89
- const entryData = index$1.applyTransforms(
90
- Object.assign(components.omitComponentData(contentType, validData), componentData),
91
- { contentType }
69
+ const entriesToDelete = await strapi.db.query(uid).findMany(query$1);
70
+ const deletedEntries = await strapiUtils.async.map(
71
+ entriesToDelete,
72
+ (entryToDelete) => entries$1.delete(entryToDelete.id)
92
73
  );
93
- const doc = await strapi.db.query(uid).create({ ...query, data: entryData });
94
- return doc;
74
+ entriesToDelete.forEach(emitEvent("entry.delete"));
75
+ return { documentId, entries: deletedEntries };
95
76
  }
96
- async function create(params2 = {}) {
77
+ async function create(opts = {}) {
78
+ const { documentId, ...params2 } = opts;
97
79
  const queryParams = await strapiUtils.async.pipe(
98
80
  draftAndPublish.filterDataPublishedAt,
99
81
  draftAndPublish.setStatusToDraft(contentType),
@@ -101,19 +83,24 @@ const createContentTypeRepository = (uid) => {
101
83
  internationalization.defaultLocale(contentType),
102
84
  internationalization.localeToData(contentType)
103
85
  )(params2);
104
- const doc = await createEntry(queryParams);
86
+ const doc = await entries$1.create(queryParams);
87
+ emitEvent("entry.create", doc);
105
88
  if (hasDraftAndPublish && params2.status === "published") {
106
- return publish(doc.documentId, params2).then((doc2) => doc2.versions[0]);
89
+ return publish({
90
+ ...params2,
91
+ documentId: doc.documentId
92
+ }).then((doc2) => doc2.entries[0]);
107
93
  }
108
94
  return doc;
109
95
  }
110
- async function clone(documentId, params2 = {}) {
96
+ async function clone(opts = {}) {
97
+ const { documentId, ...params2 } = opts;
111
98
  const queryParams = await strapiUtils.async.pipe(
112
99
  draftAndPublish.filterDataPublishedAt,
113
100
  internationalization.defaultLocale(contentType),
114
101
  internationalization.multiLocaleToLookup(contentType)
115
102
  )(params2);
116
- const entriesToClone = await strapi.db?.query(uid).findMany({
103
+ const entriesToClone = await strapi.db.query(uid).findMany({
117
104
  where: {
118
105
  ...queryParams?.lookup,
119
106
  documentId,
@@ -130,13 +117,15 @@ const createContentTypeRepository = (uid) => {
130
117
  // assign new documentId
131
118
  _.assoc("documentId", transformContentTypesToModels.createDocumentId()),
132
119
  // Merge new data into it
133
- (data2) => _.merge(data2, queryParams.data),
134
- (data2) => createEntry({ ...queryParams, data: data2, status: "draft" })
120
+ (data) => _.merge(data, queryParams.data),
121
+ (data) => entries$1.create({ ...queryParams, data, status: "draft" })
135
122
  )
136
123
  );
137
- return { documentId: clonedEntries.at(0)?.documentId, versions: clonedEntries };
124
+ clonedEntries.forEach(emitEvent("entry.create"));
125
+ return { documentId: clonedEntries.at(0)?.documentId, entries: clonedEntries };
138
126
  }
139
- async function update(documentId, params$1 = {}) {
127
+ async function update(opts = {}) {
128
+ const { documentId, ...params$1 } = opts;
140
129
  const queryParams = await strapiUtils.async.pipe(
141
130
  draftAndPublish.filterDataPublishedAt,
142
131
  draftAndPublish.setStatusToDraft(contentType),
@@ -147,148 +136,142 @@ const createContentTypeRepository = (uid) => {
147
136
  internationalization.localeToLookup(contentType),
148
137
  internationalization.localeToData(contentType)
149
138
  )(params$1);
150
- const { data: data2, ...restParams } = await idTransform.transformParamsDocumentId(uid, queryParams || {});
151
- const query = transformParamsToQuery(uid, params.pickSelectionParams(restParams || {}));
152
- const model = strapi.contentType(uid);
153
- const entryToUpdate = await strapi.db.query(uid).findOne({ ...query, where: { ...queryParams?.lookup, ...query?.where, documentId } });
139
+ const { data, ...restParams } = await idTransform.transformParamsDocumentId(uid, queryParams || {});
140
+ const query$1 = query.transformParamsToQuery(uid, params.pickSelectionParams(restParams || {}));
141
+ const entryToUpdate = await strapi.db.query(uid).findOne({ ...query$1, where: { ...queryParams?.lookup, ...query$1?.where, documentId } });
154
142
  let updatedDraft = null;
155
143
  if (entryToUpdate) {
156
- const validData = await index.validateEntityUpdate(
157
- model,
158
- data2,
159
- {
160
- isDraft: !queryParams?.data?.publishedAt,
161
- // Always update the draft version
162
- locale: queryParams?.locale
163
- },
164
- entryToUpdate
165
- );
166
- const componentData = await components.updateComponents(uid, entryToUpdate, validData);
167
- const entryData = index$1.applyTransforms(
168
- Object.assign(components.omitComponentData(model, validData), componentData),
169
- { contentType: model }
170
- );
171
- updatedDraft = await strapi.db.query(uid).update({ ...query, where: { id: entryToUpdate.id }, data: entryData });
144
+ updatedDraft = await entries$1.update(entryToUpdate, queryParams);
145
+ emitEvent("entry.update", updatedDraft);
172
146
  }
173
147
  if (!updatedDraft) {
174
148
  const documentExists = await strapi.db.query(contentType.uid).findOne({ where: { documentId } });
175
149
  if (documentExists) {
176
- updatedDraft = await createEntry({
150
+ updatedDraft = await entries$1.create({
177
151
  ...queryParams,
178
152
  data: { ...queryParams.data, documentId }
179
153
  });
154
+ emitEvent("entry.create", updatedDraft);
180
155
  }
181
156
  }
182
157
  if (hasDraftAndPublish && updatedDraft && params$1.status === "published") {
183
- return publish(documentId, params$1).then((doc) => doc.versions[0]);
158
+ return publish({
159
+ ...params$1,
160
+ documentId
161
+ }).then((doc) => doc.entries[0]);
184
162
  }
185
163
  return updatedDraft;
186
164
  }
187
165
  async function count(params2 = {}) {
188
- const query = await strapiUtils.async.pipe(
166
+ const query$1 = await strapiUtils.async.pipe(
189
167
  draftAndPublish.defaultStatus(contentType),
190
168
  draftAndPublish.statusToLookup(contentType),
191
169
  internationalization.defaultLocale(contentType),
192
170
  internationalization.localeToLookup(contentType),
193
- transformParamsToQuery(uid)
171
+ query.transformParamsToQuery(uid)
194
172
  )(params2);
195
- return strapi.db.query(uid).count(query);
173
+ return strapi.db.query(uid).count(query$1);
196
174
  }
197
- async function publish(documentId, params2 = {}) {
175
+ async function publish(opts = {}) {
176
+ const { documentId, ...params2 } = opts;
198
177
  const queryParams = await strapiUtils.async.pipe(
199
178
  internationalization.defaultLocale(contentType),
200
179
  internationalization.multiLocaleToLookup(contentType)
201
180
  )(params2);
202
- await deleteFn(documentId, {
203
- ...queryParams,
204
- lookup: { ...queryParams?.lookup, publishedAt: { $ne: null } }
205
- });
206
- const entriesToPublish = await strapi.db?.query(uid).findMany({
207
- where: {
208
- ...queryParams?.lookup,
209
- documentId,
210
- publishedAt: null
211
- },
212
- populate: populate.getDeepPopulate(uid, { relationalFields: ["documentId", "locale"] })
213
- });
214
- const publishedEntries = await strapiUtils.async.map(
215
- entriesToPublish,
216
- strapiUtils.async.pipe(
217
- // Updated at value is used to know if draft has been modified
218
- // If both versions share the same value, it means the draft has not been modified
219
- (draft) => _.assoc("updatedAt", draft.updatedAt, draft),
220
- _.assoc("publishedAt", /* @__PURE__ */ new Date()),
221
- _.assoc("documentId", documentId),
222
- _.omit("id"),
223
- // Transform relations to target published versions
224
- (entry) => {
225
- const opts = { uid, locale: entry.locale, status: "published", allowMissingId: true };
226
- return data.transformData(entry, opts);
181
+ const [draftsToPublish, publishedToDelete] = await Promise.all([
182
+ strapi.db.query(uid).findMany({
183
+ where: {
184
+ ...queryParams?.lookup,
185
+ documentId,
186
+ publishedAt: null
187
+ // Ignore lookup
227
188
  },
228
- // Create the published entry
229
- (data2) => createEntry({ ...queryParams, data: data2, locale: data2.locale, status: "published" })
230
- )
189
+ // Populate relations, media, compos and dz
190
+ populate: populate.getDeepPopulate(uid, { relationalFields: ["documentId", "locale"] })
191
+ }),
192
+ strapi.db.query(uid).findMany({
193
+ where: {
194
+ ...queryParams?.lookup,
195
+ documentId,
196
+ publishedAt: { $ne: null }
197
+ },
198
+ select: ["id"]
199
+ })
200
+ ]);
201
+ await strapiUtils.async.map(publishedToDelete, (entry) => entries$1.delete(entry.id));
202
+ const publishedEntries = await strapiUtils.async.map(
203
+ draftsToPublish,
204
+ (draft) => entries$1.publish(draft, queryParams)
231
205
  );
232
- return { versions: publishedEntries };
206
+ publishedEntries.forEach(emitEvent("entry.publish"));
207
+ return { documentId, entries: publishedEntries };
233
208
  }
234
- async function unpublish(documentId, params2 = {}) {
235
- const queryParams = await strapiUtils.async.pipe(
209
+ async function unpublish(opts = {}) {
210
+ const { documentId, ...params2 } = opts;
211
+ const query$1 = await strapiUtils.async.pipe(
236
212
  internationalization.defaultLocale(contentType),
237
- internationalization.multiLocaleToLookup(contentType)
213
+ internationalization.multiLocaleToLookup(contentType),
214
+ query.transformParamsToQuery(uid),
215
+ (query2) => _.assoc("where", { ...query2.where, documentId, publishedAt: { $ne: null } }, query2)
238
216
  )(params2);
239
- const { deletedEntries } = await deleteFn(documentId, {
240
- ...params2,
241
- lookup: { ...queryParams?.lookup, publishedAt: { $ne: null } }
242
- });
243
- return { versions: deletedEntries };
217
+ const versionsToDelete = await strapi.db.query(uid).findMany(query$1);
218
+ await strapiUtils.async.map(versionsToDelete, (entry) => entries$1.delete(entry.id));
219
+ versionsToDelete.forEach(emitEvent("entry.unpublish"));
220
+ return { documentId, entries: versionsToDelete };
244
221
  }
245
- async function discardDraft(documentId, params2 = {}) {
222
+ async function discardDraft(opts = {}) {
223
+ const { documentId, ...params2 } = opts;
246
224
  const queryParams = await strapiUtils.async.pipe(
247
225
  internationalization.defaultLocale(contentType),
248
226
  internationalization.multiLocaleToLookup(contentType)
249
227
  )(params2);
250
- await deleteFn(documentId, {
251
- ...queryParams,
252
- // Delete all drafts that match query
253
- lookup: { ...queryParams?.lookup, publishedAt: null }
254
- });
255
- const entriesToDraft = await strapi.db?.query(uid).findMany({
256
- where: {
257
- ...queryParams?.lookup,
258
- documentId,
259
- publishedAt: { $ne: null }
260
- },
261
- populate: populate.getDeepPopulate(uid, { relationalFields: ["documentId", "locale"] })
262
- });
263
- const draftEntries = await strapiUtils.async.map(
264
- entriesToDraft,
265
- strapiUtils.async.pipe(
266
- _.assoc("publishedAt", null),
267
- _.assoc("documentId", documentId),
268
- _.omit("id"),
269
- // Transform relations to target draft versions
270
- (entry) => {
271
- const opts = { uid, locale: entry.locale, status: "draft", allowMissingId: true };
272
- return data.transformData(entry, opts);
228
+ const [versionsToDraft, versionsToDelete] = await Promise.all([
229
+ strapi.db.query(uid).findMany({
230
+ where: {
231
+ ...queryParams?.lookup,
232
+ documentId,
233
+ publishedAt: { $ne: null }
273
234
  },
274
- // Create the draft entry
275
- (data2) => createEntry({ ...queryParams, locale: data2.locale, data: data2, status: "draft" })
276
- )
235
+ // Populate relations, media, compos and dz
236
+ populate: populate.getDeepPopulate(uid, { relationalFields: ["documentId", "locale"] })
237
+ }),
238
+ strapi.db.query(uid).findMany({
239
+ where: {
240
+ ...queryParams?.lookup,
241
+ documentId,
242
+ publishedAt: null
243
+ },
244
+ select: ["id"]
245
+ })
246
+ ]);
247
+ await strapiUtils.async.map(versionsToDelete, (entry) => entries$1.delete(entry.id));
248
+ const draftEntries = await strapiUtils.async.map(
249
+ versionsToDraft,
250
+ (entry) => entries$1.discardDraft(entry, queryParams)
277
251
  );
278
- return { versions: draftEntries };
252
+ draftEntries.forEach(emitEvent("entry.draft-discard"));
253
+ return { documentId, entries: draftEntries };
254
+ }
255
+ async function updateComponents(entry, data) {
256
+ return components.updateComponents(uid, entry, data);
257
+ }
258
+ function omitComponentData(data) {
259
+ return components.omitComponentData(contentType, data);
279
260
  }
280
261
  return {
281
262
  findMany: common.wrapInTransaction(findMany),
282
263
  findFirst: common.wrapInTransaction(findFirst),
283
264
  findOne: common.wrapInTransaction(findOne),
284
- delete: common.wrapInTransaction(deleteFn),
265
+ delete: common.wrapInTransaction(deleteDocument),
285
266
  create: common.wrapInTransaction(create),
286
267
  clone: common.wrapInTransaction(clone),
287
268
  update: common.wrapInTransaction(update),
288
269
  count: common.wrapInTransaction(count),
289
270
  publish: hasDraftAndPublish ? common.wrapInTransaction(publish) : void 0,
290
271
  unpublish: hasDraftAndPublish ? common.wrapInTransaction(unpublish) : void 0,
291
- discardDraft: hasDraftAndPublish ? common.wrapInTransaction(discardDraft) : void 0
272
+ discardDraft: hasDraftAndPublish ? common.wrapInTransaction(discardDraft) : void 0,
273
+ updateComponents,
274
+ omitComponentData
292
275
  };
293
276
  };
294
277
  exports.createContentTypeRepository = createContentTypeRepository;