@strapi/core 5.0.0-beta.1 → 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 (392) hide show
  1. package/dist/Strapi.d.ts +34 -45
  2. package/dist/Strapi.d.ts.map +1 -1
  3. package/dist/Strapi.js +143 -222
  4. package/dist/Strapi.js.map +1 -1
  5. package/dist/Strapi.mjs +133 -213
  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/core-api/controller/collection-type.d.ts.map +1 -1
  25. package/dist/core-api/controller/collection-type.js +3 -0
  26. package/dist/core-api/controller/collection-type.js.map +1 -1
  27. package/dist/core-api/controller/collection-type.mjs +3 -0
  28. package/dist/core-api/controller/collection-type.mjs.map +1 -1
  29. package/dist/core-api/controller/single-type.d.ts.map +1 -1
  30. package/dist/core-api/controller/single-type.js +1 -0
  31. package/dist/core-api/controller/single-type.js.map +1 -1
  32. package/dist/core-api/controller/single-type.mjs +1 -0
  33. package/dist/core-api/controller/single-type.mjs.map +1 -1
  34. package/dist/core-api/routes/index.d.ts.map +1 -1
  35. package/dist/core-api/service/collection-type.d.ts +5 -11
  36. package/dist/core-api/service/collection-type.d.ts.map +1 -1
  37. package/dist/core-api/service/collection-type.js +18 -7
  38. package/dist/core-api/service/collection-type.js.map +1 -1
  39. package/dist/core-api/service/collection-type.mjs +19 -8
  40. package/dist/core-api/service/collection-type.mjs.map +1 -1
  41. package/dist/core-api/service/pagination.d.ts +4 -11
  42. package/dist/core-api/service/pagination.d.ts.map +1 -1
  43. package/dist/core-api/service/pagination.js +14 -40
  44. package/dist/core-api/service/pagination.js.map +1 -1
  45. package/dist/core-api/service/pagination.mjs +16 -42
  46. package/dist/core-api/service/pagination.mjs.map +1 -1
  47. package/dist/core-api/service/single-type.d.ts.map +1 -1
  48. package/dist/core-api/service/single-type.js +9 -2
  49. package/dist/core-api/service/single-type.js.map +1 -1
  50. package/dist/core-api/service/single-type.mjs +9 -2
  51. package/dist/core-api/service/single-type.mjs.map +1 -1
  52. package/dist/ee/index.d.ts +2 -0
  53. package/dist/ee/index.d.ts.map +1 -1
  54. package/dist/ee/index.js.map +1 -1
  55. package/dist/ee/index.mjs.map +1 -1
  56. package/dist/ee/license.d.ts.map +1 -1
  57. package/dist/ee/license.js +2 -1
  58. package/dist/ee/license.js.map +1 -1
  59. package/dist/ee/license.mjs +2 -1
  60. package/dist/ee/license.mjs.map +1 -1
  61. package/dist/factories.d.ts +2 -2
  62. package/dist/factories.d.ts.map +1 -1
  63. package/dist/factories.js.map +1 -1
  64. package/dist/factories.mjs.map +1 -1
  65. package/dist/index.d.ts +4 -2
  66. package/dist/index.d.ts.map +1 -1
  67. package/dist/index.js +25 -1
  68. package/dist/index.js.map +1 -1
  69. package/dist/index.mjs +27 -3
  70. package/dist/index.mjs.map +1 -1
  71. package/dist/loaders/admin.js +0 -1
  72. package/dist/loaders/admin.js.map +1 -1
  73. package/dist/loaders/admin.mjs +0 -1
  74. package/dist/loaders/admin.mjs.map +1 -1
  75. package/dist/loaders/apis.d.ts.map +1 -1
  76. package/dist/loaders/apis.js +10 -10
  77. package/dist/loaders/apis.js.map +1 -1
  78. package/dist/loaders/apis.mjs +10 -10
  79. package/dist/loaders/apis.mjs.map +1 -1
  80. package/dist/loaders/index.d.ts.map +1 -1
  81. package/dist/loaders/index.js +0 -2
  82. package/dist/loaders/index.js.map +1 -1
  83. package/dist/loaders/index.mjs +0 -2
  84. package/dist/loaders/index.mjs.map +1 -1
  85. package/dist/loaders/plugins/get-enabled-plugins.d.ts.map +1 -1
  86. package/dist/loaders/plugins/get-enabled-plugins.js +7 -6
  87. package/dist/loaders/plugins/get-enabled-plugins.js.map +1 -1
  88. package/dist/loaders/plugins/get-enabled-plugins.mjs +7 -6
  89. package/dist/loaders/plugins/get-enabled-plugins.mjs.map +1 -1
  90. package/dist/middlewares/body.d.ts +2 -2
  91. package/dist/middlewares/body.d.ts.map +1 -1
  92. package/dist/middlewares/body.js +4 -4
  93. package/dist/middlewares/body.js.map +1 -1
  94. package/dist/middlewares/body.mjs +4 -4
  95. package/dist/middlewares/body.mjs.map +1 -1
  96. package/dist/middlewares/cors.d.ts.map +1 -1
  97. package/dist/middlewares/cors.js +6 -8
  98. package/dist/middlewares/cors.js.map +1 -1
  99. package/dist/middlewares/cors.mjs +6 -8
  100. package/dist/middlewares/cors.mjs.map +1 -1
  101. package/dist/middlewares/public.js +1 -1
  102. package/dist/middlewares/public.js.map +1 -1
  103. package/dist/middlewares/public.mjs +1 -1
  104. package/dist/middlewares/public.mjs.map +1 -1
  105. package/dist/middlewares/security.d.ts.map +1 -1
  106. package/dist/middlewares/security.js +10 -3
  107. package/dist/middlewares/security.js.map +1 -1
  108. package/dist/middlewares/security.mjs +11 -4
  109. package/dist/middlewares/security.mjs.map +1 -1
  110. package/dist/migrations/database/5.0.0-discard-drafts.d.ts +30 -0
  111. package/dist/migrations/database/5.0.0-discard-drafts.d.ts.map +1 -0
  112. package/dist/migrations/database/5.0.0-discard-drafts.js +50 -0
  113. package/dist/migrations/database/5.0.0-discard-drafts.js.map +1 -0
  114. package/dist/migrations/database/5.0.0-discard-drafts.mjs +50 -0
  115. package/dist/migrations/database/5.0.0-discard-drafts.mjs.map +1 -0
  116. package/dist/migrations/draft-publish.d.ts.map +1 -1
  117. package/dist/migrations/draft-publish.js +14 -31
  118. package/dist/migrations/draft-publish.js.map +1 -1
  119. package/dist/migrations/draft-publish.mjs +15 -32
  120. package/dist/migrations/draft-publish.mjs.map +1 -1
  121. package/dist/providers/admin.d.ts +3 -0
  122. package/dist/providers/admin.d.ts.map +1 -0
  123. package/dist/providers/admin.js +20 -0
  124. package/dist/providers/admin.js.map +1 -0
  125. package/dist/providers/admin.mjs +21 -0
  126. package/dist/providers/admin.mjs.map +1 -0
  127. package/dist/providers/coreStore.d.ts +3 -0
  128. package/dist/providers/coreStore.d.ts.map +1 -0
  129. package/dist/providers/coreStore.js +11 -0
  130. package/dist/providers/coreStore.js.map +1 -0
  131. package/dist/providers/coreStore.mjs +12 -0
  132. package/dist/providers/coreStore.mjs.map +1 -0
  133. package/dist/providers/cron.d.ts +3 -0
  134. package/dist/providers/cron.d.ts.map +1 -0
  135. package/dist/providers/cron.js +20 -0
  136. package/dist/providers/cron.js.map +1 -0
  137. package/dist/providers/cron.mjs +21 -0
  138. package/dist/providers/cron.mjs.map +1 -0
  139. package/dist/providers/index.d.ts +3 -0
  140. package/dist/providers/index.d.ts.map +1 -0
  141. package/dist/providers/index.js +11 -0
  142. package/dist/providers/index.js.map +1 -0
  143. package/dist/providers/index.mjs +11 -0
  144. package/dist/providers/index.mjs.map +1 -0
  145. package/dist/providers/provider.d.ts +9 -0
  146. package/dist/providers/provider.d.ts.map +1 -0
  147. package/dist/providers/provider.js +5 -0
  148. package/dist/providers/provider.js.map +1 -0
  149. package/dist/providers/provider.mjs +5 -0
  150. package/dist/providers/provider.mjs.map +1 -0
  151. package/dist/providers/registries.d.ts +3 -0
  152. package/dist/providers/registries.d.ts.map +1 -0
  153. package/dist/providers/registries.js +35 -0
  154. package/dist/providers/registries.js.map +1 -0
  155. package/dist/providers/registries.mjs +36 -0
  156. package/dist/providers/registries.mjs.map +1 -0
  157. package/dist/providers/telemetry.d.ts +3 -0
  158. package/dist/providers/telemetry.d.ts.map +1 -0
  159. package/dist/providers/telemetry.js +19 -0
  160. package/dist/providers/telemetry.js.map +1 -0
  161. package/dist/providers/telemetry.mjs +20 -0
  162. package/dist/providers/telemetry.mjs.map +1 -0
  163. package/dist/providers/webhooks.d.ts +3 -0
  164. package/dist/providers/webhooks.d.ts.map +1 -0
  165. package/dist/providers/webhooks.js +30 -0
  166. package/dist/providers/webhooks.js.map +1 -0
  167. package/dist/providers/webhooks.mjs +31 -0
  168. package/dist/providers/webhooks.mjs.map +1 -0
  169. package/dist/registries/index.d.ts +0 -1
  170. package/dist/registries/index.d.ts.map +1 -1
  171. package/dist/services/config.d.ts +3 -0
  172. package/dist/services/config.d.ts.map +1 -0
  173. package/dist/{registries → services}/config.js +11 -7
  174. package/dist/services/config.js.map +1 -0
  175. package/dist/{registries → services}/config.mjs +10 -7
  176. package/dist/services/config.mjs.map +1 -0
  177. package/dist/services/content-api/index.js +1 -1
  178. package/dist/services/content-api/index.js.map +1 -1
  179. package/dist/services/content-api/index.mjs +1 -1
  180. package/dist/services/content-api/index.mjs.map +1 -1
  181. package/dist/services/content-api/permissions/index.js +1 -1
  182. package/dist/services/content-api/permissions/index.js.map +1 -1
  183. package/dist/services/content-api/permissions/index.mjs +1 -1
  184. package/dist/services/content-api/permissions/index.mjs.map +1 -1
  185. package/dist/services/core-store.d.ts.map +1 -1
  186. package/dist/services/document-service/attributes/index.d.ts +6 -0
  187. package/dist/services/document-service/attributes/index.d.ts.map +1 -0
  188. package/dist/services/{entity-service → document-service}/attributes/index.js +5 -5
  189. package/dist/services/document-service/attributes/index.js.map +1 -0
  190. package/dist/services/{entity-service → document-service}/attributes/index.mjs +5 -5
  191. package/dist/services/document-service/attributes/index.mjs.map +1 -0
  192. package/dist/services/document-service/attributes/transforms.d.ts.map +1 -0
  193. package/dist/services/document-service/attributes/transforms.js.map +1 -0
  194. package/dist/services/document-service/attributes/transforms.mjs.map +1 -0
  195. package/dist/services/document-service/common.d.ts +1 -1
  196. package/dist/services/document-service/common.d.ts.map +1 -1
  197. package/dist/services/document-service/common.js.map +1 -1
  198. package/dist/services/document-service/common.mjs.map +1 -1
  199. package/dist/services/document-service/components.d.ts +25 -1
  200. package/dist/services/document-service/components.d.ts.map +1 -1
  201. package/dist/services/{entity-service → document-service}/components.js +35 -45
  202. package/dist/services/document-service/components.js.map +1 -0
  203. package/dist/services/{entity-service → document-service}/components.mjs +36 -46
  204. package/dist/services/document-service/components.mjs.map +1 -0
  205. package/dist/services/document-service/entries.d.ts +10 -0
  206. package/dist/services/document-service/entries.d.ts.map +1 -0
  207. package/dist/services/document-service/entries.js +96 -0
  208. package/dist/services/document-service/entries.js.map +1 -0
  209. package/dist/services/document-service/entries.mjs +96 -0
  210. package/dist/services/document-service/entries.mjs.map +1 -0
  211. package/dist/services/document-service/events.d.ts +25 -0
  212. package/dist/services/document-service/events.d.ts.map +1 -0
  213. package/dist/services/document-service/events.js +47 -0
  214. package/dist/services/document-service/events.js.map +1 -0
  215. package/dist/services/document-service/events.mjs +47 -0
  216. package/dist/services/document-service/events.mjs.map +1 -0
  217. package/dist/services/document-service/index.d.ts +0 -2
  218. package/dist/services/document-service/index.d.ts.map +1 -1
  219. package/dist/services/document-service/index.js +13 -2
  220. package/dist/services/document-service/index.js.map +1 -1
  221. package/dist/services/document-service/index.mjs +13 -2
  222. package/dist/services/document-service/index.mjs.map +1 -1
  223. package/dist/services/document-service/internationalization.d.ts.map +1 -1
  224. package/dist/services/document-service/internationalization.js +14 -5
  225. package/dist/services/document-service/internationalization.js.map +1 -1
  226. package/dist/services/document-service/internationalization.mjs +14 -5
  227. package/dist/services/document-service/internationalization.mjs.map +1 -1
  228. package/dist/services/document-service/middlewares/middleware-manager.d.ts +5 -2
  229. package/dist/services/document-service/middlewares/middleware-manager.d.ts.map +1 -1
  230. package/dist/services/document-service/middlewares/middleware-manager.js +8 -5
  231. package/dist/services/document-service/middlewares/middleware-manager.js.map +1 -1
  232. package/dist/services/document-service/middlewares/middleware-manager.mjs +8 -5
  233. package/dist/services/document-service/middlewares/middleware-manager.mjs.map +1 -1
  234. package/dist/services/document-service/params.d.ts +3 -1
  235. package/dist/services/document-service/params.d.ts.map +1 -1
  236. package/dist/services/document-service/params.js.map +1 -0
  237. package/dist/services/document-service/params.mjs.map +1 -0
  238. package/dist/services/document-service/repository.d.ts.map +1 -1
  239. package/dist/services/document-service/repository.js +135 -154
  240. package/dist/services/document-service/repository.js.map +1 -1
  241. package/dist/services/document-service/repository.mjs +117 -136
  242. package/dist/services/document-service/repository.mjs.map +1 -1
  243. package/dist/services/document-service/transform/data.d.ts.map +1 -1
  244. package/dist/services/document-service/transform/data.js +4 -2
  245. package/dist/services/document-service/transform/data.js.map +1 -1
  246. package/dist/services/document-service/transform/data.mjs +4 -2
  247. package/dist/services/document-service/transform/data.mjs.map +1 -1
  248. package/dist/services/document-service/transform/id-map.d.ts.map +1 -1
  249. package/dist/services/document-service/transform/query.d.ts +5 -0
  250. package/dist/services/document-service/transform/query.d.ts.map +1 -0
  251. package/dist/services/document-service/transform/query.js +9 -0
  252. package/dist/services/document-service/transform/query.js.map +1 -0
  253. package/dist/services/document-service/transform/query.mjs +9 -0
  254. package/dist/services/document-service/transform/query.mjs.map +1 -0
  255. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +8 -7
  256. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -1
  257. package/dist/services/document-service/transform/relations/extract/data-ids.js +44 -77
  258. package/dist/services/document-service/transform/relations/extract/data-ids.js.map +1 -1
  259. package/dist/services/document-service/transform/relations/extract/data-ids.mjs +44 -77
  260. package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +1 -1
  261. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts +7 -3
  262. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts.map +1 -1
  263. package/dist/services/document-service/transform/relations/transform/data-ids.js +60 -125
  264. package/dist/services/document-service/transform/relations/transform/data-ids.js.map +1 -1
  265. package/dist/services/document-service/transform/relations/transform/data-ids.mjs +61 -126
  266. package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +1 -1
  267. package/dist/services/document-service/transform/relations/transform/default-locale.d.ts +9 -0
  268. package/dist/services/document-service/transform/relations/transform/default-locale.d.ts.map +1 -0
  269. package/dist/services/document-service/transform/relations/transform/default-locale.js +32 -0
  270. package/dist/services/document-service/transform/relations/transform/default-locale.js.map +1 -0
  271. package/dist/services/document-service/transform/relations/transform/default-locale.mjs +32 -0
  272. package/dist/services/document-service/transform/relations/transform/default-locale.mjs.map +1 -0
  273. package/dist/services/document-service/transform/relations/utils/i18n.d.ts +2 -2
  274. package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -1
  275. package/dist/services/document-service/transform/relations/utils/i18n.js +3 -9
  276. package/dist/services/document-service/transform/relations/utils/i18n.js.map +1 -1
  277. package/dist/services/document-service/transform/relations/utils/i18n.mjs +3 -9
  278. package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +1 -1
  279. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts +6 -0
  280. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts.map +1 -0
  281. package/dist/services/document-service/transform/relations/utils/map-relation.js +91 -0
  282. package/dist/services/document-service/transform/relations/utils/map-relation.js.map +1 -0
  283. package/dist/services/document-service/transform/relations/utils/map-relation.mjs +91 -0
  284. package/dist/services/document-service/transform/relations/utils/map-relation.mjs.map +1 -0
  285. package/dist/services/document-service/transform/relations/utils/types.d.ts +6 -0
  286. package/dist/services/document-service/transform/relations/utils/types.d.ts.map +1 -1
  287. package/dist/services/entity-service/index.d.ts.map +1 -1
  288. package/dist/services/entity-service/index.js +11 -4
  289. package/dist/services/entity-service/index.js.map +1 -1
  290. package/dist/services/entity-service/index.mjs +11 -4
  291. package/dist/services/entity-service/index.mjs.map +1 -1
  292. package/dist/services/entity-validator/index.d.ts.map +1 -1
  293. package/dist/services/entity-validator/index.js +93 -87
  294. package/dist/services/entity-validator/index.js.map +1 -1
  295. package/dist/services/entity-validator/index.mjs +93 -87
  296. package/dist/services/entity-validator/index.mjs.map +1 -1
  297. package/dist/services/event-hub.d.ts +1 -0
  298. package/dist/services/event-hub.d.ts.map +1 -1
  299. package/dist/services/event-hub.js +9 -4
  300. package/dist/services/event-hub.js.map +1 -1
  301. package/dist/services/event-hub.mjs +9 -4
  302. package/dist/services/event-hub.mjs.map +1 -1
  303. package/dist/services/metrics/middleware.d.ts.map +1 -1
  304. package/dist/services/metrics/rate-limiter.d.ts.map +1 -1
  305. package/dist/services/metrics/rate-limiter.js.map +1 -1
  306. package/dist/services/metrics/rate-limiter.mjs.map +1 -1
  307. package/dist/services/reloader.d.ts +7 -0
  308. package/dist/services/reloader.d.ts.map +1 -0
  309. package/dist/services/reloader.js +36 -0
  310. package/dist/services/reloader.js.map +1 -0
  311. package/dist/services/reloader.mjs +36 -0
  312. package/dist/services/reloader.mjs.map +1 -0
  313. package/dist/services/server/compose-endpoint.d.ts.map +1 -1
  314. package/dist/services/server/koa.d.ts.map +1 -1
  315. package/dist/services/server/koa.js +1 -1
  316. package/dist/services/server/koa.js.map +1 -1
  317. package/dist/services/server/koa.mjs +1 -1
  318. package/dist/services/server/koa.mjs.map +1 -1
  319. package/dist/services/server/register-routes.js +3 -3
  320. package/dist/services/server/register-routes.js.map +1 -1
  321. package/dist/services/server/register-routes.mjs +3 -3
  322. package/dist/services/server/register-routes.mjs.map +1 -1
  323. package/dist/services/server/routing.d.ts +1 -1
  324. package/dist/services/webhook-runner.d.ts +2 -1
  325. package/dist/services/webhook-runner.d.ts.map +1 -1
  326. package/dist/services/webhook-runner.js.map +1 -1
  327. package/dist/services/webhook-runner.mjs.map +1 -1
  328. package/dist/services/webhook-store.d.ts +2 -8
  329. package/dist/services/webhook-store.d.ts.map +1 -1
  330. package/dist/services/webhook-store.js +14 -8
  331. package/dist/services/webhook-store.js.map +1 -1
  332. package/dist/services/webhook-store.mjs +14 -8
  333. package/dist/services/webhook-store.mjs.map +1 -1
  334. package/dist/utils/index.d.ts +2 -1
  335. package/dist/utils/index.d.ts.map +1 -1
  336. package/dist/utils/load-files.d.ts.map +1 -1
  337. package/dist/utils/resolve-working-dirs.d.ts +19 -0
  338. package/dist/utils/resolve-working-dirs.d.ts.map +1 -0
  339. package/dist/utils/resolve-working-dirs.js +13 -0
  340. package/dist/utils/resolve-working-dirs.js.map +1 -0
  341. package/dist/utils/resolve-working-dirs.mjs +11 -0
  342. package/dist/utils/resolve-working-dirs.mjs.map +1 -0
  343. package/dist/utils/startup-logger.d.ts.map +1 -1
  344. package/dist/utils/transform-content-types-to-models.d.ts +21 -16
  345. package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
  346. package/dist/utils/transform-content-types-to-models.js +105 -57
  347. package/dist/utils/transform-content-types-to-models.js.map +1 -1
  348. package/dist/utils/transform-content-types-to-models.mjs +105 -57
  349. package/dist/utils/transform-content-types-to-models.mjs.map +1 -1
  350. package/dist/utils/update-notifier/index.d.ts +1 -6
  351. package/dist/utils/update-notifier/index.d.ts.map +1 -1
  352. package/dist/utils/update-notifier/index.js +11 -14
  353. package/dist/utils/update-notifier/index.js.map +1 -1
  354. package/dist/utils/update-notifier/index.mjs +11 -14
  355. package/dist/utils/update-notifier/index.mjs.map +1 -1
  356. package/package.json +28 -26
  357. package/dist/registries/config.d.ts +0 -4
  358. package/dist/registries/config.d.ts.map +0 -1
  359. package/dist/registries/config.js.map +0 -1
  360. package/dist/registries/config.mjs.map +0 -1
  361. package/dist/services/document-service/document-engine.d.ts +0 -2
  362. package/dist/services/document-service/document-engine.d.ts.map +0 -1
  363. package/dist/services/document-service/transform/relations/transform/output-ids.d.ts +0 -2
  364. package/dist/services/document-service/transform/relations/transform/output-ids.d.ts.map +0 -1
  365. package/dist/services/document-service/transform/relations/utils/data.js +0 -12
  366. package/dist/services/document-service/transform/relations/utils/data.js.map +0 -1
  367. package/dist/services/document-service/transform/relations/utils/data.mjs +0 -12
  368. package/dist/services/document-service/transform/relations/utils/data.mjs.map +0 -1
  369. package/dist/services/entity-service/attributes/index.d.ts +0 -6
  370. package/dist/services/entity-service/attributes/index.d.ts.map +0 -1
  371. package/dist/services/entity-service/attributes/index.js.map +0 -1
  372. package/dist/services/entity-service/attributes/index.mjs.map +0 -1
  373. package/dist/services/entity-service/attributes/transforms.d.ts.map +0 -1
  374. package/dist/services/entity-service/attributes/transforms.js.map +0 -1
  375. package/dist/services/entity-service/attributes/transforms.mjs.map +0 -1
  376. package/dist/services/entity-service/components.d.ts +0 -95
  377. package/dist/services/entity-service/components.d.ts.map +0 -1
  378. package/dist/services/entity-service/components.js.map +0 -1
  379. package/dist/services/entity-service/components.mjs.map +0 -1
  380. package/dist/services/entity-service/params.d.ts +0 -8
  381. package/dist/services/entity-service/params.d.ts.map +0 -1
  382. package/dist/services/entity-service/params.js.map +0 -1
  383. package/dist/services/entity-service/params.mjs.map +0 -1
  384. package/dist/utils/get-dirs.d.ts +0 -9
  385. package/dist/utils/get-dirs.d.ts.map +0 -1
  386. package/dist/utils/get-dirs.js.map +0 -1
  387. package/dist/utils/get-dirs.mjs.map +0 -1
  388. /package/dist/services/{entity-service → document-service}/attributes/transforms.d.ts +0 -0
  389. /package/dist/services/{entity-service → document-service}/attributes/transforms.js +0 -0
  390. /package/dist/services/{entity-service → document-service}/attributes/transforms.mjs +0 -0
  391. /package/dist/services/{entity-service → document-service}/params.js +0 -0
  392. /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 { Struct, Modules } from '@strapi/types';\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 // 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,uBA4VzC,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,96 +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 = strapi.get("query-params").transform(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 (!data2) {
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 contentTypeWithoutComponentData = components.omitComponentData(contentType, validData);
90
- const entryData = index$1.applyTransforms(
91
- Object.assign(contentTypeWithoutComponentData, componentData),
92
- { 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)
93
73
  );
