@strapi/core 0.0.0-experimental.cb311d9fcfbd8e441f790aea232f0a39bdd90e16 → 0.0.0-experimental.cbffd35b6dcd522ced2dc08f13ce2c2ec983514b

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 (709) hide show
  1. package/dist/Strapi.d.ts.map +1 -1
  2. package/dist/configuration/index.d.ts.map +1 -1
  3. package/dist/core-api/service/collection-type.d.ts +2 -2
  4. package/dist/ee/index.d.ts.map +1 -1
  5. package/dist/index.js +10110 -27
  6. package/dist/index.js.map +1 -1
  7. package/dist/index.mjs +10088 -29
  8. package/dist/index.mjs.map +1 -1
  9. package/dist/loaders/plugins/get-enabled-plugins.d.ts.map +1 -1
  10. package/dist/loaders/plugins/index.d.ts.map +1 -1
  11. package/dist/middlewares/body.d.ts.map +1 -1
  12. package/dist/middlewares/security.d.ts.map +1 -1
  13. package/dist/migrations/database/5.0.0-discard-drafts.d.ts +14 -11
  14. package/dist/migrations/database/5.0.0-discard-drafts.d.ts.map +1 -1
  15. package/dist/migrations/draft-publish.d.ts +2 -2
  16. package/dist/migrations/draft-publish.d.ts.map +1 -1
  17. package/dist/migrations/i18n.d.ts +5 -0
  18. package/dist/migrations/i18n.d.ts.map +1 -0
  19. package/dist/migrations/index.d.ts +5 -0
  20. package/dist/migrations/index.d.ts.map +1 -0
  21. package/dist/providers/admin.d.ts.map +1 -1
  22. package/dist/registries/policies.d.ts +1 -1
  23. package/dist/registries/policies.d.ts.map +1 -1
  24. package/dist/services/content-api/index.d.ts +10 -12
  25. package/dist/services/content-api/index.d.ts.map +1 -1
  26. package/dist/services/content-api/permissions/index.d.ts +10 -12
  27. package/dist/services/content-api/permissions/index.d.ts.map +1 -1
  28. package/dist/services/content-api/permissions/providers/action.d.ts +5 -6
  29. package/dist/services/content-api/permissions/providers/action.d.ts.map +1 -1
  30. package/dist/services/content-api/permissions/providers/condition.d.ts +5 -6
  31. package/dist/services/content-api/permissions/providers/condition.d.ts.map +1 -1
  32. package/dist/services/cron.d.ts +3 -3
  33. package/dist/services/cron.d.ts.map +1 -1
  34. package/dist/services/document-service/common.d.ts +1 -1
  35. package/dist/services/document-service/common.d.ts.map +1 -1
  36. package/dist/services/document-service/components.d.ts.map +1 -1
  37. package/dist/services/document-service/draft-and-publish.d.ts +1 -1
  38. package/dist/services/document-service/draft-and-publish.d.ts.map +1 -1
  39. package/dist/services/document-service/entries.d.ts +2 -2
  40. package/dist/services/document-service/entries.d.ts.map +1 -1
  41. package/dist/services/document-service/events.d.ts +1 -1
  42. package/dist/services/document-service/events.d.ts.map +1 -1
  43. package/dist/services/document-service/index.d.ts +2 -1
  44. package/dist/services/document-service/index.d.ts.map +1 -1
  45. package/dist/services/document-service/repository.d.ts.map +1 -1
  46. package/dist/services/document-service/transform/id-map.d.ts +1 -1
  47. package/dist/services/document-service/transform/id-map.d.ts.map +1 -1
  48. package/dist/services/document-service/transform/id-transform.d.ts +1 -1
  49. package/dist/services/document-service/transform/id-transform.d.ts.map +1 -1
  50. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +1 -1
  51. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -1
  52. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts.map +1 -1
  53. package/dist/services/document-service/transform/relations/utils/dp.d.ts +1 -1
  54. package/dist/services/document-service/transform/relations/utils/dp.d.ts.map +1 -1
  55. package/dist/services/document-service/transform/relations/utils/i18n.d.ts +1 -1
  56. package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -1
  57. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts.map +1 -1
  58. package/dist/services/document-service/utils/bidirectional-relations.d.ts +95 -0
  59. package/dist/services/document-service/utils/bidirectional-relations.d.ts.map +1 -0
  60. package/dist/services/document-service/utils/populate.d.ts +1 -1
  61. package/dist/services/document-service/utils/populate.d.ts.map +1 -1
  62. package/dist/services/document-service/utils/unidirectional-relations.d.ts +36 -0
  63. package/dist/services/document-service/utils/unidirectional-relations.d.ts.map +1 -0
  64. package/dist/services/entity-validator/index.d.ts +1 -1
  65. package/dist/services/entity-validator/index.d.ts.map +1 -1
  66. package/dist/services/entity-validator/validators.d.ts.map +1 -1
  67. package/dist/services/metrics/middleware.d.ts.map +1 -1
  68. package/dist/services/metrics/rate-limiter.d.ts.map +1 -1
  69. package/dist/utils/startup-logger.d.ts.map +1 -1
  70. package/dist/utils/transform-content-types-to-models.d.ts +355 -23
  71. package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
  72. package/dist/utils/update-notifier/index.d.ts.map +1 -1
  73. package/package.json +30 -31
  74. package/dist/Strapi.js +0 -431
  75. package/dist/Strapi.js.map +0 -1
  76. package/dist/Strapi.mjs +0 -410
  77. package/dist/Strapi.mjs.map +0 -1
  78. package/dist/compile.js +0 -18
  79. package/dist/compile.js.map +0 -1
  80. package/dist/compile.mjs +0 -17
  81. package/dist/compile.mjs.map +0 -1
  82. package/dist/configuration/config-loader.js +0 -106
  83. package/dist/configuration/config-loader.js.map +0 -1
  84. package/dist/configuration/config-loader.mjs +0 -104
  85. package/dist/configuration/config-loader.mjs.map +0 -1
  86. package/dist/configuration/get-dirs.js +0 -31
  87. package/dist/configuration/get-dirs.js.map +0 -1
  88. package/dist/configuration/get-dirs.mjs +0 -31
  89. package/dist/configuration/get-dirs.mjs.map +0 -1
  90. package/dist/configuration/index.js +0 -80
  91. package/dist/configuration/index.js.map +0 -1
  92. package/dist/configuration/index.mjs +0 -75
  93. package/dist/configuration/index.mjs.map +0 -1
  94. package/dist/configuration/urls.js +0 -68
  95. package/dist/configuration/urls.js.map +0 -1
  96. package/dist/configuration/urls.mjs +0 -66
  97. package/dist/configuration/urls.mjs.map +0 -1
  98. package/dist/container.js +0 -30
  99. package/dist/container.js.map +0 -1
  100. package/dist/container.mjs +0 -30
  101. package/dist/container.mjs.map +0 -1
  102. package/dist/core-api/controller/collection-type.js +0 -84
  103. package/dist/core-api/controller/collection-type.js.map +0 -1
  104. package/dist/core-api/controller/collection-type.mjs +0 -84
  105. package/dist/core-api/controller/collection-type.mjs.map +0 -1
  106. package/dist/core-api/controller/index.js +0 -52
  107. package/dist/core-api/controller/index.js.map +0 -1
  108. package/dist/core-api/controller/index.mjs +0 -52
  109. package/dist/core-api/controller/index.mjs.map +0 -1
  110. package/dist/core-api/controller/single-type.js +0 -46
  111. package/dist/core-api/controller/single-type.js.map +0 -1
  112. package/dist/core-api/controller/single-type.mjs +0 -46
  113. package/dist/core-api/controller/single-type.mjs.map +0 -1
  114. package/dist/core-api/controller/transform.js +0 -76
  115. package/dist/core-api/controller/transform.js.map +0 -1
  116. package/dist/core-api/controller/transform.mjs +0 -76
  117. package/dist/core-api/controller/transform.mjs.map +0 -1
  118. package/dist/core-api/routes/index.js +0 -67
  119. package/dist/core-api/routes/index.js.map +0 -1
  120. package/dist/core-api/routes/index.mjs +0 -67
  121. package/dist/core-api/routes/index.mjs.map +0 -1
  122. package/dist/core-api/service/collection-type.js +0 -67
  123. package/dist/core-api/service/collection-type.js.map +0 -1
  124. package/dist/core-api/service/collection-type.mjs +0 -67
  125. package/dist/core-api/service/collection-type.mjs.map +0 -1
  126. package/dist/core-api/service/core-service.js +0 -12
  127. package/dist/core-api/service/core-service.js.map +0 -1
  128. package/dist/core-api/service/core-service.mjs +0 -12
  129. package/dist/core-api/service/core-service.mjs.map +0 -1
  130. package/dist/core-api/service/index.js +0 -16
  131. package/dist/core-api/service/index.js.map +0 -1
  132. package/dist/core-api/service/index.mjs +0 -16
  133. package/dist/core-api/service/index.mjs.map +0 -1
  134. package/dist/core-api/service/pagination.js +0 -52
  135. package/dist/core-api/service/pagination.js.map +0 -1
  136. package/dist/core-api/service/pagination.mjs +0 -52
  137. package/dist/core-api/service/pagination.mjs.map +0 -1
  138. package/dist/core-api/service/single-type.js +0 -46
  139. package/dist/core-api/service/single-type.js.map +0 -1
  140. package/dist/core-api/service/single-type.mjs +0 -46
  141. package/dist/core-api/service/single-type.mjs.map +0 -1
  142. package/dist/domain/content-type/index.js +0 -111
  143. package/dist/domain/content-type/index.js.map +0 -1
  144. package/dist/domain/content-type/index.mjs +0 -109
  145. package/dist/domain/content-type/index.mjs.map +0 -1
  146. package/dist/domain/content-type/validator.js +0 -77
  147. package/dist/domain/content-type/validator.js.map +0 -1
  148. package/dist/domain/content-type/validator.mjs +0 -75
  149. package/dist/domain/content-type/validator.mjs.map +0 -1
  150. package/dist/domain/module/index.js +0 -107
  151. package/dist/domain/module/index.js.map +0 -1
  152. package/dist/domain/module/index.mjs +0 -105
  153. package/dist/domain/module/index.mjs.map +0 -1
  154. package/dist/domain/module/validation.js +0 -25
  155. package/dist/domain/module/validation.js.map +0 -1
  156. package/dist/domain/module/validation.mjs +0 -25
  157. package/dist/domain/module/validation.mjs.map +0 -1
  158. package/dist/ee/index.js +0 -153
  159. package/dist/ee/index.js.map +0 -1
  160. package/dist/ee/index.mjs +0 -154
  161. package/dist/ee/index.mjs.map +0 -1
  162. package/dist/ee/license.js +0 -91
  163. package/dist/ee/license.js.map +0 -1
  164. package/dist/ee/license.mjs +0 -88
  165. package/dist/ee/license.mjs.map +0 -1
  166. package/dist/factories.js +0 -80
  167. package/dist/factories.js.map +0 -1
  168. package/dist/factories.mjs +0 -80
  169. package/dist/factories.mjs.map +0 -1
  170. package/dist/loaders/admin.js +0 -26
  171. package/dist/loaders/admin.js.map +0 -1
  172. package/dist/loaders/admin.mjs +0 -25
  173. package/dist/loaders/admin.mjs.map +0 -1
  174. package/dist/loaders/apis.js +0 -137
  175. package/dist/loaders/apis.js.map +0 -1
  176. package/dist/loaders/apis.mjs +0 -135
  177. package/dist/loaders/apis.mjs.map +0 -1
  178. package/dist/loaders/components.js +0 -38
  179. package/dist/loaders/components.js.map +0 -1
  180. package/dist/loaders/components.mjs +0 -37
  181. package/dist/loaders/components.mjs.map +0 -1
  182. package/dist/loaders/index.js +0 -24
  183. package/dist/loaders/index.js.map +0 -1
  184. package/dist/loaders/index.mjs +0 -24
  185. package/dist/loaders/index.mjs.map +0 -1
  186. package/dist/loaders/middlewares.js +0 -31
  187. package/dist/loaders/middlewares.js.map +0 -1
  188. package/dist/loaders/middlewares.mjs +0 -30
  189. package/dist/loaders/middlewares.mjs.map +0 -1
  190. package/dist/loaders/plugins/get-enabled-plugins.js +0 -138
  191. package/dist/loaders/plugins/get-enabled-plugins.js.map +0 -1
  192. package/dist/loaders/plugins/get-enabled-plugins.mjs +0 -114
  193. package/dist/loaders/plugins/get-enabled-plugins.mjs.map +0 -1
  194. package/dist/loaders/plugins/get-user-plugins-config.js +0 -27
  195. package/dist/loaders/plugins/get-user-plugins-config.js.map +0 -1
  196. package/dist/loaders/plugins/get-user-plugins-config.mjs +0 -25
  197. package/dist/loaders/plugins/get-user-plugins-config.mjs.map +0 -1
  198. package/dist/loaders/plugins/index.js +0 -118
  199. package/dist/loaders/plugins/index.js.map +0 -1
  200. package/dist/loaders/plugins/index.mjs +0 -117
  201. package/dist/loaders/plugins/index.mjs.map +0 -1
  202. package/dist/loaders/policies.js +0 -25
  203. package/dist/loaders/policies.js.map +0 -1
  204. package/dist/loaders/policies.mjs +0 -24
  205. package/dist/loaders/policies.mjs.map +0 -1
  206. package/dist/loaders/sanitizers.js +0 -6
  207. package/dist/loaders/sanitizers.js.map +0 -1
  208. package/dist/loaders/sanitizers.mjs +0 -7
  209. package/dist/loaders/sanitizers.mjs.map +0 -1
  210. package/dist/loaders/src-index.js +0 -33
  211. package/dist/loaders/src-index.js.map +0 -1
  212. package/dist/loaders/src-index.mjs +0 -34
  213. package/dist/loaders/src-index.mjs.map +0 -1
  214. package/dist/loaders/validators.js +0 -6
  215. package/dist/loaders/validators.js.map +0 -1
  216. package/dist/loaders/validators.mjs +0 -7
  217. package/dist/loaders/validators.mjs.map +0 -1
  218. package/dist/middlewares/body.js +0 -65
  219. package/dist/middlewares/body.js.map +0 -1
  220. package/dist/middlewares/body.mjs +0 -61
  221. package/dist/middlewares/body.mjs.map +0 -1
  222. package/dist/middlewares/compression.js +0 -8
  223. package/dist/middlewares/compression.js.map +0 -1
  224. package/dist/middlewares/compression.mjs +0 -6
  225. package/dist/middlewares/compression.mjs.map +0 -1
  226. package/dist/middlewares/cors.js +0 -53
  227. package/dist/middlewares/cors.js.map +0 -1
  228. package/dist/middlewares/cors.mjs +0 -51
  229. package/dist/middlewares/cors.mjs.map +0 -1
  230. package/dist/middlewares/errors.js +0 -33
  231. package/dist/middlewares/errors.js.map +0 -1
  232. package/dist/middlewares/errors.mjs +0 -33
  233. package/dist/middlewares/errors.mjs.map +0 -1
  234. package/dist/middlewares/favicon.js +0 -22
  235. package/dist/middlewares/favicon.js.map +0 -1
  236. package/dist/middlewares/favicon.mjs +0 -20
  237. package/dist/middlewares/favicon.mjs.map +0 -1
  238. package/dist/middlewares/index.js +0 -34
  239. package/dist/middlewares/index.js.map +0 -1
  240. package/dist/middlewares/index.mjs +0 -34
  241. package/dist/middlewares/index.mjs.map +0 -1
  242. package/dist/middlewares/ip.js +0 -8
  243. package/dist/middlewares/ip.js.map +0 -1
  244. package/dist/middlewares/ip.mjs +0 -6
  245. package/dist/middlewares/ip.mjs.map +0 -1
  246. package/dist/middlewares/logger.js +0 -12
  247. package/dist/middlewares/logger.js.map +0 -1
  248. package/dist/middlewares/logger.mjs +0 -12
  249. package/dist/middlewares/logger.mjs.map +0 -1
  250. package/dist/middlewares/powered-by.js +0 -14
  251. package/dist/middlewares/powered-by.js.map +0 -1
  252. package/dist/middlewares/powered-by.mjs +0 -14
  253. package/dist/middlewares/powered-by.mjs.map +0 -1
  254. package/dist/middlewares/public.js +0 -34
  255. package/dist/middlewares/public.js.map +0 -1
  256. package/dist/middlewares/public.mjs +0 -32
  257. package/dist/middlewares/public.mjs.map +0 -1
  258. package/dist/middlewares/query.js +0 -40
  259. package/dist/middlewares/query.js.map +0 -1
  260. package/dist/middlewares/query.mjs +0 -38
  261. package/dist/middlewares/query.mjs.map +0 -1
  262. package/dist/middlewares/response-time.js +0 -12
  263. package/dist/middlewares/response-time.js.map +0 -1
  264. package/dist/middlewares/response-time.mjs +0 -12
  265. package/dist/middlewares/response-time.mjs.map +0 -1
  266. package/dist/middlewares/responses.js +0 -15
  267. package/dist/middlewares/responses.js.map +0 -1
  268. package/dist/middlewares/responses.mjs +0 -15
  269. package/dist/middlewares/responses.mjs.map +0 -1
  270. package/dist/middlewares/security.js +0 -78
  271. package/dist/middlewares/security.js.map +0 -1
  272. package/dist/middlewares/security.mjs +0 -76
  273. package/dist/middlewares/security.mjs.map +0 -1
  274. package/dist/middlewares/session.js +0 -30
  275. package/dist/middlewares/session.js.map +0 -1
  276. package/dist/middlewares/session.mjs +0 -28
  277. package/dist/middlewares/session.mjs.map +0 -1
  278. package/dist/migrations/database/5.0.0-discard-drafts.js +0 -50
  279. package/dist/migrations/database/5.0.0-discard-drafts.js.map +0 -1
  280. package/dist/migrations/database/5.0.0-discard-drafts.mjs +0 -50
  281. package/dist/migrations/database/5.0.0-discard-drafts.mjs.map +0 -1
  282. package/dist/migrations/draft-publish.js +0 -42
  283. package/dist/migrations/draft-publish.js.map +0 -1
  284. package/dist/migrations/draft-publish.mjs +0 -42
  285. package/dist/migrations/draft-publish.mjs.map +0 -1
  286. package/dist/providers/admin.js +0 -20
  287. package/dist/providers/admin.js.map +0 -1
  288. package/dist/providers/admin.mjs +0 -21
  289. package/dist/providers/admin.mjs.map +0 -1
  290. package/dist/providers/coreStore.js +0 -11
  291. package/dist/providers/coreStore.js.map +0 -1
  292. package/dist/providers/coreStore.mjs +0 -12
  293. package/dist/providers/coreStore.mjs.map +0 -1
  294. package/dist/providers/cron.js +0 -20
  295. package/dist/providers/cron.js.map +0 -1
  296. package/dist/providers/cron.mjs +0 -21
  297. package/dist/providers/cron.mjs.map +0 -1
  298. package/dist/providers/index.js +0 -11
  299. package/dist/providers/index.js.map +0 -1
  300. package/dist/providers/index.mjs +0 -11
  301. package/dist/providers/index.mjs.map +0 -1
  302. package/dist/providers/provider.js +0 -5
  303. package/dist/providers/provider.js.map +0 -1
  304. package/dist/providers/provider.mjs +0 -5
  305. package/dist/providers/provider.mjs.map +0 -1
  306. package/dist/providers/registries.js +0 -35
  307. package/dist/providers/registries.js.map +0 -1
  308. package/dist/providers/registries.mjs +0 -36
  309. package/dist/providers/registries.mjs.map +0 -1
  310. package/dist/providers/telemetry.js +0 -19
  311. package/dist/providers/telemetry.js.map +0 -1
  312. package/dist/providers/telemetry.mjs +0 -20
  313. package/dist/providers/telemetry.mjs.map +0 -1
  314. package/dist/providers/webhooks.js +0 -30
  315. package/dist/providers/webhooks.js.map +0 -1
  316. package/dist/providers/webhooks.mjs +0 -31
  317. package/dist/providers/webhooks.mjs.map +0 -1
  318. package/dist/registries/apis.js +0 -23
  319. package/dist/registries/apis.js.map +0 -1
  320. package/dist/registries/apis.mjs +0 -24
  321. package/dist/registries/apis.mjs.map +0 -1
  322. package/dist/registries/components.js +0 -45
  323. package/dist/registries/components.js.map +0 -1
  324. package/dist/registries/components.mjs +0 -46
  325. package/dist/registries/components.mjs.map +0 -1
  326. package/dist/registries/content-types.js +0 -70
  327. package/dist/registries/content-types.js.map +0 -1
  328. package/dist/registries/content-types.mjs +0 -71
  329. package/dist/registries/content-types.mjs.map +0 -1
  330. package/dist/registries/controllers.js +0 -80
  331. package/dist/registries/controllers.js.map +0 -1
  332. package/dist/registries/controllers.mjs +0 -81
  333. package/dist/registries/controllers.mjs.map +0 -1
  334. package/dist/registries/custom-fields.js +0 -71
  335. package/dist/registries/custom-fields.js.map +0 -1
  336. package/dist/registries/custom-fields.mjs +0 -72
  337. package/dist/registries/custom-fields.mjs.map +0 -1
  338. package/dist/registries/hooks.js +0 -58
  339. package/dist/registries/hooks.js.map +0 -1
  340. package/dist/registries/hooks.mjs +0 -59
  341. package/dist/registries/hooks.mjs.map +0 -1
  342. package/dist/registries/middlewares.js +0 -60
  343. package/dist/registries/middlewares.js.map +0 -1
  344. package/dist/registries/middlewares.mjs +0 -61
  345. package/dist/registries/middlewares.mjs.map +0 -1
  346. package/dist/registries/models.js +0 -16
  347. package/dist/registries/models.js.map +0 -1
  348. package/dist/registries/models.mjs +0 -16
  349. package/dist/registries/models.mjs.map +0 -1
  350. package/dist/registries/modules.js +0 -39
  351. package/dist/registries/modules.js.map +0 -1
  352. package/dist/registries/modules.mjs +0 -40
  353. package/dist/registries/modules.mjs.map +0 -1
  354. package/dist/registries/namespace.js +0 -27
  355. package/dist/registries/namespace.js.map +0 -1
  356. package/dist/registries/namespace.mjs +0 -27
  357. package/dist/registries/namespace.mjs.map +0 -1
  358. package/dist/registries/plugins.js +0 -23
  359. package/dist/registries/plugins.js.map +0 -1
  360. package/dist/registries/plugins.mjs +0 -24
  361. package/dist/registries/plugins.mjs.map +0 -1
  362. package/dist/registries/policies.js +0 -108
  363. package/dist/registries/policies.js.map +0 -1
  364. package/dist/registries/policies.mjs +0 -109
  365. package/dist/registries/policies.mjs.map +0 -1
  366. package/dist/registries/sanitizers.js +0 -25
  367. package/dist/registries/sanitizers.js.map +0 -1
  368. package/dist/registries/sanitizers.mjs +0 -24
  369. package/dist/registries/sanitizers.mjs.map +0 -1
  370. package/dist/registries/services.js +0 -80
  371. package/dist/registries/services.js.map +0 -1
  372. package/dist/registries/services.mjs +0 -81
  373. package/dist/registries/services.mjs.map +0 -1
  374. package/dist/registries/validators.js +0 -25
  375. package/dist/registries/validators.js.map +0 -1
  376. package/dist/registries/validators.mjs +0 -24
  377. package/dist/registries/validators.mjs.map +0 -1
  378. package/dist/services/auth/index.js +0 -81
  379. package/dist/services/auth/index.js.map +0 -1
  380. package/dist/services/auth/index.mjs +0 -80
  381. package/dist/services/auth/index.mjs.map +0 -1
  382. package/dist/services/config.js +0 -47
  383. package/dist/services/config.js.map +0 -1
  384. package/dist/services/config.mjs +0 -47
  385. package/dist/services/config.mjs.map +0 -1
  386. package/dist/services/content-api/index.js +0 -85
  387. package/dist/services/content-api/index.js.map +0 -1
  388. package/dist/services/content-api/index.mjs +0 -84
  389. package/dist/services/content-api/index.mjs.map +0 -1
  390. package/dist/services/content-api/permissions/engine.js +0 -7
  391. package/dist/services/content-api/permissions/engine.js.map +0 -1
  392. package/dist/services/content-api/permissions/engine.mjs +0 -6
  393. package/dist/services/content-api/permissions/engine.mjs.map +0 -1
  394. package/dist/services/content-api/permissions/index.js +0 -87
  395. package/dist/services/content-api/permissions/index.js.map +0 -1
  396. package/dist/services/content-api/permissions/index.mjs +0 -86
  397. package/dist/services/content-api/permissions/index.mjs.map +0 -1
  398. package/dist/services/content-api/permissions/providers/action.js +0 -16
  399. package/dist/services/content-api/permissions/providers/action.js.map +0 -1
  400. package/dist/services/content-api/permissions/providers/action.mjs +0 -17
  401. package/dist/services/content-api/permissions/providers/action.mjs.map +0 -1
  402. package/dist/services/content-api/permissions/providers/condition.js +0 -16
  403. package/dist/services/content-api/permissions/providers/condition.js.map +0 -1
  404. package/dist/services/content-api/permissions/providers/condition.mjs +0 -17
  405. package/dist/services/content-api/permissions/providers/condition.mjs.map +0 -1
  406. package/dist/services/core-store.js +0 -107
  407. package/dist/services/core-store.js.map +0 -1
  408. package/dist/services/core-store.mjs +0 -107
  409. package/dist/services/core-store.mjs.map +0 -1
  410. package/dist/services/cron.js +0 -63
  411. package/dist/services/cron.js.map +0 -1
  412. package/dist/services/cron.mjs +0 -64
  413. package/dist/services/cron.mjs.map +0 -1
  414. package/dist/services/custom-fields.js +0 -10
  415. package/dist/services/custom-fields.js.map +0 -1
  416. package/dist/services/custom-fields.mjs +0 -11
  417. package/dist/services/custom-fields.mjs.map +0 -1
  418. package/dist/services/document-service/attributes/index.js +0 -22
  419. package/dist/services/document-service/attributes/index.js.map +0 -1
  420. package/dist/services/document-service/attributes/index.mjs +0 -22
  421. package/dist/services/document-service/attributes/index.mjs.map +0 -1
  422. package/dist/services/document-service/attributes/transforms.js +0 -20
  423. package/dist/services/document-service/attributes/transforms.js.map +0 -1
  424. package/dist/services/document-service/attributes/transforms.mjs +0 -19
  425. package/dist/services/document-service/attributes/transforms.mjs.map +0 -1
  426. package/dist/services/document-service/common.js +0 -7
  427. package/dist/services/document-service/common.js.map +0 -1
  428. package/dist/services/document-service/common.mjs +0 -7
  429. package/dist/services/document-service/common.mjs.map +0 -1
  430. package/dist/services/document-service/components.js +0 -288
  431. package/dist/services/document-service/components.js.map +0 -1
  432. package/dist/services/document-service/components.mjs +0 -286
  433. package/dist/services/document-service/components.mjs.map +0 -1
  434. package/dist/services/document-service/draft-and-publish.js +0 -69
  435. package/dist/services/document-service/draft-and-publish.js.map +0 -1
  436. package/dist/services/document-service/draft-and-publish.mjs +0 -69
  437. package/dist/services/document-service/draft-and-publish.mjs.map +0 -1
  438. package/dist/services/document-service/entries.js +0 -96
  439. package/dist/services/document-service/entries.js.map +0 -1
  440. package/dist/services/document-service/entries.mjs +0 -96
  441. package/dist/services/document-service/entries.mjs.map +0 -1
  442. package/dist/services/document-service/events.js +0 -47
  443. package/dist/services/document-service/events.js.map +0 -1
  444. package/dist/services/document-service/events.mjs +0 -47
  445. package/dist/services/document-service/events.mjs.map +0 -1
  446. package/dist/services/document-service/index.js +0 -35
  447. package/dist/services/document-service/index.js.map +0 -1
  448. package/dist/services/document-service/index.mjs +0 -35
  449. package/dist/services/document-service/index.mjs.map +0 -1
  450. package/dist/services/document-service/internationalization.js +0 -63
  451. package/dist/services/document-service/internationalization.js.map +0 -1
  452. package/dist/services/document-service/internationalization.mjs +0 -63
  453. package/dist/services/document-service/internationalization.mjs.map +0 -1
  454. package/dist/services/document-service/middlewares/errors.js +0 -25
  455. package/dist/services/document-service/middlewares/errors.js.map +0 -1
  456. package/dist/services/document-service/middlewares/errors.mjs +0 -25
  457. package/dist/services/document-service/middlewares/errors.mjs.map +0 -1
  458. package/dist/services/document-service/middlewares/middleware-manager.js +0 -49
  459. package/dist/services/document-service/middlewares/middleware-manager.js.map +0 -1
  460. package/dist/services/document-service/middlewares/middleware-manager.mjs +0 -49
  461. package/dist/services/document-service/middlewares/middleware-manager.mjs.map +0 -1
  462. package/dist/services/document-service/params.js +0 -8
  463. package/dist/services/document-service/params.js.map +0 -1
  464. package/dist/services/document-service/params.mjs +0 -8
  465. package/dist/services/document-service/params.mjs.map +0 -1
  466. package/dist/services/document-service/repository.js +0 -278
  467. package/dist/services/document-service/repository.js.map +0 -1
  468. package/dist/services/document-service/repository.mjs +0 -278
  469. package/dist/services/document-service/repository.mjs.map +0 -1
  470. package/dist/services/document-service/transform/data.js +0 -15
  471. package/dist/services/document-service/transform/data.js.map +0 -1
  472. package/dist/services/document-service/transform/data.mjs +0 -15
  473. package/dist/services/document-service/transform/data.mjs.map +0 -1
  474. package/dist/services/document-service/transform/fields.js +0 -24
  475. package/dist/services/document-service/transform/fields.js.map +0 -1
  476. package/dist/services/document-service/transform/fields.mjs +0 -24
  477. package/dist/services/document-service/transform/fields.mjs.map +0 -1
  478. package/dist/services/document-service/transform/id-map.js +0 -78
  479. package/dist/services/document-service/transform/id-map.js.map +0 -1
  480. package/dist/services/document-service/transform/id-map.mjs +0 -78
  481. package/dist/services/document-service/transform/id-map.mjs.map +0 -1
  482. package/dist/services/document-service/transform/id-transform.js +0 -33
  483. package/dist/services/document-service/transform/id-transform.js.map +0 -1
  484. package/dist/services/document-service/transform/id-transform.mjs +0 -33
  485. package/dist/services/document-service/transform/id-transform.mjs.map +0 -1
  486. package/dist/services/document-service/transform/populate.js +0 -21
  487. package/dist/services/document-service/transform/populate.js.map +0 -1
  488. package/dist/services/document-service/transform/populate.mjs +0 -21
  489. package/dist/services/document-service/transform/populate.mjs.map +0 -1
  490. package/dist/services/document-service/transform/query.js +0 -9
  491. package/dist/services/document-service/transform/query.js.map +0 -1
  492. package/dist/services/document-service/transform/query.mjs +0 -9
  493. package/dist/services/document-service/transform/query.mjs.map +0 -1
  494. package/dist/services/document-service/transform/relations/extract/data-ids.js +0 -57
  495. package/dist/services/document-service/transform/relations/extract/data-ids.js.map +0 -1
  496. package/dist/services/document-service/transform/relations/extract/data-ids.mjs +0 -57
  497. package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +0 -1
  498. package/dist/services/document-service/transform/relations/transform/data-ids.js +0 -76
  499. package/dist/services/document-service/transform/relations/transform/data-ids.js.map +0 -1
  500. package/dist/services/document-service/transform/relations/transform/data-ids.mjs +0 -76
  501. package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +0 -1
  502. package/dist/services/document-service/transform/relations/transform/default-locale.js +0 -32
  503. package/dist/services/document-service/transform/relations/transform/default-locale.js.map +0 -1
  504. package/dist/services/document-service/transform/relations/transform/default-locale.mjs +0 -32
  505. package/dist/services/document-service/transform/relations/transform/default-locale.mjs.map +0 -1
  506. package/dist/services/document-service/transform/relations/utils/dp.js +0 -30
  507. package/dist/services/document-service/transform/relations/utils/dp.js.map +0 -1
  508. package/dist/services/document-service/transform/relations/utils/dp.mjs +0 -30
  509. package/dist/services/document-service/transform/relations/utils/dp.mjs.map +0 -1
  510. package/dist/services/document-service/transform/relations/utils/i18n.js +0 -25
  511. package/dist/services/document-service/transform/relations/utils/i18n.js.map +0 -1
  512. package/dist/services/document-service/transform/relations/utils/i18n.mjs +0 -25
  513. package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +0 -1
  514. package/dist/services/document-service/transform/relations/utils/map-relation.js +0 -91
  515. package/dist/services/document-service/transform/relations/utils/map-relation.js.map +0 -1
  516. package/dist/services/document-service/transform/relations/utils/map-relation.mjs +0 -91
  517. package/dist/services/document-service/transform/relations/utils/map-relation.mjs.map +0 -1
  518. package/dist/services/document-service/utils/populate.js +0 -45
  519. package/dist/services/document-service/utils/populate.js.map +0 -1
  520. package/dist/services/document-service/utils/populate.mjs +0 -45
  521. package/dist/services/document-service/utils/populate.mjs.map +0 -1
  522. package/dist/services/entity-service/index.js +0 -169
  523. package/dist/services/entity-service/index.js.map +0 -1
  524. package/dist/services/entity-service/index.mjs +0 -167
  525. package/dist/services/entity-service/index.mjs.map +0 -1
  526. package/dist/services/entity-validator/blocks-validator.js +0 -128
  527. package/dist/services/entity-validator/blocks-validator.js.map +0 -1
  528. package/dist/services/entity-validator/blocks-validator.mjs +0 -128
  529. package/dist/services/entity-validator/blocks-validator.mjs.map +0 -1
  530. package/dist/services/entity-validator/index.js +0 -385
  531. package/dist/services/entity-validator/index.js.map +0 -1
  532. package/dist/services/entity-validator/index.mjs +0 -384
  533. package/dist/services/entity-validator/index.mjs.map +0 -1
  534. package/dist/services/entity-validator/validators.js +0 -237
  535. package/dist/services/entity-validator/validators.js.map +0 -1
  536. package/dist/services/entity-validator/validators.mjs +0 -235
  537. package/dist/services/entity-validator/validators.mjs.map +0 -1
  538. package/dist/services/errors.js +0 -76
  539. package/dist/services/errors.js.map +0 -1
  540. package/dist/services/errors.mjs +0 -74
  541. package/dist/services/errors.mjs.map +0 -1
  542. package/dist/services/event-hub.js +0 -72
  543. package/dist/services/event-hub.js.map +0 -1
  544. package/dist/services/event-hub.mjs +0 -73
  545. package/dist/services/event-hub.mjs.map +0 -1
  546. package/dist/services/features.js +0 -17
  547. package/dist/services/features.js.map +0 -1
  548. package/dist/services/features.mjs +0 -17
  549. package/dist/services/features.mjs.map +0 -1
  550. package/dist/services/fs.js +0 -51
  551. package/dist/services/fs.js.map +0 -1
  552. package/dist/services/fs.mjs +0 -49
  553. package/dist/services/fs.mjs.map +0 -1
  554. package/dist/services/metrics/admin-user-hash.js +0 -14
  555. package/dist/services/metrics/admin-user-hash.js.map +0 -1
  556. package/dist/services/metrics/admin-user-hash.mjs +0 -12
  557. package/dist/services/metrics/admin-user-hash.mjs.map +0 -1
  558. package/dist/services/metrics/index.js +0 -45
  559. package/dist/services/metrics/index.js.map +0 -1
  560. package/dist/services/metrics/index.mjs +0 -46
  561. package/dist/services/metrics/index.mjs.map +0 -1
  562. package/dist/services/metrics/is-truthy.js +0 -9
  563. package/dist/services/metrics/is-truthy.js.map +0 -1
  564. package/dist/services/metrics/is-truthy.mjs +0 -8
  565. package/dist/services/metrics/is-truthy.mjs.map +0 -1
  566. package/dist/services/metrics/middleware.js +0 -25
  567. package/dist/services/metrics/middleware.js.map +0 -1
  568. package/dist/services/metrics/middleware.mjs +0 -26
  569. package/dist/services/metrics/middleware.mjs.map +0 -1
  570. package/dist/services/metrics/rate-limiter.js +0 -21
  571. package/dist/services/metrics/rate-limiter.js.map +0 -1
  572. package/dist/services/metrics/rate-limiter.mjs +0 -22
  573. package/dist/services/metrics/rate-limiter.mjs.map +0 -1
  574. package/dist/services/metrics/sender.js +0 -76
  575. package/dist/services/metrics/sender.js.map +0 -1
  576. package/dist/services/metrics/sender.mjs +0 -70
  577. package/dist/services/metrics/sender.mjs.map +0 -1
  578. package/dist/services/query-params.js +0 -12
  579. package/dist/services/query-params.js.map +0 -1
  580. package/dist/services/query-params.mjs +0 -13
  581. package/dist/services/query-params.mjs.map +0 -1
  582. package/dist/services/reloader.js +0 -36
  583. package/dist/services/reloader.js.map +0 -1
  584. package/dist/services/reloader.mjs +0 -36
  585. package/dist/services/reloader.mjs.map +0 -1
  586. package/dist/services/request-context.js +0 -13
  587. package/dist/services/request-context.js.map +0 -1
  588. package/dist/services/request-context.mjs +0 -14
  589. package/dist/services/request-context.mjs.map +0 -1
  590. package/dist/services/server/admin-api.js +0 -13
  591. package/dist/services/server/admin-api.js.map +0 -1
  592. package/dist/services/server/admin-api.mjs +0 -13
  593. package/dist/services/server/admin-api.mjs.map +0 -1
  594. package/dist/services/server/api.js +0 -30
  595. package/dist/services/server/api.js.map +0 -1
  596. package/dist/services/server/api.mjs +0 -28
  597. package/dist/services/server/api.mjs.map +0 -1
  598. package/dist/services/server/compose-endpoint.js +0 -117
  599. package/dist/services/server/compose-endpoint.js.map +0 -1
  600. package/dist/services/server/compose-endpoint.mjs +0 -116
  601. package/dist/services/server/compose-endpoint.mjs.map +0 -1
  602. package/dist/services/server/content-api.js +0 -12
  603. package/dist/services/server/content-api.js.map +0 -1
  604. package/dist/services/server/content-api.mjs +0 -12
  605. package/dist/services/server/content-api.mjs.map +0 -1
  606. package/dist/services/server/http-server.js +0 -50
  607. package/dist/services/server/http-server.js.map +0 -1
  608. package/dist/services/server/http-server.mjs +0 -48
  609. package/dist/services/server/http-server.mjs.map +0 -1
  610. package/dist/services/server/index.js +0 -87
  611. package/dist/services/server/index.js.map +0 -1
  612. package/dist/services/server/index.mjs +0 -85
  613. package/dist/services/server/index.mjs.map +0 -1
  614. package/dist/services/server/koa.js +0 -52
  615. package/dist/services/server/koa.js.map +0 -1
  616. package/dist/services/server/koa.mjs +0 -48
  617. package/dist/services/server/koa.mjs.map +0 -1
  618. package/dist/services/server/middleware.js +0 -92
  619. package/dist/services/server/middleware.js.map +0 -1
  620. package/dist/services/server/middleware.mjs +0 -90
  621. package/dist/services/server/middleware.mjs.map +0 -1
  622. package/dist/services/server/policy.js +0 -20
  623. package/dist/services/server/policy.js.map +0 -1
  624. package/dist/services/server/policy.mjs +0 -20
  625. package/dist/services/server/policy.mjs.map +0 -1
  626. package/dist/services/server/register-middlewares.js +0 -72
  627. package/dist/services/server/register-middlewares.js.map +0 -1
  628. package/dist/services/server/register-middlewares.mjs +0 -73
  629. package/dist/services/server/register-middlewares.mjs.map +0 -1
  630. package/dist/services/server/register-routes.js +0 -76
  631. package/dist/services/server/register-routes.js.map +0 -1
  632. package/dist/services/server/register-routes.mjs +0 -75
  633. package/dist/services/server/register-routes.mjs.map +0 -1
  634. package/dist/services/server/routing.js +0 -91
  635. package/dist/services/server/routing.js.map +0 -1
  636. package/dist/services/server/routing.mjs +0 -89
  637. package/dist/services/server/routing.mjs.map +0 -1
  638. package/dist/services/utils/dynamic-zones.js +0 -17
  639. package/dist/services/utils/dynamic-zones.js.map +0 -1
  640. package/dist/services/utils/dynamic-zones.mjs +0 -18
  641. package/dist/services/utils/dynamic-zones.mjs.map +0 -1
  642. package/dist/services/webhook-runner.js +0 -133
  643. package/dist/services/webhook-runner.js.map +0 -1
  644. package/dist/services/webhook-runner.mjs +0 -131
  645. package/dist/services/webhook-runner.mjs.map +0 -1
  646. package/dist/services/webhook-store.js +0 -110
  647. package/dist/services/webhook-store.js.map +0 -1
  648. package/dist/services/webhook-store.mjs +0 -110
  649. package/dist/services/webhook-store.mjs.map +0 -1
  650. package/dist/services/worker-queue.js +0 -56
  651. package/dist/services/worker-queue.js.map +0 -1
  652. package/dist/services/worker-queue.mjs +0 -55
  653. package/dist/services/worker-queue.mjs.map +0 -1
  654. package/dist/utils/convert-custom-field-type.js +0 -24
  655. package/dist/utils/convert-custom-field-type.js.map +0 -1
  656. package/dist/utils/convert-custom-field-type.mjs +0 -24
  657. package/dist/utils/convert-custom-field-type.mjs.map +0 -1
  658. package/dist/utils/cron.js +0 -38
  659. package/dist/utils/cron.js.map +0 -1
  660. package/dist/utils/cron.mjs +0 -38
  661. package/dist/utils/cron.mjs.map +0 -1
  662. package/dist/utils/fetch.js +0 -21
  663. package/dist/utils/fetch.js.map +0 -1
  664. package/dist/utils/fetch.mjs +0 -21
  665. package/dist/utils/fetch.mjs.map +0 -1
  666. package/dist/utils/filepath-to-prop-path.js +0 -33
  667. package/dist/utils/filepath-to-prop-path.js.map +0 -1
  668. package/dist/utils/filepath-to-prop-path.mjs +0 -30
  669. package/dist/utils/filepath-to-prop-path.mjs.map +0 -1
  670. package/dist/utils/is-initialized.js +0 -16
  671. package/dist/utils/is-initialized.js.map +0 -1
  672. package/dist/utils/is-initialized.mjs +0 -16
  673. package/dist/utils/is-initialized.mjs.map +0 -1
  674. package/dist/utils/lifecycles.js +0 -9
  675. package/dist/utils/lifecycles.js.map +0 -1
  676. package/dist/utils/lifecycles.mjs +0 -9
  677. package/dist/utils/lifecycles.mjs.map +0 -1
  678. package/dist/utils/load-config-file.js +0 -45
  679. package/dist/utils/load-config-file.js.map +0 -1
  680. package/dist/utils/load-config-file.mjs +0 -42
  681. package/dist/utils/load-config-file.mjs.map +0 -1
  682. package/dist/utils/load-files.js +0 -39
  683. package/dist/utils/load-files.js.map +0 -1
  684. package/dist/utils/load-files.mjs +0 -35
  685. package/dist/utils/load-files.mjs.map +0 -1
  686. package/dist/utils/open-browser.js +0 -11
  687. package/dist/utils/open-browser.js.map +0 -1
  688. package/dist/utils/open-browser.mjs +0 -9
  689. package/dist/utils/open-browser.mjs.map +0 -1
  690. package/dist/utils/resolve-working-dirs.js +0 -13
  691. package/dist/utils/resolve-working-dirs.js.map +0 -1
  692. package/dist/utils/resolve-working-dirs.mjs +0 -11
  693. package/dist/utils/resolve-working-dirs.mjs.map +0 -1
  694. package/dist/utils/signals.js +0 -17
  695. package/dist/utils/signals.js.map +0 -1
  696. package/dist/utils/signals.mjs +0 -17
  697. package/dist/utils/signals.mjs.map +0 -1
  698. package/dist/utils/startup-logger.js +0 -81
  699. package/dist/utils/startup-logger.js.map +0 -1
  700. package/dist/utils/startup-logger.mjs +0 -77
  701. package/dist/utils/startup-logger.mjs.map +0 -1
  702. package/dist/utils/transform-content-types-to-models.js +0 -287
  703. package/dist/utils/transform-content-types-to-models.js.map +0 -1
  704. package/dist/utils/transform-content-types-to-models.mjs +0 -284
  705. package/dist/utils/transform-content-types-to-models.mjs.map +0 -1
  706. package/dist/utils/update-notifier/index.js +0 -85
  707. package/dist/utils/update-notifier/index.js.map +0 -1
  708. package/dist/utils/update-notifier/index.mjs +0 -78
  709. package/dist/utils/update-notifier/index.mjs.map +0 -1
