@strapi/core 0.0.0-next.504076d2165a82f124620a3f1f3e3a6017e97f3f → 0.0.0-next.5314209d201eef10092dc1c34d7b196c62e7115f

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 (711) hide show
  1. package/dist/Strapi.d.ts.map +1 -1
  2. package/dist/Strapi.js +427 -403
  3. package/dist/Strapi.js.map +1 -1
  4. package/dist/Strapi.mjs +426 -402
  5. package/dist/Strapi.mjs.map +1 -1
  6. package/dist/compile.js +23 -14
  7. package/dist/compile.js.map +1 -1
  8. package/dist/compile.mjs +22 -14
  9. package/dist/compile.mjs.map +1 -1
  10. package/dist/configuration/config-loader.js +110 -97
  11. package/dist/configuration/config-loader.js.map +1 -1
  12. package/dist/configuration/config-loader.mjs +109 -96
  13. package/dist/configuration/config-loader.mjs.map +1 -1
  14. package/dist/configuration/get-dirs.js +31 -29
  15. package/dist/configuration/get-dirs.js.map +1 -1
  16. package/dist/configuration/get-dirs.mjs +30 -30
  17. package/dist/configuration/get-dirs.mjs.map +1 -1
  18. package/dist/configuration/index.d.ts.map +1 -1
  19. package/dist/configuration/index.js +84 -73
  20. package/dist/configuration/index.js.map +1 -1
  21. package/dist/configuration/index.mjs +83 -69
  22. package/dist/configuration/index.mjs.map +1 -1
  23. package/dist/configuration/urls.d.ts.map +1 -1
  24. package/dist/configuration/urls.js +74 -61
  25. package/dist/configuration/urls.js.map +1 -1
  26. package/dist/configuration/urls.mjs +73 -62
  27. package/dist/configuration/urls.mjs.map +1 -1
  28. package/dist/container.js +27 -23
  29. package/dist/container.js.map +1 -1
  30. package/dist/container.mjs +26 -24
  31. package/dist/container.mjs.map +1 -1
  32. package/dist/core-api/controller/collection-type.js +77 -76
  33. package/dist/core-api/controller/collection-type.js.map +1 -1
  34. package/dist/core-api/controller/collection-type.mjs +76 -77
  35. package/dist/core-api/controller/collection-type.mjs.map +1 -1
  36. package/dist/core-api/controller/index.js +63 -48
  37. package/dist/core-api/controller/index.js.map +1 -1
  38. package/dist/core-api/controller/index.mjs +62 -49
  39. package/dist/core-api/controller/index.mjs.map +1 -1
  40. package/dist/core-api/controller/single-type.js +41 -40
  41. package/dist/core-api/controller/single-type.js.map +1 -1
  42. package/dist/core-api/controller/single-type.mjs +40 -41
  43. package/dist/core-api/controller/single-type.mjs.map +1 -1
  44. package/dist/core-api/controller/transform.js +72 -63
  45. package/dist/core-api/controller/transform.js.map +1 -1
  46. package/dist/core-api/controller/transform.mjs +71 -64
  47. package/dist/core-api/controller/transform.mjs.map +1 -1
  48. package/dist/core-api/routes/index.js +64 -62
  49. package/dist/core-api/routes/index.js.map +1 -1
  50. package/dist/core-api/routes/index.mjs +62 -62
  51. package/dist/core-api/routes/index.mjs.map +1 -1
  52. package/dist/core-api/service/collection-type.js +73 -60
  53. package/dist/core-api/service/collection-type.js.map +1 -1
  54. package/dist/core-api/service/collection-type.mjs +72 -62
  55. package/dist/core-api/service/collection-type.mjs.map +1 -1
  56. package/dist/core-api/service/core-service.js +9 -8
  57. package/dist/core-api/service/core-service.js.map +1 -1
  58. package/dist/core-api/service/core-service.mjs +8 -9
  59. package/dist/core-api/service/core-service.mjs.map +1 -1
  60. package/dist/core-api/service/index.js +13 -13
  61. package/dist/core-api/service/index.js.map +1 -1
  62. package/dist/core-api/service/index.mjs +12 -14
  63. package/dist/core-api/service/index.mjs.map +1 -1
  64. package/dist/core-api/service/pagination.js +69 -43
  65. package/dist/core-api/service/pagination.js.map +1 -1
  66. package/dist/core-api/service/pagination.mjs +68 -47
  67. package/dist/core-api/service/pagination.mjs.map +1 -1
  68. package/dist/core-api/service/single-type.js +43 -39
  69. package/dist/core-api/service/single-type.js.map +1 -1
  70. package/dist/core-api/service/single-type.mjs +42 -41
  71. package/dist/core-api/service/single-type.mjs.map +1 -1
  72. package/dist/domain/content-type/index.js +95 -100
  73. package/dist/domain/content-type/index.js.map +1 -1
  74. package/dist/domain/content-type/index.mjs +94 -100
  75. package/dist/domain/content-type/index.mjs.map +1 -1
  76. package/dist/domain/content-type/validator.js +84 -69
  77. package/dist/domain/content-type/validator.js.map +1 -1
  78. package/dist/domain/content-type/validator.mjs +83 -68
  79. package/dist/domain/content-type/validator.mjs.map +1 -1
  80. package/dist/domain/module/index.js +109 -100
  81. package/dist/domain/module/index.js.map +1 -1
  82. package/dist/domain/module/index.mjs +108 -99
  83. package/dist/domain/module/index.mjs.map +1 -1
  84. package/dist/domain/module/validation.js +25 -20
  85. package/dist/domain/module/validation.js.map +1 -1
  86. package/dist/domain/module/validation.mjs +24 -21
  87. package/dist/domain/module/validation.mjs.map +1 -1
  88. package/dist/ee/index.d.ts +1 -0
  89. package/dist/ee/index.d.ts.map +1 -1
  90. package/dist/ee/index.js +171 -132
  91. package/dist/ee/index.js.map +1 -1
  92. package/dist/ee/index.mjs +170 -134
  93. package/dist/ee/index.mjs.map +1 -1
  94. package/dist/ee/license.d.ts.map +1 -1
  95. package/dist/ee/license.js +99 -75
  96. package/dist/ee/license.js.map +1 -1
  97. package/dist/ee/license.mjs +98 -76
  98. package/dist/ee/license.mjs.map +1 -1
  99. package/dist/factories.js +72 -67
  100. package/dist/factories.js.map +1 -1
  101. package/dist/factories.mjs +71 -71
  102. package/dist/factories.mjs.map +1 -1
  103. package/dist/index.js +29 -26
  104. package/dist/index.js.map +1 -1
  105. package/dist/index.mjs +29 -29
  106. package/dist/index.mjs.map +1 -1
  107. package/dist/loaders/admin.d.ts.map +1 -1
  108. package/dist/loaders/admin.js +21 -20
  109. package/dist/loaders/admin.js.map +1 -1
  110. package/dist/loaders/admin.mjs +20 -20
  111. package/dist/loaders/admin.mjs.map +1 -1
  112. package/dist/loaders/apis.js +143 -120
  113. package/dist/loaders/apis.js.map +1 -1
  114. package/dist/loaders/apis.mjs +142 -119
  115. package/dist/loaders/apis.mjs.map +1 -1
  116. package/dist/loaders/components.js +33 -34
  117. package/dist/loaders/components.js.map +1 -1
  118. package/dist/loaders/components.mjs +32 -34
  119. package/dist/loaders/components.mjs.map +1 -1
  120. package/dist/loaders/index.js +22 -20
  121. package/dist/loaders/index.js.map +1 -1
  122. package/dist/loaders/index.mjs +21 -21
  123. package/dist/loaders/index.mjs.map +1 -1
  124. package/dist/loaders/middlewares.js +29 -25
  125. package/dist/loaders/middlewares.js.map +1 -1
  126. package/dist/loaders/middlewares.mjs +28 -25
  127. package/dist/loaders/middlewares.mjs.map +1 -1
  128. package/dist/loaders/plugins/get-enabled-plugins.js +126 -131
  129. package/dist/loaders/plugins/get-enabled-plugins.js.map +1 -1
  130. package/dist/loaders/plugins/get-enabled-plugins.mjs +125 -108
  131. package/dist/loaders/plugins/get-enabled-plugins.mjs.map +1 -1
  132. package/dist/loaders/plugins/get-user-plugins-config.js +25 -24
  133. package/dist/loaders/plugins/get-user-plugins-config.js.map +1 -1
  134. package/dist/loaders/plugins/get-user-plugins-config.mjs +24 -23
  135. package/dist/loaders/plugins/get-user-plugins-config.mjs.map +1 -1
  136. package/dist/loaders/plugins/index.js +132 -122
  137. package/dist/loaders/plugins/index.js.map +1 -1
  138. package/dist/loaders/plugins/index.mjs +121 -112
  139. package/dist/loaders/plugins/index.mjs.map +1 -1
  140. package/dist/loaders/policies.js +24 -20
  141. package/dist/loaders/policies.js.map +1 -1
  142. package/dist/loaders/policies.mjs +23 -20
  143. package/dist/loaders/policies.mjs.map +1 -1
  144. package/dist/loaders/sanitizers.js +10 -4
  145. package/dist/loaders/sanitizers.js.map +1 -1
  146. package/dist/loaders/sanitizers.mjs +9 -6
  147. package/dist/loaders/sanitizers.mjs.map +1 -1
  148. package/dist/loaders/src-index.js +35 -27
  149. package/dist/loaders/src-index.js.map +1 -1
  150. package/dist/loaders/src-index.mjs +34 -29
  151. package/dist/loaders/src-index.mjs.map +1 -1
  152. package/dist/loaders/validators.js +9 -4
  153. package/dist/loaders/validators.js.map +1 -1
  154. package/dist/loaders/validators.mjs +8 -6
  155. package/dist/loaders/validators.mjs.map +1 -1
  156. package/dist/middlewares/body.d.ts.map +1 -1
  157. package/dist/middlewares/body.js +58 -54
  158. package/dist/middlewares/body.js.map +1 -1
  159. package/dist/middlewares/body.mjs +57 -51
  160. package/dist/middlewares/body.mjs.map +1 -1
  161. package/dist/middlewares/compression.js +6 -6
  162. package/dist/middlewares/compression.js.map +1 -1
  163. package/dist/middlewares/compression.mjs +5 -5
  164. package/dist/middlewares/compression.mjs.map +1 -1
  165. package/dist/middlewares/cors.js +59 -48
  166. package/dist/middlewares/cors.js.map +1 -1
  167. package/dist/middlewares/cors.mjs +58 -47
  168. package/dist/middlewares/cors.mjs.map +1 -1
  169. package/dist/middlewares/errors.js +32 -30
  170. package/dist/middlewares/errors.js.map +1 -1
  171. package/dist/middlewares/errors.mjs +31 -31
  172. package/dist/middlewares/errors.mjs.map +1 -1
  173. package/dist/middlewares/favicon.js +27 -17
  174. package/dist/middlewares/favicon.js.map +1 -1
  175. package/dist/middlewares/favicon.mjs +26 -16
  176. package/dist/middlewares/favicon.mjs.map +1 -1
  177. package/dist/middlewares/index.js +32 -30
  178. package/dist/middlewares/index.js.map +1 -1
  179. package/dist/middlewares/index.mjs +31 -31
  180. package/dist/middlewares/index.mjs.map +1 -1
  181. package/dist/middlewares/ip.js +6 -6
  182. package/dist/middlewares/ip.js.map +1 -1
  183. package/dist/middlewares/ip.mjs +5 -5
  184. package/dist/middlewares/ip.mjs.map +1 -1
  185. package/dist/middlewares/logger.js +10 -9
  186. package/dist/middlewares/logger.js.map +1 -1
  187. package/dist/middlewares/logger.mjs +9 -10
  188. package/dist/middlewares/logger.mjs.map +1 -1
  189. package/dist/middlewares/powered-by.js +13 -9
  190. package/dist/middlewares/powered-by.js.map +1 -1
  191. package/dist/middlewares/powered-by.mjs +12 -10
  192. package/dist/middlewares/powered-by.mjs.map +1 -1
  193. package/dist/middlewares/public.js +33 -29
  194. package/dist/middlewares/public.js.map +1 -1
  195. package/dist/middlewares/public.mjs +32 -28
  196. package/dist/middlewares/public.mjs.map +1 -1
  197. package/dist/middlewares/query.js +35 -32
  198. package/dist/middlewares/query.js.map +1 -1
  199. package/dist/middlewares/query.mjs +34 -31
  200. package/dist/middlewares/query.mjs.map +1 -1
  201. package/dist/middlewares/response-time.js +10 -9
  202. package/dist/middlewares/response-time.js.map +1 -1
  203. package/dist/middlewares/response-time.mjs +9 -10
  204. package/dist/middlewares/response-time.mjs.map +1 -1
  205. package/dist/middlewares/responses.js +14 -12
  206. package/dist/middlewares/responses.js.map +1 -1
  207. package/dist/middlewares/responses.mjs +13 -13
  208. package/dist/middlewares/responses.mjs.map +1 -1
  209. package/dist/middlewares/security.js +109 -71
  210. package/dist/middlewares/security.js.map +1 -1
  211. package/dist/middlewares/security.mjs +108 -70
  212. package/dist/middlewares/security.mjs.map +1 -1
  213. package/dist/middlewares/session.js +26 -25
  214. package/dist/middlewares/session.js.map +1 -1
  215. package/dist/middlewares/session.mjs +25 -24
  216. package/dist/middlewares/session.mjs.map +1 -1
  217. package/dist/migrations/database/5.0.0-discard-drafts.d.ts +2 -2
  218. package/dist/migrations/database/5.0.0-discard-drafts.d.ts.map +1 -1
  219. package/dist/migrations/database/5.0.0-discard-drafts.js +154 -80
  220. package/dist/migrations/database/5.0.0-discard-drafts.js.map +1 -1
  221. package/dist/migrations/database/5.0.0-discard-drafts.mjs +153 -82
  222. package/dist/migrations/database/5.0.0-discard-drafts.mjs.map +1 -1
  223. package/dist/migrations/draft-publish.d.ts +1 -1
  224. package/dist/migrations/draft-publish.d.ts.map +1 -1
  225. package/dist/migrations/draft-publish.js +61 -34
  226. package/dist/migrations/draft-publish.js.map +1 -1
  227. package/dist/migrations/draft-publish.mjs +60 -36
  228. package/dist/migrations/draft-publish.mjs.map +1 -1
  229. package/dist/migrations/i18n.js +62 -45
  230. package/dist/migrations/i18n.js.map +1 -1
  231. package/dist/migrations/i18n.mjs +61 -47
  232. package/dist/migrations/i18n.mjs.map +1 -1
  233. package/dist/migrations/index.js +24 -10
  234. package/dist/migrations/index.js.map +1 -1
  235. package/dist/migrations/index.mjs +23 -12
  236. package/dist/migrations/index.mjs.map +1 -1
  237. package/dist/package.json.js +182 -0
  238. package/dist/package.json.js.map +1 -0
  239. package/dist/package.json.mjs +159 -0
  240. package/dist/package.json.mjs.map +1 -0
  241. package/dist/providers/admin.js +27 -17
  242. package/dist/providers/admin.js.map +1 -1
  243. package/dist/providers/admin.mjs +26 -19
  244. package/dist/providers/admin.mjs.map +1 -1
  245. package/dist/providers/coreStore.js +13 -8
  246. package/dist/providers/coreStore.js.map +1 -1
  247. package/dist/providers/coreStore.mjs +12 -10
  248. package/dist/providers/coreStore.mjs.map +1 -1
  249. package/dist/providers/cron.js +19 -16
  250. package/dist/providers/cron.js.map +1 -1
  251. package/dist/providers/cron.mjs +18 -18
  252. package/dist/providers/cron.mjs.map +1 -1
  253. package/dist/providers/index.js +18 -9
  254. package/dist/providers/index.js.map +1 -1
  255. package/dist/providers/index.mjs +17 -10
  256. package/dist/providers/index.mjs.map +1 -1
  257. package/dist/providers/provider.js +4 -3
  258. package/dist/providers/provider.js.map +1 -1
  259. package/dist/providers/provider.mjs +3 -4
  260. package/dist/providers/provider.mjs.map +1 -1
  261. package/dist/providers/registries.js +37 -32
  262. package/dist/providers/registries.js.map +1 -1
  263. package/dist/providers/registries.mjs +36 -34
  264. package/dist/providers/registries.mjs.map +1 -1
  265. package/dist/providers/telemetry.js +19 -16
  266. package/dist/providers/telemetry.js.map +1 -1
  267. package/dist/providers/telemetry.mjs +18 -18
  268. package/dist/providers/telemetry.mjs.map +1 -1
  269. package/dist/providers/webhooks.js +28 -26
  270. package/dist/providers/webhooks.js.map +1 -1
  271. package/dist/providers/webhooks.mjs +27 -28
  272. package/dist/providers/webhooks.mjs.map +1 -1
  273. package/dist/registries/apis.js +23 -20
  274. package/dist/registries/apis.js.map +1 -1
  275. package/dist/registries/apis.mjs +22 -22
  276. package/dist/registries/apis.mjs.map +1 -1
  277. package/dist/registries/components.js +35 -37
  278. package/dist/registries/components.js.map +1 -1
  279. package/dist/registries/components.mjs +34 -39
  280. package/dist/registries/components.mjs.map +1 -1
  281. package/dist/registries/content-types.js +54 -59
  282. package/dist/registries/content-types.js.map +1 -1
  283. package/dist/registries/content-types.mjs +53 -61
  284. package/dist/registries/content-types.mjs.map +1 -1
  285. package/dist/registries/controllers.js +70 -71
  286. package/dist/registries/controllers.js.map +1 -1
  287. package/dist/registries/controllers.mjs +69 -73
  288. package/dist/registries/controllers.mjs.map +1 -1
  289. package/dist/registries/custom-fields.js +75 -65
  290. package/dist/registries/custom-fields.js.map +1 -1
  291. package/dist/registries/custom-fields.mjs +74 -67
  292. package/dist/registries/custom-fields.mjs.map +1 -1
  293. package/dist/registries/hooks.js +46 -49
  294. package/dist/registries/hooks.js.map +1 -1
  295. package/dist/registries/hooks.mjs +45 -51
  296. package/dist/registries/hooks.mjs.map +1 -1
  297. package/dist/registries/middlewares.js +49 -51
  298. package/dist/registries/middlewares.js.map +1 -1
  299. package/dist/registries/middlewares.mjs +48 -53
  300. package/dist/registries/middlewares.mjs.map +1 -1
  301. package/dist/registries/models.js +14 -13
  302. package/dist/registries/models.js.map +1 -1
  303. package/dist/registries/models.mjs +13 -14
  304. package/dist/registries/models.mjs.map +1 -1
  305. package/dist/registries/modules.js +39 -36
  306. package/dist/registries/modules.js.map +1 -1
  307. package/dist/registries/modules.mjs +38 -38
  308. package/dist/registries/modules.mjs.map +1 -1
  309. package/dist/registries/namespace.js +21 -20
  310. package/dist/registries/namespace.js.map +1 -1
  311. package/dist/registries/namespace.mjs +20 -23
  312. package/dist/registries/namespace.mjs.map +1 -1
  313. package/dist/registries/plugins.js +23 -20
  314. package/dist/registries/plugins.js.map +1 -1
  315. package/dist/registries/plugins.mjs +22 -22
  316. package/dist/registries/plugins.mjs.map +1 -1
  317. package/dist/registries/policies.js +103 -96
  318. package/dist/registries/policies.js.map +1 -1
  319. package/dist/registries/policies.mjs +102 -98
  320. package/dist/registries/policies.mjs.map +1 -1
  321. package/dist/registries/sanitizers.js +23 -22
  322. package/dist/registries/sanitizers.js.map +1 -1
  323. package/dist/registries/sanitizers.mjs +22 -22
  324. package/dist/registries/sanitizers.mjs.map +1 -1
  325. package/dist/registries/services.js +71 -71
  326. package/dist/registries/services.js.map +1 -1
  327. package/dist/registries/services.mjs +70 -73
  328. package/dist/registries/services.mjs.map +1 -1
  329. package/dist/registries/validators.js +23 -22
  330. package/dist/registries/validators.js.map +1 -1
  331. package/dist/registries/validators.mjs +22 -22
  332. package/dist/registries/validators.mjs.map +1 -1
  333. package/dist/services/auth/index.js +74 -74
  334. package/dist/services/auth/index.js.map +1 -1
  335. package/dist/services/auth/index.mjs +73 -74
  336. package/dist/services/auth/index.mjs.map +1 -1
  337. package/dist/services/config.js +47 -43
  338. package/dist/services/config.js.map +1 -1
  339. package/dist/services/config.mjs +46 -44
  340. package/dist/services/config.mjs.map +1 -1
  341. package/dist/services/content-api/index.js +80 -79
  342. package/dist/services/content-api/index.js.map +1 -1
  343. package/dist/services/content-api/index.mjs +79 -79
  344. package/dist/services/content-api/index.mjs.map +1 -1
  345. package/dist/services/content-api/permissions/engine.js +8 -5
  346. package/dist/services/content-api/permissions/engine.js.map +1 -1
  347. package/dist/services/content-api/permissions/engine.mjs +7 -5
  348. package/dist/services/content-api/permissions/engine.mjs.map +1 -1
  349. package/dist/services/content-api/permissions/index.js +101 -81
  350. package/dist/services/content-api/permissions/index.js.map +1 -1
  351. package/dist/services/content-api/permissions/index.mjs +100 -81
  352. package/dist/services/content-api/permissions/index.mjs.map +1 -1
  353. package/dist/services/content-api/permissions/providers/action.js +17 -14
  354. package/dist/services/content-api/permissions/providers/action.js.map +1 -1
  355. package/dist/services/content-api/permissions/providers/action.mjs +16 -16
  356. package/dist/services/content-api/permissions/providers/action.mjs.map +1 -1
  357. package/dist/services/content-api/permissions/providers/condition.js +17 -14
  358. package/dist/services/content-api/permissions/providers/condition.js.map +1 -1
  359. package/dist/services/content-api/permissions/providers/condition.mjs +16 -16
  360. package/dist/services/content-api/permissions/providers/condition.mjs.map +1 -1
  361. package/dist/services/core-store.js +115 -95
  362. package/dist/services/core-store.js.map +1 -1
  363. package/dist/services/core-store.mjs +114 -97
  364. package/dist/services/core-store.mjs.map +1 -1
  365. package/dist/services/cron.js +74 -60
  366. package/dist/services/cron.js.map +1 -1
  367. package/dist/services/cron.mjs +73 -62
  368. package/dist/services/cron.mjs.map +1 -1
  369. package/dist/services/custom-fields.js +9 -7
  370. package/dist/services/custom-fields.js.map +1 -1
  371. package/dist/services/custom-fields.mjs +8 -9
  372. package/dist/services/custom-fields.mjs.map +1 -1
  373. package/dist/services/document-service/attributes/index.js +23 -18
  374. package/dist/services/document-service/attributes/index.js.map +1 -1
  375. package/dist/services/document-service/attributes/index.mjs +22 -19
  376. package/dist/services/document-service/attributes/index.mjs.map +1 -1
  377. package/dist/services/document-service/attributes/transforms.js +16 -15
  378. package/dist/services/document-service/attributes/transforms.js.map +1 -1
  379. package/dist/services/document-service/attributes/transforms.mjs +15 -15
  380. package/dist/services/document-service/attributes/transforms.mjs.map +1 -1
  381. package/dist/services/document-service/common.d.ts +1 -1
  382. package/dist/services/document-service/common.d.ts.map +1 -1
  383. package/dist/services/document-service/common.js +5 -4
  384. package/dist/services/document-service/common.js.map +1 -1
  385. package/dist/services/document-service/common.mjs +4 -5
  386. package/dist/services/document-service/common.mjs.map +1 -1
  387. package/dist/services/document-service/components.d.ts.map +1 -1
  388. package/dist/services/document-service/components.js +255 -257
  389. package/dist/services/document-service/components.js.map +1 -1
  390. package/dist/services/document-service/components.mjs +254 -262
  391. package/dist/services/document-service/components.mjs.map +1 -1
  392. package/dist/services/document-service/draft-and-publish.d.ts +1 -1
  393. package/dist/services/document-service/draft-and-publish.d.ts.map +1 -1
  394. package/dist/services/document-service/draft-and-publish.js +88 -48
  395. package/dist/services/document-service/draft-and-publish.js.map +1 -1
  396. package/dist/services/document-service/draft-and-publish.mjs +87 -54
  397. package/dist/services/document-service/draft-and-publish.mjs.map +1 -1
  398. package/dist/services/document-service/entries.d.ts +2 -2
  399. package/dist/services/document-service/entries.d.ts.map +1 -1
  400. package/dist/services/document-service/entries.js +109 -92
  401. package/dist/services/document-service/entries.js.map +1 -1
  402. package/dist/services/document-service/entries.mjs +108 -93
  403. package/dist/services/document-service/entries.mjs.map +1 -1
  404. package/dist/services/document-service/events.d.ts +1 -1
  405. package/dist/services/document-service/events.d.ts.map +1 -1
  406. package/dist/services/document-service/events.js +52 -40
  407. package/dist/services/document-service/events.js.map +1 -1
  408. package/dist/services/document-service/events.mjs +51 -41
  409. package/dist/services/document-service/events.mjs.map +1 -1
  410. package/dist/services/document-service/index.d.ts +2 -1
  411. package/dist/services/document-service/index.d.ts.map +1 -1
  412. package/dist/services/document-service/index.js +53 -32
  413. package/dist/services/document-service/index.js.map +1 -1
  414. package/dist/services/document-service/index.mjs +52 -33
  415. package/dist/services/document-service/index.mjs.map +1 -1
  416. package/dist/services/document-service/internationalization.js +62 -46
  417. package/dist/services/document-service/internationalization.js.map +1 -1
  418. package/dist/services/document-service/internationalization.mjs +61 -50
  419. package/dist/services/document-service/internationalization.mjs.map +1 -1
  420. package/dist/services/document-service/middlewares/errors.js +23 -19
  421. package/dist/services/document-service/middlewares/errors.js.map +1 -1
  422. package/dist/services/document-service/middlewares/errors.mjs +22 -20
  423. package/dist/services/document-service/middlewares/errors.mjs.map +1 -1
  424. package/dist/services/document-service/middlewares/middleware-manager.js +46 -44
  425. package/dist/services/document-service/middlewares/middleware-manager.js.map +1 -1
  426. package/dist/services/document-service/middlewares/middleware-manager.mjs +45 -45
  427. package/dist/services/document-service/middlewares/middleware-manager.mjs.map +1 -1
  428. package/dist/services/document-service/params.js +11 -5
  429. package/dist/services/document-service/params.js.map +1 -1
  430. package/dist/services/document-service/params.mjs +10 -6
  431. package/dist/services/document-service/params.mjs.map +1 -1
  432. package/dist/services/document-service/repository.d.ts.map +1 -1
  433. package/dist/services/document-service/repository.js +354 -304
  434. package/dist/services/document-service/repository.js.map +1 -1
  435. package/dist/services/document-service/repository.mjs +353 -305
  436. package/dist/services/document-service/repository.mjs.map +1 -1
  437. package/dist/services/document-service/transform/data.js +22 -12
  438. package/dist/services/document-service/transform/data.js.map +1 -1
  439. package/dist/services/document-service/transform/data.mjs +21 -13
  440. package/dist/services/document-service/transform/data.mjs.map +1 -1
  441. package/dist/services/document-service/transform/fields.js +26 -17
  442. package/dist/services/document-service/transform/fields.js.map +1 -1
  443. package/dist/services/document-service/transform/fields.mjs +25 -18
  444. package/dist/services/document-service/transform/fields.mjs.map +1 -1
  445. package/dist/services/document-service/transform/id-map.d.ts +1 -1
  446. package/dist/services/document-service/transform/id-map.d.ts.map +1 -1
  447. package/dist/services/document-service/transform/id-map.js +116 -69
  448. package/dist/services/document-service/transform/id-map.js.map +1 -1
  449. package/dist/services/document-service/transform/id-map.mjs +115 -70
  450. package/dist/services/document-service/transform/id-map.mjs.map +1 -1
  451. package/dist/services/document-service/transform/id-transform.d.ts +1 -1
  452. package/dist/services/document-service/transform/id-transform.d.ts.map +1 -1
  453. package/dist/services/document-service/transform/id-transform.js +37 -29
  454. package/dist/services/document-service/transform/id-transform.js.map +1 -1
  455. package/dist/services/document-service/transform/id-transform.mjs +36 -30
  456. package/dist/services/document-service/transform/id-transform.mjs.map +1 -1
  457. package/dist/services/document-service/transform/populate.js +23 -18
  458. package/dist/services/document-service/transform/populate.js.map +1 -1
  459. package/dist/services/document-service/transform/populate.mjs +22 -19
  460. package/dist/services/document-service/transform/populate.mjs.map +1 -1
  461. package/dist/services/document-service/transform/query.js +11 -6
  462. package/dist/services/document-service/transform/query.js.map +1 -1
  463. package/dist/services/document-service/transform/query.mjs +10 -7
  464. package/dist/services/document-service/transform/query.mjs.map +1 -1
  465. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +1 -1
  466. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -1
  467. package/dist/services/document-service/transform/relations/extract/data-ids.js +71 -48
  468. package/dist/services/document-service/transform/relations/extract/data-ids.js.map +1 -1
  469. package/dist/services/document-service/transform/relations/extract/data-ids.mjs +70 -49
  470. package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +1 -1
  471. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts.map +1 -1
  472. package/dist/services/document-service/transform/relations/transform/data-ids.js +97 -63
  473. package/dist/services/document-service/transform/relations/transform/data-ids.js.map +1 -1
  474. package/dist/services/document-service/transform/relations/transform/data-ids.mjs +96 -64
  475. package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +1 -1
  476. package/dist/services/document-service/transform/relations/transform/default-locale.js +47 -29
  477. package/dist/services/document-service/transform/relations/transform/default-locale.js.map +1 -1
  478. package/dist/services/document-service/transform/relations/transform/default-locale.mjs +46 -30
  479. package/dist/services/document-service/transform/relations/transform/default-locale.mjs.map +1 -1
  480. package/dist/services/document-service/transform/relations/utils/dp.d.ts +1 -1
  481. package/dist/services/document-service/transform/relations/utils/dp.d.ts.map +1 -1
  482. package/dist/services/document-service/transform/relations/utils/dp.js +52 -26
  483. package/dist/services/document-service/transform/relations/utils/dp.js.map +1 -1
  484. package/dist/services/document-service/transform/relations/utils/dp.mjs +51 -27
  485. package/dist/services/document-service/transform/relations/utils/dp.mjs.map +1 -1
  486. package/dist/services/document-service/transform/relations/utils/i18n.d.ts +1 -1
  487. package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -1
  488. package/dist/services/document-service/transform/relations/utils/i18n.js +20 -18
  489. package/dist/services/document-service/transform/relations/utils/i18n.js.map +1 -1
  490. package/dist/services/document-service/transform/relations/utils/i18n.mjs +19 -21
  491. package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +1 -1
  492. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts.map +1 -1
  493. package/dist/services/document-service/transform/relations/utils/map-relation.js +116 -77
  494. package/dist/services/document-service/transform/relations/utils/map-relation.js.map +1 -1
  495. package/dist/services/document-service/transform/relations/utils/map-relation.mjs +115 -79
  496. package/dist/services/document-service/transform/relations/utils/map-relation.mjs.map +1 -1
  497. package/dist/services/document-service/utils/bidirectional-relations.d.ts +95 -0
  498. package/dist/services/document-service/utils/bidirectional-relations.d.ts.map +1 -0
  499. package/dist/services/document-service/utils/bidirectional-relations.js +148 -0
  500. package/dist/services/document-service/utils/bidirectional-relations.js.map +1 -0
  501. package/dist/services/document-service/utils/bidirectional-relations.mjs +145 -0
  502. package/dist/services/document-service/utils/bidirectional-relations.mjs.map +1 -0
  503. package/dist/services/document-service/utils/populate.d.ts +1 -1
  504. package/dist/services/document-service/utils/populate.d.ts.map +1 -1
  505. package/dist/services/document-service/utils/populate.js +66 -42
  506. package/dist/services/document-service/utils/populate.js.map +1 -1
  507. package/dist/services/document-service/utils/populate.mjs +65 -43
  508. package/dist/services/document-service/utils/populate.mjs.map +1 -1
  509. package/dist/services/document-service/utils/unidirectional-relations.d.ts +12 -9
  510. package/dist/services/document-service/utils/unidirectional-relations.d.ts.map +1 -1
  511. package/dist/services/document-service/utils/unidirectional-relations.js +110 -52
  512. package/dist/services/document-service/utils/unidirectional-relations.js.map +1 -1
  513. package/dist/services/document-service/utils/unidirectional-relations.mjs +109 -54
  514. package/dist/services/document-service/utils/unidirectional-relations.mjs.map +1 -1
  515. package/dist/services/entity-service/index.js +230 -161
  516. package/dist/services/entity-service/index.js.map +1 -1
  517. package/dist/services/entity-service/index.mjs +229 -160
  518. package/dist/services/entity-service/index.mjs.map +1 -1
  519. package/dist/services/entity-validator/blocks-validator.js +135 -103
  520. package/dist/services/entity-validator/blocks-validator.js.map +1 -1
  521. package/dist/services/entity-validator/blocks-validator.mjs +134 -104
  522. package/dist/services/entity-validator/blocks-validator.mjs.map +1 -1
  523. package/dist/services/entity-validator/index.d.ts +1 -1
  524. package/dist/services/entity-validator/index.d.ts.map +1 -1
  525. package/dist/services/entity-validator/index.js +362 -367
  526. package/dist/services/entity-validator/index.js.map +1 -1
  527. package/dist/services/entity-validator/index.mjs +358 -364
  528. package/dist/services/entity-validator/index.mjs.map +1 -1
  529. package/dist/services/entity-validator/validators.js +268 -210
  530. package/dist/services/entity-validator/validators.js.map +1 -1
  531. package/dist/services/entity-validator/validators.mjs +267 -216
  532. package/dist/services/entity-validator/validators.mjs.map +1 -1
  533. package/dist/services/errors.js +65 -65
  534. package/dist/services/errors.js.map +1 -1
  535. package/dist/services/errors.mjs +64 -66
  536. package/dist/services/errors.mjs.map +1 -1
  537. package/dist/services/event-hub.js +82 -69
  538. package/dist/services/event-hub.js.map +1 -1
  539. package/dist/services/event-hub.mjs +81 -71
  540. package/dist/services/event-hub.mjs.map +1 -1
  541. package/dist/services/features.js +19 -14
  542. package/dist/services/features.js.map +1 -1
  543. package/dist/services/features.mjs +18 -15
  544. package/dist/services/features.mjs.map +1 -1
  545. package/dist/services/fs.js +41 -40
  546. package/dist/services/fs.js.map +1 -1
  547. package/dist/services/fs.mjs +40 -39
  548. package/dist/services/fs.mjs.map +1 -1
  549. package/dist/services/metrics/admin-user-hash.js +13 -11
  550. package/dist/services/metrics/admin-user-hash.js.map +1 -1
  551. package/dist/services/metrics/admin-user-hash.mjs +12 -10
  552. package/dist/services/metrics/admin-user-hash.mjs.map +1 -1
  553. package/dist/services/metrics/index.js +46 -40
  554. package/dist/services/metrics/index.js.map +1 -1
  555. package/dist/services/metrics/index.mjs +45 -42
  556. package/dist/services/metrics/index.mjs.map +1 -1
  557. package/dist/services/metrics/is-truthy.js +13 -6
  558. package/dist/services/metrics/is-truthy.js.map +1 -1
  559. package/dist/services/metrics/is-truthy.mjs +12 -6
  560. package/dist/services/metrics/is-truthy.mjs.map +1 -1
  561. package/dist/services/metrics/middleware.d.ts.map +1 -1
  562. package/dist/services/metrics/middleware.js +37 -22
  563. package/dist/services/metrics/middleware.js.map +1 -1
  564. package/dist/services/metrics/middleware.mjs +36 -24
  565. package/dist/services/metrics/middleware.mjs.map +1 -1
  566. package/dist/services/metrics/rate-limiter.d.ts.map +1 -1
  567. package/dist/services/metrics/rate-limiter.js +24 -19
  568. package/dist/services/metrics/rate-limiter.js.map +1 -1
  569. package/dist/services/metrics/rate-limiter.mjs +23 -21
  570. package/dist/services/metrics/rate-limiter.mjs.map +1 -1
  571. package/dist/services/metrics/sender.js +78 -69
  572. package/dist/services/metrics/sender.js.map +1 -1
  573. package/dist/services/metrics/sender.mjs +77 -64
  574. package/dist/services/metrics/sender.mjs.map +1 -1
  575. package/dist/services/query-params.js +13 -10
  576. package/dist/services/query-params.js.map +1 -1
  577. package/dist/services/query-params.mjs +12 -12
  578. package/dist/services/query-params.mjs.map +1 -1
  579. package/dist/services/reloader.js +35 -32
  580. package/dist/services/reloader.js.map +1 -1
  581. package/dist/services/reloader.mjs +34 -33
  582. package/dist/services/reloader.mjs.map +1 -1
  583. package/dist/services/request-context.js +11 -8
  584. package/dist/services/request-context.js.map +1 -1
  585. package/dist/services/request-context.mjs +10 -10
  586. package/dist/services/request-context.mjs.map +1 -1
  587. package/dist/services/server/admin-api.js +11 -10
  588. package/dist/services/server/admin-api.js.map +1 -1
  589. package/dist/services/server/admin-api.mjs +10 -11
  590. package/dist/services/server/admin-api.mjs.map +1 -1
  591. package/dist/services/server/api.js +33 -27
  592. package/dist/services/server/api.js.map +1 -1
  593. package/dist/services/server/api.mjs +32 -26
  594. package/dist/services/server/api.mjs.map +1 -1
  595. package/dist/services/server/compose-endpoint.js +116 -105
  596. package/dist/services/server/compose-endpoint.js.map +1 -1
  597. package/dist/services/server/compose-endpoint.mjs +115 -105
  598. package/dist/services/server/compose-endpoint.mjs.map +1 -1
  599. package/dist/services/server/content-api.js +11 -9
  600. package/dist/services/server/content-api.js.map +1 -1
  601. package/dist/services/server/content-api.mjs +10 -10
  602. package/dist/services/server/content-api.mjs.map +1 -1
  603. package/dist/services/server/http-server.js +48 -44
  604. package/dist/services/server/http-server.js.map +1 -1
  605. package/dist/services/server/http-server.mjs +47 -43
  606. package/dist/services/server/http-server.mjs.map +1 -1
  607. package/dist/services/server/index.js +85 -82
  608. package/dist/services/server/index.js.map +1 -1
  609. package/dist/services/server/index.mjs +84 -81
  610. package/dist/services/server/index.mjs.map +1 -1
  611. package/dist/services/server/koa.js +49 -47
  612. package/dist/services/server/koa.js.map +1 -1
  613. package/dist/services/server/koa.mjs +48 -44
  614. package/dist/services/server/koa.mjs.map +1 -1
  615. package/dist/services/server/middleware.js +86 -82
  616. package/dist/services/server/middleware.js.map +1 -1
  617. package/dist/services/server/middleware.mjs +85 -82
  618. package/dist/services/server/middleware.mjs.map +1 -1
  619. package/dist/services/server/policy.js +24 -17
  620. package/dist/services/server/policy.js.map +1 -1
  621. package/dist/services/server/policy.mjs +23 -18
  622. package/dist/services/server/policy.mjs.map +1 -1
  623. package/dist/services/server/register-middlewares.js +68 -61
  624. package/dist/services/server/register-middlewares.js.map +1 -1
  625. package/dist/services/server/register-middlewares.mjs +67 -63
  626. package/dist/services/server/register-middlewares.mjs.map +1 -1
  627. package/dist/services/server/register-routes.js +90 -67
  628. package/dist/services/server/register-routes.js.map +1 -1
  629. package/dist/services/server/register-routes.mjs +89 -67
  630. package/dist/services/server/register-routes.mjs.map +1 -1
  631. package/dist/services/server/routing.js +94 -81
  632. package/dist/services/server/routing.js.map +1 -1
  633. package/dist/services/server/routing.mjs +93 -81
  634. package/dist/services/server/routing.mjs.map +1 -1
  635. package/dist/services/utils/dynamic-zones.js +13 -14
  636. package/dist/services/utils/dynamic-zones.js.map +1 -1
  637. package/dist/services/utils/dynamic-zones.mjs +12 -16
  638. package/dist/services/utils/dynamic-zones.mjs.map +1 -1
  639. package/dist/services/webhook-runner.js +124 -122
  640. package/dist/services/webhook-runner.js.map +1 -1
  641. package/dist/services/webhook-runner.mjs +123 -121
  642. package/dist/services/webhook-runner.mjs.map +1 -1
  643. package/dist/services/webhook-store.js +132 -99
  644. package/dist/services/webhook-store.js.map +1 -1
  645. package/dist/services/webhook-store.mjs +131 -101
  646. package/dist/services/webhook-store.mjs.map +1 -1
  647. package/dist/services/worker-queue.js +44 -49
  648. package/dist/services/worker-queue.js.map +1 -1
  649. package/dist/services/worker-queue.mjs +43 -49
  650. package/dist/services/worker-queue.mjs.map +1 -1
  651. package/dist/utils/convert-custom-field-type.js +17 -20
  652. package/dist/utils/convert-custom-field-type.js.map +1 -1
  653. package/dist/utils/convert-custom-field-type.mjs +16 -21
  654. package/dist/utils/convert-custom-field-type.mjs.map +1 -1
  655. package/dist/utils/cron.js +64 -30
  656. package/dist/utils/cron.js.map +1 -1
  657. package/dist/utils/cron.mjs +63 -31
  658. package/dist/utils/cron.mjs.map +1 -1
  659. package/dist/utils/fetch.js +24 -18
  660. package/dist/utils/fetch.js.map +1 -1
  661. package/dist/utils/fetch.mjs +23 -19
  662. package/dist/utils/fetch.mjs.map +1 -1
  663. package/dist/utils/filepath-to-prop-path.js +20 -28
  664. package/dist/utils/filepath-to-prop-path.js.map +1 -1
  665. package/dist/utils/filepath-to-prop-path.mjs +19 -26
  666. package/dist/utils/filepath-to-prop-path.mjs.map +1 -1
  667. package/dist/utils/is-initialized.js +21 -12
  668. package/dist/utils/is-initialized.js.map +1 -1
  669. package/dist/utils/is-initialized.mjs +20 -13
  670. package/dist/utils/is-initialized.mjs.map +1 -1
  671. package/dist/utils/lifecycles.js +6 -5
  672. package/dist/utils/lifecycles.js.map +1 -1
  673. package/dist/utils/lifecycles.mjs +5 -6
  674. package/dist/utils/lifecycles.mjs.map +1 -1
  675. package/dist/utils/load-config-file.js +40 -38
  676. package/dist/utils/load-config-file.js.map +1 -1
  677. package/dist/utils/load-config-file.mjs +39 -36
  678. package/dist/utils/load-config-file.mjs.map +1 -1
  679. package/dist/utils/load-files.js +40 -35
  680. package/dist/utils/load-files.js.map +1 -1
  681. package/dist/utils/load-files.mjs +39 -32
  682. package/dist/utils/load-files.mjs.map +1 -1
  683. package/dist/utils/open-browser.js +8 -8
  684. package/dist/utils/open-browser.js.map +1 -1
  685. package/dist/utils/open-browser.mjs +7 -7
  686. package/dist/utils/open-browser.mjs.map +1 -1
  687. package/dist/utils/resolve-working-dirs.js +23 -10
  688. package/dist/utils/resolve-working-dirs.js.map +1 -1
  689. package/dist/utils/resolve-working-dirs.mjs +22 -9
  690. package/dist/utils/resolve-working-dirs.mjs.map +1 -1
  691. package/dist/utils/signals.js +20 -14
  692. package/dist/utils/signals.js.map +1 -1
  693. package/dist/utils/signals.mjs +19 -15
  694. package/dist/utils/signals.mjs.map +1 -1
  695. package/dist/utils/startup-logger.d.ts.map +1 -1
  696. package/dist/utils/startup-logger.js +107 -78
  697. package/dist/utils/startup-logger.js.map +1 -1
  698. package/dist/utils/startup-logger.mjs +106 -75
  699. package/dist/utils/startup-logger.mjs.map +1 -1
  700. package/dist/utils/transform-content-types-to-models.d.ts +353 -21
  701. package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
  702. package/dist/utils/transform-content-types-to-models.js +350 -261
  703. package/dist/utils/transform-content-types-to-models.js.map +1 -1
  704. package/dist/utils/transform-content-types-to-models.mjs +349 -269
  705. package/dist/utils/transform-content-types-to-models.mjs.map +1 -1
  706. package/dist/utils/update-notifier/index.d.ts.map +1 -1
  707. package/dist/utils/update-notifier/index.js +68 -73
  708. package/dist/utils/update-notifier/index.js.map +1 -1
  709. package/dist/utils/update-notifier/index.mjs +67 -67
  710. package/dist/utils/update-notifier/index.mjs.map +1 -1
  711. package/package.json +27 -28