94
- const doc = await strapi.db.query(uid).create({ ...query, data: entryData });
95
- return doc;
74
+ entriesToDelete.forEach(emitEvent("entry.delete"));
75
+ return { documentId, entries: deletedEntries };
96
76
  }
97
- async function create(params2 = {}) {
77
+ async function create(opts = {}) {
78
+ const { documentId, ...params2 } = opts;
98
79
  const queryParams = await strapiUtils.async.pipe(
99
80
  draftAndPublish.filterDataPublishedAt,
100
81
  draftAndPublish.setStatusToDraft(contentType),
@@ -102,19 +83,24 @@ const createContentTypeRepository = (uid) => {
102
83
  internationalization.defaultLocale(contentType),
103
84
  internationalization.localeToData(contentType)
104
85
  )(params2);
105
- const doc = await createEntry(queryParams);
86
+ const doc = await entries$1.create(queryParams);
87
+ emitEvent("entry.create", doc);
106
88
  if (hasDraftAndPublish && params2.status === "published") {
107
- 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]);
108
93
  }
109
94
  return doc;
110
95
  }
111
- async function clone(documentId, params2 = {}) {
96
+ async function clone(opts = {}) {
97
+ const { documentId, ...params2 } = opts;
112
98
  const queryParams = await strapiUtils.async.pipe(
113
99
  draftAndPublish.filterDataPublishedAt,
114
100
  internationalization.defaultLocale(contentType),
115
101
  internationalization.multiLocaleToLookup(contentType)
116
102
  )(params2);
117
- const entriesToClone = await strapi.db?.query(uid).findMany({
103
+ const entriesToClone = await strapi.db.query(uid).findMany({
118
104
  where: {
119
105
  ...queryParams?.lookup,
120
106
  documentId,
@@ -131,13 +117,15 @@ const createContentTypeRepository = (uid) => {
131
117
  // assign new documentId
132
118
  _.assoc("documentId", transformContentTypesToModels.createDocumentId()),
133
119
  // Merge new data into it
134
- (data2) => _.merge(data2, queryParams.data),
135
- (data2) => createEntry({ ...queryParams, data: data2, status: "draft" })
120
+ (data) => _.merge(data, queryParams.data),
121
+ (data) => entries$1.create({ ...queryParams, data, status: "draft" })
136
122
  )
137
123
  );
138
- return { documentId: clonedEntries.at(0)?.documentId, versions: clonedEntries };
124
+ clonedEntries.forEach(emitEvent("entry.create"));
125
+ return { documentId: clonedEntries.at(0)?.documentId, entries: clonedEntries };
139
126
  }
140
- async function update(documentId, params$1 = {}) {
127
+ async function update(opts = {}) {
128
+ const { documentId, ...params$1 } = opts;
141
129
  const queryParams = await strapiUtils.async.pipe(
142
130
  draftAndPublish.filterDataPublishedAt,
143
131
  draftAndPublish.setStatusToDraft(contentType),
@@ -148,149 +136,142 @@ const createContentTypeRepository = (uid) => {
148
136
  internationalization.localeToLookup(contentType),
149
137
  internationalization.localeToData(contentType)
150
138
  )(params$1);
151
- const { data: data2, ...restParams } = await idTransform.transformParamsDocumentId(uid, queryParams || {});
152
- const query = transformParamsToQuery(uid, params.pickSelectionParams(restParams || {}));
153
- const model = strapi.contentType(uid);
154
- 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 } });
155
142
  let updatedDraft = null;
156
143
  if (entryToUpdate) {
157
- const validData = await index.validateEntityUpdate(
158
- model,
159
- // @ts-expect-error we need type guard to assert that data has the valid type
160
- data2,
161
- {
162
- isDraft: !queryParams?.data?.publishedAt,
163
- // Always update the draft version
164
- locale: queryParams?.locale
165
- },
166
- entryToUpdate
167
- );
168
- const componentData = await components.updateComponents(uid, entryToUpdate, validData);
169
- const entryData = index$1.applyTransforms(
170
- Object.assign(components.omitComponentData(model, validData), componentData),
171
- { contentType: model }
172
- );
173
- 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);
174
146
  }
175
147
  if (!updatedDraft) {
176
148
  const documentExists = await strapi.db.query(contentType.uid).findOne({ where: { documentId } });
177
149
  if (documentExists) {
178
- updatedDraft = await createEntry({
150
+ updatedDraft = await entries$1.create({
179
151
  ...queryParams,
180
152
  data: { ...queryParams.data, documentId }
181
153
  });
154
+ emitEvent("entry.create", updatedDraft);
182
155
  }
183
156
  }
184
157
  if (hasDraftAndPublish && updatedDraft && params$1.status === "published") {
185
- return publish(documentId, params$1).then((doc) => doc.versions[0]);
158
+ return publish({
159
+ ...params$1,
160
+ documentId
161
+ }).then((doc) => doc.entries[0]);
186
162
  }
187
163
  return updatedDraft;
188
164
  }
189
165
  async function count(params2 = {}) {
190
- const query = await strapiUtils.async.pipe(
166
+ const query$1 = await strapiUtils.async.pipe(
191
167
  draftAndPublish.defaultStatus(contentType),
192
168
  draftAndPublish.statusToLookup(contentType),
193
169
  internationalization.defaultLocale(contentType),
194
170
  internationalization.localeToLookup(contentType),
195
- transformParamsToQuery(uid)
171
+ query.transformParamsToQuery(uid)
196
172
  )(params2);
197
- return strapi.db.query(uid).count(query);
173
+ return strapi.db.query(uid).count(query$1);
198
174
  }
199
- async function publish(documentId, params2 = {}) {
175
+ async function publish(opts = {}) {
176
+ const { documentId, ...params2 } = opts;
200
177
  const queryParams = await strapiUtils.async.pipe(
201
178
  internationalization.defaultLocale(contentType),
202
179
  internationalization.multiLocaleToLookup(contentType)
203
180
  )(params2);
204
- await deleteFn(documentId, {
205
- ...queryParams,
206
- lookup: { ...queryParams?.lookup, publishedAt: { $ne: null } }
207
- });
208
- const entriesToPublish = await strapi.db?.query(uid).findMany({
209
- where: {
210
- ...queryParams?.lookup,
211
- documentId,
212
- publishedAt: null
213
- },
214
- populate: populate.getDeepPopulate(uid, { relationalFields: ["documentId", "locale"] })
215
- });
216
- const publishedEntries = await strapiUtils.async.map(
217
- entriesToPublish,
218
- strapiUtils.async.pipe(
219
- // Updated at value is used to know if draft has been modified
220
- // If both versions share the same value, it means the draft has not been modified
221
- (draft) => _.assoc("updatedAt", draft.updatedAt, draft),
222
- _.assoc("publishedAt", /* @__PURE__ */ new Date()),
223
- _.assoc("documentId", documentId),
224
- _.omit("id"),
225
- // Transform relations to target published versions
226
- (entry) => {
227
- const opts = { uid, locale: entry.locale, status: "published", allowMissingId: true };
228
- 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
229
188
  },
230
- // Create the published entry
231
- (data2) => createEntry({ ...queryParams, data: data2, locale: data2.locale, status: "published" })
232
- )
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)
233
205
  );
234
- return { versions: publishedEntries };
206
+ publishedEntries.forEach(emitEvent("entry.publish"));
207
+ return { documentId, entries: publishedEntries };
235
208
  }
236
- async function unpublish(documentId, params2 = {}) {
237
- const queryParams = await strapiUtils.async.pipe(
209
+ async function unpublish(opts = {}) {
210
+ const { documentId, ...params2 } = opts;
211
+ const query$1 = await strapiUtils.async.pipe(
238
212
  internationalization.defaultLocale(contentType),
239
- internationalization.multiLocaleToLookup(contentType)
213
+ internationalization.multiLocaleToLookup(contentType),
214
+ query.transformParamsToQuery(uid),
215
+ (query2) => _.assoc("where", { ...query2.where, documentId, publishedAt: { $ne: null } }, query2)
240
216
  )(params2);
241
- const { deletedEntries } = await deleteFn(documentId, {
242
- ...params2,
243
- lookup: { ...queryParams?.lookup, publishedAt: { $ne: null } }
244
- });
245
- 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 };
246
221
  }
247
- async function discardDraft(documentId, params2 = {}) {
222
+ async function discardDraft(opts = {}) {
223
+ const { documentId, ...params2 } = opts;
248
224
  const queryParams = await strapiUtils.async.pipe(
249
225
  internationalization.defaultLocale(contentType),
250
226
  internationalization.multiLocaleToLookup(contentType)
251
227
  )(params2);
252
- await deleteFn(documentId, {
253
- ...queryParams,
254
- // Delete all drafts that match query
255
- lookup: { ...queryParams?.lookup, publishedAt: null }
256
- });
257
- const entriesToDraft = await strapi.db?.query(uid).findMany({
258
- where: {
259
- ...queryParams?.lookup,
260
- documentId,
261
- publishedAt: { $ne: null }
262
- },
263
- populate: populate.getDeepPopulate(uid, { relationalFields: ["documentId", "locale"] })
264
- });
265
- const draftEntries = await strapiUtils.async.map(
266
- entriesToDraft,
267
- strapiUtils.async.pipe(
268
- _.assoc("publishedAt", null),
269
- _.assoc("documentId", documentId),
270
- _.omit("id"),
271
- // Transform relations to target draft versions
272
- (entry) => {
273
- const opts = { uid, locale: entry.locale, status: "draft", allowMissingId: true };
274
- 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 }
275
234
  },
276
- // Create the draft entry
277
- (data2) => createEntry({ ...queryParams, locale: data2.locale, data: data2, status: "draft" })
278
- )
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)
279
251
  );
280
- 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);
281
260
  }
282
261
  return {
283
262
  findMany: common.wrapInTransaction(findMany),
284
263
  findFirst: common.wrapInTransaction(findFirst),
285
264
  findOne: common.wrapInTransaction(findOne),
286
- delete: common.wrapInTransaction(deleteFn),
265
+ delete: common.wrapInTransaction(deleteDocument),
287
266
  create: common.wrapInTransaction(create),
288
267
  clone: common.wrapInTransaction(clone),
289
268
  update: common.wrapInTransaction(update),
290
269
  count: common.wrapInTransaction(count),
291
270
  publish: hasDraftAndPublish ? common.wrapInTransaction(publish) : void 0,
292
271
  unpublish: hasDraftAndPublish ? common.wrapInTransaction(unpublish) : void 0,
293
- discardDraft: hasDraftAndPublish ? common.wrapInTransaction(discardDraft) : void 0
272
+ discardDraft: hasDraftAndPublish ? common.wrapInTransaction(discardDraft) : void 0,
273
+ updateComponents,
274
+ omitComponentData
294
275
  };
295
276
  };
296
277
  exports.createContentTypeRepository = createContentTypeRepository;