@@ -1,278 +0,0 @@
1
- import { curry, assoc, omit, merge } from "lodash/fp";
2
- import { contentTypes, async } from "@strapi/utils";
3
- import { wrapInTransaction } from "./common.mjs";
4
- import { defaultToDraft as defaultToDraftCurry, statusToLookup as statusToLookupCurry, filterDataPublishedAt as filterDataPublishedAtCurry, setStatusToDraft as setStatusToDraftCurry, statusToData as statusToDataCurry, defaultStatus as defaultStatusCurry } from "./draft-and-publish.mjs";
5
- import { defaultLocale as defaultLocaleCurry, multiLocaleToLookup as multiLocaleToLookupCurry, localeToLookup as localeToLookupCurry, localeToData as localeToDataCurry } from "./internationalization.mjs";
6
- import { updateComponents, omitComponentData } from "./components.mjs";
7
- import { createEntriesService } from "./entries.mjs";
8
- import { pickSelectionParams } from "./params.mjs";
9
- import { createDocumentId } from "../../utils/transform-content-types-to-models.mjs";
10
- import { getDeepPopulate } from "./utils/populate.mjs";
11
- import { transformParamsToQuery } from "./transform/query.mjs";
12
- import { transformParamsDocumentId as curriedTransformParamsDocumentId } from "./transform/id-transform.mjs";
13
- import { createEventManager } from "./events.mjs";
14
- const createContentTypeRepository = (uid) => {
15
- const contentType = strapi.contentType(uid);
16
- const hasDraftAndPublish = contentTypes.hasDraftAndPublish(contentType);
17
- const entries = createEntriesService(uid);
18
- const eventManager = createEventManager(strapi, uid);
19
- const emitEvent = curry(eventManager.emitEvent);
20
- async function findMany(params = {}) {
21
- const query = await async.pipe(
22
- defaultToDraftCurry,
23
- statusToLookupCurry(contentType),
24
- defaultLocaleCurry(contentType),
25
- multiLocaleToLookupCurry(contentType),
26
- curriedTransformParamsDocumentId(uid),
27
- transformParamsToQuery(uid)
28
- )(params || {});
29
- return strapi.db.query(uid).findMany(query);
30
- }
31
- async function findFirst(params = {}) {
32
- const query = await async.pipe(
33
- defaultToDraftCurry,
34
- statusToLookupCurry(contentType),
35
- defaultLocaleCurry(contentType),
36
- localeToLookupCurry(contentType),
37
- curriedTransformParamsDocumentId(uid),
38
- transformParamsToQuery(uid)
39
- )(params);
40
- return strapi.db.query(uid).findOne(query);
41
- }
42
- async function findOne(opts = {}) {
43
- const { documentId, ...params } = opts;
44
- const query = await async.pipe(
45
- defaultToDraftCurry,
46
- statusToLookupCurry(contentType),
47
- defaultLocaleCurry(contentType),
48
- localeToLookupCurry(contentType),
49
- curriedTransformParamsDocumentId(uid),
50
- transformParamsToQuery(uid),
51
- (query2) => assoc("where", { ...query2.where, documentId }, query2)
52
- )(params);
53
- return strapi.db.query(uid).findOne(query);
54
- }
55
- async function deleteDocument(opts = {}) {
56
- const { documentId, ...params } = opts;
57
- const query = await async.pipe(
58
- omit("status"),
59
- defaultLocaleCurry(contentType),
60
- multiLocaleToLookupCurry(contentType),
61
- transformParamsToQuery(uid),
62
- (query2) => assoc("where", { ...query2.where, documentId }, query2)
63
- )(params);
64
- if (params.status === "draft") {
65
- throw new Error("Cannot delete a draft document");
66
- }
67
- const entriesToDelete = await strapi.db.query(uid).findMany(query);
68
- const deletedEntries = await async.map(
69
- entriesToDelete,
70
- (entryToDelete) => entries.delete(entryToDelete.id)
71
- );
72
- entriesToDelete.forEach(emitEvent("entry.delete"));
73
- return { documentId, entries: deletedEntries };
74
- }
75
- async function create(opts = {}) {
76
- const { documentId, ...params } = opts;
77
- const queryParams = await async.pipe(
78
- filterDataPublishedAtCurry,
79
- setStatusToDraftCurry(contentType),
80
- statusToDataCurry(contentType),
81
- defaultLocaleCurry(contentType),
82
- localeToDataCurry(contentType)
83
- )(params);
84
- const doc = await entries.create(queryParams);
85
- emitEvent("entry.create", doc);
86
- if (hasDraftAndPublish && params.status === "published") {
87
- return publish({
88
- ...params,
89
- documentId: doc.documentId
90
- }).then((doc2) => doc2.entries[0]);
91
- }
92
- return doc;
93
- }
94
- async function clone(opts = {}) {
95
- const { documentId, ...params } = opts;
96
- const queryParams = await async.pipe(
97
- filterDataPublishedAtCurry,
98
- defaultLocaleCurry(contentType),
99
- multiLocaleToLookupCurry(contentType)
100
- )(params);
101
- const entriesToClone = await strapi.db.query(uid).findMany({
102
- where: {
103
- ...queryParams?.lookup,
104
- documentId,
105
- // DP Enabled: Clone drafts
106
- // DP Disabled: Clone only the existing version (published)
107
- publishedAt: { $null: hasDraftAndPublish }
108
- },
109
- populate: getDeepPopulate(uid, { relationalFields: ["id"] })
110
- });
111
- const clonedEntries = await async.map(
112
- entriesToClone,
113
- async.pipe(
114
- omit("id"),
115
- // assign new documentId
116
- assoc("documentId", createDocumentId()),
117
- // Merge new data into it
118
- (data) => merge(data, queryParams.data),
119
- (data) => entries.create({ ...queryParams, data, status: "draft" })
120
- )
121
- );
122
- clonedEntries.forEach(emitEvent("entry.create"));
123
- return { documentId: clonedEntries.at(0)?.documentId, entries: clonedEntries };
124
- }
125
- async function update(opts = {}) {
126
- const { documentId, ...params } = opts;
127
- const queryParams = await async.pipe(
128
- filterDataPublishedAtCurry,
129
- setStatusToDraftCurry(contentType),
130
- statusToLookupCurry(contentType),
131
- statusToDataCurry(contentType),
132
- // Default locale will be set if not provided
133
- defaultLocaleCurry(contentType),
134
- localeToLookupCurry(contentType),
135
- localeToDataCurry(contentType)
136
- )(params);
137
- const { data, ...restParams } = await curriedTransformParamsDocumentId(uid, queryParams || {});
138
- const query = transformParamsToQuery(uid, pickSelectionParams(restParams || {}));
139
- const entryToUpdate = await strapi.db.query(uid).findOne({ ...query, where: { ...queryParams?.lookup, ...query?.where, documentId } });
140
- let updatedDraft = null;
141
- if (entryToUpdate) {
142
- updatedDraft = await entries.update(entryToUpdate, queryParams);
143
- emitEvent("entry.update", updatedDraft);
144
- }
145
- if (!updatedDraft) {
146
- const documentExists = await strapi.db.query(contentType.uid).findOne({ where: { documentId } });
147
- if (documentExists) {
148
- updatedDraft = await entries.create({
149
- ...queryParams,
150
- data: { ...queryParams.data, documentId }
151
- });
152
- emitEvent("entry.create", updatedDraft);
153
- }
154
- }
155
- if (hasDraftAndPublish && updatedDraft && params.status === "published") {
156
- return publish({
157
- ...params,
158
- documentId
159
- }).then((doc) => doc.entries[0]);
160
- }
161
- return updatedDraft;
162
- }
163
- async function count(params = {}) {
164
- const query = await async.pipe(
165
- defaultStatusCurry(contentType),
166
- statusToLookupCurry(contentType),
167
- defaultLocaleCurry(contentType),
168
- localeToLookupCurry(contentType),
169
- transformParamsToQuery(uid)
170
- )(params);
171
- return strapi.db.query(uid).count(query);
172
- }
173
- async function publish(opts = {}) {
174
- const { documentId, ...params } = opts;
175
- const queryParams = await async.pipe(
176
- defaultLocaleCurry(contentType),
177
- multiLocaleToLookupCurry(contentType)
178
- )(params);
179
- const [draftsToPublish, publishedToDelete] = await Promise.all([
180
- strapi.db.query(uid).findMany({
181
- where: {
182
- ...queryParams?.lookup,
183
- documentId,
184
- publishedAt: null
185
- // Ignore lookup
186
- },
187
- // Populate relations, media, compos and dz
188
- populate: getDeepPopulate(uid, { relationalFields: ["documentId", "locale"] })
189
- }),
190
- strapi.db.query(uid).findMany({
191
- where: {
192
- ...queryParams?.lookup,
193
- documentId,
194
- publishedAt: { $ne: null }
195
- },
196
- select: ["id"]
197
- })
198
- ]);
199
- await async.map(publishedToDelete, (entry) => entries.delete(entry.id));
200
- const publishedEntries = await async.map(
201
- draftsToPublish,
202
- (draft) => entries.publish(draft, queryParams)
203
- );
204
- publishedEntries.forEach(emitEvent("entry.publish"));
205
- return { documentId, entries: publishedEntries };
206
- }
207
- async function unpublish(opts = {}) {
208
- const { documentId, ...params } = opts;
209
- const query = await async.pipe(
210
- defaultLocaleCurry(contentType),
211
- multiLocaleToLookupCurry(contentType),
212
- transformParamsToQuery(uid),
213
- (query2) => assoc("where", { ...query2.where, documentId, publishedAt: { $ne: null } }, query2)
214
- )(params);
215
- const versionsToDelete = await strapi.db.query(uid).findMany(query);
216
- await async.map(versionsToDelete, (entry) => entries.delete(entry.id));
217
- versionsToDelete.forEach(emitEvent("entry.unpublish"));
218
- return { documentId, entries: versionsToDelete };
219
- }
220
- async function discardDraft(opts = {}) {
221
- const { documentId, ...params } = opts;
222
- const queryParams = await async.pipe(
223
- defaultLocaleCurry(contentType),
224
- multiLocaleToLookupCurry(contentType)
225
- )(params);
226
- const [versionsToDraft, versionsToDelete] = await Promise.all([
227
- strapi.db.query(uid).findMany({
228
- where: {
229
- ...queryParams?.lookup,
230
- documentId,
231
- publishedAt: { $ne: null }
232
- },
233
- // Populate relations, media, compos and dz
234
- populate: getDeepPopulate(uid, { relationalFields: ["documentId", "locale"] })
235
- }),
236
- strapi.db.query(uid).findMany({
237
- where: {
238
- ...queryParams?.lookup,
239
- documentId,
240
- publishedAt: null
241
- },
242
- select: ["id"]
243
- })
244
- ]);
245
- await async.map(versionsToDelete, (entry) => entries.delete(entry.id));
246
- const draftEntries = await async.map(
247
- versionsToDraft,
248
- (entry) => entries.discardDraft(entry, queryParams)
249
- );
250
- draftEntries.forEach(emitEvent("entry.draft-discard"));
251
- return { documentId, entries: draftEntries };
252
- }
253
- async function updateComponents$1(entry, data) {
254
- return updateComponents(uid, entry, data);
255
- }
256
- function omitComponentData$1(data) {
257
- return omitComponentData(contentType, data);
258
- }
259
- return {
260
- findMany: wrapInTransaction(findMany),
261
- findFirst: wrapInTransaction(findFirst),
262
- findOne: wrapInTransaction(findOne),
263
- delete: wrapInTransaction(deleteDocument),
264
- create: wrapInTransaction(create),
265
- clone: wrapInTransaction(clone),
266
- update: wrapInTransaction(update),
267
- count: wrapInTransaction(count),
268
- publish: hasDraftAndPublish ? wrapInTransaction(publish) : void 0,
269
- unpublish: hasDraftAndPublish ? wrapInTransaction(unpublish) : void 0,
270
- discardDraft: hasDraftAndPublish ? wrapInTransaction(discardDraft) : void 0,
271
- updateComponents: updateComponents$1,
272
- omitComponentData: omitComponentData$1
273
- };
274
- };
275
- export {
276
- createContentTypeRepository
277
- };
278
- //# sourceMappingURL=repository.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"repository.mjs","sources":["../../../src/services/document-service/repository.ts"],"sourcesContent":["import { omit, assoc, merge, curry } from 'lodash/fp';\n\nimport { async, contentTypes as contentTypesUtils } from '@strapi/utils';\n\nimport { wrapInTransaction, type RepositoryFactoryMethod } from './common';\nimport * as DP from './draft-and-publish';\nimport * as i18n from './internationalization';\nimport * as components from './components';\n\nimport { createEntriesService } from './entries';\nimport { pickSelectionParams } from './params';\nimport { createDocumentId } from '../../utils/transform-content-types-to-models';\nimport { getDeepPopulate } from './utils/populate';\nimport { transformParamsToQuery } from './transform/query';\nimport { transformParamsDocumentId } from './transform/id-transform';\nimport { createEventManager } from './events';\n\nexport const createContentTypeRepository: RepositoryFactoryMethod = (uid) => {\n const contentType = strapi.contentType(uid);\n const hasDraftAndPublish = contentTypesUtils.hasDraftAndPublish(contentType);\n\n const entries = createEntriesService(uid);\n\n const eventManager = createEventManager(strapi, uid);\n const emitEvent = curry(eventManager.emitEvent);\n\n async function findMany(params = {} as any) {\n const query = await async.pipe(\n DP.defaultToDraft,\n DP.statusToLookup(contentType),\n i18n.defaultLocale(contentType),\n i18n.multiLocaleToLookup(contentType),\n transformParamsDocumentId(uid),\n transformParamsToQuery(uid)\n )(params || {});\n\n return strapi.db.query(uid).findMany(query);\n }\n\n async function findFirst(params = {} as any) {\n const query = await async.pipe(\n DP.defaultToDraft,\n DP.statusToLookup(contentType),\n i18n.defaultLocale(contentType),\n i18n.localeToLookup(contentType),\n transformParamsDocumentId(uid),\n transformParamsToQuery(uid)\n )(params);\n\n return strapi.db.query(uid).findOne(query);\n }\n\n // TODO: do we really want to add filters on the findOne now that we have findFirst ?\n async function findOne(opts = {} as any) {\n const { documentId, ...params } = opts;\n\n const query = await async.pipe(\n DP.defaultToDraft,\n DP.statusToLookup(contentType),\n i18n.defaultLocale(contentType),\n i18n.localeToLookup(contentType),\n transformParamsDocumentId(uid),\n transformParamsToQuery(uid),\n (query) => assoc('where', { ...query.where, documentId }, query)\n )(params);\n\n return strapi.db.query(uid).findOne(query);\n }\n\n async function deleteDocument(opts = {} as any) {\n const { documentId, ...params } = opts;\n\n const query = await async.pipe(\n omit('status'),\n i18n.defaultLocale(contentType),\n i18n.multiLocaleToLookup(contentType),\n transformParamsToQuery(uid),\n (query) => assoc('where', { ...query.where, documentId }, query)\n )(params);\n\n if (params.status === 'draft') {\n throw new Error('Cannot delete a draft document');\n }\n\n const entriesToDelete = await strapi.db.query(uid).findMany(query);\n\n // Delete all matched entries and its components\n const deletedEntries = await async.map(entriesToDelete, (entryToDelete: any) =>\n entries.delete(entryToDelete.id)\n );\n\n entriesToDelete.forEach(emitEvent('entry.delete'));\n\n return { documentId, entries: deletedEntries };\n }\n\n async function create(opts = {} as any) {\n const { documentId, ...params } = opts;\n\n const queryParams = await async.pipe(\n DP.filterDataPublishedAt,\n DP.setStatusToDraft(contentType),\n DP.statusToData(contentType),\n i18n.defaultLocale(contentType),\n i18n.localeToData(contentType)\n )(params);\n\n const doc = await entries.create(queryParams);\n\n emitEvent('entry.create', doc);\n\n if (hasDraftAndPublish && params.status === 'published') {\n return publish({\n ...params,\n documentId: doc.documentId,\n }).then((doc) => doc.entries[0]);\n }\n\n return doc;\n }\n\n async function clone(opts = {} as any) {\n const { documentId, ...params } = opts;\n\n const queryParams = await async.pipe(\n DP.filterDataPublishedAt,\n i18n.defaultLocale(contentType),\n i18n.multiLocaleToLookup(contentType)\n )(params);\n\n // Get deep populate\n const entriesToClone = await strapi.db.query(uid).findMany({\n where: {\n ...queryParams?.lookup,\n documentId,\n // DP Enabled: Clone drafts\n // DP Disabled: Clone only the existing version (published)\n publishedAt: { $null: hasDraftAndPublish },\n },\n populate: getDeepPopulate(uid, { relationalFields: ['id'] }),\n });\n\n const clonedEntries = await async.map(\n entriesToClone,\n async.pipe(\n omit('id'),\n // assign new documentId\n assoc('documentId', createDocumentId()),\n // Merge new data into it\n (data) => merge(data, queryParams.data),\n (data) => entries.create({ ...queryParams, data, status: 'draft' })\n )\n );\n\n clonedEntries.forEach(emitEvent('entry.create'));\n\n return { documentId: clonedEntries.at(0)?.documentId, entries: clonedEntries };\n }\n\n async function update(opts = {} as any) {\n const { documentId, ...params } = opts;\n\n const queryParams = await async.pipe(\n DP.filterDataPublishedAt,\n DP.setStatusToDraft(contentType),\n DP.statusToLookup(contentType),\n DP.statusToData(contentType),\n // Default locale will be set if not provided\n i18n.defaultLocale(contentType),\n i18n.localeToLookup(contentType),\n i18n.localeToData(contentType)\n )(params);\n\n const { data, ...restParams } = await transformParamsDocumentId(uid, queryParams || {});\n const query = transformParamsToQuery(uid, pickSelectionParams(restParams || {}) as any);\n\n // Validation\n // Find if document exists\n const entryToUpdate = await strapi.db\n .query(uid)\n .findOne({ ...query, where: { ...queryParams?.lookup, ...query?.where, documentId } });\n\n let updatedDraft = null;\n if (entryToUpdate) {\n updatedDraft = await entries.update(entryToUpdate, queryParams);\n emitEvent('entry.update', updatedDraft);\n }\n\n if (!updatedDraft) {\n const documentExists = await strapi.db\n .query(contentType.uid)\n .findOne({ where: { documentId } });\n\n if (documentExists) {\n updatedDraft = await entries.create({\n ...queryParams,\n data: { ...queryParams.data, documentId },\n });\n emitEvent('entry.create', updatedDraft);\n }\n }\n\n if (hasDraftAndPublish && updatedDraft && params.status === 'published') {\n return publish({\n ...params,\n documentId,\n }).then((doc) => doc.entries[0]);\n }\n\n return updatedDraft;\n }\n\n async function count(params = {} as any) {\n const query = await async.pipe(\n DP.defaultStatus(contentType),\n DP.statusToLookup(contentType),\n i18n.defaultLocale(contentType),\n i18n.localeToLookup(contentType),\n transformParamsToQuery(uid)\n )(params);\n\n return strapi.db.query(uid).count(query);\n }\n\n async function publish(opts = {} as any) {\n const { documentId, ...params } = opts;\n\n const queryParams = await async.pipe(\n i18n.defaultLocale(contentType),\n i18n.multiLocaleToLookup(contentType)\n )(params);\n\n const [draftsToPublish, publishedToDelete] = await Promise.all([\n strapi.db.query(uid).findMany({\n where: {\n ...queryParams?.lookup,\n documentId,\n publishedAt: null, // Ignore lookup\n },\n // Populate relations, media, compos and dz\n populate: getDeepPopulate(uid, { relationalFields: ['documentId', 'locale'] }),\n }),\n strapi.db.query(uid).findMany({\n where: {\n ...queryParams?.lookup,\n documentId,\n publishedAt: { $ne: null },\n },\n select: ['id'],\n }),\n ]);\n\n // Delete all published versions\n await async.map(publishedToDelete, (entry: any) => entries.delete(entry.id));\n\n // Transform draft entry data and create published versions\n const publishedEntries = await async.map(draftsToPublish, (draft: unknown) =>\n entries.publish(draft, queryParams)\n );\n\n publishedEntries.forEach(emitEvent('entry.publish'));\n return { documentId, entries: publishedEntries };\n }\n\n async function unpublish(opts = {} as any) {\n const { documentId, ...params } = opts;\n\n const query = await async.pipe(\n i18n.defaultLocale(contentType),\n i18n.multiLocaleToLookup(contentType),\n transformParamsToQuery(uid),\n (query) => assoc('where', { ...query.where, documentId, publishedAt: { $ne: null } }, query)\n )(params);\n\n // Delete all published versions\n const versionsToDelete = await strapi.db.query(uid).findMany(query);\n await async.map(versionsToDelete, (entry: any) => entries.delete(entry.id));\n\n versionsToDelete.forEach(emitEvent('entry.unpublish'));\n return { documentId, entries: versionsToDelete };\n }\n\n async function discardDraft(opts = {} as any) {\n const { documentId, ...params } = opts;\n\n const queryParams = await async.pipe(\n i18n.defaultLocale(contentType),\n i18n.multiLocaleToLookup(contentType)\n )(params);\n\n const [versionsToDraft, versionsToDelete] = await Promise.all([\n strapi.db.query(uid).findMany({\n where: {\n ...queryParams?.lookup,\n documentId,\n publishedAt: { $ne: null },\n },\n // Populate relations, media, compos and dz\n populate: getDeepPopulate(uid, { relationalFields: ['documentId', 'locale'] }),\n }),\n strapi.db.query(uid).findMany({\n where: {\n ...queryParams?.lookup,\n documentId,\n publishedAt: null,\n },\n select: ['id'],\n }),\n ]);\n\n // Delete all drafts\n await async.map(versionsToDelete, (entry: any) => entries.delete(entry.id));\n\n // Transform published entry data and create draft versions\n const draftEntries = await async.map(versionsToDraft, (entry: any) =>\n entries.discardDraft(entry, queryParams)\n );\n\n draftEntries.forEach(emitEvent('entry.draft-discard'));\n return { documentId, entries: draftEntries };\n }\n\n async function updateComponents(entry: any, data: any) {\n return components.updateComponents(uid, entry, data);\n }\n\n function omitComponentData(data: any) {\n return components.omitComponentData(contentType, data);\n }\n\n return {\n findMany: wrapInTransaction(findMany),\n findFirst: wrapInTransaction(findFirst),\n findOne: wrapInTransaction(findOne),\n delete: wrapInTransaction(deleteDocument),\n create: wrapInTransaction(create),\n clone: wrapInTransaction(clone),\n update: wrapInTransaction(update),\n count: wrapInTransaction(count),\n publish: hasDraftAndPublish ? wrapInTransaction(publish) : (undefined as any),\n unpublish: hasDraftAndPublish ? wrapInTransaction(unpublish) : (undefined as any),\n discardDraft: hasDraftAndPublish ? wrapInTransaction(discardDraft) : (undefined as any),\n\n updateComponents,\n omitComponentData,\n };\n};\n"],"names":["contentTypesUtils","DP.defaultToDraft","DP.statusToLookup","i18n.defaultLocale","i18n.multiLocaleToLookup","transformParamsDocumentId","i18n.localeToLookup","query","DP.filterDataPublishedAt","DP.setStatusToDraft","DP.statusToData","i18n.localeToData","doc","DP.defaultStatus","updateComponents","components.updateComponents","omitComponentData","components.omitComponentData"],"mappings":";;;;;;;;;;;;;AAiBa,MAAA,8BAAuD,CAAC,QAAQ;AACrE,QAAA,cAAc,OAAO,YAAY,GAAG;AACpC,QAAA,qBAAqBA,aAAkB,mBAAmB,WAAW;AAErE,QAAA,UAAU,qBAAqB,GAAG;AAElC,QAAA,eAAe,mBAAmB,QAAQ,GAAG;AAC7C,QAAA,YAAY,MAAM,aAAa,SAAS;AAE/B,iBAAA,SAAS,SAAS,IAAW;AACpC,UAAA,QAAQ,MAAM,MAAM;AAAA,MACxBC;AAAAA,MACAC,oBAAkB,WAAW;AAAA,MAC7BC,mBAAmB,WAAW;AAAA,MAC9BC,yBAAyB,WAAW;AAAA,MACpCC,iCAA0B,GAAG;AAAA,MAC7B,uBAAuB,GAAG;AAAA,IAAA,EAC1B,UAAU,CAAA,CAAE;AAEd,WAAO,OAAO,GAAG,MAAM,GAAG,EAAE,SAAS,KAAK;AAAA,EAC5C;AAEe,iBAAA,UAAU,SAAS,IAAW;AACrC,UAAA,QAAQ,MAAM,MAAM;AAAA,MACxBJ;AAAAA,MACAC,oBAAkB,WAAW;AAAA,MAC7BC,mBAAmB,WAAW;AAAA,MAC9BG,oBAAoB,WAAW;AAAA,MAC/BD,iCAA0B,GAAG;AAAA,MAC7B,uBAAuB,GAAG;AAAA,MAC1B,MAAM;AAER,WAAO,OAAO,GAAG,MAAM,GAAG,EAAE,QAAQ,KAAK;AAAA,EAC3C;AAGe,iBAAA,QAAQ,OAAO,IAAW;AACvC,UAAM,EAAE,YAAY,GAAG,OAAA,IAAW;AAE5B,UAAA,QAAQ,MAAM,MAAM;AAAA,MACxBJ;AAAAA,MACAC,oBAAkB,WAAW;AAAA,MAC7BC,mBAAmB,WAAW;AAAA,MAC9BG,oBAAoB,WAAW;AAAA,MAC/BD,iCAA0B,GAAG;AAAA,MAC7B,uBAAuB,GAAG;AAAA,MAC1B,CAACE,WAAU,MAAM,SAAS,EAAE,GAAGA,OAAM,OAAO,WAAW,GAAGA,MAAK;AAAA,MAC/D,MAAM;AAER,WAAO,OAAO,GAAG,MAAM,GAAG,EAAE,QAAQ,KAAK;AAAA,EAC3C;AAEe,iBAAA,eAAe,OAAO,IAAW;AAC9C,UAAM,EAAE,YAAY,GAAG,OAAA,IAAW;AAE5B,UAAA,QAAQ,MAAM,MAAM;AAAA,MACxB,KAAK,QAAQ;AAAA,MACbJ,mBAAmB,WAAW;AAAA,MAC9BC,yBAAyB,WAAW;AAAA,MACpC,uBAAuB,GAAG;AAAA,MAC1B,CAACG,WAAU,MAAM,SAAS,EAAE,GAAGA,OAAM,OAAO,WAAW,GAAGA,MAAK;AAAA,MAC/D,MAAM;AAEJ,QAAA,OAAO,WAAW,SAAS;AACvB,YAAA,IAAI,MAAM,gCAAgC;AAAA,IAClD;AAEM,UAAA,kBAAkB,MAAM,OAAO,GAAG,MAAM,GAAG,EAAE,SAAS,KAAK;AAG3D,UAAA,iBAAiB,MAAM,MAAM;AAAA,MAAI;AAAA,MAAiB,CAAC,kBACvD,QAAQ,OAAO,cAAc,EAAE;AAAA,IAAA;AAGjB,oBAAA,QAAQ,UAAU,cAAc,CAAC;AAE1C,WAAA,EAAE,YAAY,SAAS;EAChC;AAEe,iBAAA,OAAO,OAAO,IAAW;AACtC,UAAM,EAAE,YAAY,GAAG,OAAA,IAAW;AAE5B,UAAA,cAAc,MAAM,MAAM;AAAA,MAC9BC;AAAAA,MACAC,sBAAoB,WAAW;AAAA,MAC/BC,kBAAgB,WAAW;AAAA,MAC3BP,mBAAmB,WAAW;AAAA,MAC9BQ,kBAAkB,WAAW;AAAA,MAC7B,MAAM;AAER,UAAM,MAAM,MAAM,QAAQ,OAAO,WAAW;AAE5C,cAAU,gBAAgB,GAAG;AAEzB,QAAA,sBAAsB,OAAO,WAAW,aAAa;AACvD,aAAO,QAAQ;AAAA,QACb,GAAG;AAAA,QACH,YAAY,IAAI;AAAA,MAAA,CACjB,EAAE,KAAK,CAACC,SAAQA,KAAI,QAAQ,CAAC,CAAC;AAAA,IACjC;AAEO,WAAA;AAAA,EACT;AAEe,iBAAA,MAAM,OAAO,IAAW;AACrC,UAAM,EAAE,YAAY,GAAG,OAAA,IAAW;AAE5B,UAAA,cAAc,MAAM,MAAM;AAAA,MAC9BJ;AAAAA,MACAL,mBAAmB,WAAW;AAAA,MAC9BC,yBAAyB,WAAW;AAAA,MACpC,MAAM;AAGR,UAAM,iBAAiB,MAAM,OAAO,GAAG,MAAM,GAAG,EAAE,SAAS;AAAA,MACzD,OAAO;AAAA,QACL,GAAG,aAAa;AAAA,QAChB;AAAA;AAAA;AAAA,QAGA,aAAa,EAAE,OAAO,mBAAmB;AAAA,MAC3C;AAAA,MACA,UAAU,gBAAgB,KAAK,EAAE,kBAAkB,CAAC,IAAI,GAAG;AAAA,IAAA,CAC5D;AAEK,UAAA,gBAAgB,MAAM,MAAM;AAAA,MAChC;AAAA,MACA,MAAM;AAAA,QACJ,KAAK,IAAI;AAAA;AAAA,QAET,MAAM,cAAc,kBAAkB;AAAA;AAAA,QAEtC,CAAC,SAAS,MAAM,MAAM,YAAY,IAAI;AAAA,QACtC,CAAC,SAAS,QAAQ,OAAO,EAAE,GAAG,aAAa,MAAM,QAAQ,SAAS;AAAA,MACpE;AAAA,IAAA;AAGY,kBAAA,QAAQ,UAAU,cAAc,CAAC;AAExC,WAAA,EAAE,YAAY,cAAc,GAAG,CAAC,GAAG,YAAY,SAAS;EACjE;AAEe,iBAAA,OAAO,OAAO,IAAW;AACtC,UAAM,EAAE,YAAY,GAAG,OAAA,IAAW;AAE5B,UAAA,cAAc,MAAM,MAAM;AAAA,MAC9BI;AAAAA,MACAC,sBAAoB,WAAW;AAAA,MAC/BP,oBAAkB,WAAW;AAAA,MAC7BQ,kBAAgB,WAAW;AAAA;AAAA,MAE3BP,mBAAmB,WAAW;AAAA,MAC9BG,oBAAoB,WAAW;AAAA,MAC/BK,kBAAkB,WAAW;AAAA,MAC7B,MAAM;AAEF,UAAA,EAAE,MAAM,GAAG,WAAW,IAAI,MAAMN,iCAA0B,KAAK,eAAe,CAAA,CAAE;AACtF,UAAM,QAAQ,uBAAuB,KAAK,oBAAoB,cAAc,CAAE,CAAA,CAAQ;AAIhF,UAAA,gBAAgB,MAAM,OAAO,GAChC,MAAM,GAAG,EACT,QAAQ,EAAE,GAAG,OAAO,OAAO,EAAE,GAAG,aAAa,QAAQ,GAAG,OAAO,OAAO,WAAW,EAAA,CAAG;AAEvF,QAAI,eAAe;AACnB,QAAI,eAAe;AACjB,qBAAe,MAAM,QAAQ,OAAO,eAAe,WAAW;AAC9D,gBAAU,gBAAgB,YAAY;AAAA,IACxC;AAEA,QAAI,CAAC,cAAc;AACjB,YAAM,iBAAiB,MAAM,OAAO,GACjC,MAAM,YAAY,GAAG,EACrB,QAAQ,EAAE,OAAO,EAAE,WAAA,EAAc,CAAA;AAEpC,UAAI,gBAAgB;AACH,uBAAA,MAAM,QAAQ,OAAO;AAAA,UAClC,GAAG;AAAA,UACH,MAAM,EAAE,GAAG,YAAY,MAAM,WAAW;AAAA,QAAA,CACzC;AACD,kBAAU,gBAAgB,YAAY;AAAA,MACxC;AAAA,IACF;AAEA,QAAI,sBAAsB,gBAAgB,OAAO,WAAW,aAAa;AACvE,aAAO,QAAQ;AAAA,QACb,GAAG;AAAA,QACH;AAAA,MAAA,CACD,EAAE,KAAK,CAAC,QAAQ,IAAI,QAAQ,CAAC,CAAC;AAAA,IACjC;AAEO,WAAA;AAAA,EACT;AAEe,iBAAA,MAAM,SAAS,IAAW;AACjC,UAAA,QAAQ,MAAM,MAAM;AAAA,MACxBQ,mBAAiB,WAAW;AAAA,MAC5BX,oBAAkB,WAAW;AAAA,MAC7BC,mBAAmB,WAAW;AAAA,MAC9BG,oBAAoB,WAAW;AAAA,MAC/B,uBAAuB,GAAG;AAAA,MAC1B,MAAM;AAER,WAAO,OAAO,GAAG,MAAM,GAAG,EAAE,MAAM,KAAK;AAAA,EACzC;AAEe,iBAAA,QAAQ,OAAO,IAAW;AACvC,UAAM,EAAE,YAAY,GAAG,OAAA,IAAW;AAE5B,UAAA,cAAc,MAAM,MAAM;AAAA,MAC9BH,mBAAmB,WAAW;AAAA,MAC9BC,yBAAyB,WAAW;AAAA,MACpC,MAAM;AAER,UAAM,CAAC,iBAAiB,iBAAiB,IAAI,MAAM,QAAQ,IAAI;AAAA,MAC7D,OAAO,GAAG,MAAM,GAAG,EAAE,SAAS;AAAA,QAC5B,OAAO;AAAA,UACL,GAAG,aAAa;AAAA,UAChB;AAAA,UACA,aAAa;AAAA;AAAA,QACf;AAAA;AAAA,QAEA,UAAU,gBAAgB,KAAK,EAAE,kBAAkB,CAAC,cAAc,QAAQ,GAAG;AAAA,MAAA,CAC9E;AAAA,MACD,OAAO,GAAG,MAAM,GAAG,EAAE,SAAS;AAAA,QAC5B,OAAO;AAAA,UACL,GAAG,aAAa;AAAA,UAChB;AAAA,UACA,aAAa,EAAE,KAAK,KAAK;AAAA,QAC3B;AAAA,QACA,QAAQ,CAAC,IAAI;AAAA,MAAA,CACd;AAAA,IAAA,CACF;AAGK,UAAA,MAAM,IAAI,mBAAmB,CAAC,UAAe,QAAQ,OAAO,MAAM,EAAE,CAAC;AAGrE,UAAA,mBAAmB,MAAM,MAAM;AAAA,MAAI;AAAA,MAAiB,CAAC,UACzD,QAAQ,QAAQ,OAAO,WAAW;AAAA,IAAA;AAGnB,qBAAA,QAAQ,UAAU,eAAe,CAAC;AAC5C,WAAA,EAAE,YAAY,SAAS;EAChC;AAEe,iBAAA,UAAU,OAAO,IAAW;AACzC,UAAM,EAAE,YAAY,GAAG,OAAA,IAAW;AAE5B,UAAA,QAAQ,MAAM,MAAM;AAAA,MACxBD,mBAAmB,WAAW;AAAA,MAC9BC,yBAAyB,WAAW;AAAA,MACpC,uBAAuB,GAAG;AAAA,MAC1B,CAACG,WAAU,MAAM,SAAS,EAAE,GAAGA,OAAM,OAAO,YAAY,aAAa,EAAE,KAAK,KAAK,EAAA,GAAKA,MAAK;AAAA,MAC3F,MAAM;AAGF,UAAA,mBAAmB,MAAM,OAAO,GAAG,MAAM,GAAG,EAAE,SAAS,KAAK;AAC5D,UAAA,MAAM,IAAI,kBAAkB,CAAC,UAAe,QAAQ,OAAO,MAAM,EAAE,CAAC;AAEzD,qBAAA,QAAQ,UAAU,iBAAiB,CAAC;AAC9C,WAAA,EAAE,YAAY,SAAS;EAChC;AAEe,iBAAA,aAAa,OAAO,IAAW;AAC5C,UAAM,EAAE,YAAY,GAAG,OAAA,IAAW;AAE5B,UAAA,cAAc,MAAM,MAAM;AAAA,MAC9BJ,mBAAmB,WAAW;AAAA,MAC9BC,yBAAyB,WAAW;AAAA,MACpC,MAAM;AAER,UAAM,CAAC,iBAAiB,gBAAgB,IAAI,MAAM,QAAQ,IAAI;AAAA,MAC5D,OAAO,GAAG,MAAM,GAAG,EAAE,SAAS;AAAA,QAC5B,OAAO;AAAA,UACL,GAAG,aAAa;AAAA,UAChB;AAAA,UACA,aAAa,EAAE,KAAK,KAAK;AAAA,QAC3B;AAAA;AAAA,QAEA,UAAU,gBAAgB,KAAK,EAAE,kBAAkB,CAAC,cAAc,QAAQ,GAAG;AAAA,MAAA,CAC9E;AAAA,MACD,OAAO,GAAG,MAAM,GAAG,EAAE,SAAS;AAAA,QAC5B,OAAO;AAAA,UACL,GAAG,aAAa;AAAA,UAChB;AAAA,UACA,aAAa;AAAA,QACf;AAAA,QACA,QAAQ,CAAC,IAAI;AAAA,MAAA,CACd;AAAA,IAAA,CACF;AAGK,UAAA,MAAM,IAAI,kBAAkB,CAAC,UAAe,QAAQ,OAAO,MAAM,EAAE,CAAC;AAGpE,UAAA,eAAe,MAAM,MAAM;AAAA,MAAI;AAAA,MAAiB,CAAC,UACrD,QAAQ,aAAa,OAAO,WAAW;AAAA,IAAA;AAG5B,iBAAA,QAAQ,UAAU,qBAAqB,CAAC;AAC9C,WAAA,EAAE,YAAY,SAAS;EAChC;AAEe,iBAAAU,mBAAiB,OAAY,MAAW;AACrD,WAAOC,iBAA4B,KAAK,OAAO,IAAI;AAAA,EACrD;AAEA,WAASC,oBAAkB,MAAW;AAC7B,WAAAC,kBAA6B,aAAa,IAAI;AAAA,EACvD;AAEO,SAAA;AAAA,IACL,UAAU,kBAAkB,QAAQ;AAAA,IACpC,WAAW,kBAAkB,SAAS;AAAA,IACtC,SAAS,kBAAkB,OAAO;AAAA,IAClC,QAAQ,kBAAkB,cAAc;AAAA,IACxC,QAAQ,kBAAkB,MAAM;AAAA,IAChC,OAAO,kBAAkB,KAAK;AAAA,IAC9B,QAAQ,kBAAkB,MAAM;AAAA,IAChC,OAAO,kBAAkB,KAAK;AAAA,IAC9B,SAAS,qBAAqB,kBAAkB,OAAO,IAAK;AAAA,IAC5D,WAAW,qBAAqB,kBAAkB,SAAS,IAAK;AAAA,IAChE,cAAc,qBAAqB,kBAAkB,YAAY,IAAK;AAAA,IAAA,kBAEtEH;AAAAA,IAAA,mBACAE;AAAAA,EAAA;AAEJ;"}
@@ -1,15 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const idMap = require("./id-map.js");
4
- const dataIds = require("./relations/extract/data-ids.js");
5
- const dataIds$1 = require("./relations/transform/data-ids.js");
6
- const defaultLocale = require("./relations/transform/default-locale.js");
7
- const transformData = async (data, opts) => {
8
- const idMap$1 = idMap.createIdMap({ strapi });
9
- const transformedData = await defaultLocale.setDefaultLocaleToRelations(data, opts.uid);
10
- await dataIds.extractDataIds(idMap$1, transformedData, opts);
11
- await idMap$1.load();
12
- return dataIds$1.transformDataIdsVisitor(idMap$1, transformedData, opts);
13
- };
14
- exports.transformData = transformData;
15
- //# sourceMappingURL=data.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"data.js","sources":["../../../../src/services/document-service/transform/data.ts"],"sourcesContent":["import { createIdMap } from './id-map';\nimport { extractDataIds as extractDataRelationIds } from './relations/extract/data-ids';\nimport { transformDataIdsVisitor as transformRelationDataIds } from './relations/transform/data-ids';\nimport { setDefaultLocaleToRelations } from './relations/transform/default-locale';\n\n/**\n * Transforms input data, containing relation document ids, to entity ids.\n */\nexport const transformData = async (data: any, opts: any) => {\n const idMap = createIdMap({ strapi });\n\n // Assign default locales\n const transformedData = await setDefaultLocaleToRelations(data, opts.uid);\n\n // Extract any relation ids from the input\n await extractDataRelationIds(idMap, transformedData, opts);\n\n // Load any relation the extract methods found\n await idMap.load();\n\n // Transform any relation ids to entity ids\n return transformRelationDataIds(idMap, transformedData, opts);\n};\n"],"names":["idMap","createIdMap","setDefaultLocaleToRelations","extractDataRelationIds","transformRelationDataIds"],"mappings":";;;;;;AAQa,MAAA,gBAAgB,OAAO,MAAW,SAAc;AAC3D,QAAMA,UAAQC,MAAAA,YAAY,EAAE,OAAQ,CAAA;AAGpC,QAAM,kBAAkB,MAAMC,cAA4B,4BAAA,MAAM,KAAK,GAAG;AAGlE,QAAAC,uBAAuBH,SAAO,iBAAiB,IAAI;AAGzD,QAAMA,QAAM;AAGL,SAAAI,kCAAyBJ,SAAO,iBAAiB,IAAI;AAC9D;;"}
@@ -1,15 +0,0 @@
1
- import { createIdMap } from "./id-map.mjs";
2
- import { extractDataIds } from "./relations/extract/data-ids.mjs";
3
- import { transformDataIdsVisitor } from "./relations/transform/data-ids.mjs";
4
- import { setDefaultLocaleToRelations } from "./relations/transform/default-locale.mjs";
5
- const transformData = async (data, opts) => {
6
- const idMap = createIdMap({ strapi });
7
- const transformedData = await setDefaultLocaleToRelations(data, opts.uid);
8
- await extractDataIds(idMap, transformedData, opts);
9
- await idMap.load();
10
- return transformDataIdsVisitor(idMap, transformedData, opts);
11
- };
12
- export {
13
- transformData
14
- };
15
- //# sourceMappingURL=data.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"data.mjs","sources":["../../../../src/services/document-service/transform/data.ts"],"sourcesContent":["import { createIdMap } from './id-map';\nimport { extractDataIds as extractDataRelationIds } from './relations/extract/data-ids';\nimport { transformDataIdsVisitor as transformRelationDataIds } from './relations/transform/data-ids';\nimport { setDefaultLocaleToRelations } from './relations/transform/default-locale';\n\n/**\n * Transforms input data, containing relation document ids, to entity ids.\n */\nexport const transformData = async (data: any, opts: any) => {\n const idMap = createIdMap({ strapi });\n\n // Assign default locales\n const transformedData = await setDefaultLocaleToRelations(data, opts.uid);\n\n // Extract any relation ids from the input\n await extractDataRelationIds(idMap, transformedData, opts);\n\n // Load any relation the extract methods found\n await idMap.load();\n\n // Transform any relation ids to entity ids\n return transformRelationDataIds(idMap, transformedData, opts);\n};\n"],"names":["extractDataRelationIds","transformRelationDataIds"],"mappings":";;;;AAQa,MAAA,gBAAgB,OAAO,MAAW,SAAc;AAC3D,QAAM,QAAQ,YAAY,EAAE,OAAQ,CAAA;AAGpC,QAAM,kBAAkB,MAAM,4BAA4B,MAAM,KAAK,GAAG;AAGlE,QAAAA,eAAuB,OAAO,iBAAiB,IAAI;AAGzD,QAAM,MAAM;AAGL,SAAAC,wBAAyB,OAAO,iBAAiB,IAAI;AAC9D;"}
@@ -1,24 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const transformFields = (fields) => {
4
- if (typeof fields === "string") {
5
- if (fields === "*") {
6
- return fields;
7
- }
8
- if (fields === "") {
9
- return "documentId";
10
- }
11
- if (!fields.split(",").includes("documentId")) {
12
- return `${fields},documentId`;
13
- }
14
- }
15
- if (!fields || !Array.isArray(fields)) {
16
- return fields;
17
- }
18
- if (!fields.includes("documentId")) {
19
- fields.push("documentId");
20
- }
21
- return fields;
22
- };
23
- exports.transformFields = transformFields;
24
- //# sourceMappingURL=fields.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"fields.js","sources":["../../../../src/services/document-service/transform/fields.ts"],"sourcesContent":["import type { Modules, UID } from '@strapi/types';\n\ntype Fields = Modules.Documents.Params.Pick<UID.Schema, 'fields'>['fields'];\n\nexport const transformFields = (fields: Fields): Fields => {\n // If it's a string, and it doesn't contain documentId, should be an array\n if (typeof fields === 'string') {\n // '*' => '*'\n if (fields === '*') {\n return fields;\n }\n\n // '' => 'documentId'\n if (fields === '') {\n return 'documentId';\n }\n\n // 'name,description' => 'name,description,documentId'\n if (!fields.split(',').includes('documentId')) {\n return `${fields},documentId`;\n }\n }\n\n // It's not an array, ignore it\n if (!fields || !Array.isArray(fields)) {\n // If fields is empty, return it as is\n return fields;\n }\n\n // Ensure we are always selecting the documentId\n // ['name', 'description'] => ['name', 'description', 'documentId']\n if (!fields.includes('documentId')) {\n fields.push('documentId');\n }\n\n return fields;\n};\n"],"names":[],"mappings":";;AAIa,MAAA,kBAAkB,CAAC,WAA2B;AAErD,MAAA,OAAO,WAAW,UAAU;AAE9B,QAAI,WAAW,KAAK;AACX,aAAA;AAAA,IACT;AAGA,QAAI,WAAW,IAAI;AACV,aAAA;AAAA,IACT;AAGA,QAAI,CAAC,OAAO,MAAM,GAAG,EAAE,SAAS,YAAY,GAAG;AAC7C,aAAO,GAAG,MAAM;AAAA,IAClB;AAAA,EACF;AAGA,MAAI,CAAC,UAAU,CAAC,MAAM,QAAQ,MAAM,GAAG;AAE9B,WAAA;AAAA,EACT;AAIA,MAAI,CAAC,OAAO,SAAS,YAAY,GAAG;AAClC,WAAO,KAAK,YAAY;AAAA,EAC1B;AAEO,SAAA;AACT;;"}
@@ -1,24 +0,0 @@
1
- const transformFields = (fields) => {
2
- if (typeof fields === "string") {
3
- if (fields === "*") {
4
- return fields;
5
- }
6
- if (fields === "") {
7
- return "documentId";
8
- }
9
- if (!fields.split(",").includes("documentId")) {
10
- return `${fields},documentId`;
11
- }
12
- }
13
- if (!fields || !Array.isArray(fields)) {
14
- return fields;
15
- }
16
- if (!fields.includes("documentId")) {
17
- fields.push("documentId");
18
- }
19
- return fields;
20
- };
21
- export {
22
- transformFields
23
- };
24
- //# sourceMappingURL=fields.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"fields.mjs","sources":["../../../../src/services/document-service/transform/fields.ts"],"sourcesContent":["import type { Modules, UID } from '@strapi/types';\n\ntype Fields = Modules.Documents.Params.Pick<UID.Schema, 'fields'>['fields'];\n\nexport const transformFields = (fields: Fields): Fields => {\n // If it's a string, and it doesn't contain documentId, should be an array\n if (typeof fields === 'string') {\n // '*' => '*'\n if (fields === '*') {\n return fields;\n }\n\n // '' => 'documentId'\n if (fields === '') {\n return 'documentId';\n }\n\n // 'name,description' => 'name,description,documentId'\n if (!fields.split(',').includes('documentId')) {\n return `${fields},documentId`;\n }\n }\n\n // It's not an array, ignore it\n if (!fields || !Array.isArray(fields)) {\n // If fields is empty, return it as is\n return fields;\n }\n\n // Ensure we are always selecting the documentId\n // ['name', 'description'] => ['name', 'description', 'documentId']\n if (!fields.includes('documentId')) {\n fields.push('documentId');\n }\n\n return fields;\n};\n"],"names":[],"mappings":"AAIa,MAAA,kBAAkB,CAAC,WAA2B;AAErD,MAAA,OAAO,WAAW,UAAU;AAE9B,QAAI,WAAW,KAAK;AACX,aAAA;AAAA,IACT;AAGA,QAAI,WAAW,IAAI;AACV,aAAA;AAAA,IACT;AAGA,QAAI,CAAC,OAAO,MAAM,GAAG,EAAE,SAAS,YAAY,GAAG;AAC7C,aAAO,GAAG,MAAM;AAAA,IAClB;AAAA,EACF;AAGA,MAAI,CAAC,UAAU,CAAC,MAAM,QAAQ,MAAM,GAAG;AAE9B,WAAA;AAAA,EACT;AAIA,MAAI,CAAC,OAAO,SAAS,YAAY,GAAG;AAClC,WAAO,KAAK,YAAY;AAAA,EAC1B;AAEO,SAAA;AACT;"}
@@ -1,78 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const strapiUtils = require("@strapi/utils");
4
- const encodeKey = (obj) => {
5
- const keys = Object.keys(obj).sort();
6
- return keys.map((key) => `${key}:::${obj[key]}`).join("&&");
7
- };
8
- const createIdMap = ({ strapi }) => {
9
- const loadedIds = /* @__PURE__ */ new Map();
10
- const toLoadIds = /* @__PURE__ */ new Map();
11
- return {
12
- loadedIds,
13
- toLoadIds,
14
- /**
15
- * Register a new document id and its corresponding entity id.
16
- */
17
- add(keyFields) {
18
- const key = encodeKey({ status: "published", locale: null, ...keyFields });
19
- if (loadedIds.has(key))
20
- return;
21
- if (toLoadIds.has(key))
22
- return;
23
- toLoadIds.set(key, keyFields);
24
- },
25
- /**
26
- * Load all ids from the registry.
27
- */
28
- async load() {
29
- const loadIdValues = Array.from(toLoadIds.values());
30
- const idsByUidAndLocale = loadIdValues.reduce((acc, { documentId, ...rest }) => {
31
- const key = encodeKey(rest);
32
- const ids = acc[key] || { ...rest, documentIds: [] };
33
- ids.documentIds.push(documentId);
34
- return { ...acc, [key]: ids };
35
- }, {});
36
- await strapiUtils.async.map(
37
- Object.values(idsByUidAndLocale),
38
- async ({ uid, locale, documentIds, status }) => {
39
- const findParams = {
40
- select: ["id", "documentId", "locale", "publishedAt"],
41
- where: {
42
- documentId: { $in: documentIds },
43
- locale: locale || null,
44
- publishedAt: status === "draft" ? null : { $ne: null }
45
- }
46
- };
47
- const result = await strapi?.db?.query(uid).findMany(findParams);
48
- result?.forEach(({ documentId, id, locale: locale2, publishedAt }) => {
49
- const key = encodeKey({
50
- documentId,
51
- uid,
52
- locale: locale2,
53
- status: publishedAt ? "published" : "draft"
54
- });
55
- loadedIds.set(key, id);
56
- });
57
- }
58
- );
59
- toLoadIds.clear();
60
- },
61
- /**
62
- * Get the entity id for a given document id.
63
- */
64
- get(keys) {
65
- const key = encodeKey({ status: "published", locale: null, ...keys });
66
- return loadedIds.get(key);
67
- },
68
- /**
69
- * Clear the registry.
70
- */
71
- clear() {
72
- loadedIds.clear();
73
- toLoadIds.clear();
74
- }
75
- };
76
- };
77
- exports.createIdMap = createIdMap;
78
- //# sourceMappingURL=id-map.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"id-map.js","sources":["../../../../src/services/document-service/transform/id-map.ts"],"sourcesContent":["import { Core, Data } from '@strapi/types';\nimport { async } from '@strapi/utils';\n\n/**\n * TODO: Find a better way to encode keys than this\n * This converts an object into a string by joining its keys and values,\n * so it can be used as a key in a Map.\n *\n * @example\n * const obj = { a: 1, b: 2 };\n * const key = encodeKey(obj);\n * ^ \"a:::1&&b:::2\"\n */\nconst encodeKey = (obj: any) => {\n // Sort keys to always keep the same order when encoding\n const keys = Object.keys(obj).sort();\n return keys.map((key) => `${key}:::${obj[key]}`).join('&&');\n};\n\ninterface KeyFields {\n uid: string;\n documentId: Data.ID;\n locale?: string | null;\n status?: 'draft' | 'published';\n}\n\nexport interface IdMap {\n loadedIds: Map<string, string>;\n toLoadIds: Map<string, KeyFields>;\n // Make the Keys type to be the params of add\n add(keys: KeyFields): void;\n load(): Promise<void>;\n get(keys: KeyFields): string | undefined;\n clear(): void;\n}\n\n/**\n * Holds a registry of document ids and their corresponding entity ids.\n */\nconst createIdMap = ({ strapi }: { strapi: Core.Strapi }): IdMap => {\n const loadedIds = new Map();\n const toLoadIds = new Map();\n\n return {\n loadedIds,\n toLoadIds,\n /**\n * Register a new document id and its corresponding entity id.\n */\n add(keyFields: KeyFields) {\n const key = encodeKey({ status: 'published', locale: null, ...keyFields });\n\n // If the id is already loaded, do nothing\n if (loadedIds.has(key)) return;\n // If the id is already in the toLoadIds, do nothing\n if (toLoadIds.has(key)) return;\n\n // Add the id to the toLoadIds\n toLoadIds.set(key, keyFields);\n },\n\n /**\n * Load all ids from the registry.\n */\n async load() {\n // Document Id to Entry Id queries are batched by its uid and locale\n // TODO: Add publication state too\n const loadIdValues = Array.from(toLoadIds.values());\n\n // 1. Group ids to query together\n const idsByUidAndLocale = loadIdValues.reduce((acc, { documentId, ...rest }) => {\n const key = encodeKey(rest);\n const ids = acc[key] || { ...rest, documentIds: [] };\n ids.documentIds.push(documentId);\n return { ...acc, [key]: ids };\n }, {});\n\n // 2. Query ids\n await async.map(\n Object.values(idsByUidAndLocale),\n async ({ uid, locale, documentIds, status }: any) => {\n const findParams = {\n select: ['id', 'documentId', 'locale', 'publishedAt'],\n where: {\n documentId: { $in: documentIds },\n locale: locale || null,\n publishedAt: status === 'draft' ? null : { $ne: null },\n },\n } as any;\n\n const result = await strapi?.db?.query(uid).findMany(findParams);\n\n // 3. Store result in loadedIds\n result?.forEach(({ documentId, id, locale, publishedAt }: any) => {\n const key = encodeKey({\n documentId,\n uid,\n locale,\n status: publishedAt ? 'published' : 'draft',\n });\n loadedIds.set(key, id);\n });\n }\n );\n\n // 4. Clear toLoadIds\n toLoadIds.clear();\n },\n\n /**\n * Get the entity id for a given document id.\n */\n get(keys: KeyFields) {\n const key = encodeKey({ status: 'published', locale: null, ...keys });\n return loadedIds.get(key);\n },\n\n /**\n * Clear the registry.\n */\n clear() {\n loadedIds.clear();\n toLoadIds.clear();\n },\n };\n};\n\nexport { createIdMap };\n"],"names":["async","locale"],"mappings":";;;AAaA,MAAM,YAAY,CAAC,QAAa;AAE9B,QAAM,OAAO,OAAO,KAAK,GAAG,EAAE,KAAK;AACnC,SAAO,KAAK,IAAI,CAAC,QAAQ,GAAG,GAAG,MAAM,IAAI,GAAG,CAAC,EAAE,EAAE,KAAK,IAAI;AAC5D;AAsBA,MAAM,cAAc,CAAC,EAAE,aAA6C;AAC5D,QAAA,gCAAgB;AAChB,QAAA,gCAAgB;AAEf,SAAA;AAAA,IACL;AAAA,IACA;AAAA;AAAA;AAAA;AAAA,IAIA,IAAI,WAAsB;AAClB,YAAA,MAAM,UAAU,EAAE,QAAQ,aAAa,QAAQ,MAAM,GAAG,UAAA,CAAW;AAGrE,UAAA,UAAU,IAAI,GAAG;AAAG;AAEpB,UAAA,UAAU,IAAI,GAAG;AAAG;AAGd,gBAAA,IAAI,KAAK,SAAS;AAAA,IAC9B;AAAA;AAAA;AAAA;AAAA,IAKA,MAAM,OAAO;AAGX,YAAM,eAAe,MAAM,KAAK,UAAU,OAAQ,CAAA;AAG5C,YAAA,oBAAoB,aAAa,OAAO,CAAC,KAAK,EAAE,YAAY,GAAG,WAAW;AACxE,cAAA,MAAM,UAAU,IAAI;AACpB,cAAA,MAAM,IAAI,GAAG,KAAK,EAAE,GAAG,MAAM,aAAa,CAAA;AAC5C,YAAA,YAAY,KAAK,UAAU;AAC/B,eAAO,EAAE,GAAG,KAAK,CAAC,GAAG,GAAG,IAAI;AAAA,MAC9B,GAAG,CAAE,CAAA;AAGL,YAAMA,YAAM,MAAA;AAAA,QACV,OAAO,OAAO,iBAAiB;AAAA,QAC/B,OAAO,EAAE,KAAK,QAAQ,aAAa,aAAkB;AACnD,gBAAM,aAAa;AAAA,YACjB,QAAQ,CAAC,MAAM,cAAc,UAAU,aAAa;AAAA,YACpD,OAAO;AAAA,cACL,YAAY,EAAE,KAAK,YAAY;AAAA,cAC/B,QAAQ,UAAU;AAAA,cAClB,aAAa,WAAW,UAAU,OAAO,EAAE,KAAK,KAAK;AAAA,YACvD;AAAA,UAAA;AAGI,gBAAA,SAAS,MAAM,QAAQ,IAAI,MAAM,GAAG,EAAE,SAAS,UAAU;AAGvD,kBAAA,QAAQ,CAAC,EAAE,YAAY,IAAI,QAAAC,SAAQ,kBAAuB;AAChE,kBAAM,MAAM,UAAU;AAAA,cACpB;AAAA,cACA;AAAA,cACA,QAAAA;AAAAA,cACA,QAAQ,cAAc,cAAc;AAAA,YAAA,CACrC;AACS,sBAAA,IAAI,KAAK,EAAE;AAAA,UAAA,CACtB;AAAA,QACH;AAAA,MAAA;AAIF,gBAAU,MAAM;AAAA,IAClB;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,MAAiB;AACb,YAAA,MAAM,UAAU,EAAE,QAAQ,aAAa,QAAQ,MAAM,GAAG,KAAA,CAAM;AAC7D,aAAA,UAAU,IAAI,GAAG;AAAA,IAC1B;AAAA;AAAA;AAAA;AAAA,IAKA,QAAQ;AACN,gBAAU,MAAM;AAChB,gBAAU,MAAM;AAAA,IAClB;AAAA,EAAA;AAEJ;;"}
@@ -1,78 +0,0 @@
1
- import { async } from "@strapi/utils";
2
- const encodeKey = (obj) => {
3
- const keys = Object.keys(obj).sort();
4
- return keys.map((key) => `${key}:::${obj[key]}`).join("&&");
5
- };
6
- const createIdMap = ({ strapi }) => {
7
- const loadedIds = /* @__PURE__ */ new Map();
8
- const toLoadIds = /* @__PURE__ */ new Map();
9
- return {
10
- loadedIds,
11
- toLoadIds,
12
- /**
13
- * Register a new document id and its corresponding entity id.
14
- */
15
- add(keyFields) {
16
- const key = encodeKey({ status: "published", locale: null, ...keyFields });
17
- if (loadedIds.has(key))
18
- return;
19
- if (toLoadIds.has(key))
20
- return;
21
- toLoadIds.set(key, keyFields);
22
- },
23
- /**
24
- * Load all ids from the registry.
25
- */
26
- async load() {
27
- const loadIdValues = Array.from(toLoadIds.values());
28
- const idsByUidAndLocale = loadIdValues.reduce((acc, { documentId, ...rest }) => {
29
- const key = encodeKey(rest);
30
- const ids = acc[key] || { ...rest, documentIds: [] };
31
- ids.documentIds.push(documentId);
32
- return { ...acc, [key]: ids };
33
- }, {});
34
- await async.map(
35
- Object.values(idsByUidAndLocale),
36
- async ({ uid, locale, documentIds, status }) => {
37
- const findParams = {
38
- select: ["id", "documentId", "locale", "publishedAt"],
39
- where: {
40
- documentId: { $in: documentIds },
41
- locale: locale || null,
42
- publishedAt: status === "draft" ? null : { $ne: null }
43
- }
44
- };
45
- const result = await strapi?.db?.query(uid).findMany(findParams);
46
- result?.forEach(({ documentId, id, locale: locale2, publishedAt }) => {
47
- const key = encodeKey({
48
- documentId,
49
- uid,
50
- locale: locale2,
51
- status: publishedAt ? "published" : "draft"
52
- });
53
- loadedIds.set(key, id);
54
- });
55
- }
56
- );
57
- toLoadIds.clear();
58
- },
59
- /**
60
- * Get the entity id for a given document id.
61
- */
62
- get(keys) {
63
- const key = encodeKey({ status: "published", locale: null, ...keys });
64
- return loadedIds.get(key);
65
- },
66
- /**
67
- * Clear the registry.
68
- */
69
- clear() {
70
- loadedIds.clear();
71
- toLoadIds.clear();
72
- }
73
- };
74
- };
75
- export {
76
- createIdMap
77
- };
78
- //# sourceMappingURL=id-map.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"id-map.mjs","sources":["../../../../src/services/document-service/transform/id-map.ts"],"sourcesContent":["import { Core, Data } from '@strapi/types';\nimport { async } from '@strapi/utils';\n\n/**\n * TODO: Find a better way to encode keys than this\n * This converts an object into a string by joining its keys and values,\n * so it can be used as a key in a Map.\n *\n * @example\n * const obj = { a: 1, b: 2 };\n * const key = encodeKey(obj);\n * ^ \"a:::1&&b:::2\"\n */\nconst encodeKey = (obj: any) => {\n // Sort keys to always keep the same order when encoding\n const keys = Object.keys(obj).sort();\n return keys.map((key) => `${key}:::${obj[key]}`).join('&&');\n};\n\ninterface KeyFields {\n uid: string;\n documentId: Data.ID;\n locale?: string | null;\n status?: 'draft' | 'published';\n}\n\nexport interface IdMap {\n loadedIds: Map<string, string>;\n toLoadIds: Map<string, KeyFields>;\n // Make the Keys type to be the params of add\n add(keys: KeyFields): void;\n load(): Promise<void>;\n get(keys: KeyFields): string | undefined;\n clear(): void;\n}\n\n/**\n * Holds a registry of document ids and their corresponding entity ids.\n */\nconst createIdMap = ({ strapi }: { strapi: Core.Strapi }): IdMap => {\n const loadedIds = new Map();\n const toLoadIds = new Map();\n\n return {\n loadedIds,\n toLoadIds,\n /**\n * Register a new document id and its corresponding entity id.\n */\n add(keyFields: KeyFields) {\n const key = encodeKey({ status: 'published', locale: null, ...keyFields });\n\n // If the id is already loaded, do nothing\n if (loadedIds.has(key)) return;\n // If the id is already in the toLoadIds, do nothing\n if (toLoadIds.has(key)) return;\n\n // Add the id to the toLoadIds\n toLoadIds.set(key, keyFields);\n },\n\n /**\n * Load all ids from the registry.\n */\n async load() {\n // Document Id to Entry Id queries are batched by its uid and locale\n // TODO: Add publication state too\n const loadIdValues = Array.from(toLoadIds.values());\n\n // 1. Group ids to query together\n const idsByUidAndLocale = loadIdValues.reduce((acc, { documentId, ...rest }) => {\n const key = encodeKey(rest);\n const ids = acc[key] || { ...rest, documentIds: [] };\n ids.documentIds.push(documentId);\n return { ...acc, [key]: ids };\n }, {});\n\n // 2. Query ids\n await async.map(\n Object.values(idsByUidAndLocale),\n async ({ uid, locale, documentIds, status }: any) => {\n const findParams = {\n select: ['id', 'documentId', 'locale', 'publishedAt'],\n where: {\n documentId: { $in: documentIds },\n locale: locale || null,\n publishedAt: status === 'draft' ? null : { $ne: null },\n },\n } as any;\n\n const result = await strapi?.db?.query(uid).findMany(findParams);\n\n // 3. Store result in loadedIds\n result?.forEach(({ documentId, id, locale, publishedAt }: any) => {\n const key = encodeKey({\n documentId,\n uid,\n locale,\n status: publishedAt ? 'published' : 'draft',\n });\n loadedIds.set(key, id);\n });\n }\n );\n\n // 4. Clear toLoadIds\n toLoadIds.clear();\n },\n\n /**\n * Get the entity id for a given document id.\n */\n get(keys: KeyFields) {\n const key = encodeKey({ status: 'published', locale: null, ...keys });\n return loadedIds.get(key);\n },\n\n /**\n * Clear the registry.\n */\n clear() {\n loadedIds.clear();\n toLoadIds.clear();\n },\n };\n};\n\nexport { createIdMap };\n"],"names":["locale"],"mappings":";AAaA,MAAM,YAAY,CAAC,QAAa;AAE9B,QAAM,OAAO,OAAO,KAAK,GAAG,EAAE,KAAK;AACnC,SAAO,KAAK,IAAI,CAAC,QAAQ,GAAG,GAAG,MAAM,IAAI,GAAG,CAAC,EAAE,EAAE,KAAK,IAAI;AAC5D;AAsBA,MAAM,cAAc,CAAC,EAAE,aAA6C;AAC5D,QAAA,gCAAgB;AAChB,QAAA,gCAAgB;AAEf,SAAA;AAAA,IACL;AAAA,IACA;AAAA;AAAA;AAAA;AAAA,IAIA,IAAI,WAAsB;AAClB,YAAA,MAAM,UAAU,EAAE,QAAQ,aAAa,QAAQ,MAAM,GAAG,UAAA,CAAW;AAGrE,UAAA,UAAU,IAAI,GAAG;AAAG;AAEpB,UAAA,UAAU,IAAI,GAAG;AAAG;AAGd,gBAAA,IAAI,KAAK,SAAS;AAAA,IAC9B;AAAA;AAAA;AAAA;AAAA,IAKA,MAAM,OAAO;AAGX,YAAM,eAAe,MAAM,KAAK,UAAU,OAAQ,CAAA;AAG5C,YAAA,oBAAoB,aAAa,OAAO,CAAC,KAAK,EAAE,YAAY,GAAG,WAAW;AACxE,cAAA,MAAM,UAAU,IAAI;AACpB,cAAA,MAAM,IAAI,GAAG,KAAK,EAAE,GAAG,MAAM,aAAa,CAAA;AAC5C,YAAA,YAAY,KAAK,UAAU;AAC/B,eAAO,EAAE,GAAG,KAAK,CAAC,GAAG,GAAG,IAAI;AAAA,MAC9B,GAAG,CAAE,CAAA;AAGL,YAAM,MAAM;AAAA,QACV,OAAO,OAAO,iBAAiB;AAAA,QAC/B,OAAO,EAAE,KAAK,QAAQ,aAAa,aAAkB;AACnD,gBAAM,aAAa;AAAA,YACjB,QAAQ,CAAC,MAAM,cAAc,UAAU,aAAa;AAAA,YACpD,OAAO;AAAA,cACL,YAAY,EAAE,KAAK,YAAY;AAAA,cAC/B,QAAQ,UAAU;AAAA,cAClB,aAAa,WAAW,UAAU,OAAO,EAAE,KAAK,KAAK;AAAA,YACvD;AAAA,UAAA;AAGI,gBAAA,SAAS,MAAM,QAAQ,IAAI,MAAM,GAAG,EAAE,SAAS,UAAU;AAGvD,kBAAA,QAAQ,CAAC,EAAE,YAAY,IAAI,QAAAA,SAAQ,kBAAuB;AAChE,kBAAM,MAAM,UAAU;AAAA,cACpB;AAAA,cACA;AAAA,cACA,QAAAA;AAAAA,cACA,QAAQ,cAAc,cAAc;AAAA,YAAA,CACrC;AACS,sBAAA,IAAI,KAAK,EAAE;AAAA,UAAA,CACtB;AAAA,QACH;AAAA,MAAA;AAIF,gBAAU,MAAM;AAAA,IAClB;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,MAAiB;AACb,YAAA,MAAM,UAAU,EAAE,QAAQ,aAAa,QAAQ,MAAM,GAAG,KAAA,CAAM;AAC7D,aAAA,UAAU,IAAI,GAAG;AAAA,IAC1B;AAAA;AAAA;AAAA;AAAA,IAKA,QAAQ;AACN,gBAAU,MAAM;AAChB,gBAAU,MAAM;AAAA,IAClB;AAAA,EAAA;AAEJ;"}
@@ -1,33 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const fp = require("lodash/fp");
4
- const data = require("./data.js");
5
- const fields = require("./fields.js");
6
- const populate = require("./populate.js");
7
- async function transformParamsDocumentId(uid, query) {
8
- let data$1 = query.data;
9
- if (query.data) {
10
- data$1 = await data.transformData(query.data, {
11
- locale: query.locale,
12
- status: query.status,
13
- uid
14
- });
15
- }
16
- let fields$1 = query.fields;
17
- if (query.fields) {
18
- fields$1 = fields.transformFields(query.fields);
19
- }
20
- let populate$1 = query.populate;
21
- if (query.populate) {
22
- populate$1 = await populate.transformPopulate(query.populate, { uid });
23
- }
24
- return {
25
- ...query,
26
- data: data$1,
27
- fields: fields$1,
28
- populate: populate$1
29
- };
30
- }
31
- const curriedTransformParamsDocumentId = fp.curry(transformParamsDocumentId);
32
- exports.transformParamsDocumentId = curriedTransformParamsDocumentId;
33
- //# sourceMappingURL=id-transform.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"id-transform.js","sources":["../../../../src/services/document-service/transform/id-transform.ts"],"sourcesContent":["import { curry } from 'lodash/fp';\n\nimport { UID, Modules } from '@strapi/types';\n\nimport { transformData } from './data';\nimport { transformFields } from './fields';\nimport { transformPopulate } from './populate';\n\n/**\n * Transform input of a query to map document ids to entity ids.\n */\nasync function transformParamsDocumentId(\n uid: UID.Schema,\n query: Modules.Documents.Params.All\n): Promise<Modules.Documents.Params.All> {\n // Transform relational documentIds to entity ids\n let data = query.data;\n if (query.data) {\n data = await transformData(query.data, {\n locale: query.locale,\n status: query.status,\n uid,\n });\n }\n\n // Make sure documentId is always present in the response\n let fields = query.fields;\n if (query.fields) {\n fields = transformFields(query.fields) as typeof query.fields;\n }\n\n let populate = query.populate;\n if (query.populate) {\n populate = (await transformPopulate(query.populate, { uid })) as typeof query.populate;\n }\n\n return {\n ...query,\n data,\n fields,\n populate,\n };\n}\n\nconst curriedTransformParamsDocumentId = curry(transformParamsDocumentId);\n\nexport { curriedTransformParamsDocumentId as transformParamsDocumentId };\n"],"names":["data","transformData","fields","transformFields","populate","transformPopulate","curry"],"mappings":";;;;;;AAWA,eAAe,0BACb,KACA,OACuC;AAEvC,MAAIA,SAAO,MAAM;AACjB,MAAI,MAAM,MAAM;AACPA,aAAA,MAAMC,KAAAA,cAAc,MAAM,MAAM;AAAA,MACrC,QAAQ,MAAM;AAAA,MACd,QAAQ,MAAM;AAAA,MACd;AAAA,IAAA,CACD;AAAA,EACH;AAGA,MAAIC,WAAS,MAAM;AACnB,MAAI,MAAM,QAAQ;AACPA,eAAAC,OAAA,gBAAgB,MAAM,MAAM;AAAA,EACvC;AAEA,MAAIC,aAAW,MAAM;AACrB,MAAI,MAAM,UAAU;AAClBA,iBAAY,MAAMC,SAAAA,kBAAkB,MAAM,UAAU,EAAE,KAAK;AAAA,EAC7D;AAEO,SAAA;AAAA,IACL,GAAG;AAAA,IAAA,MACHL;AAAAA,IAAA,QACAE;AAAAA,IAAA,UACAE;AAAAA,EAAA;AAEJ;AAEM,MAAA,mCAAmCE,SAAM,yBAAyB;;"}