@@ -1 +1 @@
1
- {"version":3,"file":"populate.js","sources":["../../../../src/services/document-service/utils/populate.ts"],"sourcesContent":["import { UID } from '@strapi/types';\nimport { contentTypes } from '@strapi/utils';\n\ninterface Options {\n /**\n * Fields to select when populating relations\n */\n relationalFields?: string[];\n}\n\nconst { CREATED_BY_ATTRIBUTE, UPDATED_BY_ATTRIBUTE } = contentTypes.constants;\n\n// We want to build a populate object based on the schema\nexport const getDeepPopulate = (uid: UID.Schema, opts: Options = {}) => {\n const model = strapi.getModel(uid);\n const attributes = Object.entries(model.attributes);\n\n return attributes.reduce((acc: any, [attributeName, attribute]) => {\n switch (attribute.type) {\n case 'relation': {\n // TODO: Support polymorphic relations\n const isMorphRelation = attribute.relation.toLowerCase().startsWith('morph');\n if (isMorphRelation) {\n break;\n }\n\n // Ignore not visible fields other than createdBy and updatedBy\n const isVisible = contentTypes.isVisibleAttribute(model, attributeName);\n const isCreatorField = [CREATED_BY_ATTRIBUTE, UPDATED_BY_ATTRIBUTE].includes(attributeName);\n\n if (isVisible || isCreatorField) {\n acc[attributeName] = { select: opts.relationalFields };\n }\n\n break;\n }\n\n case 'media': {\n acc[attributeName] = { select: ['id'] };\n break;\n }\n\n case 'component': {\n const populate = getDeepPopulate(attribute.component, opts);\n acc[attributeName] = { populate };\n break;\n }\n\n case 'dynamiczone': {\n // Use fragments to populate the dynamic zone components\n const populatedComponents = (attribute.components || []).reduce(\n (acc: any, componentUID: UID.Component) => {\n acc[componentUID] = { populate: getDeepPopulate(componentUID, opts) };\n return acc;\n },\n {}\n );\n\n acc[attributeName] = { on: populatedComponents };\n break;\n }\n default:\n break;\n }\n\n return acc;\n }, {});\n};\n"],"names":["contentTypes","acc"],"mappings":";;;AAUA,MAAM,EAAE,sBAAsB,yBAAyBA,YAAAA,aAAa;AAG7D,MAAM,kBAAkB,CAAC,KAAiB,OAAgB,OAAO;AAChE,QAAA,QAAQ,OAAO,SAAS,GAAG;AACjC,QAAM,aAAa,OAAO,QAAQ,MAAM,UAAU;AAElD,SAAO,WAAW,OAAO,CAAC,KAAU,CAAC,eAAe,SAAS,MAAM;AACjE,YAAQ,UAAU,MAAM;AAAA,MACtB,KAAK,YAAY;AAEf,cAAM,kBAAkB,UAAU,SAAS,YAAY,EAAE,WAAW,OAAO;AAC3E,YAAI,iBAAiB;AACnB;AAAA,QACF;AAGA,cAAM,YAAYA,YAAA,aAAa,mBAAmB,OAAO,aAAa;AACtE,cAAM,iBAAiB,CAAC,sBAAsB,oBAAoB,EAAE,SAAS,aAAa;AAE1F,YAAI,aAAa,gBAAgB;AAC/B,cAAI,aAAa,IAAI,EAAE,QAAQ,KAAK,iBAAiB;AAAA,QACvD;AAEA;AAAA,MACF;AAAA,MAEA,KAAK,SAAS;AACZ,YAAI,aAAa,IAAI,EAAE,QAAQ,CAAC,IAAI,EAAE;AACtC;AAAA,MACF;AAAA,MAEA,KAAK,aAAa;AAChB,cAAM,WAAW,gBAAgB,UAAU,WAAW,IAAI;AACtD,YAAA,aAAa,IAAI,EAAE;AACvB;AAAA,MACF;AAAA,MAEA,KAAK,eAAe;AAElB,cAAM,uBAAuB,UAAU,cAAc,CAAI,GAAA;AAAA,UACvD,CAACC,MAAU,iBAAgC;AACzCA,iBAAI,YAAY,IAAI,EAAE,UAAU,gBAAgB,cAAc,IAAI;AAC3DA,mBAAAA;AAAAA,UACT;AAAA,UACA,CAAC;AAAA,QAAA;AAGH,YAAI,aAAa,IAAI,EAAE,IAAI,oBAAoB;AAC/C;AAAA,MACF;AAAA,IAGF;AAEO,WAAA;AAAA,EACT,GAAG,CAAE,CAAA;AACP;;"}
1
+ {"version":3,"file":"populate.js","sources":["../../../../src/services/document-service/utils/populate.ts"],"sourcesContent":["import type { UID } from '@strapi/types';\nimport { contentTypes } from '@strapi/utils';\n\ninterface Options {\n /**\n * Fields to select when populating relations\n */\n relationalFields?: string[];\n}\n\nconst { CREATED_BY_ATTRIBUTE, UPDATED_BY_ATTRIBUTE } = contentTypes.constants;\n\n// We want to build a populate object based on the schema\nexport const getDeepPopulate = (uid: UID.Schema, opts: Options = {}) => {\n const model = strapi.getModel(uid);\n const attributes = Object.entries(model.attributes);\n\n return attributes.reduce((acc: any, [attributeName, attribute]) => {\n switch (attribute.type) {\n case 'relation': {\n // TODO: Support polymorphic relations\n const isMorphRelation = attribute.relation.toLowerCase().startsWith('morph');\n if (isMorphRelation) {\n break;\n }\n\n // Ignore not visible fields other than createdBy and updatedBy\n const isVisible = contentTypes.isVisibleAttribute(model, attributeName);\n const isCreatorField = [CREATED_BY_ATTRIBUTE, UPDATED_BY_ATTRIBUTE].includes(attributeName);\n\n if (isVisible || isCreatorField) {\n acc[attributeName] = { select: opts.relationalFields };\n }\n\n break;\n }\n\n case 'media': {\n // We populate all media fields for completeness of webhook responses\n // see https://github.com/strapi/strapi/issues/21546\n acc[attributeName] = { select: ['*'] };\n break;\n }\n\n case 'component': {\n const populate = getDeepPopulate(attribute.component, opts);\n acc[attributeName] = { populate };\n break;\n }\n\n case 'dynamiczone': {\n // Use fragments to populate the dynamic zone components\n const populatedComponents = (attribute.components || []).reduce(\n (acc: any, componentUID: UID.Component) => {\n acc[componentUID] = { populate: getDeepPopulate(componentUID, opts) };\n return acc;\n },\n {}\n );\n\n acc[attributeName] = { on: populatedComponents };\n break;\n }\n default:\n break;\n }\n\n return acc;\n }, {});\n};\n"],"names":["CREATED_BY_ATTRIBUTE","UPDATED_BY_ATTRIBUTE","contentTypes","constants","getDeepPopulate","uid","opts","model","strapi","getModel","attributes","Object","entries","reduce","acc","attributeName","attribute","type","isMorphRelation","relation","toLowerCase","startsWith","isVisible","isVisibleAttribute","isCreatorField","includes","select","relationalFields","populate","component","populatedComponents","components","componentUID","on"],"mappings":";;;;AAUA,MAAM,EAAEA,oBAAoB,EAAEC,oBAAoB,EAAE,GAAGC,yBAAaC,SAAS;AAE7E;MACaC,eAAkB,GAAA,CAACC,GAAiBC,EAAAA,IAAAA,GAAgB,EAAE,GAAA;IACjE,MAAMC,KAAAA,GAAQC,MAAOC,CAAAA,QAAQ,CAACJ,GAAAA,CAAAA;AAC9B,IAAA,MAAMK,UAAaC,GAAAA,MAAAA,CAAOC,OAAO,CAACL,MAAMG,UAAU,CAAA;AAElD,IAAA,OAAOA,WAAWG,MAAM,CAAC,CAACC,GAAU,EAAA,CAACC,eAAeC,SAAU,CAAA,GAAA;AAC5D,QAAA,OAAQA,UAAUC,IAAI;YACpB,KAAK,UAAA;AAAY,gBAAA;;AAEf,oBAAA,MAAMC,kBAAkBF,SAAUG,CAAAA,QAAQ,CAACC,WAAW,EAAA,CAAGC,UAAU,CAAC,OAAA,CAAA;AACpE,oBAAA,IAAIH,eAAiB,EAAA;AACnB,wBAAA;AACF;;AAGA,oBAAA,MAAMI,SAAYpB,GAAAA,wBAAAA,CAAaqB,kBAAkB,CAAChB,KAAOQ,EAAAA,aAAAA,CAAAA;AACzD,oBAAA,MAAMS,cAAiB,GAAA;AAACxB,wBAAAA,oBAAAA;AAAsBC,wBAAAA;AAAqB,qBAAA,CAACwB,QAAQ,CAACV,aAAAA,CAAAA;AAE7E,oBAAA,IAAIO,aAAaE,cAAgB,EAAA;wBAC/BV,GAAG,CAACC,cAAc,GAAG;AAAEW,4BAAAA,MAAAA,EAAQpB,KAAKqB;AAAiB,yBAAA;AACvD;AAEA,oBAAA;AACF;YAEA,KAAK,OAAA;AAAS,gBAAA;;;oBAGZb,GAAG,CAACC,cAAc,GAAG;wBAAEW,MAAQ,EAAA;AAAC,4BAAA;AAAI;AAAC,qBAAA;AACrC,oBAAA;AACF;YAEA,KAAK,WAAA;AAAa,gBAAA;AAChB,oBAAA,MAAME,QAAWxB,GAAAA,eAAAA,CAAgBY,SAAUa,CAAAA,SAAS,EAAEvB,IAAAA,CAAAA;oBACtDQ,GAAG,CAACC,cAAc,GAAG;AAAEa,wBAAAA;AAAS,qBAAA;AAChC,oBAAA;AACF;YAEA,KAAK,aAAA;AAAe,gBAAA;;AAElB,oBAAA,MAAME,mBAAsB,GAACd,CAAAA,SAAAA,CAAUe,UAAU,IAAI,EAAC,EAAGlB,MAAM,CAC7D,CAACC,GAAUkB,EAAAA,YAAAA,GAAAA;wBACTlB,GAAG,CAACkB,aAAa,GAAG;AAAEJ,4BAAAA,QAAAA,EAAUxB,gBAAgB4B,YAAc1B,EAAAA,IAAAA;AAAM,yBAAA;wBACpE,OAAOQ,GAAAA;AACT,qBAAA,EACA,EAAC,CAAA;oBAGHA,GAAG,CAACC,cAAc,GAAG;wBAAEkB,EAAIH,EAAAA;AAAoB,qBAAA;AAC/C,oBAAA;AACF;AAGF;QAEA,OAAOhB,GAAAA;AACT,KAAA,EAAG,EAAC,CAAA;AACN;;;;"}
@@ -1,47 +1,69 @@
1
- import { contentTypes } from "@strapi/utils";
1
+ import { contentTypes } from '@strapi/utils';
2
+
2
3
  const { CREATED_BY_ATTRIBUTE, UPDATED_BY_ATTRIBUTE } = contentTypes.constants;
