@strapi/core 0.0.0-next.896eb4438c1f4d64f28d9d2ddcf1eeb53b6d0851 → 0.0.0-next.8b11c0eca020d4c84f17c9f06f36fb9c87fb3266

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.

Potentially problematic release.


This version of @strapi/core might be problematic. Click here for more details.

Files changed (799) hide show
  1. package/dist/Strapi.d.ts +1 -0
  2. package/dist/Strapi.d.ts.map +1 -1
  3. package/dist/Strapi.js +476 -0
  4. package/dist/Strapi.js.map +1 -0
  5. package/dist/Strapi.mjs +455 -0
  6. package/dist/Strapi.mjs.map +1 -0
  7. package/dist/compile.js +27 -0
  8. package/dist/compile.js.map +1 -0
  9. package/dist/compile.mjs +25 -0
  10. package/dist/compile.mjs.map +1 -0
  11. package/dist/configuration/config-loader.js +119 -0
  12. package/dist/configuration/config-loader.js.map +1 -0
  13. package/dist/configuration/config-loader.mjs +117 -0
  14. package/dist/configuration/config-loader.mjs.map +1 -0
  15. package/dist/configuration/get-dirs.js +33 -0
  16. package/dist/configuration/get-dirs.js.map +1 -0
  17. package/dist/configuration/get-dirs.mjs +31 -0
  18. package/dist/configuration/get-dirs.mjs.map +1 -0
  19. package/dist/configuration/index.d.ts +1 -0
  20. package/dist/configuration/index.d.ts.map +1 -1
  21. package/dist/configuration/index.js +92 -0
  22. package/dist/configuration/index.js.map +1 -0
  23. package/dist/configuration/index.mjs +90 -0
  24. package/dist/configuration/index.mjs.map +1 -0
  25. package/dist/configuration/urls.d.ts.map +1 -1
  26. package/dist/configuration/urls.js +81 -0
  27. package/dist/configuration/urls.js.map +1 -0
  28. package/dist/configuration/urls.mjs +77 -0
  29. package/dist/configuration/urls.mjs.map +1 -0
  30. package/dist/constants.d.ts +3 -0
  31. package/dist/constants.d.ts.map +1 -0
  32. package/dist/constants.js +6 -0
  33. package/dist/constants.js.map +1 -0
  34. package/dist/constants.mjs +4 -0
  35. package/dist/constants.mjs.map +1 -0
  36. package/dist/container.js +34 -0
  37. package/dist/container.js.map +1 -0
  38. package/dist/container.mjs +32 -0
  39. package/dist/container.mjs.map +1 -0
  40. package/dist/core-api/controller/collection-type.js +85 -0
  41. package/dist/core-api/controller/collection-type.js.map +1 -0
  42. package/dist/core-api/controller/collection-type.mjs +83 -0
  43. package/dist/core-api/controller/collection-type.mjs.map +1 -0
  44. package/dist/core-api/controller/index.d.ts.map +1 -1
  45. package/dist/core-api/controller/index.js +68 -0
  46. package/dist/core-api/controller/index.js.map +1 -0
  47. package/dist/core-api/controller/index.mjs +66 -0
  48. package/dist/core-api/controller/index.mjs.map +1 -0
  49. package/dist/core-api/controller/single-type.js +47 -0
  50. package/dist/core-api/controller/single-type.js.map +1 -0
  51. package/dist/core-api/controller/single-type.mjs +45 -0
  52. package/dist/core-api/controller/single-type.mjs.map +1 -0
  53. package/dist/core-api/controller/transform.d.ts +3 -2
  54. package/dist/core-api/controller/transform.d.ts.map +1 -1
  55. package/dist/core-api/controller/transform.js +95 -0
  56. package/dist/core-api/controller/transform.js.map +1 -0
  57. package/dist/core-api/controller/transform.mjs +93 -0
  58. package/dist/core-api/controller/transform.mjs.map +1 -0
  59. package/dist/core-api/routes/index.d.ts +4 -22
  60. package/dist/core-api/routes/index.d.ts.map +1 -1
  61. package/dist/core-api/routes/index.js +211 -0
  62. package/dist/core-api/routes/index.js.map +1 -0
  63. package/dist/core-api/routes/index.mjs +190 -0
  64. package/dist/core-api/routes/index.mjs.map +1 -0
  65. package/dist/core-api/routes/validation/attributes.d.ts +244 -0
  66. package/dist/core-api/routes/validation/attributes.d.ts.map +1 -0
  67. package/dist/core-api/routes/validation/attributes.js +560 -0
  68. package/dist/core-api/routes/validation/attributes.js.map +1 -0
  69. package/dist/core-api/routes/validation/attributes.mjs +521 -0
  70. package/dist/core-api/routes/validation/attributes.mjs.map +1 -0
  71. package/dist/core-api/routes/validation/common.d.ts +105 -0
  72. package/dist/core-api/routes/validation/common.d.ts.map +1 -0
  73. package/dist/core-api/routes/validation/common.js +116 -0
  74. package/dist/core-api/routes/validation/common.js.map +1 -0
  75. package/dist/core-api/routes/validation/common.mjs +95 -0
  76. package/dist/core-api/routes/validation/common.mjs.map +1 -0
  77. package/dist/core-api/routes/validation/component.d.ts +34 -0
  78. package/dist/core-api/routes/validation/component.d.ts.map +1 -0
  79. package/dist/core-api/routes/validation/component.js +45 -0
  80. package/dist/core-api/routes/validation/component.js.map +1 -0
  81. package/dist/core-api/routes/validation/component.mjs +43 -0
  82. package/dist/core-api/routes/validation/component.mjs.map +1 -0
  83. package/dist/core-api/routes/validation/constants.d.ts +8 -0
  84. package/dist/core-api/routes/validation/constants.d.ts.map +1 -0
  85. package/dist/core-api/routes/validation/constants.js +18 -0
  86. package/dist/core-api/routes/validation/constants.js.map +1 -0
  87. package/dist/core-api/routes/validation/constants.mjs +16 -0
  88. package/dist/core-api/routes/validation/constants.mjs.map +1 -0
  89. package/dist/core-api/routes/validation/content-type.d.ts +128 -0
  90. package/dist/core-api/routes/validation/content-type.d.ts.map +1 -0
  91. package/dist/core-api/routes/validation/content-type.js +201 -0
  92. package/dist/core-api/routes/validation/content-type.js.map +1 -0
  93. package/dist/core-api/routes/validation/content-type.mjs +180 -0
  94. package/dist/core-api/routes/validation/content-type.mjs.map +1 -0
  95. package/dist/core-api/routes/validation/index.d.ts +5 -0
  96. package/dist/core-api/routes/validation/index.d.ts.map +1 -0
  97. package/dist/core-api/routes/validation/mappers.d.ts +105 -0
  98. package/dist/core-api/routes/validation/mappers.d.ts.map +1 -0
  99. package/dist/core-api/routes/validation/mappers.js +273 -0
  100. package/dist/core-api/routes/validation/mappers.js.map +1 -0
  101. package/dist/core-api/routes/validation/mappers.mjs +249 -0
  102. package/dist/core-api/routes/validation/mappers.mjs.map +1 -0
  103. package/dist/core-api/routes/validation/utils.d.ts +47 -0
  104. package/dist/core-api/routes/validation/utils.d.ts.map +1 -0
  105. package/dist/core-api/routes/validation/utils.js +128 -0
  106. package/dist/core-api/routes/validation/utils.js.map +1 -0
  107. package/dist/core-api/routes/validation/utils.mjs +106 -0
  108. package/dist/core-api/routes/validation/utils.mjs.map +1 -0
  109. package/dist/core-api/service/collection-type.js +80 -0
  110. package/dist/core-api/service/collection-type.js.map +1 -0
  111. package/dist/core-api/service/collection-type.mjs +77 -0
  112. package/dist/core-api/service/collection-type.mjs.map +1 -0
  113. package/dist/core-api/service/core-service.js +13 -0
  114. package/dist/core-api/service/core-service.js.map +1 -0
  115. package/dist/core-api/service/core-service.mjs +11 -0
  116. package/dist/core-api/service/core-service.mjs.map +1 -0
  117. package/dist/core-api/service/index.js +16 -0
  118. package/dist/core-api/service/index.js.map +1 -0
  119. package/dist/core-api/service/index.mjs +14 -0
  120. package/dist/core-api/service/index.mjs.map +1 -0
  121. package/dist/core-api/service/pagination.js +78 -0
  122. package/dist/core-api/service/pagination.js.map +1 -0
  123. package/dist/core-api/service/pagination.mjs +73 -0
  124. package/dist/core-api/service/pagination.mjs.map +1 -0
  125. package/dist/core-api/service/single-type.js +50 -0
  126. package/dist/core-api/service/single-type.js.map +1 -0
  127. package/dist/core-api/service/single-type.mjs +47 -0
  128. package/dist/core-api/service/single-type.mjs.map +1 -0
  129. package/dist/domain/content-type/index.d.ts.map +1 -1
  130. package/dist/domain/content-type/index.js +122 -0
  131. package/dist/domain/content-type/index.js.map +1 -0
  132. package/dist/domain/content-type/index.mjs +119 -0
  133. package/dist/domain/content-type/index.mjs.map +1 -0
  134. package/dist/domain/content-type/validator.js +92 -0
  135. package/dist/domain/content-type/validator.js.map +1 -0
  136. package/dist/domain/content-type/validator.mjs +90 -0
  137. package/dist/domain/content-type/validator.mjs.map +1 -0
  138. package/dist/domain/module/index.d.ts.map +1 -1
  139. package/dist/domain/module/index.js +119 -0
  140. package/dist/domain/module/index.js.map +1 -0
  141. package/dist/domain/module/index.mjs +117 -0
  142. package/dist/domain/module/index.mjs.map +1 -0
  143. package/dist/domain/module/validation.js +30 -0
  144. package/dist/domain/module/validation.js.map +1 -0
  145. package/dist/domain/module/validation.mjs +28 -0
  146. package/dist/domain/module/validation.mjs.map +1 -0
  147. package/dist/ee/index.d.ts +7 -0
  148. package/dist/ee/index.d.ts.map +1 -1
  149. package/dist/ee/index.js +218 -0
  150. package/dist/ee/index.js.map +1 -0
  151. package/dist/ee/index.mjs +216 -0
  152. package/dist/ee/index.mjs.map +1 -0
  153. package/dist/ee/license.d.ts +3 -1
  154. package/dist/ee/license.d.ts.map +1 -1
  155. package/dist/ee/license.js +121 -0
  156. package/dist/ee/license.js.map +1 -0
  157. package/dist/ee/license.mjs +115 -0
  158. package/dist/ee/license.mjs.map +1 -0
  159. package/dist/factories.d.ts +3 -1
  160. package/dist/factories.d.ts.map +1 -1
  161. package/dist/factories.js +93 -0
  162. package/dist/factories.js.map +1 -0
  163. package/dist/factories.mjs +87 -0
  164. package/dist/factories.mjs.map +1 -0
  165. package/dist/index.js +19 -10099
  166. package/dist/index.js.map +1 -1
  167. package/dist/index.mjs +17 -10076
  168. package/dist/index.mjs.map +1 -1
  169. package/dist/loaders/admin.d.ts.map +1 -1
  170. package/dist/loaders/admin.js +27 -0
  171. package/dist/loaders/admin.js.map +1 -0
  172. package/dist/loaders/admin.mjs +25 -0
  173. package/dist/loaders/admin.mjs.map +1 -0
  174. package/dist/loaders/apis.js +160 -0
  175. package/dist/loaders/apis.js.map +1 -0
  176. package/dist/loaders/apis.mjs +158 -0
  177. package/dist/loaders/apis.mjs.map +1 -0
  178. package/dist/loaders/components.js +37 -0
  179. package/dist/loaders/components.js.map +1 -0
  180. package/dist/loaders/components.mjs +35 -0
  181. package/dist/loaders/components.mjs.map +1 -0
  182. package/dist/loaders/index.js +26 -0
  183. package/dist/loaders/index.js.map +1 -0
  184. package/dist/loaders/index.mjs +24 -0
  185. package/dist/loaders/index.mjs.map +1 -0
  186. package/dist/loaders/middlewares.js +35 -0
  187. package/dist/loaders/middlewares.js.map +1 -0
  188. package/dist/loaders/middlewares.mjs +33 -0
  189. package/dist/loaders/middlewares.mjs.map +1 -0
  190. package/dist/loaders/plugins/get-enabled-plugins.js +136 -0
  191. package/dist/loaders/plugins/get-enabled-plugins.js.map +1 -0
  192. package/dist/loaders/plugins/get-enabled-plugins.mjs +134 -0
  193. package/dist/loaders/plugins/get-enabled-plugins.mjs.map +1 -0
  194. package/dist/loaders/plugins/get-user-plugins-config.js +28 -0
  195. package/dist/loaders/plugins/get-user-plugins-config.js.map +1 -0
  196. package/dist/loaders/plugins/get-user-plugins-config.mjs +26 -0
  197. package/dist/loaders/plugins/get-user-plugins-config.mjs.map +1 -0
  198. package/dist/loaders/plugins/index.js +155 -0
  199. package/dist/loaders/plugins/index.js.map +1 -0
  200. package/dist/loaders/plugins/index.mjs +134 -0
  201. package/dist/loaders/plugins/index.mjs.map +1 -0
  202. package/dist/loaders/policies.js +29 -0
  203. package/dist/loaders/policies.js.map +1 -0
  204. package/dist/loaders/policies.mjs +27 -0
  205. package/dist/loaders/policies.mjs.map +1 -0
  206. package/dist/loaders/sanitizers.js +12 -0
  207. package/dist/loaders/sanitizers.js.map +1 -0
  208. package/dist/loaders/sanitizers.mjs +10 -0
  209. package/dist/loaders/sanitizers.mjs.map +1 -0
  210. package/dist/loaders/src-index.js +41 -0
  211. package/dist/loaders/src-index.js.map +1 -0
  212. package/dist/loaders/src-index.mjs +39 -0
  213. package/dist/loaders/src-index.mjs.map +1 -0
  214. package/dist/loaders/validators.js +11 -0
  215. package/dist/loaders/validators.js.map +1 -0
  216. package/dist/loaders/validators.mjs +9 -0
  217. package/dist/loaders/validators.mjs.map +1 -0
  218. package/dist/middlewares/body.js +69 -0
  219. package/dist/middlewares/body.js.map +1 -0
  220. package/dist/middlewares/body.mjs +67 -0
  221. package/dist/middlewares/body.mjs.map +1 -0
  222. package/dist/middlewares/compression.js +8 -0
  223. package/dist/middlewares/compression.js.map +1 -0
  224. package/dist/middlewares/compression.mjs +6 -0
  225. package/dist/middlewares/compression.mjs.map +1 -0
  226. package/dist/middlewares/cors.d.ts +9 -1
  227. package/dist/middlewares/cors.d.ts.map +1 -1
  228. package/dist/middlewares/cors.js +86 -0
  229. package/dist/middlewares/cors.js.map +1 -0
  230. package/dist/middlewares/cors.mjs +83 -0
  231. package/dist/middlewares/cors.mjs.map +1 -0
  232. package/dist/middlewares/errors.js +35 -0
  233. package/dist/middlewares/errors.js.map +1 -0
  234. package/dist/middlewares/errors.mjs +33 -0
  235. package/dist/middlewares/errors.mjs.map +1 -0
  236. package/dist/middlewares/favicon.js +32 -0
  237. package/dist/middlewares/favicon.js.map +1 -0
  238. package/dist/middlewares/favicon.mjs +30 -0
  239. package/dist/middlewares/favicon.mjs.map +1 -0
  240. package/dist/middlewares/index.js +36 -0
  241. package/dist/middlewares/index.js.map +1 -0
  242. package/dist/middlewares/index.mjs +34 -0
  243. package/dist/middlewares/index.mjs.map +1 -0
  244. package/dist/middlewares/ip.js +8 -0
  245. package/dist/middlewares/ip.js.map +1 -0
  246. package/dist/middlewares/ip.mjs +6 -0
  247. package/dist/middlewares/ip.mjs.map +1 -0
  248. package/dist/middlewares/logger.js +13 -0
  249. package/dist/middlewares/logger.js.map +1 -0
  250. package/dist/middlewares/logger.mjs +11 -0
  251. package/dist/middlewares/logger.mjs.map +1 -0
  252. package/dist/middlewares/powered-by.js +18 -0
  253. package/dist/middlewares/powered-by.js.map +1 -0
  254. package/dist/middlewares/powered-by.mjs +16 -0
  255. package/dist/middlewares/powered-by.mjs.map +1 -0
  256. package/dist/middlewares/public.js +38 -0
  257. package/dist/middlewares/public.js.map +1 -0
  258. package/dist/middlewares/public.mjs +36 -0
  259. package/dist/middlewares/public.mjs.map +1 -0
  260. package/dist/middlewares/query.js +43 -0
  261. package/dist/middlewares/query.js.map +1 -0
  262. package/dist/middlewares/query.mjs +41 -0
  263. package/dist/middlewares/query.mjs.map +1 -0
  264. package/dist/middlewares/response-time.js +13 -0
  265. package/dist/middlewares/response-time.js.map +1 -0
  266. package/dist/middlewares/response-time.mjs +11 -0
  267. package/dist/middlewares/response-time.mjs.map +1 -0
  268. package/dist/middlewares/responses.js +17 -0
  269. package/dist/middlewares/responses.js.map +1 -0
  270. package/dist/middlewares/responses.mjs +15 -0
  271. package/dist/middlewares/responses.mjs.map +1 -0
  272. package/dist/middlewares/security.js +116 -0
  273. package/dist/middlewares/security.js.map +1 -0
  274. package/dist/middlewares/security.mjs +114 -0
  275. package/dist/middlewares/security.mjs.map +1 -0
  276. package/dist/middlewares/session.js +31 -0
  277. package/dist/middlewares/session.js.map +1 -0
  278. package/dist/middlewares/session.mjs +29 -0
  279. package/dist/middlewares/session.mjs.map +1 -0
  280. package/dist/migrations/database/5.0.0-discard-drafts.js +168 -0
  281. package/dist/migrations/database/5.0.0-discard-drafts.js.map +1 -0
  282. package/dist/migrations/database/5.0.0-discard-drafts.mjs +165 -0
  283. package/dist/migrations/database/5.0.0-discard-drafts.mjs.map +1 -0
  284. package/dist/migrations/draft-publish.js +69 -0
  285. package/dist/migrations/draft-publish.js.map +1 -0
  286. package/dist/migrations/draft-publish.mjs +66 -0
  287. package/dist/migrations/draft-publish.mjs.map +1 -0
  288. package/dist/migrations/first-published-at.d.ts +4 -0
  289. package/dist/migrations/first-published-at.d.ts.map +1 -0
  290. package/dist/migrations/first-published-at.js +51 -0
  291. package/dist/migrations/first-published-at.js.map +1 -0
  292. package/dist/migrations/first-published-at.mjs +49 -0
  293. package/dist/migrations/first-published-at.mjs.map +1 -0
  294. package/dist/migrations/i18n.js +71 -0
  295. package/dist/migrations/i18n.js.map +1 -0
  296. package/dist/migrations/i18n.mjs +68 -0
  297. package/dist/migrations/i18n.mjs.map +1 -0
  298. package/dist/migrations/index.d.ts.map +1 -1
  299. package/dist/migrations/index.js +34 -0
  300. package/dist/migrations/index.js.map +1 -0
  301. package/dist/migrations/index.mjs +31 -0
  302. package/dist/migrations/index.mjs.map +1 -0
  303. package/dist/package.json.js +187 -0
  304. package/dist/package.json.js.map +1 -0
  305. package/dist/package.json.mjs +164 -0
  306. package/dist/package.json.mjs.map +1 -0
  307. package/dist/providers/admin.js +30 -0
  308. package/dist/providers/admin.js.map +1 -0
  309. package/dist/providers/admin.mjs +28 -0
  310. package/dist/providers/admin.mjs.map +1 -0
  311. package/dist/providers/coreStore.js +16 -0
  312. package/dist/providers/coreStore.js.map +1 -0
  313. package/dist/providers/coreStore.mjs +14 -0
  314. package/dist/providers/coreStore.mjs.map +1 -0
  315. package/dist/providers/cron.js +23 -0
  316. package/dist/providers/cron.js.map +1 -0
  317. package/dist/providers/cron.mjs +21 -0
  318. package/dist/providers/cron.mjs.map +1 -0
  319. package/dist/providers/index.d.ts.map +1 -1
  320. package/dist/providers/index.js +22 -0
  321. package/dist/providers/index.js.map +1 -0
  322. package/dist/providers/index.mjs +20 -0
  323. package/dist/providers/index.mjs.map +1 -0
  324. package/dist/providers/provider.js +6 -0
  325. package/dist/providers/provider.js.map +1 -0
  326. package/dist/providers/provider.mjs +4 -0
  327. package/dist/providers/provider.mjs.map +1 -0
  328. package/dist/providers/registries.js +40 -0
  329. package/dist/providers/registries.js.map +1 -0
  330. package/dist/providers/registries.mjs +38 -0
  331. package/dist/providers/registries.mjs.map +1 -0
  332. package/dist/providers/session-manager.d.ts +3 -0
  333. package/dist/providers/session-manager.d.ts.map +1 -0
  334. package/dist/providers/session-manager.js +23 -0
  335. package/dist/providers/session-manager.js.map +1 -0
  336. package/dist/providers/session-manager.mjs +21 -0
  337. package/dist/providers/session-manager.mjs.map +1 -0
  338. package/dist/providers/telemetry.js +22 -0
  339. package/dist/providers/telemetry.js.map +1 -0
  340. package/dist/providers/telemetry.mjs +20 -0
  341. package/dist/providers/telemetry.mjs.map +1 -0
  342. package/dist/providers/webhooks.js +32 -0
  343. package/dist/providers/webhooks.js.map +1 -0
  344. package/dist/providers/webhooks.mjs +30 -0
  345. package/dist/providers/webhooks.mjs.map +1 -0
  346. package/dist/registries/apis.js +26 -0
  347. package/dist/registries/apis.js.map +1 -0
  348. package/dist/registries/apis.mjs +24 -0
  349. package/dist/registries/apis.mjs.map +1 -0
  350. package/dist/registries/components.js +43 -0
  351. package/dist/registries/components.js.map +1 -0
  352. package/dist/registries/components.mjs +41 -0
  353. package/dist/registries/components.mjs.map +1 -0
  354. package/dist/registries/content-types.js +65 -0
  355. package/dist/registries/content-types.js.map +1 -0
  356. package/dist/registries/content-types.mjs +63 -0
  357. package/dist/registries/content-types.mjs.map +1 -0
  358. package/dist/registries/controllers.js +79 -0
  359. package/dist/registries/controllers.js.map +1 -0
  360. package/dist/registries/controllers.mjs +77 -0
  361. package/dist/registries/controllers.mjs.map +1 -0
  362. package/dist/registries/custom-fields.js +81 -0
  363. package/dist/registries/custom-fields.js.map +1 -0
  364. package/dist/registries/custom-fields.mjs +79 -0
  365. package/dist/registries/custom-fields.mjs.map +1 -0
  366. package/dist/registries/hooks.js +55 -0
  367. package/dist/registries/hooks.js.map +1 -0
  368. package/dist/registries/hooks.mjs +53 -0
  369. package/dist/registries/hooks.mjs.map +1 -0
  370. package/dist/registries/middlewares.js +58 -0
  371. package/dist/registries/middlewares.js.map +1 -0
  372. package/dist/registries/middlewares.mjs +56 -0
  373. package/dist/registries/middlewares.mjs.map +1 -0
  374. package/dist/registries/models.js +17 -0
  375. package/dist/registries/models.js.map +1 -0
  376. package/dist/registries/models.mjs +15 -0
  377. package/dist/registries/models.mjs.map +1 -0
  378. package/dist/registries/modules.js +42 -0
  379. package/dist/registries/modules.js.map +1 -0
  380. package/dist/registries/modules.mjs +40 -0
  381. package/dist/registries/modules.mjs.map +1 -0
  382. package/dist/registries/namespace.js +28 -0
  383. package/dist/registries/namespace.js.map +1 -0
  384. package/dist/registries/namespace.mjs +24 -0
  385. package/dist/registries/namespace.mjs.map +1 -0
  386. package/dist/registries/plugins.js +26 -0
  387. package/dist/registries/plugins.js.map +1 -0
  388. package/dist/registries/plugins.mjs +24 -0
  389. package/dist/registries/plugins.mjs.map +1 -0
  390. package/dist/registries/policies.js +115 -0
  391. package/dist/registries/policies.js.map +1 -0
  392. package/dist/registries/policies.mjs +113 -0
  393. package/dist/registries/policies.mjs.map +1 -0
  394. package/dist/registries/sanitizers.js +26 -0
  395. package/dist/registries/sanitizers.js.map +1 -0
  396. package/dist/registries/sanitizers.mjs +24 -0
  397. package/dist/registries/sanitizers.mjs.map +1 -0
  398. package/dist/registries/services.js +80 -0
  399. package/dist/registries/services.js.map +1 -0
  400. package/dist/registries/services.mjs +78 -0
  401. package/dist/registries/services.mjs.map +1 -0
  402. package/dist/registries/validators.js +26 -0
  403. package/dist/registries/validators.js.map +1 -0
  404. package/dist/registries/validators.mjs +24 -0
  405. package/dist/registries/validators.mjs.map +1 -0
  406. package/dist/services/auth/index.js +81 -0
  407. package/dist/services/auth/index.js.map +1 -0
  408. package/dist/services/auth/index.mjs +79 -0
  409. package/dist/services/auth/index.mjs.map +1 -0
  410. package/dist/services/config.js +51 -0
  411. package/dist/services/config.js.map +1 -0
  412. package/dist/services/config.mjs +49 -0
  413. package/dist/services/config.mjs.map +1 -0
  414. package/dist/services/content-api/index.d.ts +1 -1
  415. package/dist/services/content-api/index.d.ts.map +1 -1
  416. package/dist/services/content-api/index.js +86 -0
  417. package/dist/services/content-api/index.js.map +1 -0
  418. package/dist/services/content-api/index.mjs +84 -0
  419. package/dist/services/content-api/index.mjs.map +1 -0
  420. package/dist/services/content-api/permissions/engine.js +10 -0
  421. package/dist/services/content-api/permissions/engine.js.map +1 -0
  422. package/dist/services/content-api/permissions/engine.mjs +8 -0
  423. package/dist/services/content-api/permissions/engine.mjs.map +1 -0
  424. package/dist/services/content-api/permissions/index.js +107 -0
  425. package/dist/services/content-api/permissions/index.js.map +1 -0
  426. package/dist/services/content-api/permissions/index.mjs +105 -0
  427. package/dist/services/content-api/permissions/index.mjs.map +1 -0
  428. package/dist/services/content-api/permissions/providers/action.js +19 -0
  429. package/dist/services/content-api/permissions/providers/action.js.map +1 -0
  430. package/dist/services/content-api/permissions/providers/action.mjs +17 -0
  431. package/dist/services/content-api/permissions/providers/action.mjs.map +1 -0
  432. package/dist/services/content-api/permissions/providers/condition.js +19 -0
  433. package/dist/services/content-api/permissions/providers/condition.js.map +1 -0
  434. package/dist/services/content-api/permissions/providers/condition.mjs +17 -0
  435. package/dist/services/content-api/permissions/providers/condition.mjs.map +1 -0
  436. package/dist/services/content-source-maps.d.ts +13 -0
  437. package/dist/services/content-source-maps.d.ts.map +1 -0
  438. package/dist/services/content-source-maps.js +108 -0
  439. package/dist/services/content-source-maps.js.map +1 -0
  440. package/dist/services/content-source-maps.mjs +106 -0
  441. package/dist/services/content-source-maps.mjs.map +1 -0
  442. package/dist/services/core-store.d.ts +2 -2
  443. package/dist/services/core-store.d.ts.map +1 -1
  444. package/dist/services/core-store.js +127 -0
  445. package/dist/services/core-store.js.map +1 -0
  446. package/dist/services/core-store.mjs +124 -0
  447. package/dist/services/core-store.mjs.map +1 -0
  448. package/dist/services/cron.js +77 -0
  449. package/dist/services/cron.js.map +1 -0
  450. package/dist/services/cron.mjs +75 -0
  451. package/dist/services/cron.mjs.map +1 -0
  452. package/dist/services/custom-fields.js +12 -0
  453. package/dist/services/custom-fields.js.map +1 -0
  454. package/dist/services/custom-fields.mjs +10 -0
  455. package/dist/services/custom-fields.mjs.map +1 -0
  456. package/dist/services/document-service/attributes/index.js +27 -0
  457. package/dist/services/document-service/attributes/index.js.map +1 -0
  458. package/dist/services/document-service/attributes/index.mjs +25 -0
  459. package/dist/services/document-service/attributes/index.mjs.map +1 -0
  460. package/dist/services/document-service/attributes/transforms.js +21 -0
  461. package/dist/services/document-service/attributes/transforms.js.map +1 -0
  462. package/dist/services/document-service/attributes/transforms.mjs +19 -0
  463. package/dist/services/document-service/attributes/transforms.mjs.map +1 -0
  464. package/dist/services/document-service/common.js +8 -0
  465. package/dist/services/document-service/common.js.map +1 -0
  466. package/dist/services/document-service/common.mjs +6 -0
  467. package/dist/services/document-service/common.mjs.map +1 -0
  468. package/dist/services/document-service/components.d.ts +31 -1
  469. package/dist/services/document-service/components.d.ts.map +1 -1
  470. package/dist/services/document-service/components.js +395 -0
  471. package/dist/services/document-service/components.js.map +1 -0
  472. package/dist/services/document-service/components.mjs +384 -0
  473. package/dist/services/document-service/components.mjs.map +1 -0
  474. package/dist/services/document-service/draft-and-publish.js +109 -0
  475. package/dist/services/document-service/draft-and-publish.js.map +1 -0
  476. package/dist/services/document-service/draft-and-publish.mjs +102 -0
  477. package/dist/services/document-service/draft-and-publish.mjs.map +1 -0
  478. package/dist/services/document-service/entries.d.ts.map +1 -1
  479. package/dist/services/document-service/entries.js +155 -0
  480. package/dist/services/document-service/entries.js.map +1 -0
  481. package/dist/services/document-service/entries.mjs +153 -0
  482. package/dist/services/document-service/entries.mjs.map +1 -0
  483. package/dist/services/document-service/events.js +59 -0
  484. package/dist/services/document-service/events.js.map +1 -0
  485. package/dist/services/document-service/events.mjs +57 -0
  486. package/dist/services/document-service/events.mjs.map +1 -0
  487. package/dist/services/document-service/first-published-at.d.ts +7 -0
  488. package/dist/services/document-service/first-published-at.d.ts.map +1 -0
  489. package/dist/services/document-service/first-published-at.js +31 -0
  490. package/dist/services/document-service/first-published-at.js.map +1 -0
  491. package/dist/services/document-service/first-published-at.mjs +28 -0
  492. package/dist/services/document-service/first-published-at.mjs.map +1 -0
  493. package/dist/services/document-service/index.js +56 -0
  494. package/dist/services/document-service/index.js.map +1 -0
  495. package/dist/services/document-service/index.mjs +54 -0
  496. package/dist/services/document-service/index.mjs.map +1 -0
  497. package/dist/services/document-service/internationalization.d.ts +6 -1
  498. package/dist/services/document-service/internationalization.d.ts.map +1 -1
  499. package/dist/services/document-service/internationalization.js +111 -0
  500. package/dist/services/document-service/internationalization.js.map +1 -0
  501. package/dist/services/document-service/internationalization.mjs +105 -0
  502. package/dist/services/document-service/internationalization.mjs.map +1 -0
  503. package/dist/services/document-service/middlewares/errors.js +29 -0
  504. package/dist/services/document-service/middlewares/errors.js.map +1 -0
  505. package/dist/services/document-service/middlewares/errors.mjs +27 -0
  506. package/dist/services/document-service/middlewares/errors.mjs.map +1 -0
  507. package/dist/services/document-service/middlewares/middleware-manager.js +51 -0
  508. package/dist/services/document-service/middlewares/middleware-manager.js.map +1 -0
  509. package/dist/services/document-service/middlewares/middleware-manager.mjs +49 -0
  510. package/dist/services/document-service/middlewares/middleware-manager.mjs.map +1 -0
  511. package/dist/services/document-service/params.js +14 -0
  512. package/dist/services/document-service/params.js.map +1 -0
  513. package/dist/services/document-service/params.mjs +12 -0
  514. package/dist/services/document-service/params.mjs.map +1 -0
  515. package/dist/services/document-service/repository.d.ts.map +1 -1
  516. package/dist/services/document-service/repository.js +372 -0
  517. package/dist/services/document-service/repository.js.map +1 -0
  518. package/dist/services/document-service/repository.mjs +370 -0
  519. package/dist/services/document-service/repository.mjs.map +1 -0
  520. package/dist/services/document-service/transform/data.js +25 -0
  521. package/dist/services/document-service/transform/data.js.map +1 -0
  522. package/dist/services/document-service/transform/data.mjs +23 -0
  523. package/dist/services/document-service/transform/data.mjs.map +1 -0
  524. package/dist/services/document-service/transform/fields.js +33 -0
  525. package/dist/services/document-service/transform/fields.js.map +1 -0
  526. package/dist/services/document-service/transform/fields.mjs +31 -0
  527. package/dist/services/document-service/transform/fields.mjs.map +1 -0
  528. package/dist/services/document-service/transform/id-map.js +125 -0
  529. package/dist/services/document-service/transform/id-map.js.map +1 -0
  530. package/dist/services/document-service/transform/id-map.mjs +123 -0
  531. package/dist/services/document-service/transform/id-map.mjs.map +1 -0
  532. package/dist/services/document-service/transform/id-transform.js +41 -0
  533. package/dist/services/document-service/transform/id-transform.js.map +1 -0
  534. package/dist/services/document-service/transform/id-transform.mjs +39 -0
  535. package/dist/services/document-service/transform/id-transform.mjs.map +1 -0
  536. package/dist/services/document-service/transform/populate.js +26 -0
  537. package/dist/services/document-service/transform/populate.js.map +1 -0
  538. package/dist/services/document-service/transform/populate.mjs +24 -0
  539. package/dist/services/document-service/transform/populate.mjs.map +1 -0
  540. package/dist/services/document-service/transform/query.js +14 -0
  541. package/dist/services/document-service/transform/query.js.map +1 -0
  542. package/dist/services/document-service/transform/query.mjs +12 -0
  543. package/dist/services/document-service/transform/query.mjs.map +1 -0
  544. package/dist/services/document-service/transform/relations/extract/data-ids.js +80 -0
  545. package/dist/services/document-service/transform/relations/extract/data-ids.js.map +1 -0
  546. package/dist/services/document-service/transform/relations/extract/data-ids.mjs +78 -0
  547. package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +1 -0
  548. package/dist/services/document-service/transform/relations/transform/data-ids.js +110 -0
  549. package/dist/services/document-service/transform/relations/transform/data-ids.js.map +1 -0
  550. package/dist/services/document-service/transform/relations/transform/data-ids.mjs +108 -0
  551. package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +1 -0
  552. package/dist/services/document-service/transform/relations/transform/default-locale.js +50 -0
  553. package/dist/services/document-service/transform/relations/transform/default-locale.js.map +1 -0
  554. package/dist/services/document-service/transform/relations/transform/default-locale.mjs +48 -0
  555. package/dist/services/document-service/transform/relations/transform/default-locale.mjs.map +1 -0
  556. package/dist/services/document-service/transform/relations/utils/dp.js +56 -0
  557. package/dist/services/document-service/transform/relations/utils/dp.js.map +1 -0
  558. package/dist/services/document-service/transform/relations/utils/dp.mjs +54 -0
  559. package/dist/services/document-service/transform/relations/utils/dp.mjs.map +1 -0
  560. package/dist/services/document-service/transform/relations/utils/i18n.js +27 -0
  561. package/dist/services/document-service/transform/relations/utils/i18n.js.map +1 -0
  562. package/dist/services/document-service/transform/relations/utils/i18n.mjs +23 -0
  563. package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +1 -0
  564. package/dist/services/document-service/transform/relations/utils/map-relation.js +130 -0
  565. package/dist/services/document-service/transform/relations/utils/map-relation.js.map +1 -0
  566. package/dist/services/document-service/transform/relations/utils/map-relation.mjs +127 -0
  567. package/dist/services/document-service/transform/relations/utils/map-relation.mjs.map +1 -0
  568. package/dist/services/document-service/utils/bidirectional-relations.js +148 -0
  569. package/dist/services/document-service/utils/bidirectional-relations.js.map +1 -0
  570. package/dist/services/document-service/utils/bidirectional-relations.mjs +145 -0
  571. package/dist/services/document-service/utils/bidirectional-relations.mjs.map +1 -0
  572. package/dist/services/document-service/utils/clean-component-join-table.d.ts +7 -0
  573. package/dist/services/document-service/utils/clean-component-join-table.d.ts.map +1 -0
  574. package/dist/services/document-service/utils/populate.js +71 -0
  575. package/dist/services/document-service/utils/populate.js.map +1 -0
  576. package/dist/services/document-service/utils/populate.mjs +69 -0
  577. package/dist/services/document-service/utils/populate.mjs.map +1 -0
  578. package/dist/services/document-service/utils/unidirectional-relations.d.ts +19 -2
  579. package/dist/services/document-service/utils/unidirectional-relations.d.ts.map +1 -1
  580. package/dist/services/document-service/utils/unidirectional-relations.js +131 -0
  581. package/dist/services/document-service/utils/unidirectional-relations.js.map +1 -0
  582. package/dist/services/document-service/utils/unidirectional-relations.mjs +128 -0
  583. package/dist/services/document-service/utils/unidirectional-relations.mjs.map +1 -0
  584. package/dist/services/entity-service/index.js +238 -0
  585. package/dist/services/entity-service/index.js.map +1 -0
  586. package/dist/services/entity-service/index.mjs +236 -0
  587. package/dist/services/entity-service/index.mjs.map +1 -0
  588. package/dist/services/entity-validator/blocks-validator.js +160 -0
  589. package/dist/services/entity-validator/blocks-validator.js.map +1 -0
  590. package/dist/services/entity-validator/blocks-validator.mjs +158 -0
  591. package/dist/services/entity-validator/blocks-validator.mjs.map +1 -0
  592. package/dist/services/entity-validator/index.d.ts.map +1 -1
  593. package/dist/services/entity-validator/index.js +393 -0
  594. package/dist/services/entity-validator/index.js.map +1 -0
  595. package/dist/services/entity-validator/index.mjs +391 -0
  596. package/dist/services/entity-validator/index.mjs.map +1 -0
  597. package/dist/services/entity-validator/validators.d.ts +1 -0
  598. package/dist/services/entity-validator/validators.d.ts.map +1 -1
  599. package/dist/services/entity-validator/validators.js +302 -0
  600. package/dist/services/entity-validator/validators.js.map +1 -0
  601. package/dist/services/entity-validator/validators.mjs +293 -0
  602. package/dist/services/entity-validator/validators.mjs.map +1 -0
  603. package/dist/services/errors.js +76 -0
  604. package/dist/services/errors.js.map +1 -0
  605. package/dist/services/errors.mjs +72 -0
  606. package/dist/services/errors.mjs.map +1 -0
  607. package/dist/services/event-hub.js +85 -0
  608. package/dist/services/event-hub.js.map +1 -0
  609. package/dist/services/event-hub.mjs +83 -0
  610. package/dist/services/event-hub.mjs.map +1 -0
  611. package/dist/services/features.js +22 -0
  612. package/dist/services/features.js.map +1 -0
  613. package/dist/services/features.mjs +20 -0
  614. package/dist/services/features.mjs.map +1 -0
  615. package/dist/services/fs.js +52 -0
  616. package/dist/services/fs.js.map +1 -0
  617. package/dist/services/fs.mjs +50 -0
  618. package/dist/services/fs.mjs.map +1 -0
  619. package/dist/services/metrics/admin-user-hash.d.ts.map +1 -1
  620. package/dist/services/metrics/admin-user-hash.js +16 -0
  621. package/dist/services/metrics/admin-user-hash.js.map +1 -0
  622. package/dist/services/metrics/admin-user-hash.mjs +14 -0
  623. package/dist/services/metrics/admin-user-hash.mjs.map +1 -0
  624. package/dist/services/metrics/index.d.ts +1 -1
  625. package/dist/services/metrics/index.d.ts.map +1 -1
  626. package/dist/services/metrics/index.js +53 -0
  627. package/dist/services/metrics/index.js.map +1 -0
  628. package/dist/services/metrics/index.mjs +51 -0
  629. package/dist/services/metrics/index.mjs.map +1 -0
  630. package/dist/services/metrics/is-truthy.js +16 -0
  631. package/dist/services/metrics/is-truthy.js.map +1 -0
  632. package/dist/services/metrics/is-truthy.mjs +14 -0
  633. package/dist/services/metrics/is-truthy.mjs.map +1 -0
  634. package/dist/services/metrics/middleware.d.ts +2 -1
  635. package/dist/services/metrics/middleware.d.ts.map +1 -1
  636. package/dist/services/metrics/middleware.js +40 -0
  637. package/dist/services/metrics/middleware.js.map +1 -0
  638. package/dist/services/metrics/middleware.mjs +38 -0
  639. package/dist/services/metrics/middleware.mjs.map +1 -0
  640. package/dist/services/metrics/rate-limiter.js +26 -0
  641. package/dist/services/metrics/rate-limiter.js.map +1 -0
  642. package/dist/services/metrics/rate-limiter.mjs +24 -0
  643. package/dist/services/metrics/rate-limiter.mjs.map +1 -0
  644. package/dist/services/metrics/sender.d.ts.map +1 -1
  645. package/dist/services/metrics/sender.js +86 -0
  646. package/dist/services/metrics/sender.js.map +1 -0
  647. package/dist/services/metrics/sender.mjs +84 -0
  648. package/dist/services/metrics/sender.mjs.map +1 -0
  649. package/dist/services/query-params.js +15 -0
  650. package/dist/services/query-params.js.map +1 -0
  651. package/dist/services/query-params.mjs +13 -0
  652. package/dist/services/query-params.mjs.map +1 -0
  653. package/dist/services/reloader.js +39 -0
  654. package/dist/services/reloader.js.map +1 -0
  655. package/dist/services/reloader.mjs +37 -0
  656. package/dist/services/reloader.mjs.map +1 -0
  657. package/dist/services/request-context.js +16 -0
  658. package/dist/services/request-context.js.map +1 -0
  659. package/dist/services/request-context.mjs +14 -0
  660. package/dist/services/request-context.mjs.map +1 -0
  661. package/dist/services/server/admin-api.js +14 -0
  662. package/dist/services/server/admin-api.js.map +1 -0
  663. package/dist/services/server/admin-api.mjs +12 -0
  664. package/dist/services/server/admin-api.mjs.map +1 -0
  665. package/dist/services/server/api.js +36 -0
  666. package/dist/services/server/api.js.map +1 -0
  667. package/dist/services/server/api.mjs +34 -0
  668. package/dist/services/server/api.mjs.map +1 -0
  669. package/dist/services/server/compose-endpoint.js +128 -0
  670. package/dist/services/server/compose-endpoint.js.map +1 -0
  671. package/dist/services/server/compose-endpoint.mjs +126 -0
  672. package/dist/services/server/compose-endpoint.mjs.map +1 -0
  673. package/dist/services/server/content-api.js +14 -0
  674. package/dist/services/server/content-api.js.map +1 -0
  675. package/dist/services/server/content-api.mjs +12 -0
  676. package/dist/services/server/content-api.mjs.map +1 -0
  677. package/dist/services/server/http-server.js +54 -0
  678. package/dist/services/server/http-server.js.map +1 -0
  679. package/dist/services/server/http-server.mjs +52 -0
  680. package/dist/services/server/http-server.mjs.map +1 -0
  681. package/dist/services/server/index.js +90 -0
  682. package/dist/services/server/index.js.map +1 -0
  683. package/dist/services/server/index.mjs +88 -0
  684. package/dist/services/server/index.mjs.map +1 -0
  685. package/dist/services/server/koa.js +54 -0
  686. package/dist/services/server/koa.js.map +1 -0
  687. package/dist/services/server/koa.mjs +52 -0
  688. package/dist/services/server/koa.mjs.map +1 -0
  689. package/dist/services/server/middleware.js +96 -0
  690. package/dist/services/server/middleware.js.map +1 -0
  691. package/dist/services/server/middleware.mjs +93 -0
  692. package/dist/services/server/middleware.mjs.map +1 -0
  693. package/dist/services/server/policy.js +27 -0
  694. package/dist/services/server/policy.js.map +1 -0
  695. package/dist/services/server/policy.mjs +25 -0
  696. package/dist/services/server/policy.mjs.map +1 -0
  697. package/dist/services/server/register-middlewares.js +79 -0
  698. package/dist/services/server/register-middlewares.js.map +1 -0
  699. package/dist/services/server/register-middlewares.mjs +77 -0
  700. package/dist/services/server/register-middlewares.mjs.map +1 -0
  701. package/dist/services/server/register-routes.js +119 -0
  702. package/dist/services/server/register-routes.js.map +1 -0
  703. package/dist/services/server/register-routes.mjs +117 -0
  704. package/dist/services/server/register-routes.mjs.map +1 -0
  705. package/dist/services/server/routing.d.ts +10 -0
  706. package/dist/services/server/routing.d.ts.map +1 -1
  707. package/dist/services/server/routing.js +110 -0
  708. package/dist/services/server/routing.js.map +1 -0
  709. package/dist/services/server/routing.mjs +107 -0
  710. package/dist/services/server/routing.mjs.map +1 -0
  711. package/dist/services/session-manager.d.ts +167 -0
  712. package/dist/services/session-manager.d.ts.map +1 -0
  713. package/dist/services/session-manager.js +529 -0
  714. package/dist/services/session-manager.js.map +1 -0
  715. package/dist/services/session-manager.mjs +526 -0
  716. package/dist/services/session-manager.mjs.map +1 -0
  717. package/dist/services/utils/conditional-fields.d.ts +3 -0
  718. package/dist/services/utils/conditional-fields.d.ts.map +1 -0
  719. package/dist/services/utils/conditional-fields.js +22 -0
  720. package/dist/services/utils/conditional-fields.js.map +1 -0
  721. package/dist/services/utils/conditional-fields.mjs +20 -0
  722. package/dist/services/utils/conditional-fields.mjs.map +1 -0
  723. package/dist/services/utils/dynamic-zones.js +16 -0
  724. package/dist/services/utils/dynamic-zones.js.map +1 -0
  725. package/dist/services/utils/dynamic-zones.mjs +14 -0
  726. package/dist/services/utils/dynamic-zones.mjs.map +1 -0
  727. package/dist/services/webhook-runner.js +135 -0
  728. package/dist/services/webhook-runner.js.map +1 -0
  729. package/dist/services/webhook-runner.mjs +133 -0
  730. package/dist/services/webhook-runner.mjs.map +1 -0
  731. package/dist/services/webhook-store.js +143 -0
  732. package/dist/services/webhook-store.js.map +1 -0
  733. package/dist/services/webhook-store.mjs +140 -0
  734. package/dist/services/webhook-store.mjs.map +1 -0
  735. package/dist/services/worker-queue.js +51 -0
  736. package/dist/services/worker-queue.js.map +1 -0
  737. package/dist/services/worker-queue.mjs +49 -0
  738. package/dist/services/worker-queue.mjs.map +1 -0
  739. package/dist/utils/convert-custom-field-type.js +21 -0
  740. package/dist/utils/convert-custom-field-type.js.map +1 -0
  741. package/dist/utils/convert-custom-field-type.mjs +19 -0
  742. package/dist/utils/convert-custom-field-type.mjs.map +1 -0
  743. package/dist/utils/cron.js +72 -0
  744. package/dist/utils/cron.js.map +1 -0
  745. package/dist/utils/cron.mjs +70 -0
  746. package/dist/utils/cron.mjs.map +1 -0
  747. package/dist/utils/fetch.d.ts +5 -1
  748. package/dist/utils/fetch.d.ts.map +1 -1
  749. package/dist/utils/fetch.js +31 -0
  750. package/dist/utils/fetch.js.map +1 -0
  751. package/dist/utils/fetch.mjs +29 -0
  752. package/dist/utils/fetch.mjs.map +1 -0
  753. package/dist/utils/filepath-to-prop-path.js +25 -0
  754. package/dist/utils/filepath-to-prop-path.js.map +1 -0
  755. package/dist/utils/filepath-to-prop-path.mjs +23 -0
  756. package/dist/utils/filepath-to-prop-path.mjs.map +1 -0
  757. package/dist/utils/is-initialized.js +25 -0
  758. package/dist/utils/is-initialized.js.map +1 -0
  759. package/dist/utils/is-initialized.mjs +23 -0
  760. package/dist/utils/is-initialized.mjs.map +1 -0
  761. package/dist/utils/lifecycles.js +10 -0
  762. package/dist/utils/lifecycles.js.map +1 -0
  763. package/dist/utils/lifecycles.mjs +8 -0
  764. package/dist/utils/lifecycles.mjs.map +1 -0
  765. package/dist/utils/load-config-file.js +47 -0
  766. package/dist/utils/load-config-file.js.map +1 -0
  767. package/dist/utils/load-config-file.mjs +45 -0
  768. package/dist/utils/load-config-file.mjs.map +1 -0
  769. package/dist/utils/load-files.js +44 -0
  770. package/dist/utils/load-files.js.map +1 -0
  771. package/dist/utils/load-files.mjs +42 -0
  772. package/dist/utils/load-files.mjs.map +1 -0
  773. package/dist/utils/open-browser.js +11 -0
  774. package/dist/utils/open-browser.js.map +1 -0
  775. package/dist/utils/open-browser.mjs +9 -0
  776. package/dist/utils/open-browser.mjs.map +1 -0
  777. package/dist/utils/resolve-working-dirs.js +26 -0
  778. package/dist/utils/resolve-working-dirs.js.map +1 -0
  779. package/dist/utils/resolve-working-dirs.mjs +24 -0
  780. package/dist/utils/resolve-working-dirs.mjs.map +1 -0
  781. package/dist/utils/signals.js +23 -0
  782. package/dist/utils/signals.js.map +1 -0
  783. package/dist/utils/signals.mjs +21 -0
  784. package/dist/utils/signals.mjs.map +1 -0
  785. package/dist/utils/startup-logger.js +110 -0
  786. package/dist/utils/startup-logger.js.map +1 -0
  787. package/dist/utils/startup-logger.mjs +108 -0
  788. package/dist/utils/startup-logger.mjs.map +1 -0
  789. package/dist/utils/transform-content-types-to-models.d.ts +197 -0
  790. package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
  791. package/dist/utils/transform-content-types-to-models.js +377 -0
  792. package/dist/utils/transform-content-types-to-models.js.map +1 -0
  793. package/dist/utils/transform-content-types-to-models.mjs +365 -0
  794. package/dist/utils/transform-content-types-to-models.mjs.map +1 -0
  795. package/dist/utils/update-notifier/index.js +80 -0
  796. package/dist/utils/update-notifier/index.js.map +1 -0
  797. package/dist/utils/update-notifier/index.mjs +78 -0
  798. package/dist/utils/update-notifier/index.mjs.map +1 -0
  799. package/package.json +19 -14
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bidirectional-relations.mjs","sources":["../../../../src/services/document-service/utils/bidirectional-relations.ts"],"sourcesContent":["/* eslint-disable no-continue */\nimport { keyBy } from 'lodash/fp';\nimport { async } from '@strapi/utils';\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 all bidirectional relations that need to be synchronized when content entries change state\n * (e.g., during publish/unpublish operations).\n *\n * In Strapi, bidirectional relations allow maintaining order from both sides of the relation.\n * When an entry is published, the following occurs:\n *\n * 1. The old published entry is deleted\n * 2. A new entry is created with all its relations\n *\n * This process affects relation ordering in the following way:\n *\n * Initial state (Entry A related to X, Y, Z):\n * ```\n * Entry A (draft) Entry A (published)\n * │ │\n * ├──(1)→ X ├──(1)→ X\n * ├──(2)→ Y ├──(2)→ Y\n * └──(3)→ Z └──(3)→ Z\n *\n * X's perspective: Y's perspective: Z's perspective:\n * └──(2)→ Entry A └──(1)→ Entry A └──(3)→ Entry A\n * ```\n *\n * After publishing Entry A (without relation order sync):\n * ```\n * Entry A (draft) Entry A (new published)\n * │ │\n * ├──(1)→ X ├──(1)→ X\n * ├──(2)→ Y ├──(2)→ Y\n * └──(3)→ Z └──(3)→ Z\n *\n * X's perspective: Y's perspective: Z's perspective:\n * └──(3)→ Entry A └──(3)→ Entry A └──(3)→ Entry A\n * (all relations appear last in order)\n * ```\n *\n * This module preserves the original ordering from both perspectives by:\n * 1. Capturing the relation order before the entry state changes\n * 2. Restoring this order after the new relations are created\n *\n * @param uid - The unique identifier of the content type being processed\n * @param context - Object containing arrays of old and new entry versions\n * @returns Array of objects containing join table metadata and relations to be updated\n */\nconst load = async (uid: UID.ContentType, { oldVersions }: LoadContext) => {\n const relationsToUpdate = [] as any;\n\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 // Skip if not a bidirectional relation targeting our content type\n if (\n attribute.type !== 'relation' ||\n attribute.target !== uid ||\n !(attribute.inversedBy || attribute.mappedBy)\n ) {\n continue;\n }\n\n // If it's a self referencing relation, there is no need to sync any relation\n // The order will already be handled as both sides are inside the same content type\n if (model.uid === uid) {\n continue;\n }\n\n const joinTable = attribute.joinTable;\n if (!joinTable) {\n continue;\n }\n\n const { name: targetColumnName } = joinTable.inverseJoinColumn;\n\n // Load all relations that need their order preserved\n const oldEntryIds = oldVersions.map((entry) => entry.id);\n\n const existingRelations = await strapi.db\n .getConnection()\n .select('*')\n .from(joinTable.name)\n .whereIn(targetColumnName, oldEntryIds)\n .transacting(trx);\n\n if (existingRelations.length > 0) {\n relationsToUpdate.push({ joinTable, relations: existingRelations });\n }\n }\n }\n });\n\n return relationsToUpdate;\n};\n\n/**\n * Synchronizes the order of bidirectional relations after content entries have changed state.\n *\n * When entries change state (e.g., draft → published), their IDs change and all relations are recreated.\n * While the order of relations from the entry's perspective is maintained (as they're created in order),\n * the inverse relations (from related entries' perspective) would all appear last in order since they're new.\n *\n * Example:\n * ```\n * Before publish:\n * Article(id:1) →(order:1)→ Category(id:5)\n * Category(id:5) →(order:3)→ Article(id:1)\n *\n * After publish (without sync):\n * Article(id:2) →(order:1)→ Category(id:5) [order preserved]\n * Category(id:5) →(order:99)→ Article(id:2) [order lost - appears last]\n *\n * After sync:\n * Article(id:2) →(order:1)→ Category(id:5) [order preserved]\n * Category(id:5) →(order:3)→ Article(id:2) [order restored]\n * ```\n *\n * @param oldEntries - Array of previous entry versions with their IDs and locales\n * @param newEntries - Array of new entry versions with their IDs and locales\n * @param existingRelations - Array of join table data containing the relations to be updated\n */\nconst sync = async (\n oldEntries: { id: string; locale: string }[],\n newEntries: { id: string; locale: string }[],\n existingRelations: { joinTable: any; relations: any[] }[]\n) => {\n // Group new entries by locale for easier lookup\n const newEntriesByLocale = keyBy('locale', newEntries);\n\n // Create a mapping of old entry IDs to new entry IDs based on locale\n const entryIdMapping = oldEntries.reduce(\n (acc, oldEntry) => {\n const newEntry = newEntriesByLocale[oldEntry.locale];\n if (!newEntry) return acc;\n acc[oldEntry.id] = newEntry.id;\n return acc;\n },\n {} as Record<string, string>\n );\n\n await strapi.db.transaction(async ({ trx }) => {\n for (const { joinTable, relations } of existingRelations) {\n const sourceColumn = joinTable.inverseJoinColumn.name;\n const targetColumn = joinTable.joinColumn.name;\n const orderColumn = joinTable.orderColumnName;\n\n // Failsafe in case those don't exist\n if (!sourceColumn || !targetColumn || !orderColumn) {\n continue;\n }\n\n // Update order values for each relation\n // TODO: Find a way to batch it more efficiently\n await async.map(relations, (relation: any) => {\n const {\n [sourceColumn]: oldSourceId,\n [targetColumn]: targetId,\n [orderColumn]: originalOrder,\n } = relation;\n\n // Update the order column for the new relation entry\n return trx\n .from(joinTable.name)\n .where(sourceColumn, entryIdMapping[oldSourceId])\n .where(targetColumn, targetId)\n .update({ [orderColumn]: originalOrder });\n });\n }\n });\n};\n\nexport { load, sync };\n"],"names":["load","uid","oldVersions","relationsToUpdate","strapi","db","transaction","trx","contentTypes","Object","values","components","model","dbModel","metadata","get","attribute","attributes","type","target","inversedBy","mappedBy","joinTable","name","targetColumnName","inverseJoinColumn","oldEntryIds","map","entry","id","existingRelations","getConnection","select","from","whereIn","transacting","length","push","relations","sync","oldEntries","newEntries","newEntriesByLocale","keyBy","entryIdMapping","reduce","acc","oldEntry","newEntry","locale","sourceColumn","targetColumn","joinColumn","orderColumn","orderColumnName","async","relation","oldSourceId","targetId","originalOrder","where","update"],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ import type { Database } from '@strapi/database';
2
+ /**
3
+ * Cleans ghost relations with publication state mismatches from a join table
4
+ * Uses schema-based draft/publish checking like prevention fix
5
+ */
6
+ export declare const cleanComponentJoinTable: (db: Database, joinTableName: string, relation: any, sourceModel: any) => Promise<number>;
7
+ //# sourceMappingURL=clean-component-join-table.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"clean-component-join-table.d.ts","sourceRoot":"","sources":["../../../../src/services/document-service/utils/clean-component-join-table.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAIjD;;;GAGG;AACH,eAAO,MAAM,uBAAuB,OAC9B,QAAQ,iBACG,MAAM,YACX,GAAG,eACA,GAAG,KACf,QAAQ,MAAM,CA2ChB,CAAC"}
@@ -0,0 +1,71 @@
1
+ 'use strict';
2
+
3
+ var strapiUtils = require('@strapi/utils');
4
+
5
+ const { CREATED_BY_ATTRIBUTE, UPDATED_BY_ATTRIBUTE } = strapiUtils.contentTypes.constants;
6
+ // We want to build a populate object based on the schema
7
+ const getDeepPopulate = (uid, opts = {})=>{
8
+ const model = strapi.getModel(uid);
9
+ const attributes = Object.entries(model.attributes);
10
+ return attributes.reduce((acc, [attributeName, attribute])=>{
11
+ switch(attribute.type){
12
+ case 'relation':
13
+ {
14
+ // TODO: Support polymorphic relations
15
+ const isMorphRelation = attribute.relation.toLowerCase().startsWith('morph');
16
+ if (isMorphRelation) {
17
+ break;
18
+ }
19
+ // Ignore not visible fields other than createdBy and updatedBy
20
+ const isVisible = strapiUtils.contentTypes.isVisibleAttribute(model, attributeName);
21
+ const isCreatorField = [
22
+ CREATED_BY_ATTRIBUTE,
23
+ UPDATED_BY_ATTRIBUTE
24
+ ].includes(attributeName);
25
+ if (isVisible || isCreatorField) {
26
+ acc[attributeName] = {
27
+ select: opts.relationalFields
28
+ };
29
+ }
30
+ break;
31
+ }
32
+ case 'media':
33
+ {
34
+ // We populate all media fields for completeness of webhook responses
35
+ // see https://github.com/strapi/strapi/issues/21546
36
+ acc[attributeName] = {
37
+ select: [
38
+ '*'
39
+ ]
40
+ };
41
+ break;
42
+ }
43
+ case 'component':
44
+ {
45
+ const populate = getDeepPopulate(attribute.component, opts);
46
+ acc[attributeName] = {
47
+ populate
48
+ };
49
+ break;
50
+ }
51
+ case 'dynamiczone':
52
+ {
53
+ // Use fragments to populate the dynamic zone components
54
+ const populatedComponents = (attribute.components || []).reduce((acc, componentUID)=>{
55
+ acc[componentUID] = {
56
+ populate: getDeepPopulate(componentUID, opts)
57
+ };
58
+ return acc;
59
+ }, {});
60
+ acc[attributeName] = {
61
+ on: populatedComponents
62
+ };
63
+ break;
64
+ }
65
+ }
66
+ return acc;
67
+ }, {});
68
+ };
69
+
70
+ exports.getDeepPopulate = getDeepPopulate;
71
+ //# sourceMappingURL=populate.js.map
@@ -0,0 +1 @@
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;;;;"}
@@ -0,0 +1,69 @@
1
+ import { contentTypes } from '@strapi/utils';
2
+
3
+ const { CREATED_BY_ATTRIBUTE, UPDATED_BY_ATTRIBUTE } = contentTypes.constants;
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
+ }
63
+ }
64
+ return acc;
65
+ }, {});
66
+ };
67
+
68
+ export { getDeepPopulate };
69
+ //# sourceMappingURL=populate.mjs.map
@@ -0,0 +1 @@
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,4 +1,5 @@
1
- import type { UID } from '@strapi/types';
1
+ import type { UID, Schema } from '@strapi/types';
2
+ import type { JoinTable } from '@strapi/database';
2
3
  interface LoadContext {
3
4
  oldVersions: {
4
5
  id: string;
@@ -9,15 +10,30 @@ interface LoadContext {
9
10
  locale: string;
10
11
  }[];
11
12
  }
13
+ interface RelationUpdate {
14
+ joinTable: JoinTable;
15
+ relations: Record<string, any>[];
16
+ }
17
+ interface RelationFilterOptions {
18
+ /**
19
+ * Function to determine if a relation should be propagated to new document versions
20
+ * This replaces the hardcoded component-specific logic
21
+ */
22
+ shouldPropagateRelation?: (relation: Record<string, any>, model: Schema.Component | Schema.ContentType, trx: any) => Promise<boolean>;
23
+ }
12
24
  /**
13
25
  * Loads lingering relations that need to be updated when overriding a published or draft entry.
14
26
  * This is necessary because the relations are uni-directional and the target entry is not aware of the source entry.
15
27
  * This is not the case for bi-directional relations, where the target entry is also linked to the source entry.
16
28
  */
17
- declare const load: (uid: UID.ContentType, { oldVersions, newVersions }: LoadContext) => Promise<any>;
29
+ declare const load: (uid: UID.ContentType, { oldVersions, newVersions }: LoadContext, options?: RelationFilterOptions) => Promise<RelationUpdate[]>;
18
30
  /**
19
31
  * Updates uni directional relations to target the right entries when overriding published or draft entries.
20
32
  *
33
+ * This function:
34
+ * 1. Creates new relations pointing to the new entry versions
35
+ * 2. Precisely deletes only the old relations being replaced to prevent orphaned links
36
+ *
21
37
  * @param oldEntries The old entries that are being overridden
22
38
  * @param newEntries The new entries that are overriding the old ones
23
39
  * @param oldRelations The relations that were previously loaded with `load` @see load
@@ -33,4 +49,5 @@ declare const sync: (oldEntries: {
33
49
  relations: any[];
34
50
  }[]) => Promise<void>;
35
51
  export { load, sync };
52
+ export type { RelationFilterOptions };
36
53
  //# sourceMappingURL=unidirectional-relations.d.ts.map
@@ -1 +1 @@
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
+ {"version":3,"file":"unidirectional-relations.d.ts","sourceRoot":"","sources":["../../../../src/services/document-service/utils/unidirectional-relations.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEjD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAElD,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,UAAU,cAAc;IACtB,SAAS,EAAE,SAAS,CAAC;IACrB,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EAAE,CAAC;CAClC;AAED,UAAU,qBAAqB;IAC7B;;;OAGG;IACH,uBAAuB,CAAC,EAAE,CACxB,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EAC7B,KAAK,EAAE,MAAM,CAAC,SAAS,GAAG,MAAM,CAAC,WAAW,EAC5C,GAAG,EAAE,GAAG,KACL,OAAO,CAAC,OAAO,CAAC,CAAC;CACvB;AAED;;;;GAIG;AACH,QAAA,MAAM,IAAI,QACH,IAAI,WAAW,gCACU,WAAW,YAChC,qBAAqB,KAC7B,QAAQ,cAAc,EAAE,CAyG1B,CAAC;AAEF;;;;;;;;;;GAUG;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;AACtB,YAAY,EAAE,qBAAqB,EAAE,CAAC"}
@@ -0,0 +1,131 @@
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 }, options = {})=>{
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
+ // This is the step were we query the join table based on the id of the document
57
+ const newVersionsRelations = await strapi.db.getConnection().select('*').from(joinTable.name).whereIn(targetColumnName, ids).transacting(trx);
58
+ let versionRelations = newVersionsRelations;
59
+ if (options.shouldPropagateRelation) {
60
+ const relationsToPropagate = [];
61
+ for (const relation of newVersionsRelations){
62
+ if (await options.shouldPropagateRelation(relation, model, trx)) {
63
+ relationsToPropagate.push(relation);
64
+ }
65
+ }
66
+ versionRelations = relationsToPropagate;
67
+ }
68
+ if (versionRelations.length > 0) {
69
+ // when publishing a draft that doesn't have a published version yet,
70
+ // copy the links to the draft over to the published version
71
+ // when discarding a published version, if no drafts exists
72
+ const discardToAdd = versionRelations.filter((relation)=>{
73
+ const matchingOldVersion = oldVersionsRelations.find((oldRelation)=>{
74
+ return oldRelation[sourceColumnName] === relation[sourceColumnName];
75
+ });
76
+ return !matchingOldVersion;
77
+ }).map(fp.omit(strapi.db.metadata.identifiers.ID_COLUMN));
78
+ updates.push({
79
+ joinTable,
80
+ relations: discardToAdd
81
+ });
82
+ }
83
+ }
84
+ }
85
+ }
86
+ });
87
+ return updates;
88
+ };
89
+ /**
90
+ * Updates uni directional relations to target the right entries when overriding published or draft entries.
91
+ *
92
+ * This function:
93
+ * 1. Creates new relations pointing to the new entry versions
94
+ * 2. Precisely deletes only the old relations being replaced to prevent orphaned links
95
+ *
96
+ * @param oldEntries The old entries that are being overridden
97
+ * @param newEntries The new entries that are overriding the old ones
98
+ * @param oldRelations The relations that were previously loaded with `load` @see load
99
+ */ const sync = async (oldEntries, newEntries, oldRelations)=>{
100
+ /**
101
+ * Create a map of old entry ids to new entry ids
102
+ *
103
+ * Will be used to update the relation target ids
104
+ */ const newEntryByLocale = fp.keyBy('locale', newEntries);
105
+ const oldEntriesMap = oldEntries.reduce((acc, entry)=>{
106
+ const newEntry = newEntryByLocale[entry.locale];
107
+ if (!newEntry) return acc;
108
+ acc[entry.id] = newEntry.id;
109
+ return acc;
110
+ }, {});
111
+ await strapi.db.transaction(async ({ trx })=>{
112
+ // Iterate old relations that are deleted and insert the new ones
113
+ for (const { joinTable, relations } of oldRelations){
114
+ // Update old ids with the new ones
115
+ const column = joinTable.inverseJoinColumn.name;
116
+ const newRelations = relations.map((relation)=>{
117
+ const newId = oldEntriesMap[relation[column]];
118
+ return {
119
+ ...relation,
120
+ [column]: newId
121
+ };
122
+ });
123
+ // Insert those relations into the join table
124
+ await trx.batchInsert(joinTable.name, newRelations, 1000);
125
+ }
126
+ });
127
+ };
128
+
129
+ exports.load = load;
130
+ exports.sync = sync;
131
+ //# sourceMappingURL=unidirectional-relations.js.map
@@ -0,0 +1 @@
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\nimport type { JoinTable } from '@strapi/database';\n\ninterface LoadContext {\n oldVersions: { id: string; locale: string }[];\n newVersions: { id: string; locale: string }[];\n}\n\ninterface RelationUpdate {\n joinTable: JoinTable;\n relations: Record<string, any>[];\n}\n\ninterface RelationFilterOptions {\n /**\n * Function to determine if a relation should be propagated to new document versions\n * This replaces the hardcoded component-specific logic\n */\n shouldPropagateRelation?: (\n relation: Record<string, any>,\n model: Schema.Component | Schema.ContentType,\n trx: any\n ) => Promise<boolean>;\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 (\n uid: UID.ContentType,\n { oldVersions, newVersions }: LoadContext,\n options: RelationFilterOptions = {}\n): Promise<RelationUpdate[]> => {\n const updates: RelationUpdate[] = [];\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 if (!model.options?.draftAndPublish) {\n const ids = newVersions.map((entry) => entry.id);\n\n // This is the step were we query the join table based on the id of the document\n const newVersionsRelations = await strapi.db\n .getConnection()\n .select('*')\n .from(joinTable.name)\n .whereIn(targetColumnName, ids)\n .transacting(trx);\n\n let versionRelations = newVersionsRelations;\n if (options.shouldPropagateRelation) {\n const relationsToPropagate = [];\n for (const relation of newVersionsRelations) {\n if (await options.shouldPropagateRelation(relation, model, trx)) {\n relationsToPropagate.push(relation);\n }\n }\n versionRelations = relationsToPropagate;\n }\n\n if (versionRelations.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 = versionRelations\n .filter((relation) => {\n const matchingOldVersion = oldVersionsRelations.find((oldRelation) => {\n return oldRelation[sourceColumnName] === relation[sourceColumnName];\n });\n\n return !matchingOldVersion;\n })\n .map(omit(strapi.db.metadata.identifiers.ID_COLUMN));\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 * This function:\n * 1. Creates new relations pointing to the new entry versions\n * 2. Precisely deletes only the old relations being replaced to prevent orphaned links\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 };\nexport type { RelationFilterOptions };\n"],"names":["load","uid","oldVersions","newVersions","options","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","draftAndPublish","newVersionsRelations","versionRelations","shouldPropagateRelation","relationsToPropagate","relation","discardToAdd","filter","matchingOldVersion","find","oldRelation","omit","identifiers","ID_COLUMN","sync","oldEntries","newEntries","oldRelations","newEntryByLocale","keyBy","oldEntriesMap","reduce","acc","newEntry","locale","column","newRelations","newId","batchInsert"],"mappings":"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"}
@@ -0,0 +1,128 @@
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 }, options = {})=>{
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
+ // This is the step were we query the join table based on the id of the document
55
+ const newVersionsRelations = await strapi.db.getConnection().select('*').from(joinTable.name).whereIn(targetColumnName, ids).transacting(trx);
56
+ let versionRelations = newVersionsRelations;
57
+ if (options.shouldPropagateRelation) {
58
+ const relationsToPropagate = [];
59
+ for (const relation of newVersionsRelations){
60
+ if (await options.shouldPropagateRelation(relation, model, trx)) {
61
+ relationsToPropagate.push(relation);
62
+ }
63
+ }
64
+ versionRelations = relationsToPropagate;
65
+ }
66
+ if (versionRelations.length > 0) {
67
+ // when publishing a draft that doesn't have a published version yet,
68
+ // copy the links to the draft over to the published version
69
+ // when discarding a published version, if no drafts exists
70
+ const discardToAdd = versionRelations.filter((relation)=>{
71
+ const matchingOldVersion = oldVersionsRelations.find((oldRelation)=>{
72
+ return oldRelation[sourceColumnName] === relation[sourceColumnName];
73
+ });
74
+ return !matchingOldVersion;
75
+ }).map(omit(strapi.db.metadata.identifiers.ID_COLUMN));
76
+ updates.push({
77
+ joinTable,
78
+ relations: discardToAdd
79
+ });
80
+ }
81
+ }
82
+ }
83
+ }
84
+ });
85
+ return updates;
86
+ };
87
+ /**
88
+ * Updates uni directional relations to target the right entries when overriding published or draft entries.
89
+ *
90
+ * This function:
91
+ * 1. Creates new relations pointing to the new entry versions
92
+ * 2. Precisely deletes only the old relations being replaced to prevent orphaned links
93
+ *
94
+ * @param oldEntries The old entries that are being overridden
95
+ * @param newEntries The new entries that are overriding the old ones
96
+ * @param oldRelations The relations that were previously loaded with `load` @see load
97
+ */ const sync = async (oldEntries, newEntries, oldRelations)=>{
98
+ /**
99
+ * Create a map of old entry ids to new entry ids
100
+ *
101
+ * Will be used to update the relation target ids
102
+ */ const newEntryByLocale = keyBy('locale', newEntries);
103
+ const oldEntriesMap = oldEntries.reduce((acc, entry)=>{
104
+ const newEntry = newEntryByLocale[entry.locale];
105
+ if (!newEntry) return acc;
106
+ acc[entry.id] = newEntry.id;
107
+ return acc;
108
+ }, {});
109
+ await strapi.db.transaction(async ({ trx })=>{
110
+ // Iterate old relations that are deleted and insert the new ones
111
+ for (const { joinTable, relations } of oldRelations){
112
+ // Update old ids with the new ones
113
+ const column = joinTable.inverseJoinColumn.name;
114
+ const newRelations = relations.map((relation)=>{
115
+ const newId = oldEntriesMap[relation[column]];
116
+ return {
117
+ ...relation,
118
+ [column]: newId
119
+ };
120
+ });
121
+ // Insert those relations into the join table
122
+ await trx.batchInsert(joinTable.name, newRelations, 1000);
123
+ }
124
+ });
125
+ };
126
+
127
+ export { load, sync };
128
+ //# sourceMappingURL=unidirectional-relations.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"unidirectional-relations.mjs","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\nimport type { JoinTable } from '@strapi/database';\n\ninterface LoadContext {\n oldVersions: { id: string; locale: string }[];\n newVersions: { id: string; locale: string }[];\n}\n\ninterface RelationUpdate {\n joinTable: JoinTable;\n relations: Record<string, any>[];\n}\n\ninterface RelationFilterOptions {\n /**\n * Function to determine if a relation should be propagated to new document versions\n * This replaces the hardcoded component-specific logic\n */\n shouldPropagateRelation?: (\n relation: Record<string, any>,\n model: Schema.Component | Schema.ContentType,\n trx: any\n ) => Promise<boolean>;\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 (\n uid: UID.ContentType,\n { oldVersions, newVersions }: LoadContext,\n options: RelationFilterOptions = {}\n): Promise<RelationUpdate[]> => {\n const updates: RelationUpdate[] = [];\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 if (!model.options?.draftAndPublish) {\n const ids = newVersions.map((entry) => entry.id);\n\n // This is the step were we query the join table based on the id of the document\n const newVersionsRelations = await strapi.db\n .getConnection()\n .select('*')\n .from(joinTable.name)\n .whereIn(targetColumnName, ids)\n .transacting(trx);\n\n let versionRelations = newVersionsRelations;\n if (options.shouldPropagateRelation) {\n const relationsToPropagate = [];\n for (const relation of newVersionsRelations) {\n if (await options.shouldPropagateRelation(relation, model, trx)) {\n relationsToPropagate.push(relation);\n }\n }\n versionRelations = relationsToPropagate;\n }\n\n if (versionRelations.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 = versionRelations\n .filter((relation) => {\n const matchingOldVersion = oldVersionsRelations.find((oldRelation) => {\n return oldRelation[sourceColumnName] === relation[sourceColumnName];\n });\n\n return !matchingOldVersion;\n })\n .map(omit(strapi.db.metadata.identifiers.ID_COLUMN));\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 * This function:\n * 1. Creates new relations pointing to the new entry versions\n * 2. Precisely deletes only the old relations being replaced to prevent orphaned links\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 };\nexport type { RelationFilterOptions };\n"],"names":["load","uid","oldVersions","newVersions","options","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","draftAndPublish","newVersionsRelations","versionRelations","shouldPropagateRelation","relationsToPropagate","relation","discardToAdd","filter","matchingOldVersion","find","oldRelation","omit","identifiers","ID_COLUMN","sync","oldEntries","newEntries","oldRelations","newEntryByLocale","keyBy","oldEntriesMap","reduce","acc","newEntry","locale","column","newRelations","newId","batchInsert"],"mappings":"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"}