3
- const getDeepPopulate = (uid, opts = {}) => {
4
- const model = strapi.getModel(uid);
5
- const attributes = Object.entries(model.attributes);
6
- return attributes.reduce((acc, [attributeName, attribute]) => {
7
- switch (attribute.type) {
8
- case "relation": {
9
- const isMorphRelation = attribute.relation.toLowerCase().startsWith("morph");
10
- if (isMorphRelation) {
11
- break;
4
+ // We want to build a populate object based on the schema
5
+ const getDeepPopulate = (uid, opts = {})=>{
6
+ const model = strapi.getModel(uid);
7
+ const attributes = Object.entries(model.attributes);
8
+ return attributes.reduce((acc, [attributeName, attribute])=>{
9
+ switch(attribute.type){
10
+ case 'relation':
11
+ {
12
+ // TODO: Support polymorphic relations
13
+ const isMorphRelation = attribute.relation.toLowerCase().startsWith('morph');
14
+ if (isMorphRelation) {
15
+ break;
16
+ }
17
+ // Ignore not visible fields other than createdBy and updatedBy
18
+ const isVisible = contentTypes.isVisibleAttribute(model, attributeName);
19
+ const isCreatorField = [
20
+ CREATED_BY_ATTRIBUTE,
21
+ UPDATED_BY_ATTRIBUTE
22
+ ].includes(attributeName);
23
+ if (isVisible || isCreatorField) {
24
+ acc[attributeName] = {
25
+ select: opts.relationalFields
26
+ };
27
+ }
28
+ break;
29
+ }
30
+ case 'media':
31
+ {
32
+ // We populate all media fields for completeness of webhook responses
33
+ // see https://github.com/strapi/strapi/issues/21546
34
+ acc[attributeName] = {
35
+ select: [
36
+ '*'
37
+ ]
38
+ };
39
+ break;
40
+ }
41
+ case 'component':
42
+ {
43
+ const populate = getDeepPopulate(attribute.component, opts);
44
+ acc[attributeName] = {
45
+ populate
46
+ };
47
+ break;
48
+ }
49
+ case 'dynamiczone':
50
+ {
51
+ // Use fragments to populate the dynamic zone components
52
+ const populatedComponents = (attribute.components || []).reduce((acc, componentUID)=>{
53
+ acc[componentUID] = {
54
+ populate: getDeepPopulate(componentUID, opts)
55
+ };
56
+ return acc;
57
+ }, {});
58
+ acc[attributeName] = {
59
+ on: populatedComponents
60
+ };
61
+ break;
62
+ }
12
63
  }
13
- const isVisible = contentTypes.isVisibleAttribute(model, attributeName);
14
- const isCreatorField = [CREATED_BY_ATTRIBUTE, UPDATED_BY_ATTRIBUTE].includes(attributeName);
15
- if (isVisible || isCreatorField) {
16
- acc[attributeName] = { select: opts.relationalFields };
17
- }
18
- break;
19
- }
20
- case "media": {
21
- acc[attributeName] = { select: ["id"] };
22
- break;
23
- }
24
- case "component": {
25
- const populate = getDeepPopulate(attribute.component, opts);
26
- acc[attributeName] = { populate };
27
- break;
28
- }
29
- case "dynamiczone": {
30
- const populatedComponents = (attribute.components || []).reduce(
31
- (acc2, componentUID) => {
32
- acc2[componentUID] = { populate: getDeepPopulate(componentUID, opts) };
33
- return acc2;
34
- },
35
- {}
36
- );
37
- acc[attributeName] = { on: populatedComponents };
38
- break;
39
- }
40
- }
41
- return acc;
42
- }, {});
43
- };
44
- export {
45
- getDeepPopulate
64
+ return acc;
65
+ }, {});
46
66
  };
67
+
68
+ export { getDeepPopulate };
47
69
  //# sourceMappingURL=populate.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"populate.mjs","sources":["../../../../src/services/document-service/utils/populate.ts"],"sourcesContent":["import { UID } from '@strapi/types';\nimport { contentTypes } from '@strapi/utils';\n\ninterface Options {\n /**\n * Fields to select when populating relations\n */\n relationalFields?: string[];\n}\n\nconst { CREATED_BY_ATTRIBUTE, UPDATED_BY_ATTRIBUTE } = contentTypes.constants;\n\n// We want to build a populate object based on the schema\nexport const getDeepPopulate = (uid: UID.Schema, opts: Options = {}) => {\n const model = strapi.getModel(uid);\n const attributes = Object.entries(model.attributes);\n\n return attributes.reduce((acc: any, [attributeName, attribute]) => {\n switch (attribute.type) {\n case 'relation': {\n // TODO: Support polymorphic relations\n const isMorphRelation = attribute.relation.toLowerCase().startsWith('morph');\n if (isMorphRelation) {\n break;\n }\n\n // Ignore not visible fields other than createdBy and updatedBy\n const isVisible = contentTypes.isVisibleAttribute(model, attributeName);\n const isCreatorField = [CREATED_BY_ATTRIBUTE, UPDATED_BY_ATTRIBUTE].includes(attributeName);\n\n if (isVisible || isCreatorField) {\n acc[attributeName] = { select: opts.relationalFields };\n }\n\n break;\n }\n\n case 'media': {\n acc[attributeName] = { select: ['id'] };\n break;\n }\n\n case 'component': {\n const populate = getDeepPopulate(attribute.component, opts);\n acc[attributeName] = { populate };\n break;\n }\n\n case 'dynamiczone': {\n // Use fragments to populate the dynamic zone components\n const populatedComponents = (attribute.components || []).reduce(\n (acc: any, componentUID: UID.Component) => {\n acc[componentUID] = { populate: getDeepPopulate(componentUID, opts) };\n return acc;\n },\n {}\n );\n\n acc[attributeName] = { on: populatedComponents };\n break;\n }\n default:\n break;\n }\n\n return acc;\n }, {});\n};\n"],"names":["acc"],"mappings":";AAUA,MAAM,EAAE,sBAAsB,yBAAyB,aAAa;AAG7D,MAAM,kBAAkB,CAAC,KAAiB,OAAgB,OAAO;AAChE,QAAA,QAAQ,OAAO,SAAS,GAAG;AACjC,QAAM,aAAa,OAAO,QAAQ,MAAM,UAAU;AAElD,SAAO,WAAW,OAAO,CAAC,KAAU,CAAC,eAAe,SAAS,MAAM;AACjE,YAAQ,UAAU,MAAM;AAAA,MACtB,KAAK,YAAY;AAEf,cAAM,kBAAkB,UAAU,SAAS,YAAY,EAAE,WAAW,OAAO;AAC3E,YAAI,iBAAiB;AACnB;AAAA,QACF;AAGA,cAAM,YAAY,aAAa,mBAAmB,OAAO,aAAa;AACtE,cAAM,iBAAiB,CAAC,sBAAsB,oBAAoB,EAAE,SAAS,aAAa;AAE1F,YAAI,aAAa,gBAAgB;AAC/B,cAAI,aAAa,IAAI,EAAE,QAAQ,KAAK,iBAAiB;AAAA,QACvD;AAEA;AAAA,MACF;AAAA,MAEA,KAAK,SAAS;AACZ,YAAI,aAAa,IAAI,EAAE,QAAQ,CAAC,IAAI,EAAE;AACtC;AAAA,MACF;AAAA,MAEA,KAAK,aAAa;AAChB,cAAM,WAAW,gBAAgB,UAAU,WAAW,IAAI;AACtD,YAAA,aAAa,IAAI,EAAE;AACvB;AAAA,MACF;AAAA,MAEA,KAAK,eAAe;AAElB,cAAM,uBAAuB,UAAU,cAAc,CAAI,GAAA;AAAA,UACvD,CAACA,MAAU,iBAAgC;AACzCA,iBAAI,YAAY,IAAI,EAAE,UAAU,gBAAgB,cAAc,IAAI;AAC3DA,mBAAAA;AAAAA,UACT;AAAA,UACA,CAAC;AAAA,QAAA;AAGH,YAAI,aAAa,IAAI,EAAE,IAAI,oBAAoB;AAC/C;AAAA,MACF;AAAA,IAGF;AAEO,WAAA;AAAA,EACT,GAAG,CAAE,CAAA;AACP;"}
1
+ {"version":3,"file":"populate.mjs","sources":["../../../../src/services/document-service/utils/populate.ts"],"sourcesContent":["import type { UID } from '@strapi/types';\nimport { contentTypes } from '@strapi/utils';\n\ninterface Options {\n /**\n * Fields to select when populating relations\n */\n relationalFields?: string[];\n}\n\nconst { CREATED_BY_ATTRIBUTE, UPDATED_BY_ATTRIBUTE } = contentTypes.constants;\n\n// We want to build a populate object based on the schema\nexport const getDeepPopulate = (uid: UID.Schema, opts: Options = {}) => {\n const model = strapi.getModel(uid);\n const attributes = Object.entries(model.attributes);\n\n return attributes.reduce((acc: any, [attributeName, attribute]) => {\n switch (attribute.type) {\n case 'relation': {\n // TODO: Support polymorphic relations\n const isMorphRelation = attribute.relation.toLowerCase().startsWith('morph');\n if (isMorphRelation) {\n break;\n }\n\n // Ignore not visible fields other than createdBy and updatedBy\n const isVisible = contentTypes.isVisibleAttribute(model, attributeName);\n const isCreatorField = [CREATED_BY_ATTRIBUTE, UPDATED_BY_ATTRIBUTE].includes(attributeName);\n\n if (isVisible || isCreatorField) {\n acc[attributeName] = { select: opts.relationalFields };\n }\n\n break;\n }\n\n case 'media': {\n // We populate all media fields for completeness of webhook responses\n // see https://github.com/strapi/strapi/issues/21546\n acc[attributeName] = { select: ['*'] };\n break;\n }\n\n case 'component': {\n const populate = getDeepPopulate(attribute.component, opts);\n acc[attributeName] = { populate };\n break;\n }\n\n case 'dynamiczone': {\n // Use fragments to populate the dynamic zone components\n const populatedComponents = (attribute.components || []).reduce(\n (acc: any, componentUID: UID.Component) => {\n acc[componentUID] = { populate: getDeepPopulate(componentUID, opts) };\n return acc;\n },\n {}\n );\n\n acc[attributeName] = { on: populatedComponents };\n break;\n }\n default:\n break;\n }\n\n return acc;\n }, {});\n};\n"],"names":["CREATED_BY_ATTRIBUTE","UPDATED_BY_ATTRIBUTE","contentTypes","constants","getDeepPopulate","uid","opts","model","strapi","getModel","attributes","Object","entries","reduce","acc","attributeName","attribute","type","isMorphRelation","relation","toLowerCase","startsWith","isVisible","isVisibleAttribute","isCreatorField","includes","select","relationalFields","populate","component","populatedComponents","components","componentUID","on"],"mappings":";;AAUA,MAAM,EAAEA,oBAAoB,EAAEC,oBAAoB,EAAE,GAAGC,aAAaC,SAAS;AAE7E;MACaC,eAAkB,GAAA,CAACC,GAAiBC,EAAAA,IAAAA,GAAgB,EAAE,GAAA;IACjE,MAAMC,KAAAA,GAAQC,MAAOC,CAAAA,QAAQ,CAACJ,GAAAA,CAAAA;AAC9B,IAAA,MAAMK,UAAaC,GAAAA,MAAAA,CAAOC,OAAO,CAACL,MAAMG,UAAU,CAAA;AAElD,IAAA,OAAOA,WAAWG,MAAM,CAAC,CAACC,GAAU,EAAA,CAACC,eAAeC,SAAU,CAAA,GAAA;AAC5D,QAAA,OAAQA,UAAUC,IAAI;YACpB,KAAK,UAAA;AAAY,gBAAA;;AAEf,oBAAA,MAAMC,kBAAkBF,SAAUG,CAAAA,QAAQ,CAACC,WAAW,EAAA,CAAGC,UAAU,CAAC,OAAA,CAAA;AACpE,oBAAA,IAAIH,eAAiB,EAAA;AACnB,wBAAA;AACF;;AAGA,oBAAA,MAAMI,SAAYpB,GAAAA,YAAAA,CAAaqB,kBAAkB,CAAChB,KAAOQ,EAAAA,aAAAA,CAAAA;AACzD,oBAAA,MAAMS,cAAiB,GAAA;AAACxB,wBAAAA,oBAAAA;AAAsBC,wBAAAA;AAAqB,qBAAA,CAACwB,QAAQ,CAACV,aAAAA,CAAAA;AAE7E,oBAAA,IAAIO,aAAaE,cAAgB,EAAA;wBAC/BV,GAAG,CAACC,cAAc,GAAG;AAAEW,4BAAAA,MAAAA,EAAQpB,KAAKqB;AAAiB,yBAAA;AACvD;AAEA,oBAAA;AACF;YAEA,KAAK,OAAA;AAAS,gBAAA;;;oBAGZb,GAAG,CAACC,cAAc,GAAG;wBAAEW,MAAQ,EAAA;AAAC,4BAAA;AAAI;AAAC,qBAAA;AACrC,oBAAA;AACF;YAEA,KAAK,WAAA;AAAa,gBAAA;AAChB,oBAAA,MAAME,QAAWxB,GAAAA,eAAAA,CAAgBY,SAAUa,CAAAA,SAAS,EAAEvB,IAAAA,CAAAA;oBACtDQ,GAAG,CAACC,cAAc,GAAG;AAAEa,wBAAAA;AAAS,qBAAA;AAChC,oBAAA;AACF;YAEA,KAAK,aAAA;AAAe,gBAAA;;AAElB,oBAAA,MAAME,mBAAsB,GAACd,CAAAA,SAAAA,CAAUe,UAAU,IAAI,EAAC,EAAGlB,MAAM,CAC7D,CAACC,GAAUkB,EAAAA,YAAAA,GAAAA;wBACTlB,GAAG,CAACkB,aAAa,GAAG;AAAEJ,4BAAAA,QAAAA,EAAUxB,gBAAgB4B,YAAc1B,EAAAA,IAAAA;AAAM,yBAAA;wBACpE,OAAOQ,GAAAA;AACT,qBAAA,EACA,EAAC,CAAA;oBAGHA,GAAG,CAACC,cAAc,GAAG;wBAAEkB,EAAIH,EAAAA;AAAoB,qBAAA;AAC/C,oBAAA;AACF;AAGF;QAEA,OAAOhB,GAAAA;AACT,KAAA,EAAG,EAAC,CAAA;AACN;;;;"}
@@ -1,17 +1,20 @@
1
- import { UID } from '@strapi/types';
1
+ import type { UID } from '@strapi/types';
2
+ interface LoadContext {
3
+ oldVersions: {
4
+ id: string;
5
+ locale: string;
6
+ }[];
7
+ newVersions: {
8
+ id: string;
9
+ locale: string;
10
+ }[];
11
+ }
2
12
  /**
3
13
  * Loads lingering relations that need to be updated when overriding a published or draft entry.
4
14
  * This is necessary because the relations are uni-directional and the target entry is not aware of the source entry.
5
15
  * This is not the case for bi-directional relations, where the target entry is also linked to the source entry.
6
- *
7
- * @param uid The content type uid
8
- * @param oldEntries The old entries that are being overridden
9
- * @returns An array of relations that need to be updated with the join table reference.
10
16
  */
11
- declare const load: (uid: UID.ContentType, oldEntries: {
12
- id: string;
13
- locale: string;
14
- }[]) => Promise<any>;
17
+ declare const load: (uid: UID.ContentType, { oldVersions, newVersions }: LoadContext) => Promise<any>;
15
18
  /**
16
19
  * Updates uni directional relations to target the right entries when overriding published or draft entries.
17
20
  *
@@ -1 +1 @@
1
- {"version":3,"file":"unidirectional-relations.d.ts","sourceRoot":"","sources":["../../../../src/services/document-service/utils/unidirectional-relations.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,GAAG,EAAU,MAAM,eAAe,CAAC;AAE5C;;;;;;;;GAQG;AACH,QAAA,MAAM,IAAI,QAAe,IAAI,WAAW,cAAc;IAAE,EAAE,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,EAAE,iBA2CrF,CAAC;AAEF;;;;;;GAMG;AACH,QAAA,MAAM,IAAI,eACI;IAAE,EAAE,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,EAAE,cAChC;IAAE,EAAE,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,EAAE,gBAC9B;IAAE,SAAS,EAAE,GAAG,CAAC;IAAC,SAAS,EAAE,GAAG,EAAE,CAAA;CAAE,EAAE,kBAkCrD,CAAC;AAEF,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC"}
1
+ {"version":3,"file":"unidirectional-relations.d.ts","sourceRoot":"","sources":["../../../../src/services/document-service/utils/unidirectional-relations.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,GAAG,EAAU,MAAM,eAAe,CAAC;AAEjD,UAAU,WAAW;IACnB,WAAW,EAAE;QAAE,EAAE,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,EAAE,CAAC;IAC9C,WAAW,EAAE;QAAE,EAAE,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,EAAE,CAAC;CAC/C;AAED;;;;GAIG;AACH,QAAA,MAAM,IAAI,QAAe,IAAI,WAAW,gCAAgC,WAAW,iBA8FlF,CAAC;AAEF;;;;;;GAMG;AACH,QAAA,MAAM,IAAI,eACI;IAAE,EAAE,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,EAAE,cAChC;IAAE,EAAE,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,EAAE,gBAC9B;IAAE,SAAS,EAAE,GAAG,CAAC;IAAC,SAAS,EAAE,GAAG,EAAE,CAAA;CAAE,EAAE,kBAiCrD,CAAC;AAEF,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC"}
@@ -1,58 +1,116 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const fp = require("lodash/fp");
4
- const load = async (uid, oldEntries) => {
5
- const updates = [];
6
- await strapi.db.transaction(async ({ trx }) => {
7
- const contentTypes = Object.values(strapi.contentTypes);
8
- const components = Object.values(strapi.components);
9
- for (const model of [...contentTypes, ...components]) {
10
- const dbModel = strapi.db.metadata.get(model.uid);
11
- for (const attribute of Object.values(dbModel.attributes)) {
12
- if (attribute.type !== "relation")
13
- continue;
14
- if (attribute.target !== uid)
15
- continue;
16
- if (attribute.inversedBy || attribute.mappedBy)
17
- continue;
18
- const joinTable = attribute.joinTable;
19
- if (!joinTable)
20
- continue;
21
- const { name } = joinTable.inverseJoinColumn;
22
- const oldEntriesIds = oldEntries.map((entry) => entry.id);
23
- const relations = await strapi.db.getConnection().select("*").from(joinTable.name).whereIn(name, oldEntriesIds).transacting(trx);
24
- if (relations.length === 0)
25
- continue;
26
- updates.push({ joinTable, relations });
27
- }
28
- }
29
- });
30
- return updates;
1
+ 'use strict';
2
+
3
+ var fp = require('lodash/fp');
4
+
5
+ /**
6
+ * Loads lingering relations that need to be updated when overriding a published or draft entry.
7
+ * This is necessary because the relations are uni-directional and the target entry is not aware of the source entry.
8
+ * This is not the case for bi-directional relations, where the target entry is also linked to the source entry.
9
+ */ const load = async (uid, { oldVersions, newVersions })=>{
10
+ const updates = [];
11
+ // Iterate all components and content types to find relations that need to be updated
12
+ await strapi.db.transaction(async ({ trx })=>{
13
+ const contentTypes = Object.values(strapi.contentTypes);
14
+ const components = Object.values(strapi.components);
15
+ for (const model of [
16
+ ...contentTypes,
17
+ ...components
18
+ ]){
19
+ const dbModel = strapi.db.metadata.get(model.uid);
20
+ for (const attribute of Object.values(dbModel.attributes)){
21
+ /**
22
+ * Only consider unidirectional relations
23
+ */ if (attribute.type !== 'relation' || attribute.target !== uid || attribute.inversedBy || attribute.mappedBy) {
24
+ continue;
25
+ }
26
+ // TODO: joinColumn relations
27
+ const joinTable = attribute.joinTable;
28
+ if (!joinTable) {
29
+ continue;
30
+ }
31
+ const { name: sourceColumnName } = joinTable.joinColumn;
32
+ const { name: targetColumnName } = joinTable.inverseJoinColumn;
33
+ /**
34
+ * Load all relations that need to be updated
35
+ */ // NOTE: when the model has draft and publish, we can assume relation are only draft to draft & published to published
36
+ const ids = oldVersions.map((entry)=>entry.id);
37
+ const oldVersionsRelations = await strapi.db.getConnection().select('*').from(joinTable.name).whereIn(targetColumnName, ids).transacting(trx);
38
+ if (oldVersionsRelations.length > 0) {
39
+ updates.push({
40
+ joinTable,
41
+ relations: oldVersionsRelations
42
+ });
43
+ }
44
+ /**
45
+ * if publishing
46
+ * if published version exists
47
+ * updated published versions links
48
+ * else
49
+ * create link to newly published version
50
+ *
51
+ * if discarding
52
+ * if published version link exists & not draft version link
53
+ * create link to new draft version
54
+ */ if (!model.options?.draftAndPublish) {
55
+ const ids = newVersions.map((entry)=>entry.id);
56
+ const newVersionsRelations = await strapi.db.getConnection().select('*').from(joinTable.name).whereIn(targetColumnName, ids).transacting(trx);
57
+ if (newVersionsRelations.length > 0) {
58
+ // when publishing a draft that doesn't have a published version yet,
59
+ // copy the links to the draft over to the published version
60
+ // when discarding a published version, if no drafts exists
61
+ const discardToAdd = newVersionsRelations.filter((relation)=>{
62
+ const matchingOldVerion = oldVersionsRelations.find((oldRelation)=>{
63
+ return oldRelation[sourceColumnName] === relation[sourceColumnName];
64
+ });
65
+ return !matchingOldVerion;
66
+ }).map(fp.omit('id'));
67
+ updates.push({
68
+ joinTable,
69
+ relations: discardToAdd
70
+ });
71
+ }
72
+ }
73
+ }
74
+ }
75
+ });
76
+ return updates;
31
77
  };
32
- const sync = async (oldEntries, newEntries, oldRelations) => {
33
- const newEntryByLocale = fp.keyBy("locale", newEntries);
34
- const oldEntriesMap = oldEntries.reduce(
35
- (acc, entry) => {
36
- const newEntry = newEntryByLocale[entry.locale];
37
- if (!newEntry)
78
+ /**
79
+ * Updates uni directional relations to target the right entries when overriding published or draft entries.
80
+ *
81
+ * @param oldEntries The old entries that are being overridden
82
+ * @param newEntries The new entries that are overriding the old ones
83
+ * @param oldRelations The relations that were previously loaded with `load` @see load
84
+ */ const sync = async (oldEntries, newEntries, oldRelations)=>{
85
+ /**
86
+ * Create a map of old entry ids to new entry ids
87
+ *
88
+ * Will be used to update the relation target ids
89
+ */ const newEntryByLocale = fp.keyBy('locale', newEntries);
90
+ const oldEntriesMap = oldEntries.reduce((acc, entry)=>{
91
+ const newEntry = newEntryByLocale[entry.locale];
92
+ if (!newEntry) return acc;
93
+ acc[entry.id] = newEntry.id;
38
94
  return acc;
39
- acc[entry.id] = newEntry.id;
40
- return acc;
41
- },
42
- {}
43
- );
44
- await strapi.db.transaction(async ({ trx }) => {
45
- const con = strapi.db.getConnection();
46
- for (const { joinTable, relations } of oldRelations) {
47
- const newRelations = relations.map((relation) => {
48
- const column = joinTable.inverseJoinColumn.name;
49
- const newId = oldEntriesMap[relation[column]];
50
- return { ...relation, [column]: newId };
51
- });
52
- await con.batchInsert(joinTable.name, newRelations).transacting(trx);
53
- }
54
- });
95
+ }, {});
96
+ await strapi.db.transaction(async ({ trx })=>{
97
+ // Iterate old relations that are deleted and insert the new ones
98
+ for (const { joinTable, relations } of oldRelations){
99
+ // Update old ids with the new ones
100
+ const column = joinTable.inverseJoinColumn.name;
101
+ const newRelations = relations.map((relation)=>{
102
+ const newId = oldEntriesMap[relation[column]];
103
+ return {
104
+ ...relation,
105
+ [column]: newId
106
+ };
107
+ });
108
+ // Insert those relations into the join table
109
+ await trx.batchInsert(joinTable.name, newRelations, 1000);
110
+ }
111
+ });
55
112
  };
113
+
56
114
  exports.load = load;
57
115
  exports.sync = sync;
58
116
  //# sourceMappingURL=unidirectional-relations.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"unidirectional-relations.js","sources":["../../../../src/services/document-service/utils/unidirectional-relations.ts"],"sourcesContent":["/* eslint-disable no-continue */\nimport { keyBy } from 'lodash/fp';\n\nimport { UID, Schema } from '@strapi/types';\n\n/**\n * Loads lingering relations that need to be updated when overriding a published or draft entry.\n * This is necessary because the relations are uni-directional and the target entry is not aware of the source entry.\n * This is not the case for bi-directional relations, where the target entry is also linked to the source entry.\n *\n * @param uid The content type uid\n * @param oldEntries The old entries that are being overridden\n * @returns An array of relations that need to be updated with the join table reference.\n */\nconst load = async (uid: UID.ContentType, oldEntries: { id: string; locale: string }[]) => {\n const updates = [] as any;\n\n // Iterate all components and content types to find relations that need to be updated\n await strapi.db.transaction(async ({ trx }) => {\n const contentTypes = Object.values(strapi.contentTypes) as Schema.ContentType[];\n const components = Object.values(strapi.components) as Schema.Component[];\n\n for (const model of [...contentTypes, ...components]) {\n const dbModel = strapi.db.metadata.get(model.uid);\n\n for (const attribute of Object.values(dbModel.attributes) as any) {\n /**\n * Only consider unidirectional relations\n */\n if (attribute.type !== 'relation') continue;\n if (attribute.target !== uid) continue;\n if (attribute.inversedBy || attribute.mappedBy) continue;\n const joinTable = attribute.joinTable;\n // TODO: joinColumn relations\n if (!joinTable) continue;\n\n const { name } = joinTable.inverseJoinColumn;\n\n /**\n * Load all relations that need to be updated\n */\n const oldEntriesIds = oldEntries.map((entry) => entry.id);\n const relations = await strapi.db\n .getConnection()\n .select('*')\n .from(joinTable.name)\n .whereIn(name, oldEntriesIds)\n .transacting(trx);\n\n if (relations.length === 0) continue;\n\n updates.push({ joinTable, relations });\n }\n }\n });\n\n return updates;\n};\n\n/**\n * Updates uni directional relations to target the right entries when overriding published or draft entries.\n *\n * @param oldEntries The old entries that are being overridden\n * @param newEntries The new entries that are overriding the old ones\n * @param oldRelations The relations that were previously loaded with `load` @see load\n */\nconst sync = async (\n oldEntries: { id: string; locale: string }[],\n newEntries: { id: string; locale: string }[],\n oldRelations: { joinTable: any; relations: any[] }[]\n) => {\n /**\n * Create a map of old entry ids to new entry ids\n *\n * Will be used to update the relation target ids\n */\n const newEntryByLocale = keyBy('locale', newEntries);\n const oldEntriesMap = oldEntries.reduce(\n (acc, entry) => {\n const newEntry = newEntryByLocale[entry.locale];\n if (!newEntry) return acc;\n acc[entry.id] = newEntry.id;\n return acc;\n },\n {} as Record<string, string>\n );\n\n await strapi.db.transaction(async ({ trx }) => {\n const con = strapi.db.getConnection();\n\n // Iterate old relations that are deleted and insert the new ones\n for (const { joinTable, relations } of oldRelations) {\n // Update old ids with the new ones\n const newRelations = relations.map((relation) => {\n const column = joinTable.inverseJoinColumn.name;\n const newId = oldEntriesMap[relation[column]];\n return { ...relation, [column]: newId };\n });\n\n // Insert those relations into the join table\n await con.batchInsert(joinTable.name, newRelations).transacting(trx);\n }\n });\n};\n\nexport { load, sync };\n"],"names":["keyBy"],"mappings":";;;AAcM,MAAA,OAAO,OAAO,KAAsB,eAAiD;AACzF,QAAM,UAAU,CAAA;AAGhB,QAAM,OAAO,GAAG,YAAY,OAAO,EAAE,UAAU;AAC7C,UAAM,eAAe,OAAO,OAAO,OAAO,YAAY;AACtD,UAAM,aAAa,OAAO,OAAO,OAAO,UAAU;AAElD,eAAW,SAAS,CAAC,GAAG,cAAc,GAAG,UAAU,GAAG;AACpD,YAAM,UAAU,OAAO,GAAG,SAAS,IAAI,MAAM,GAAG;AAEhD,iBAAW,aAAa,OAAO,OAAO,QAAQ,UAAU,GAAU;AAIhE,YAAI,UAAU,SAAS;AAAY;AACnC,YAAI,UAAU,WAAW;AAAK;AAC1B,YAAA,UAAU,cAAc,UAAU;AAAU;AAChD,cAAM,YAAY,UAAU;AAE5B,YAAI,CAAC;AAAW;AAEV,cAAA,EAAE,KAAK,IAAI,UAAU;AAK3B,cAAM,gBAAgB,WAAW,IAAI,CAAC,UAAU,MAAM,EAAE;AACxD,cAAM,YAAY,MAAM,OAAO,GAC5B,gBACA,OAAO,GAAG,EACV,KAAK,UAAU,IAAI,EACnB,QAAQ,MAAM,aAAa,EAC3B,YAAY,GAAG;AAElB,YAAI,UAAU,WAAW;AAAG;AAE5B,gBAAQ,KAAK,EAAE,WAAW,UAAW,CAAA;AAAA,MACvC;AAAA,IACF;AAAA,EAAA,CACD;AAEM,SAAA;AACT;AASA,MAAM,OAAO,OACX,YACA,YACA,iBACG;AAMG,QAAA,mBAAmBA,GAAAA,MAAM,UAAU,UAAU;AACnD,QAAM,gBAAgB,WAAW;AAAA,IAC/B,CAAC,KAAK,UAAU;AACR,YAAA,WAAW,iBAAiB,MAAM,MAAM;AAC9C,UAAI,CAAC;AAAiB,eAAA;AAClB,UAAA,MAAM,EAAE,IAAI,SAAS;AAClB,aAAA;AAAA,IACT;AAAA,IACA,CAAC;AAAA,EAAA;AAGH,QAAM,OAAO,GAAG,YAAY,OAAO,EAAE,UAAU;AACvC,UAAA,MAAM,OAAO,GAAG,cAAc;AAGpC,eAAW,EAAE,WAAW,UAAU,KAAK,cAAc;AAEnD,YAAM,eAAe,UAAU,IAAI,CAAC,aAAa;AACzC,cAAA,SAAS,UAAU,kBAAkB;AAC3C,cAAM,QAAQ,cAAc,SAAS,MAAM,CAAC;AAC5C,eAAO,EAAE,GAAG,UAAU,CAAC,MAAM,GAAG,MAAM;AAAA,MAAA,CACvC;AAGD,YAAM,IAAI,YAAY,UAAU,MAAM,YAAY,EAAE,YAAY,GAAG;AAAA,IACrE;AAAA,EAAA,CACD;AACH;;;"}
1
+ {"version":3,"file":"unidirectional-relations.js","sources":["../../../../src/services/document-service/utils/unidirectional-relations.ts"],"sourcesContent":["/* eslint-disable no-continue */\nimport { keyBy, omit } from 'lodash/fp';\n\nimport type { UID, Schema } from '@strapi/types';\n\ninterface LoadContext {\n oldVersions: { id: string; locale: string }[];\n newVersions: { id: string; locale: string }[];\n}\n\n/**\n * Loads lingering relations that need to be updated when overriding a published or draft entry.\n * This is necessary because the relations are uni-directional and the target entry is not aware of the source entry.\n * This is not the case for bi-directional relations, where the target entry is also linked to the source entry.\n */\nconst load = async (uid: UID.ContentType, { oldVersions, newVersions }: LoadContext) => {\n const updates = [] as any;\n\n // Iterate all components and content types to find relations that need to be updated\n await strapi.db.transaction(async ({ trx }) => {\n const contentTypes = Object.values(strapi.contentTypes) as Schema.ContentType[];\n const components = Object.values(strapi.components) as Schema.Component[];\n\n for (const model of [...contentTypes, ...components]) {\n const dbModel = strapi.db.metadata.get(model.uid);\n\n for (const attribute of Object.values(dbModel.attributes) as any) {\n /**\n * Only consider unidirectional relations\n */\n if (\n attribute.type !== 'relation' ||\n attribute.target !== uid ||\n attribute.inversedBy ||\n attribute.mappedBy\n ) {\n continue;\n }\n\n // TODO: joinColumn relations\n const joinTable = attribute.joinTable;\n if (!joinTable) {\n continue;\n }\n\n const { name: sourceColumnName } = joinTable.joinColumn;\n const { name: targetColumnName } = joinTable.inverseJoinColumn;\n\n /**\n * Load all relations that need to be updated\n */\n // NOTE: when the model has draft and publish, we can assume relation are only draft to draft & published to published\n const ids = oldVersions.map((entry) => entry.id);\n\n const oldVersionsRelations = await strapi.db\n .getConnection()\n .select('*')\n .from(joinTable.name)\n .whereIn(targetColumnName, ids)\n .transacting(trx);\n\n if (oldVersionsRelations.length > 0) {\n updates.push({ joinTable, relations: oldVersionsRelations });\n }\n\n /**\n * if publishing\n * if published version exists\n * updated published versions links\n * else\n * create link to newly published version\n *\n * if discarding\n * if published version link exists & not draft version link\n * create link to new draft version\n */\n\n if (!model.options?.draftAndPublish) {\n const ids = newVersions.map((entry) => entry.id);\n\n const newVersionsRelations = await strapi.db\n .getConnection()\n .select('*')\n .from(joinTable.name)\n .whereIn(targetColumnName, ids)\n .transacting(trx);\n\n if (newVersionsRelations.length > 0) {\n // when publishing a draft that doesn't have a published version yet,\n // copy the links to the draft over to the published version\n // when discarding a published version, if no drafts exists\n const discardToAdd = newVersionsRelations\n .filter((relation) => {\n const matchingOldVerion = oldVersionsRelations.find((oldRelation) => {\n return oldRelation[sourceColumnName] === relation[sourceColumnName];\n });\n\n return !matchingOldVerion;\n })\n .map(omit('id'));\n\n updates.push({ joinTable, relations: discardToAdd });\n }\n }\n }\n }\n });\n\n return updates;\n};\n\n/**\n * Updates uni directional relations to target the right entries when overriding published or draft entries.\n *\n * @param oldEntries The old entries that are being overridden\n * @param newEntries The new entries that are overriding the old ones\n * @param oldRelations The relations that were previously loaded with `load` @see load\n */\nconst sync = async (\n oldEntries: { id: string; locale: string }[],\n newEntries: { id: string; locale: string }[],\n oldRelations: { joinTable: any; relations: any[] }[]\n) => {\n /**\n * Create a map of old entry ids to new entry ids\n *\n * Will be used to update the relation target ids\n */\n const newEntryByLocale = keyBy('locale', newEntries);\n const oldEntriesMap = oldEntries.reduce(\n (acc, entry) => {\n const newEntry = newEntryByLocale[entry.locale];\n if (!newEntry) return acc;\n acc[entry.id] = newEntry.id;\n return acc;\n },\n {} as Record<string, string>\n );\n\n await strapi.db.transaction(async ({ trx }) => {\n // Iterate old relations that are deleted and insert the new ones\n for (const { joinTable, relations } of oldRelations) {\n // Update old ids with the new ones\n const column = joinTable.inverseJoinColumn.name;\n\n const newRelations = relations.map((relation) => {\n const newId = oldEntriesMap[relation[column]];\n return { ...relation, [column]: newId };\n });\n\n // Insert those relations into the join table\n await trx.batchInsert(joinTable.name, newRelations, 1000);\n }\n });\n};\n\nexport { load, sync };\n"],"names":["load","uid","oldVersions","newVersions","updates","strapi","db","transaction","trx","contentTypes","Object","values","components","model","dbModel","metadata","get","attribute","attributes","type","target","inversedBy","mappedBy","joinTable","name","sourceColumnName","joinColumn","targetColumnName","inverseJoinColumn","ids","map","entry","id","oldVersionsRelations","getConnection","select","from","whereIn","transacting","length","push","relations","options","draftAndPublish","newVersionsRelations","discardToAdd","filter","relation","matchingOldVerion","find","oldRelation","omit","sync","oldEntries","newEntries","oldRelations","newEntryByLocale","keyBy","oldEntriesMap","reduce","acc","newEntry","locale","column","newRelations","newId","batchInsert"],"mappings":";;;;AAUA;;;;IAKA,MAAMA,OAAO,OAAOC,GAAAA,EAAsB,EAAEC,WAAW,EAAEC,WAAW,EAAe,GAAA;AACjF,IAAA,MAAMC,UAAU,EAAE;;IAGlB,MAAMC,MAAAA,CAAOC,EAAE,CAACC,WAAW,CAAC,OAAO,EAAEC,GAAG,EAAE,GAAA;AACxC,QAAA,MAAMC,YAAeC,GAAAA,MAAAA,CAAOC,MAAM,CAACN,OAAOI,YAAY,CAAA;AACtD,QAAA,MAAMG,UAAaF,GAAAA,MAAAA,CAAOC,MAAM,CAACN,OAAOO,UAAU,CAAA;AAElD,QAAA,KAAK,MAAMC,KAAS,IAAA;AAAIJ,YAAAA,GAAAA,YAAAA;AAAiBG,YAAAA,GAAAA;SAAW,CAAE;YACpD,MAAME,OAAAA,GAAUT,OAAOC,EAAE,CAACS,QAAQ,CAACC,GAAG,CAACH,KAAAA,CAAMZ,GAAG,CAAA;AAEhD,YAAA,KAAK,MAAMgB,SAAaP,IAAAA,MAAAA,CAAOC,MAAM,CAACG,OAAAA,CAAQI,UAAU,CAAU,CAAA;AAChE;;AAEC,YACD,IACED,SAAAA,CAAUE,IAAI,KAAK,cACnBF,SAAUG,CAAAA,MAAM,KAAKnB,GAAAA,IACrBgB,SAAUI,CAAAA,UAAU,IACpBJ,SAAAA,CAAUK,QAAQ,EAClB;AACA,oBAAA;AACF;;gBAGA,MAAMC,SAAAA,GAAYN,UAAUM,SAAS;AACrC,gBAAA,IAAI,CAACA,SAAW,EAAA;AACd,oBAAA;AACF;AAEA,gBAAA,MAAM,EAAEC,IAAMC,EAAAA,gBAAgB,EAAE,GAAGF,UAAUG,UAAU;AACvD,gBAAA,MAAM,EAAEF,IAAMG,EAAAA,gBAAgB,EAAE,GAAGJ,UAAUK,iBAAiB;AAE9D;;AAEC;AAED,gBAAA,MAAMC,MAAM3B,WAAY4B,CAAAA,GAAG,CAAC,CAACC,KAAAA,GAAUA,MAAMC,EAAE,CAAA;gBAE/C,MAAMC,oBAAAA,GAAuB,MAAM5B,MAAOC,CAAAA,EAAE,CACzC4B,aAAa,EAAA,CACbC,MAAM,CAAC,GAAA,CAAA,CACPC,IAAI,CAACb,SAAAA,CAAUC,IAAI,CACnBa,CAAAA,OAAO,CAACV,gBAAkBE,EAAAA,GAAAA,CAAAA,CAC1BS,WAAW,CAAC9B,GAAAA,CAAAA;gBAEf,IAAIyB,oBAAAA,CAAqBM,MAAM,GAAG,CAAG,EAAA;AACnCnC,oBAAAA,OAAAA,CAAQoC,IAAI,CAAC;AAAEjB,wBAAAA,SAAAA;wBAAWkB,SAAWR,EAAAA;AAAqB,qBAAA,CAAA;AAC5D;AAEA;;;;;;;;;;AAUC,YAED,IAAI,CAACpB,KAAM6B,CAAAA,OAAO,EAAEC,eAAiB,EAAA;AACnC,oBAAA,MAAMd,MAAM1B,WAAY2B,CAAAA,GAAG,CAAC,CAACC,KAAAA,GAAUA,MAAMC,EAAE,CAAA;oBAE/C,MAAMY,oBAAAA,GAAuB,MAAMvC,MAAOC,CAAAA,EAAE,CACzC4B,aAAa,EAAA,CACbC,MAAM,CAAC,GAAA,CAAA,CACPC,IAAI,CAACb,SAAAA,CAAUC,IAAI,CACnBa,CAAAA,OAAO,CAACV,gBAAkBE,EAAAA,GAAAA,CAAAA,CAC1BS,WAAW,CAAC9B,GAAAA,CAAAA;oBAEf,IAAIoC,oBAAAA,CAAqBL,MAAM,GAAG,CAAG,EAAA;;;;AAInC,wBAAA,MAAMM,YAAeD,GAAAA,oBAAAA,CAClBE,MAAM,CAAC,CAACC,QAAAA,GAAAA;AACP,4BAAA,MAAMC,iBAAoBf,GAAAA,oBAAAA,CAAqBgB,IAAI,CAAC,CAACC,WAAAA,GAAAA;AACnD,gCAAA,OAAOA,WAAW,CAACzB,gBAAAA,CAAiB,KAAKsB,QAAQ,CAACtB,gBAAiB,CAAA;AACrE,6BAAA,CAAA;AAEA,4BAAA,OAAO,CAACuB,iBAAAA;yBAETlB,CAAAA,CAAAA,GAAG,CAACqB,OAAK,CAAA,IAAA,CAAA,CAAA;AAEZ/C,wBAAAA,OAAAA,CAAQoC,IAAI,CAAC;AAAEjB,4BAAAA,SAAAA;4BAAWkB,SAAWI,EAAAA;AAAa,yBAAA,CAAA;AACpD;AACF;AACF;AACF;AACF,KAAA,CAAA;IAEA,OAAOzC,OAAAA;AACT;AAEA;;;;;;AAMC,IACKgD,MAAAA,IAAAA,GAAO,OACXC,UAAAA,EACAC,UACAC,EAAAA,YAAAA,GAAAA;AAEA;;;;MAKA,MAAMC,gBAAmBC,GAAAA,QAAAA,CAAM,QAAUH,EAAAA,UAAAA,CAAAA;AACzC,IAAA,MAAMI,aAAgBL,GAAAA,UAAAA,CAAWM,MAAM,CACrC,CAACC,GAAK7B,EAAAA,KAAAA,GAAAA;AACJ,QAAA,MAAM8B,QAAWL,GAAAA,gBAAgB,CAACzB,KAAAA,CAAM+B,MAAM,CAAC;QAC/C,IAAI,CAACD,UAAU,OAAOD,GAAAA;AACtBA,QAAAA,GAAG,CAAC7B,KAAMC,CAAAA,EAAE,CAAC,GAAG6B,SAAS7B,EAAE;QAC3B,OAAO4B,GAAAA;AACT,KAAA,EACA,EAAC,CAAA;IAGH,MAAMvD,MAAAA,CAAOC,EAAE,CAACC,WAAW,CAAC,OAAO,EAAEC,GAAG,EAAE,GAAA;;AAExC,QAAA,KAAK,MAAM,EAAEe,SAAS,EAAEkB,SAAS,EAAE,IAAIc,YAAc,CAAA;;AAEnD,YAAA,MAAMQ,MAASxC,GAAAA,SAAAA,CAAUK,iBAAiB,CAACJ,IAAI;AAE/C,YAAA,MAAMwC,YAAevB,GAAAA,SAAAA,CAAUX,GAAG,CAAC,CAACiB,QAAAA,GAAAA;AAClC,gBAAA,MAAMkB,QAAQP,aAAa,CAACX,QAAQ,CAACgB,OAAO,CAAC;gBAC7C,OAAO;AAAE,oBAAA,GAAGhB,QAAQ;AAAE,oBAAA,CAACgB,SAASE;AAAM,iBAAA;AACxC,aAAA,CAAA;;AAGA,YAAA,MAAMzD,IAAI0D,WAAW,CAAC3C,SAAUC,CAAAA,IAAI,EAAEwC,YAAc,EAAA,IAAA,CAAA;AACtD;AACF,KAAA,CAAA;AACF;;;;;"}
@@ -1,58 +1,113 @@
1
- import { keyBy } from "lodash/fp";
2
- const load = async (uid, oldEntries) => {
3
- const updates = [];
4
- await strapi.db.transaction(async ({ trx }) => {
5
- const contentTypes = Object.values(strapi.contentTypes);
6
- const components = Object.values(strapi.components);
7
- for (const model of [...contentTypes, ...components]) {
8
- const dbModel = strapi.db.metadata.get(model.uid);
9
- for (const attribute of Object.values(dbModel.attributes)) {
10
- if (attribute.type !== "relation")
11
- continue;
12
- if (attribute.target !== uid)
13
- continue;
14
- if (attribute.inversedBy || attribute.mappedBy)
15
- continue;
16
- const joinTable = attribute.joinTable;
17
- if (!joinTable)
18
- continue;
19
- const { name } = joinTable.inverseJoinColumn;
20
- const oldEntriesIds = oldEntries.map((entry) => entry.id);
21
- const relations = await strapi.db.getConnection().select("*").from(joinTable.name).whereIn(name, oldEntriesIds).transacting(trx);
22
- if (relations.length === 0)
23
- continue;
24
- updates.push({ joinTable, relations });
25
- }
26
- }
27
- });
28
- return updates;
1
+ import { omit, keyBy } from 'lodash/fp';
2
+
3
+ /**
4
+ * Loads lingering relations that need to be updated when overriding a published or draft entry.
5
+ * This is necessary because the relations are uni-directional and the target entry is not aware of the source entry.
6
+ * This is not the case for bi-directional relations, where the target entry is also linked to the source entry.
7
+ */ const load = async (uid, { oldVersions, newVersions })=>{
8
+ const updates = [];
9
+ // Iterate all components and content types to find relations that need to be updated
10
+ await strapi.db.transaction(async ({ trx })=>{
11
+ const contentTypes = Object.values(strapi.contentTypes);
12
+ const components = Object.values(strapi.components);
13
+ for (const model of [
14
+ ...contentTypes,
15
+ ...components
16
+ ]){
17
+ const dbModel = strapi.db.metadata.get(model.uid);
18
+ for (const attribute of Object.values(dbModel.attributes)){
19
+ /**
20
+ * Only consider unidirectional relations
21
+ */ if (attribute.type !== 'relation' || attribute.target !== uid || attribute.inversedBy || attribute.mappedBy) {
22
+ continue;
23
+ }
24
+ // TODO: joinColumn relations
25
+ const joinTable = attribute.joinTable;
26
+ if (!joinTable) {
27
+ continue;
28
+ }
29
+ const { name: sourceColumnName } = joinTable.joinColumn;
30
+ const { name: targetColumnName } = joinTable.inverseJoinColumn;
31
+ /**
32
+ * Load all relations that need to be updated
33
+ */ // NOTE: when the model has draft and publish, we can assume relation are only draft to draft & published to published
34
+ const ids = oldVersions.map((entry)=>entry.id);
35
+ const oldVersionsRelations = await strapi.db.getConnection().select('*').from(joinTable.name).whereIn(targetColumnName, ids).transacting(trx);
36
+ if (oldVersionsRelations.length > 0) {
37
+ updates.push({
38
+ joinTable,
39
+ relations: oldVersionsRelations
40
+ });
41
+ }
42
+ /**
43
+ * if publishing
44
+ * if published version exists
45
+ * updated published versions links
46
+ * else
47
+ * create link to newly published version
48
+ *
49
+ * if discarding
50
+ * if published version link exists & not draft version link
51
+ * create link to new draft version
52
+ */ if (!model.options?.draftAndPublish) {
53
+ const ids = newVersions.map((entry)=>entry.id);
54
+ const newVersionsRelations = await strapi.db.getConnection().select('*').from(joinTable.name).whereIn(targetColumnName, ids).transacting(trx);
55
+ if (newVersionsRelations.length > 0) {
56
+ // when publishing a draft that doesn't have a published version yet,
57
+ // copy the links to the draft over to the published version
58
+ // when discarding a published version, if no drafts exists
59
+ const discardToAdd = newVersionsRelations.filter((relation)=>{
60
+ const matchingOldVerion = oldVersionsRelations.find((oldRelation)=>{
61
+ return oldRelation[sourceColumnName] === relation[sourceColumnName];
62
+ });
63
+ return !matchingOldVerion;
64
+ }).map(omit('id'));
65
+ updates.push({
66
+ joinTable,
67
+ relations: discardToAdd
68
+ });
69
+ }
70
+ }
71
+ }
72
+ }
73
+ });
74
+ return updates;
29
75
  };
30
- const sync = async (oldEntries, newEntries, oldRelations) => {
31
- const newEntryByLocale = keyBy("locale", newEntries);
32
- const oldEntriesMap = oldEntries.reduce(
33
- (acc, entry) => {
34
- const newEntry = newEntryByLocale[entry.locale];
35
- if (!newEntry)
76
+ /**
77
+ * Updates uni directional relations to target the right entries when overriding published or draft entries.
78
+ *
79
+ * @param oldEntries The old entries that are being overridden
80
+ * @param newEntries The new entries that are overriding the old ones
81
+ * @param oldRelations The relations that were previously loaded with `load` @see load
82
+ */ const sync = async (oldEntries, newEntries, oldRelations)=>{
83
+ /**
84
+ * Create a map of old entry ids to new entry ids
85
+ *
86
+ * Will be used to update the relation target ids
87
+ */ const newEntryByLocale = keyBy('locale', newEntries);
88
+ const oldEntriesMap = oldEntries.reduce((acc, entry)=>{
89
+ const newEntry = newEntryByLocale[entry.locale];
90
+ if (!newEntry) return acc;
91
+ acc[entry.id] = newEntry.id;
36
92
  return acc;
37
- acc[entry.id] = newEntry.id;
38
- return acc;
39
- },
40
- {}
41
- );
42
- await strapi.db.transaction(async ({ trx }) => {
43
- const con = strapi.db.getConnection();
44
- for (const { joinTable, relations } of oldRelations) {
45
- const newRelations = relations.map((relation) => {
46
- const column = joinTable.inverseJoinColumn.name;
47
- const newId = oldEntriesMap[relation[column]];
48
- return { ...relation, [column]: newId };
49
- });
50
- await con.batchInsert(joinTable.name, newRelations).transacting(trx);
51
- }
52
- });
53
- };
54
- export {
55
- load,
56
- sync
93
+ }, {});
94
+ await strapi.db.transaction(async ({ trx })=>{
95
+ // Iterate old relations that are deleted and insert the new ones
96
+ for (const { joinTable, relations } of oldRelations){
97
+ // Update old ids with the new ones
98
+ const column = joinTable.inverseJoinColumn.name;
99
+ const newRelations = relations.map((relation)=>{
100
+ const newId = oldEntriesMap[relation[column]];
101
+ return {
102
+ ...relation,
103
+ [column]: newId
104
+ };
105
+ });
106
+ // Insert those relations into the join table
107
+ await trx.batchInsert(joinTable.name, newRelations, 1000);
108
+ }
109
+ });
57
110
  };
111
+
112
+ export { load, sync };
58
113
  //# sourceMappingURL=unidirectional-relations.mjs.map