@strapi/core 0.0.0-experimental.bb39175992a5cd205a7e3f2e13a96aa31eba2cff → 0.0.0-experimental.bd3419429b8caba37ca42ac08edb57cd4b5e1c47

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (699) hide show
  1. package/dist/Strapi.d.ts.map +1 -1
  2. package/dist/configuration/index.d.ts.map +1 -1
  3. package/dist/ee/index.d.ts.map +1 -1
  4. package/dist/index.js +10101 -27
  5. package/dist/index.js.map +1 -1
  6. package/dist/index.mjs +10079 -29
  7. package/dist/index.mjs.map +1 -1
  8. package/dist/middlewares/body.d.ts.map +1 -1
  9. package/dist/migrations/database/5.0.0-discard-drafts.d.ts +2 -2
  10. package/dist/migrations/database/5.0.0-discard-drafts.d.ts.map +1 -1
  11. package/dist/migrations/draft-publish.d.ts +1 -1
  12. package/dist/migrations/draft-publish.d.ts.map +1 -1
  13. package/dist/services/document-service/common.d.ts +1 -1
  14. package/dist/services/document-service/common.d.ts.map +1 -1
  15. package/dist/services/document-service/components.d.ts.map +1 -1
  16. package/dist/services/document-service/draft-and-publish.d.ts +1 -1
  17. package/dist/services/document-service/draft-and-publish.d.ts.map +1 -1
  18. package/dist/services/document-service/entries.d.ts +2 -2
  19. package/dist/services/document-service/entries.d.ts.map +1 -1
  20. package/dist/services/document-service/events.d.ts +1 -1
  21. package/dist/services/document-service/events.d.ts.map +1 -1
  22. package/dist/services/document-service/index.d.ts +2 -1
  23. package/dist/services/document-service/index.d.ts.map +1 -1
  24. package/dist/services/document-service/repository.d.ts.map +1 -1
  25. package/dist/services/document-service/transform/id-map.d.ts +1 -1
  26. package/dist/services/document-service/transform/id-map.d.ts.map +1 -1
  27. package/dist/services/document-service/transform/id-transform.d.ts +1 -1
  28. package/dist/services/document-service/transform/id-transform.d.ts.map +1 -1
  29. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +1 -1
  30. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -1
  31. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts.map +1 -1
  32. package/dist/services/document-service/transform/relations/utils/dp.d.ts +1 -1
  33. package/dist/services/document-service/transform/relations/utils/dp.d.ts.map +1 -1
  34. package/dist/services/document-service/transform/relations/utils/i18n.d.ts +1 -1
  35. package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -1
  36. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts.map +1 -1
  37. package/dist/services/document-service/utils/bidirectional-relations.d.ts +95 -0
  38. package/dist/services/document-service/utils/bidirectional-relations.d.ts.map +1 -0
  39. package/dist/services/document-service/utils/populate.d.ts +1 -1
  40. package/dist/services/document-service/utils/populate.d.ts.map +1 -1
  41. package/dist/services/document-service/utils/unidirectional-relations.d.ts +4 -5
  42. package/dist/services/document-service/utils/unidirectional-relations.d.ts.map +1 -1
  43. package/dist/services/entity-validator/index.d.ts +1 -1
  44. package/dist/services/entity-validator/index.d.ts.map +1 -1
  45. package/dist/services/metrics/middleware.d.ts.map +1 -1
  46. package/dist/services/metrics/rate-limiter.d.ts.map +1 -1
  47. package/dist/utils/startup-logger.d.ts.map +1 -1
  48. package/dist/utils/transform-content-types-to-models.d.ts +353 -21
  49. package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
  50. package/dist/utils/update-notifier/index.d.ts.map +1 -1
  51. package/package.json +25 -26
  52. package/dist/Strapi.js +0 -431
  53. package/dist/Strapi.js.map +0 -1
  54. package/dist/Strapi.mjs +0 -410
  55. package/dist/Strapi.mjs.map +0 -1
  56. package/dist/compile.js +0 -18
  57. package/dist/compile.js.map +0 -1
  58. package/dist/compile.mjs +0 -17
  59. package/dist/compile.mjs.map +0 -1
  60. package/dist/configuration/config-loader.js +0 -106
  61. package/dist/configuration/config-loader.js.map +0 -1
  62. package/dist/configuration/config-loader.mjs +0 -104
  63. package/dist/configuration/config-loader.mjs.map +0 -1
  64. package/dist/configuration/get-dirs.js +0 -31
  65. package/dist/configuration/get-dirs.js.map +0 -1
  66. package/dist/configuration/get-dirs.mjs +0 -31
  67. package/dist/configuration/get-dirs.mjs.map +0 -1
  68. package/dist/configuration/index.js +0 -80
  69. package/dist/configuration/index.js.map +0 -1
  70. package/dist/configuration/index.mjs +0 -75
  71. package/dist/configuration/index.mjs.map +0 -1
  72. package/dist/configuration/urls.js +0 -68
  73. package/dist/configuration/urls.js.map +0 -1
  74. package/dist/configuration/urls.mjs +0 -66
  75. package/dist/configuration/urls.mjs.map +0 -1
  76. package/dist/container.js +0 -30
  77. package/dist/container.js.map +0 -1
  78. package/dist/container.mjs +0 -30
  79. package/dist/container.mjs.map +0 -1
  80. package/dist/core-api/controller/collection-type.js +0 -84
  81. package/dist/core-api/controller/collection-type.js.map +0 -1
  82. package/dist/core-api/controller/collection-type.mjs +0 -84
  83. package/dist/core-api/controller/collection-type.mjs.map +0 -1
  84. package/dist/core-api/controller/index.js +0 -52
  85. package/dist/core-api/controller/index.js.map +0 -1
  86. package/dist/core-api/controller/index.mjs +0 -52
  87. package/dist/core-api/controller/index.mjs.map +0 -1
  88. package/dist/core-api/controller/single-type.js +0 -46
  89. package/dist/core-api/controller/single-type.js.map +0 -1
  90. package/dist/core-api/controller/single-type.mjs +0 -46
  91. package/dist/core-api/controller/single-type.mjs.map +0 -1
  92. package/dist/core-api/controller/transform.js +0 -76
  93. package/dist/core-api/controller/transform.js.map +0 -1
  94. package/dist/core-api/controller/transform.mjs +0 -76
  95. package/dist/core-api/controller/transform.mjs.map +0 -1
  96. package/dist/core-api/routes/index.js +0 -67
  97. package/dist/core-api/routes/index.js.map +0 -1
  98. package/dist/core-api/routes/index.mjs +0 -67
  99. package/dist/core-api/routes/index.mjs.map +0 -1
  100. package/dist/core-api/service/collection-type.js +0 -67
  101. package/dist/core-api/service/collection-type.js.map +0 -1
  102. package/dist/core-api/service/collection-type.mjs +0 -67
  103. package/dist/core-api/service/collection-type.mjs.map +0 -1
  104. package/dist/core-api/service/core-service.js +0 -12
  105. package/dist/core-api/service/core-service.js.map +0 -1
  106. package/dist/core-api/service/core-service.mjs +0 -12
  107. package/dist/core-api/service/core-service.mjs.map +0 -1
  108. package/dist/core-api/service/index.js +0 -16
  109. package/dist/core-api/service/index.js.map +0 -1
  110. package/dist/core-api/service/index.mjs +0 -16
  111. package/dist/core-api/service/index.mjs.map +0 -1
  112. package/dist/core-api/service/pagination.js +0 -52
  113. package/dist/core-api/service/pagination.js.map +0 -1
  114. package/dist/core-api/service/pagination.mjs +0 -52
  115. package/dist/core-api/service/pagination.mjs.map +0 -1
  116. package/dist/core-api/service/single-type.js +0 -46
  117. package/dist/core-api/service/single-type.js.map +0 -1
  118. package/dist/core-api/service/single-type.mjs +0 -46
  119. package/dist/core-api/service/single-type.mjs.map +0 -1
  120. package/dist/domain/content-type/index.js +0 -111
  121. package/dist/domain/content-type/index.js.map +0 -1
  122. package/dist/domain/content-type/index.mjs +0 -109
  123. package/dist/domain/content-type/index.mjs.map +0 -1
  124. package/dist/domain/content-type/validator.js +0 -77
  125. package/dist/domain/content-type/validator.js.map +0 -1
  126. package/dist/domain/content-type/validator.mjs +0 -75
  127. package/dist/domain/content-type/validator.mjs.map +0 -1
  128. package/dist/domain/module/index.js +0 -107
  129. package/dist/domain/module/index.js.map +0 -1
  130. package/dist/domain/module/index.mjs +0 -105
  131. package/dist/domain/module/index.mjs.map +0 -1
  132. package/dist/domain/module/validation.js +0 -25
  133. package/dist/domain/module/validation.js.map +0 -1
  134. package/dist/domain/module/validation.mjs +0 -25
  135. package/dist/domain/module/validation.mjs.map +0 -1
  136. package/dist/ee/index.js +0 -153
  137. package/dist/ee/index.js.map +0 -1
  138. package/dist/ee/index.mjs +0 -154
  139. package/dist/ee/index.mjs.map +0 -1
  140. package/dist/ee/license.js +0 -91
  141. package/dist/ee/license.js.map +0 -1
  142. package/dist/ee/license.mjs +0 -88
  143. package/dist/ee/license.mjs.map +0 -1
  144. package/dist/factories.js +0 -80
  145. package/dist/factories.js.map +0 -1
  146. package/dist/factories.mjs +0 -80
  147. package/dist/factories.mjs.map +0 -1
  148. package/dist/loaders/admin.js +0 -26
  149. package/dist/loaders/admin.js.map +0 -1
  150. package/dist/loaders/admin.mjs +0 -25
  151. package/dist/loaders/admin.mjs.map +0 -1
  152. package/dist/loaders/apis.js +0 -137
  153. package/dist/loaders/apis.js.map +0 -1
  154. package/dist/loaders/apis.mjs +0 -135
  155. package/dist/loaders/apis.mjs.map +0 -1
  156. package/dist/loaders/components.js +0 -38
  157. package/dist/loaders/components.js.map +0 -1
  158. package/dist/loaders/components.mjs +0 -37
  159. package/dist/loaders/components.mjs.map +0 -1
  160. package/dist/loaders/index.js +0 -24
  161. package/dist/loaders/index.js.map +0 -1
  162. package/dist/loaders/index.mjs +0 -24
  163. package/dist/loaders/index.mjs.map +0 -1
  164. package/dist/loaders/middlewares.js +0 -31
  165. package/dist/loaders/middlewares.js.map +0 -1
  166. package/dist/loaders/middlewares.mjs +0 -30
  167. package/dist/loaders/middlewares.mjs.map +0 -1
  168. package/dist/loaders/plugins/get-enabled-plugins.js +0 -141
  169. package/dist/loaders/plugins/get-enabled-plugins.js.map +0 -1
  170. package/dist/loaders/plugins/get-enabled-plugins.mjs +0 -117
  171. package/dist/loaders/plugins/get-enabled-plugins.mjs.map +0 -1
  172. package/dist/loaders/plugins/get-user-plugins-config.js +0 -27
  173. package/dist/loaders/plugins/get-user-plugins-config.js.map +0 -1
  174. package/dist/loaders/plugins/get-user-plugins-config.mjs +0 -25
  175. package/dist/loaders/plugins/get-user-plugins-config.mjs.map +0 -1
  176. package/dist/loaders/plugins/index.js +0 -145
  177. package/dist/loaders/plugins/index.js.map +0 -1
  178. package/dist/loaders/plugins/index.mjs +0 -125
  179. package/dist/loaders/plugins/index.mjs.map +0 -1
  180. package/dist/loaders/policies.js +0 -25
  181. package/dist/loaders/policies.js.map +0 -1
  182. package/dist/loaders/policies.mjs +0 -24
  183. package/dist/loaders/policies.mjs.map +0 -1
  184. package/dist/loaders/sanitizers.js +0 -6
  185. package/dist/loaders/sanitizers.js.map +0 -1
  186. package/dist/loaders/sanitizers.mjs +0 -7
  187. package/dist/loaders/sanitizers.mjs.map +0 -1
  188. package/dist/loaders/src-index.js +0 -33
  189. package/dist/loaders/src-index.js.map +0 -1
  190. package/dist/loaders/src-index.mjs +0 -34
  191. package/dist/loaders/src-index.mjs.map +0 -1
  192. package/dist/loaders/validators.js +0 -6
  193. package/dist/loaders/validators.js.map +0 -1
  194. package/dist/loaders/validators.mjs +0 -7
  195. package/dist/loaders/validators.mjs.map +0 -1
  196. package/dist/middlewares/body.js +0 -65
  197. package/dist/middlewares/body.js.map +0 -1
  198. package/dist/middlewares/body.mjs +0 -61
  199. package/dist/middlewares/body.mjs.map +0 -1
  200. package/dist/middlewares/compression.js +0 -8
  201. package/dist/middlewares/compression.js.map +0 -1
  202. package/dist/middlewares/compression.mjs +0 -6
  203. package/dist/middlewares/compression.mjs.map +0 -1
  204. package/dist/middlewares/cors.js +0 -53
  205. package/dist/middlewares/cors.js.map +0 -1
  206. package/dist/middlewares/cors.mjs +0 -51
  207. package/dist/middlewares/cors.mjs.map +0 -1
  208. package/dist/middlewares/errors.js +0 -33
  209. package/dist/middlewares/errors.js.map +0 -1
  210. package/dist/middlewares/errors.mjs +0 -33
  211. package/dist/middlewares/errors.mjs.map +0 -1
  212. package/dist/middlewares/favicon.js +0 -22
  213. package/dist/middlewares/favicon.js.map +0 -1
  214. package/dist/middlewares/favicon.mjs +0 -20
  215. package/dist/middlewares/favicon.mjs.map +0 -1
  216. package/dist/middlewares/index.js +0 -34
  217. package/dist/middlewares/index.js.map +0 -1
  218. package/dist/middlewares/index.mjs +0 -34
  219. package/dist/middlewares/index.mjs.map +0 -1
  220. package/dist/middlewares/ip.js +0 -8
  221. package/dist/middlewares/ip.js.map +0 -1
  222. package/dist/middlewares/ip.mjs +0 -6
  223. package/dist/middlewares/ip.mjs.map +0 -1
  224. package/dist/middlewares/logger.js +0 -12
  225. package/dist/middlewares/logger.js.map +0 -1
  226. package/dist/middlewares/logger.mjs +0 -12
  227. package/dist/middlewares/logger.mjs.map +0 -1
  228. package/dist/middlewares/powered-by.js +0 -14
  229. package/dist/middlewares/powered-by.js.map +0 -1
  230. package/dist/middlewares/powered-by.mjs +0 -14
  231. package/dist/middlewares/powered-by.mjs.map +0 -1
  232. package/dist/middlewares/public.js +0 -34
  233. package/dist/middlewares/public.js.map +0 -1
  234. package/dist/middlewares/public.mjs +0 -32
  235. package/dist/middlewares/public.mjs.map +0 -1
  236. package/dist/middlewares/query.js +0 -40
  237. package/dist/middlewares/query.js.map +0 -1
  238. package/dist/middlewares/query.mjs +0 -38
  239. package/dist/middlewares/query.mjs.map +0 -1
  240. package/dist/middlewares/response-time.js +0 -12
  241. package/dist/middlewares/response-time.js.map +0 -1
  242. package/dist/middlewares/response-time.mjs +0 -12
  243. package/dist/middlewares/response-time.mjs.map +0 -1
  244. package/dist/middlewares/responses.js +0 -15
  245. package/dist/middlewares/responses.js.map +0 -1
  246. package/dist/middlewares/responses.mjs +0 -15
  247. package/dist/middlewares/responses.mjs.map +0 -1
  248. package/dist/middlewares/security.js +0 -78
  249. package/dist/middlewares/security.js.map +0 -1
  250. package/dist/middlewares/security.mjs +0 -76
  251. package/dist/middlewares/security.mjs.map +0 -1
  252. package/dist/middlewares/session.js +0 -30
  253. package/dist/middlewares/session.js.map +0 -1
  254. package/dist/middlewares/session.mjs +0 -28
  255. package/dist/middlewares/session.mjs.map +0 -1
  256. package/dist/migrations/database/5.0.0-discard-drafts.js +0 -94
  257. package/dist/migrations/database/5.0.0-discard-drafts.js.map +0 -1
  258. package/dist/migrations/database/5.0.0-discard-drafts.mjs +0 -94
  259. package/dist/migrations/database/5.0.0-discard-drafts.mjs.map +0 -1
  260. package/dist/migrations/draft-publish.js +0 -42
  261. package/dist/migrations/draft-publish.js.map +0 -1
  262. package/dist/migrations/draft-publish.mjs +0 -42
  263. package/dist/migrations/draft-publish.mjs.map +0 -1
  264. package/dist/migrations/i18n.js +0 -54
  265. package/dist/migrations/i18n.js.map +0 -1
  266. package/dist/migrations/i18n.mjs +0 -54
  267. package/dist/migrations/i18n.mjs.map +0 -1
  268. package/dist/migrations/index.js +0 -15
  269. package/dist/migrations/index.js.map +0 -1
  270. package/dist/migrations/index.mjs +0 -15
  271. package/dist/migrations/index.mjs.map +0 -1
  272. package/dist/providers/admin.js +0 -20
  273. package/dist/providers/admin.js.map +0 -1
  274. package/dist/providers/admin.mjs +0 -21
  275. package/dist/providers/admin.mjs.map +0 -1
  276. package/dist/providers/coreStore.js +0 -11
  277. package/dist/providers/coreStore.js.map +0 -1
  278. package/dist/providers/coreStore.mjs +0 -12
  279. package/dist/providers/coreStore.mjs.map +0 -1
  280. package/dist/providers/cron.js +0 -20
  281. package/dist/providers/cron.js.map +0 -1
  282. package/dist/providers/cron.mjs +0 -21
  283. package/dist/providers/cron.mjs.map +0 -1
  284. package/dist/providers/index.js +0 -11
  285. package/dist/providers/index.js.map +0 -1
  286. package/dist/providers/index.mjs +0 -11
  287. package/dist/providers/index.mjs.map +0 -1
  288. package/dist/providers/provider.js +0 -5
  289. package/dist/providers/provider.js.map +0 -1
  290. package/dist/providers/provider.mjs +0 -5
  291. package/dist/providers/provider.mjs.map +0 -1
  292. package/dist/providers/registries.js +0 -35
  293. package/dist/providers/registries.js.map +0 -1
  294. package/dist/providers/registries.mjs +0 -36
  295. package/dist/providers/registries.mjs.map +0 -1
  296. package/dist/providers/telemetry.js +0 -19
  297. package/dist/providers/telemetry.js.map +0 -1
  298. package/dist/providers/telemetry.mjs +0 -20
  299. package/dist/providers/telemetry.mjs.map +0 -1
  300. package/dist/providers/webhooks.js +0 -30
  301. package/dist/providers/webhooks.js.map +0 -1
  302. package/dist/providers/webhooks.mjs +0 -31
  303. package/dist/providers/webhooks.mjs.map +0 -1
  304. package/dist/registries/apis.js +0 -23
  305. package/dist/registries/apis.js.map +0 -1
  306. package/dist/registries/apis.mjs +0 -24
  307. package/dist/registries/apis.mjs.map +0 -1
  308. package/dist/registries/components.js +0 -45
  309. package/dist/registries/components.js.map +0 -1
  310. package/dist/registries/components.mjs +0 -46
  311. package/dist/registries/components.mjs.map +0 -1
  312. package/dist/registries/content-types.js +0 -70
  313. package/dist/registries/content-types.js.map +0 -1
  314. package/dist/registries/content-types.mjs +0 -71
  315. package/dist/registries/content-types.mjs.map +0 -1
  316. package/dist/registries/controllers.js +0 -80
  317. package/dist/registries/controllers.js.map +0 -1
  318. package/dist/registries/controllers.mjs +0 -81
  319. package/dist/registries/controllers.mjs.map +0 -1
  320. package/dist/registries/custom-fields.js +0 -71
  321. package/dist/registries/custom-fields.js.map +0 -1
  322. package/dist/registries/custom-fields.mjs +0 -72
  323. package/dist/registries/custom-fields.mjs.map +0 -1
  324. package/dist/registries/hooks.js +0 -58
  325. package/dist/registries/hooks.js.map +0 -1
  326. package/dist/registries/hooks.mjs +0 -59
  327. package/dist/registries/hooks.mjs.map +0 -1
  328. package/dist/registries/middlewares.js +0 -60
  329. package/dist/registries/middlewares.js.map +0 -1
  330. package/dist/registries/middlewares.mjs +0 -61
  331. package/dist/registries/middlewares.mjs.map +0 -1
  332. package/dist/registries/models.js +0 -16
  333. package/dist/registries/models.js.map +0 -1
  334. package/dist/registries/models.mjs +0 -16
  335. package/dist/registries/models.mjs.map +0 -1
  336. package/dist/registries/modules.js +0 -39
  337. package/dist/registries/modules.js.map +0 -1
  338. package/dist/registries/modules.mjs +0 -40
  339. package/dist/registries/modules.mjs.map +0 -1
  340. package/dist/registries/namespace.js +0 -27
  341. package/dist/registries/namespace.js.map +0 -1
  342. package/dist/registries/namespace.mjs +0 -27
  343. package/dist/registries/namespace.mjs.map +0 -1
  344. package/dist/registries/plugins.js +0 -23
  345. package/dist/registries/plugins.js.map +0 -1
  346. package/dist/registries/plugins.mjs +0 -24
  347. package/dist/registries/plugins.mjs.map +0 -1
  348. package/dist/registries/policies.js +0 -108
  349. package/dist/registries/policies.js.map +0 -1
  350. package/dist/registries/policies.mjs +0 -109
  351. package/dist/registries/policies.mjs.map +0 -1
  352. package/dist/registries/sanitizers.js +0 -25
  353. package/dist/registries/sanitizers.js.map +0 -1
  354. package/dist/registries/sanitizers.mjs +0 -24
  355. package/dist/registries/sanitizers.mjs.map +0 -1
  356. package/dist/registries/services.js +0 -80
  357. package/dist/registries/services.js.map +0 -1
  358. package/dist/registries/services.mjs +0 -81
  359. package/dist/registries/services.mjs.map +0 -1
  360. package/dist/registries/validators.js +0 -25
  361. package/dist/registries/validators.js.map +0 -1
  362. package/dist/registries/validators.mjs +0 -24
  363. package/dist/registries/validators.mjs.map +0 -1
  364. package/dist/services/auth/index.js +0 -81
  365. package/dist/services/auth/index.js.map +0 -1
  366. package/dist/services/auth/index.mjs +0 -80
  367. package/dist/services/auth/index.mjs.map +0 -1
  368. package/dist/services/config.js +0 -47
  369. package/dist/services/config.js.map +0 -1
  370. package/dist/services/config.mjs +0 -47
  371. package/dist/services/config.mjs.map +0 -1
  372. package/dist/services/content-api/index.js +0 -85
  373. package/dist/services/content-api/index.js.map +0 -1
  374. package/dist/services/content-api/index.mjs +0 -84
  375. package/dist/services/content-api/index.mjs.map +0 -1
  376. package/dist/services/content-api/permissions/engine.js +0 -7
  377. package/dist/services/content-api/permissions/engine.js.map +0 -1
  378. package/dist/services/content-api/permissions/engine.mjs +0 -6
  379. package/dist/services/content-api/permissions/engine.mjs.map +0 -1
  380. package/dist/services/content-api/permissions/index.js +0 -87
  381. package/dist/services/content-api/permissions/index.js.map +0 -1
  382. package/dist/services/content-api/permissions/index.mjs +0 -86
  383. package/dist/services/content-api/permissions/index.mjs.map +0 -1
  384. package/dist/services/content-api/permissions/providers/action.js +0 -16
  385. package/dist/services/content-api/permissions/providers/action.js.map +0 -1
  386. package/dist/services/content-api/permissions/providers/action.mjs +0 -17
  387. package/dist/services/content-api/permissions/providers/action.mjs.map +0 -1
  388. package/dist/services/content-api/permissions/providers/condition.js +0 -16
  389. package/dist/services/content-api/permissions/providers/condition.js.map +0 -1
  390. package/dist/services/content-api/permissions/providers/condition.mjs +0 -17
  391. package/dist/services/content-api/permissions/providers/condition.mjs.map +0 -1
  392. package/dist/services/core-store.js +0 -107
  393. package/dist/services/core-store.js.map +0 -1
  394. package/dist/services/core-store.mjs +0 -107
  395. package/dist/services/core-store.mjs.map +0 -1
  396. package/dist/services/cron.js +0 -63
  397. package/dist/services/cron.js.map +0 -1
  398. package/dist/services/cron.mjs +0 -64
  399. package/dist/services/cron.mjs.map +0 -1
  400. package/dist/services/custom-fields.js +0 -10
  401. package/dist/services/custom-fields.js.map +0 -1
  402. package/dist/services/custom-fields.mjs +0 -11
  403. package/dist/services/custom-fields.mjs.map +0 -1
  404. package/dist/services/document-service/attributes/index.js +0 -22
  405. package/dist/services/document-service/attributes/index.js.map +0 -1
  406. package/dist/services/document-service/attributes/index.mjs +0 -22
  407. package/dist/services/document-service/attributes/index.mjs.map +0 -1
  408. package/dist/services/document-service/attributes/transforms.js +0 -20
  409. package/dist/services/document-service/attributes/transforms.js.map +0 -1
  410. package/dist/services/document-service/attributes/transforms.mjs +0 -19
  411. package/dist/services/document-service/attributes/transforms.mjs.map +0 -1
  412. package/dist/services/document-service/common.js +0 -7
  413. package/dist/services/document-service/common.js.map +0 -1
  414. package/dist/services/document-service/common.mjs +0 -7
  415. package/dist/services/document-service/common.mjs.map +0 -1
  416. package/dist/services/document-service/components.js +0 -288
  417. package/dist/services/document-service/components.js.map +0 -1
  418. package/dist/services/document-service/components.mjs +0 -286
  419. package/dist/services/document-service/components.mjs.map +0 -1
  420. package/dist/services/document-service/draft-and-publish.js +0 -69
  421. package/dist/services/document-service/draft-and-publish.js.map +0 -1
  422. package/dist/services/document-service/draft-and-publish.mjs +0 -69
  423. package/dist/services/document-service/draft-and-publish.mjs.map +0 -1
  424. package/dist/services/document-service/entries.js +0 -96
  425. package/dist/services/document-service/entries.js.map +0 -1
  426. package/dist/services/document-service/entries.mjs +0 -96
  427. package/dist/services/document-service/entries.mjs.map +0 -1
  428. package/dist/services/document-service/events.js +0 -47
  429. package/dist/services/document-service/events.js.map +0 -1
  430. package/dist/services/document-service/events.mjs +0 -47
  431. package/dist/services/document-service/events.mjs.map +0 -1
  432. package/dist/services/document-service/index.js +0 -35
  433. package/dist/services/document-service/index.js.map +0 -1
  434. package/dist/services/document-service/index.mjs +0 -35
  435. package/dist/services/document-service/index.mjs.map +0 -1
  436. package/dist/services/document-service/internationalization.js +0 -63
  437. package/dist/services/document-service/internationalization.js.map +0 -1
  438. package/dist/services/document-service/internationalization.mjs +0 -63
  439. package/dist/services/document-service/internationalization.mjs.map +0 -1
  440. package/dist/services/document-service/middlewares/errors.js +0 -25
  441. package/dist/services/document-service/middlewares/errors.js.map +0 -1
  442. package/dist/services/document-service/middlewares/errors.mjs +0 -25
  443. package/dist/services/document-service/middlewares/errors.mjs.map +0 -1
  444. package/dist/services/document-service/middlewares/middleware-manager.js +0 -49
  445. package/dist/services/document-service/middlewares/middleware-manager.js.map +0 -1
  446. package/dist/services/document-service/middlewares/middleware-manager.mjs +0 -49
  447. package/dist/services/document-service/middlewares/middleware-manager.mjs.map +0 -1
  448. package/dist/services/document-service/params.js +0 -8
  449. package/dist/services/document-service/params.js.map +0 -1
  450. package/dist/services/document-service/params.mjs +0 -8
  451. package/dist/services/document-service/params.mjs.map +0 -1
  452. package/dist/services/document-service/repository.js +0 -324
  453. package/dist/services/document-service/repository.js.map +0 -1
  454. package/dist/services/document-service/repository.mjs +0 -324
  455. package/dist/services/document-service/repository.mjs.map +0 -1
  456. package/dist/services/document-service/transform/data.js +0 -15
  457. package/dist/services/document-service/transform/data.js.map +0 -1
  458. package/dist/services/document-service/transform/data.mjs +0 -15
  459. package/dist/services/document-service/transform/data.mjs.map +0 -1
  460. package/dist/services/document-service/transform/fields.js +0 -24
  461. package/dist/services/document-service/transform/fields.js.map +0 -1
  462. package/dist/services/document-service/transform/fields.mjs +0 -24
  463. package/dist/services/document-service/transform/fields.mjs.map +0 -1
  464. package/dist/services/document-service/transform/id-map.js +0 -78
  465. package/dist/services/document-service/transform/id-map.js.map +0 -1
  466. package/dist/services/document-service/transform/id-map.mjs +0 -78
  467. package/dist/services/document-service/transform/id-map.mjs.map +0 -1
  468. package/dist/services/document-service/transform/id-transform.js +0 -33
  469. package/dist/services/document-service/transform/id-transform.js.map +0 -1
  470. package/dist/services/document-service/transform/id-transform.mjs +0 -33
  471. package/dist/services/document-service/transform/id-transform.mjs.map +0 -1
  472. package/dist/services/document-service/transform/populate.js +0 -21
  473. package/dist/services/document-service/transform/populate.js.map +0 -1
  474. package/dist/services/document-service/transform/populate.mjs +0 -21
  475. package/dist/services/document-service/transform/populate.mjs.map +0 -1
  476. package/dist/services/document-service/transform/query.js +0 -9
  477. package/dist/services/document-service/transform/query.js.map +0 -1
  478. package/dist/services/document-service/transform/query.mjs +0 -9
  479. package/dist/services/document-service/transform/query.mjs.map +0 -1
  480. package/dist/services/document-service/transform/relations/extract/data-ids.js +0 -57
  481. package/dist/services/document-service/transform/relations/extract/data-ids.js.map +0 -1
  482. package/dist/services/document-service/transform/relations/extract/data-ids.mjs +0 -57
  483. package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +0 -1
  484. package/dist/services/document-service/transform/relations/transform/data-ids.js +0 -76
  485. package/dist/services/document-service/transform/relations/transform/data-ids.js.map +0 -1
  486. package/dist/services/document-service/transform/relations/transform/data-ids.mjs +0 -76
  487. package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +0 -1
  488. package/dist/services/document-service/transform/relations/transform/default-locale.js +0 -32
  489. package/dist/services/document-service/transform/relations/transform/default-locale.js.map +0 -1
  490. package/dist/services/document-service/transform/relations/transform/default-locale.mjs +0 -32
  491. package/dist/services/document-service/transform/relations/transform/default-locale.mjs.map +0 -1
  492. package/dist/services/document-service/transform/relations/utils/dp.js +0 -30
  493. package/dist/services/document-service/transform/relations/utils/dp.js.map +0 -1
  494. package/dist/services/document-service/transform/relations/utils/dp.mjs +0 -30
  495. package/dist/services/document-service/transform/relations/utils/dp.mjs.map +0 -1
  496. package/dist/services/document-service/transform/relations/utils/i18n.js +0 -25
  497. package/dist/services/document-service/transform/relations/utils/i18n.js.map +0 -1
  498. package/dist/services/document-service/transform/relations/utils/i18n.mjs +0 -25
  499. package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +0 -1
  500. package/dist/services/document-service/transform/relations/utils/map-relation.js +0 -91
  501. package/dist/services/document-service/transform/relations/utils/map-relation.js.map +0 -1
  502. package/dist/services/document-service/transform/relations/utils/map-relation.mjs +0 -91
  503. package/dist/services/document-service/transform/relations/utils/map-relation.mjs.map +0 -1
  504. package/dist/services/document-service/utils/populate.js +0 -47
  505. package/dist/services/document-service/utils/populate.js.map +0 -1
  506. package/dist/services/document-service/utils/populate.mjs +0 -47
  507. package/dist/services/document-service/utils/populate.mjs.map +0 -1
  508. package/dist/services/document-service/utils/unidirectional-relations.js +0 -65
  509. package/dist/services/document-service/utils/unidirectional-relations.js.map +0 -1
  510. package/dist/services/document-service/utils/unidirectional-relations.mjs +0 -65
  511. package/dist/services/document-service/utils/unidirectional-relations.mjs.map +0 -1
  512. package/dist/services/entity-service/index.js +0 -169
  513. package/dist/services/entity-service/index.js.map +0 -1
  514. package/dist/services/entity-service/index.mjs +0 -167
  515. package/dist/services/entity-service/index.mjs.map +0 -1
  516. package/dist/services/entity-validator/blocks-validator.js +0 -128
  517. package/dist/services/entity-validator/blocks-validator.js.map +0 -1
  518. package/dist/services/entity-validator/blocks-validator.mjs +0 -128
  519. package/dist/services/entity-validator/blocks-validator.mjs.map +0 -1
  520. package/dist/services/entity-validator/index.js +0 -389
  521. package/dist/services/entity-validator/index.js.map +0 -1
  522. package/dist/services/entity-validator/index.mjs +0 -388
  523. package/dist/services/entity-validator/index.mjs.map +0 -1
  524. package/dist/services/entity-validator/validators.js +0 -241
  525. package/dist/services/entity-validator/validators.js.map +0 -1
  526. package/dist/services/entity-validator/validators.mjs +0 -239
  527. package/dist/services/entity-validator/validators.mjs.map +0 -1
  528. package/dist/services/errors.js +0 -76
  529. package/dist/services/errors.js.map +0 -1
  530. package/dist/services/errors.mjs +0 -74
  531. package/dist/services/errors.mjs.map +0 -1
  532. package/dist/services/event-hub.js +0 -72
  533. package/dist/services/event-hub.js.map +0 -1
  534. package/dist/services/event-hub.mjs +0 -73
  535. package/dist/services/event-hub.mjs.map +0 -1
  536. package/dist/services/features.js +0 -17
  537. package/dist/services/features.js.map +0 -1
  538. package/dist/services/features.mjs +0 -17
  539. package/dist/services/features.mjs.map +0 -1
  540. package/dist/services/fs.js +0 -51
  541. package/dist/services/fs.js.map +0 -1
  542. package/dist/services/fs.mjs +0 -49
  543. package/dist/services/fs.mjs.map +0 -1
  544. package/dist/services/metrics/admin-user-hash.js +0 -14
  545. package/dist/services/metrics/admin-user-hash.js.map +0 -1
  546. package/dist/services/metrics/admin-user-hash.mjs +0 -12
  547. package/dist/services/metrics/admin-user-hash.mjs.map +0 -1
  548. package/dist/services/metrics/index.js +0 -45
  549. package/dist/services/metrics/index.js.map +0 -1
  550. package/dist/services/metrics/index.mjs +0 -46
  551. package/dist/services/metrics/index.mjs.map +0 -1
  552. package/dist/services/metrics/is-truthy.js +0 -9
  553. package/dist/services/metrics/is-truthy.js.map +0 -1
  554. package/dist/services/metrics/is-truthy.mjs +0 -8
  555. package/dist/services/metrics/is-truthy.mjs.map +0 -1
  556. package/dist/services/metrics/middleware.js +0 -25
  557. package/dist/services/metrics/middleware.js.map +0 -1
  558. package/dist/services/metrics/middleware.mjs +0 -26
  559. package/dist/services/metrics/middleware.mjs.map +0 -1
  560. package/dist/services/metrics/rate-limiter.js +0 -21
  561. package/dist/services/metrics/rate-limiter.js.map +0 -1
  562. package/dist/services/metrics/rate-limiter.mjs +0 -22
  563. package/dist/services/metrics/rate-limiter.mjs.map +0 -1
  564. package/dist/services/metrics/sender.js +0 -76
  565. package/dist/services/metrics/sender.js.map +0 -1
  566. package/dist/services/metrics/sender.mjs +0 -70
  567. package/dist/services/metrics/sender.mjs.map +0 -1
  568. package/dist/services/query-params.js +0 -12
  569. package/dist/services/query-params.js.map +0 -1
  570. package/dist/services/query-params.mjs +0 -13
  571. package/dist/services/query-params.mjs.map +0 -1
  572. package/dist/services/reloader.js +0 -36
  573. package/dist/services/reloader.js.map +0 -1
  574. package/dist/services/reloader.mjs +0 -36
  575. package/dist/services/reloader.mjs.map +0 -1
  576. package/dist/services/request-context.js +0 -13
  577. package/dist/services/request-context.js.map +0 -1
  578. package/dist/services/request-context.mjs +0 -14
  579. package/dist/services/request-context.mjs.map +0 -1
  580. package/dist/services/server/admin-api.js +0 -13
  581. package/dist/services/server/admin-api.js.map +0 -1
  582. package/dist/services/server/admin-api.mjs +0 -13
  583. package/dist/services/server/admin-api.mjs.map +0 -1
  584. package/dist/services/server/api.js +0 -30
  585. package/dist/services/server/api.js.map +0 -1
  586. package/dist/services/server/api.mjs +0 -28
  587. package/dist/services/server/api.mjs.map +0 -1
  588. package/dist/services/server/compose-endpoint.js +0 -117
  589. package/dist/services/server/compose-endpoint.js.map +0 -1
  590. package/dist/services/server/compose-endpoint.mjs +0 -116
  591. package/dist/services/server/compose-endpoint.mjs.map +0 -1
  592. package/dist/services/server/content-api.js +0 -12
  593. package/dist/services/server/content-api.js.map +0 -1
  594. package/dist/services/server/content-api.mjs +0 -12
  595. package/dist/services/server/content-api.mjs.map +0 -1
  596. package/dist/services/server/http-server.js +0 -50
  597. package/dist/services/server/http-server.js.map +0 -1
  598. package/dist/services/server/http-server.mjs +0 -48
  599. package/dist/services/server/http-server.mjs.map +0 -1
  600. package/dist/services/server/index.js +0 -87
  601. package/dist/services/server/index.js.map +0 -1
  602. package/dist/services/server/index.mjs +0 -85
  603. package/dist/services/server/index.mjs.map +0 -1
  604. package/dist/services/server/koa.js +0 -52
  605. package/dist/services/server/koa.js.map +0 -1
  606. package/dist/services/server/koa.mjs +0 -48
  607. package/dist/services/server/koa.mjs.map +0 -1
  608. package/dist/services/server/middleware.js +0 -92
  609. package/dist/services/server/middleware.js.map +0 -1
  610. package/dist/services/server/middleware.mjs +0 -90
  611. package/dist/services/server/middleware.mjs.map +0 -1
  612. package/dist/services/server/policy.js +0 -20
  613. package/dist/services/server/policy.js.map +0 -1
  614. package/dist/services/server/policy.mjs +0 -20
  615. package/dist/services/server/policy.mjs.map +0 -1
  616. package/dist/services/server/register-middlewares.js +0 -72
  617. package/dist/services/server/register-middlewares.js.map +0 -1
  618. package/dist/services/server/register-middlewares.mjs +0 -73
  619. package/dist/services/server/register-middlewares.mjs.map +0 -1
  620. package/dist/services/server/register-routes.js +0 -76
  621. package/dist/services/server/register-routes.js.map +0 -1
  622. package/dist/services/server/register-routes.mjs +0 -75
  623. package/dist/services/server/register-routes.mjs.map +0 -1
  624. package/dist/services/server/routing.js +0 -91
  625. package/dist/services/server/routing.js.map +0 -1
  626. package/dist/services/server/routing.mjs +0 -89
  627. package/dist/services/server/routing.mjs.map +0 -1
  628. package/dist/services/utils/dynamic-zones.js +0 -17
  629. package/dist/services/utils/dynamic-zones.js.map +0 -1
  630. package/dist/services/utils/dynamic-zones.mjs +0 -18
  631. package/dist/services/utils/dynamic-zones.mjs.map +0 -1
  632. package/dist/services/webhook-runner.js +0 -133
  633. package/dist/services/webhook-runner.js.map +0 -1
  634. package/dist/services/webhook-runner.mjs +0 -131
  635. package/dist/services/webhook-runner.mjs.map +0 -1
  636. package/dist/services/webhook-store.js +0 -110
  637. package/dist/services/webhook-store.js.map +0 -1
  638. package/dist/services/webhook-store.mjs +0 -110
  639. package/dist/services/webhook-store.mjs.map +0 -1
  640. package/dist/services/worker-queue.js +0 -56
  641. package/dist/services/worker-queue.js.map +0 -1
  642. package/dist/services/worker-queue.mjs +0 -55
  643. package/dist/services/worker-queue.mjs.map +0 -1
  644. package/dist/utils/convert-custom-field-type.js +0 -24
  645. package/dist/utils/convert-custom-field-type.js.map +0 -1
  646. package/dist/utils/convert-custom-field-type.mjs +0 -24
  647. package/dist/utils/convert-custom-field-type.mjs.map +0 -1
  648. package/dist/utils/cron.js +0 -38
  649. package/dist/utils/cron.js.map +0 -1
  650. package/dist/utils/cron.mjs +0 -38
  651. package/dist/utils/cron.mjs.map +0 -1
  652. package/dist/utils/fetch.js +0 -21
  653. package/dist/utils/fetch.js.map +0 -1
  654. package/dist/utils/fetch.mjs +0 -21
  655. package/dist/utils/fetch.mjs.map +0 -1
  656. package/dist/utils/filepath-to-prop-path.js +0 -33
  657. package/dist/utils/filepath-to-prop-path.js.map +0 -1
  658. package/dist/utils/filepath-to-prop-path.mjs +0 -30
  659. package/dist/utils/filepath-to-prop-path.mjs.map +0 -1
  660. package/dist/utils/is-initialized.js +0 -16
  661. package/dist/utils/is-initialized.js.map +0 -1
  662. package/dist/utils/is-initialized.mjs +0 -16
  663. package/dist/utils/is-initialized.mjs.map +0 -1
  664. package/dist/utils/lifecycles.js +0 -9
  665. package/dist/utils/lifecycles.js.map +0 -1
  666. package/dist/utils/lifecycles.mjs +0 -9
  667. package/dist/utils/lifecycles.mjs.map +0 -1
  668. package/dist/utils/load-config-file.js +0 -45
  669. package/dist/utils/load-config-file.js.map +0 -1
  670. package/dist/utils/load-config-file.mjs +0 -42
  671. package/dist/utils/load-config-file.mjs.map +0 -1
  672. package/dist/utils/load-files.js +0 -39
  673. package/dist/utils/load-files.js.map +0 -1
  674. package/dist/utils/load-files.mjs +0 -35
  675. package/dist/utils/load-files.mjs.map +0 -1
  676. package/dist/utils/open-browser.js +0 -11
  677. package/dist/utils/open-browser.js.map +0 -1
  678. package/dist/utils/open-browser.mjs +0 -9
  679. package/dist/utils/open-browser.mjs.map +0 -1
  680. package/dist/utils/resolve-working-dirs.js +0 -13
  681. package/dist/utils/resolve-working-dirs.js.map +0 -1
  682. package/dist/utils/resolve-working-dirs.mjs +0 -11
  683. package/dist/utils/resolve-working-dirs.mjs.map +0 -1
  684. package/dist/utils/signals.js +0 -17
  685. package/dist/utils/signals.js.map +0 -1
  686. package/dist/utils/signals.mjs +0 -17
  687. package/dist/utils/signals.mjs.map +0 -1
  688. package/dist/utils/startup-logger.js +0 -81
  689. package/dist/utils/startup-logger.js.map +0 -1
  690. package/dist/utils/startup-logger.mjs +0 -77
  691. package/dist/utils/startup-logger.mjs.map +0 -1
  692. package/dist/utils/transform-content-types-to-models.js +0 -288
  693. package/dist/utils/transform-content-types-to-models.js.map +0 -1
  694. package/dist/utils/transform-content-types-to-models.mjs +0 -285
  695. package/dist/utils/transform-content-types-to-models.mjs.map +0 -1
  696. package/dist/utils/update-notifier/index.js +0 -85
  697. package/dist/utils/update-notifier/index.js.map +0 -1
  698. package/dist/utils/update-notifier/index.mjs +0 -78
  699. package/dist/utils/update-notifier/index.mjs.map +0 -1
@@ -1,30 +0,0 @@
1
- import { isNil } from "lodash/fp";
2
- import { contentTypes } from "@strapi/utils";
3
- const getRelationTargetStatus = (relation, opts) => {
4
- const targetContentType = strapi.getModel(opts.targetUid);
5
- const sourceContentType = strapi.getModel(opts.sourceUid);
6
- const targetHasDP = contentTypes.hasDraftAndPublish(targetContentType);
7
- const sourceHasDP = contentTypes.hasDraftAndPublish(sourceContentType);
8
- if (!targetHasDP) {
9
- return ["published"];
10
- }
11
- if (sourceHasDP && !isNil(opts.sourceStatus)) {
12
- return [opts.sourceStatus];
13
- }
14
- if (relation.status) {
15
- switch (relation.status) {
16
- case "published":
17
- return ["published"];
18
- default:
19
- return ["draft"];
20
- }
21
- }
22
- if (!sourceHasDP) {
23
- return ["draft", "published"];
24
- }
25
- return ["draft"];
26
- };
27
- export {
28
- getRelationTargetStatus
29
- };
30
- //# sourceMappingURL=dp.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"dp.mjs","sources":["../../../../../../src/services/document-service/transform/relations/utils/dp.ts"],"sourcesContent":["import { isNil } from 'lodash/fp';\n\nimport { contentTypes } from '@strapi/utils';\nimport { UID } from '@strapi/types';\n\nimport { LongHandDocument } from './types';\n\ntype Status = 'draft' | 'published';\n\nexport const getRelationTargetStatus = (\n relation: Pick<LongHandDocument, 'documentId' | 'status'>,\n opts: {\n targetUid: UID.Schema;\n sourceUid: UID.Schema;\n sourceStatus?: Status;\n }\n): Status[] => {\n // Ignore if the target content type does not have draft and publish enabled\n const targetContentType = strapi.getModel(opts.targetUid);\n const sourceContentType = strapi.getModel(opts.sourceUid);\n\n const targetHasDP = contentTypes.hasDraftAndPublish(targetContentType);\n const sourceHasDP = contentTypes.hasDraftAndPublish(sourceContentType);\n\n if (!targetHasDP) {\n return ['published'];\n }\n\n /**\n * If both source and target have DP enabled,\n * connect it to the same status as the source status\n */\n if (sourceHasDP && !isNil(opts.sourceStatus)) {\n return [opts.sourceStatus];\n }\n\n /**\n * Use the status from the relation if it's set\n */\n if (relation.status) {\n switch (relation.status) {\n case 'published':\n return ['published'];\n default:\n // Default to draft if it's an invalid status (e.g. modified)\n return ['draft'];\n }\n }\n\n /**\n * If DP is disabled and relation does not specify any status\n * Connect to both draft and published versions\n */\n if (!sourceHasDP) {\n return ['draft', 'published'];\n }\n\n // Default to draft as a fallback\n return ['draft'];\n};\n"],"names":[],"mappings":";;AASa,MAAA,0BAA0B,CACrC,UACA,SAKa;AAEb,QAAM,oBAAoB,OAAO,SAAS,KAAK,SAAS;AACxD,QAAM,oBAAoB,OAAO,SAAS,KAAK,SAAS;AAElD,QAAA,cAAc,aAAa,mBAAmB,iBAAiB;AAC/D,QAAA,cAAc,aAAa,mBAAmB,iBAAiB;AAErE,MAAI,CAAC,aAAa;AAChB,WAAO,CAAC,WAAW;AAAA,EACrB;AAMA,MAAI,eAAe,CAAC,MAAM,KAAK,YAAY,GAAG;AACrC,WAAA,CAAC,KAAK,YAAY;AAAA,EAC3B;AAKA,MAAI,SAAS,QAAQ;AACnB,YAAQ,SAAS,QAAQ;AAAA,MACvB,KAAK;AACH,eAAO,CAAC,WAAW;AAAA,MACrB;AAEE,eAAO,CAAC,OAAO;AAAA,IACnB;AAAA,EACF;AAMA,MAAI,CAAC,aAAa;AACT,WAAA,CAAC,SAAS,WAAW;AAAA,EAC9B;AAGA,SAAO,CAAC,OAAO;AACjB;"}
@@ -1,25 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const isLocalizedContentType = (uid) => {
4
- const model = strapi.getModel(uid);
5
- return strapi.plugin("i18n").service("content-types").isLocalizedContentType(model);
6
- };
7
- const getDefaultLocale = () => {
8
- return strapi.plugin("i18n").service("locales").getDefaultLocale();
9
- };
10
- const getRelationTargetLocale = (relation, opts) => {
11
- const targetLocale = relation.locale || opts.sourceLocale;
12
- const isTargetLocalized = isLocalizedContentType(opts.targetUid);
13
- const isSourceLocalized = isLocalizedContentType(opts.sourceUid);
14
- if (isSourceLocalized && isTargetLocalized) {
15
- return opts.sourceLocale;
16
- }
17
- if (isTargetLocalized) {
18
- return targetLocale;
19
- }
20
- return null;
21
- };
22
- exports.getDefaultLocale = getDefaultLocale;
23
- exports.getRelationTargetLocale = getRelationTargetLocale;
24
- exports.isLocalizedContentType = isLocalizedContentType;
25
- //# sourceMappingURL=i18n.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"i18n.js","sources":["../../../../../../src/services/document-service/transform/relations/utils/i18n.ts"],"sourcesContent":["import { UID } from '@strapi/types';\nimport { LongHandDocument } from './types';\n\nexport const isLocalizedContentType = (uid: UID.Schema) => {\n const model = strapi.getModel(uid);\n return strapi.plugin('i18n').service('content-types').isLocalizedContentType(model);\n};\n\nexport const getDefaultLocale = () => {\n return strapi.plugin('i18n').service('locales').getDefaultLocale();\n};\n\nexport const getRelationTargetLocale = (\n relation: LongHandDocument,\n opts: {\n targetUid: UID.Schema;\n sourceUid: UID.Schema;\n sourceLocale?: string | null;\n }\n) => {\n const targetLocale = relation.locale || opts.sourceLocale;\n\n const isTargetLocalized = isLocalizedContentType(opts.targetUid);\n const isSourceLocalized = isLocalizedContentType(opts.sourceUid);\n\n // Both source and target locales should match\n if (isSourceLocalized && isTargetLocalized) {\n return opts.sourceLocale;\n }\n\n if (isTargetLocalized) {\n return targetLocale;\n }\n\n return null;\n};\n"],"names":[],"mappings":";;AAGa,MAAA,yBAAyB,CAAC,QAAoB;AACnD,QAAA,QAAQ,OAAO,SAAS,GAAG;AAC1B,SAAA,OAAO,OAAO,MAAM,EAAE,QAAQ,eAAe,EAAE,uBAAuB,KAAK;AACpF;AAEO,MAAM,mBAAmB,MAAM;AACpC,SAAO,OAAO,OAAO,MAAM,EAAE,QAAQ,SAAS,EAAE;AAClD;AAEa,MAAA,0BAA0B,CACrC,UACA,SAKG;AACG,QAAA,eAAe,SAAS,UAAU,KAAK;AAEvC,QAAA,oBAAoB,uBAAuB,KAAK,SAAS;AACzD,QAAA,oBAAoB,uBAAuB,KAAK,SAAS;AAG/D,MAAI,qBAAqB,mBAAmB;AAC1C,WAAO,KAAK;AAAA,EACd;AAEA,MAAI,mBAAmB;AACd,WAAA;AAAA,EACT;AAEO,SAAA;AACT;;;;"}
@@ -1,25 +0,0 @@
1
- const isLocalizedContentType = (uid) => {
2
- const model = strapi.getModel(uid);
3
- return strapi.plugin("i18n").service("content-types").isLocalizedContentType(model);
4
- };
5
- const getDefaultLocale = () => {
6
- return strapi.plugin("i18n").service("locales").getDefaultLocale();
7
- };
8
- const getRelationTargetLocale = (relation, opts) => {
9
- const targetLocale = relation.locale || opts.sourceLocale;
10
- const isTargetLocalized = isLocalizedContentType(opts.targetUid);
11
- const isSourceLocalized = isLocalizedContentType(opts.sourceUid);
12
- if (isSourceLocalized && isTargetLocalized) {
13
- return opts.sourceLocale;
14
- }
15
- if (isTargetLocalized) {
16
- return targetLocale;
17
- }
18
- return null;
19
- };
20
- export {
21
- getDefaultLocale,
22
- getRelationTargetLocale,
23
- isLocalizedContentType
24
- };
25
- //# sourceMappingURL=i18n.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"i18n.mjs","sources":["../../../../../../src/services/document-service/transform/relations/utils/i18n.ts"],"sourcesContent":["import { UID } from '@strapi/types';\nimport { LongHandDocument } from './types';\n\nexport const isLocalizedContentType = (uid: UID.Schema) => {\n const model = strapi.getModel(uid);\n return strapi.plugin('i18n').service('content-types').isLocalizedContentType(model);\n};\n\nexport const getDefaultLocale = () => {\n return strapi.plugin('i18n').service('locales').getDefaultLocale();\n};\n\nexport const getRelationTargetLocale = (\n relation: LongHandDocument,\n opts: {\n targetUid: UID.Schema;\n sourceUid: UID.Schema;\n sourceLocale?: string | null;\n }\n) => {\n const targetLocale = relation.locale || opts.sourceLocale;\n\n const isTargetLocalized = isLocalizedContentType(opts.targetUid);\n const isSourceLocalized = isLocalizedContentType(opts.sourceUid);\n\n // Both source and target locales should match\n if (isSourceLocalized && isTargetLocalized) {\n return opts.sourceLocale;\n }\n\n if (isTargetLocalized) {\n return targetLocale;\n }\n\n return null;\n};\n"],"names":[],"mappings":"AAGa,MAAA,yBAAyB,CAAC,QAAoB;AACnD,QAAA,QAAQ,OAAO,SAAS,GAAG;AAC1B,SAAA,OAAO,OAAO,MAAM,EAAE,QAAQ,eAAe,EAAE,uBAAuB,KAAK;AACpF;AAEO,MAAM,mBAAmB,MAAM;AACpC,SAAO,OAAO,OAAO,MAAM,EAAE,QAAQ,SAAS,EAAE;AAClD;AAEa,MAAA,0BAA0B,CACrC,UACA,SAKG;AACG,QAAA,eAAe,SAAS,UAAU,KAAK;AAEvC,QAAA,oBAAoB,uBAAuB,KAAK,SAAS;AACzD,QAAA,oBAAoB,uBAAuB,KAAK,SAAS;AAG/D,MAAI,qBAAqB,mBAAmB;AAC1C,WAAO,KAAK;AAAA,EACd;AAEA,MAAI,mBAAmB;AACd,WAAA;AAAA,EACT;AAEO,SAAA;AACT;"}
@@ -1,91 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const fp = require("lodash/fp");
4
- const strapiUtils = require("@strapi/utils");
5
- const isNumeric = (value) => {
6
- if (Array.isArray(value))
7
- return false;
8
- const parsed = parseInt(value, 10);
9
- return !Number.isNaN(parsed);
10
- };
11
- const toArray = (value) => {
12
- if (fp.isNil(value))
13
- return value;
14
- if (Array.isArray(value))
15
- return value;
16
- return [value];
17
- };
18
- const mapRelation = async (callback, rel, isRecursive = false) => {
19
- let relation = rel;
20
- const wrapInSet = (value) => {
21
- if (isRecursive) {
22
- return value;
23
- }
24
- return { set: toArray(value) };
25
- };
26
- if (fp.isNil(relation)) {
27
- return callback(relation);
28
- }
29
- if (Array.isArray(relation)) {
30
- return strapiUtils.async.map(relation, (r) => mapRelation(callback, r, true)).then((result) => result.flat().filter(Boolean)).then(wrapInSet);
31
- }
32
- if (fp.isObject(relation)) {
33
- if ("id" in relation || "documentId" in relation) {
34
- const result = await callback(relation);
35
- return wrapInSet(result);
36
- }
37
- if (!relation.set && !relation.disconnect && !relation.connect) {
38
- return callback(relation);
39
- }
40
- if (relation.set) {
41
- const set = await mapRelation(callback, relation.set, true);
42
- relation = { ...relation, set: toArray(set) };
43
- }
44
- if (relation.disconnect) {
45
- const disconnect = await mapRelation(callback, relation.disconnect, true);
46
- relation = { ...relation, disconnect: toArray(disconnect) };
47
- }
48
- if (relation.connect) {
49
- const connect = await mapRelation(callback, relation.connect, true);
50
- relation = { ...relation, connect: toArray(connect) };
51
- }
52
- return relation;
53
- }
54
- if (isNumeric(relation)) {
55
- const result = await callback({ id: relation });
56
- return wrapInSet(result);
57
- }
58
- if (typeof relation === "string") {
59
- const result = await callback({ documentId: relation });
60
- return wrapInSet(result);
61
- }
62
- return callback(relation);
63
- };
64
- const traverseEntityRelations = async (visitor, options, data) => {
65
- return strapiUtils.traverseEntity(
66
- async (options2, utils) => {
67
- const { attribute } = options2;
68
- if (!attribute) {
69
- return;
70
- }
71
- if (attribute.type !== "relation") {
72
- return;
73
- }
74
- if (attribute.useJoinTable === false) {
75
- return;
76
- }
77
- const target = attribute.target;
78
- if (!target) {
79
- return;
80
- }
81
- return visitor(options2, utils);
82
- },
83
- options,
84
- data
85
- );
86
- };
87
- const mapRelationCurried = fp.curry(mapRelation);
88
- const traverseEntityRelationsCurried = fp.curry(traverseEntityRelations);
89
- exports.mapRelation = mapRelationCurried;
90
- exports.traverseEntityRelations = traverseEntityRelationsCurried;
91
- //# sourceMappingURL=map-relation.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"map-relation.js","sources":["../../../../../../src/services/document-service/transform/relations/utils/map-relation.ts"],"sourcesContent":["/* eslint-disable node/no-callback-literal */\nimport { isObject, curry, isNil } from 'lodash/fp';\n\nimport type { UID } from '@strapi/types';\nimport { traverseEntity, async } from '@strapi/utils';\n\nimport { Relation } from './types';\n\nconst isNumeric = (value: any): value is number => {\n if (Array.isArray(value)) return false; // Handle [1, 'docId'] case\n const parsed = parseInt(value, 10);\n return !Number.isNaN(parsed);\n};\n\nconst toArray = (value: any) => {\n // Keep value as it is if it's a nullish value\n if (isNil(value)) return value;\n if (Array.isArray(value)) return value;\n\n return [value];\n};\n\n/**\n * There are multiple ways to create Strapi relations.\n * This is a utility to traverse and transform relation data\n *\n *\n * For consistency and ease of use, the response will always be an object with the following shape:\n * { set: [{...}], connect: [{...}], disconnect: [{...}] }\n *\n * @example\n * transformRelationData({\n * onLongHand: (relation) => {\n * // Change the id of the relation\n * return { id: 'other' };\n * },\n * }, relation)\n */\nconst mapRelation = async (\n callback: (relation: any) => any,\n rel: Relation,\n isRecursive = false\n): Promise<Relation> => {\n let relation: Relation = rel;\n\n const wrapInSet = (value: any) => {\n // Ignore wrapping if it's a recursive call\n if (isRecursive) {\n return value;\n }\n return { set: toArray(value) };\n };\n\n // undefined | null\n if (isNil(relation)) {\n return callback(relation);\n }\n\n // LongHand[] | ShortHand[]\n if (Array.isArray(relation)) {\n return async\n .map(relation, (r: Relation) => mapRelation(callback, r, true))\n .then((result: any) => result.flat().filter(Boolean))\n .then(wrapInSet);\n }\n\n // LongHand\n if (isObject(relation)) {\n // { id: 1 } || { documentId: 1 }\n if ('id' in relation || 'documentId' in relation) {\n const result = await callback(relation);\n return wrapInSet(result);\n }\n\n // If not connecting anything, return default visitor\n if (!relation.set && !relation.disconnect && !relation.connect) {\n return callback(relation);\n }\n\n // { set }\n if (relation.set) {\n const set: any = await mapRelation(callback, relation.set, true);\n relation = { ...relation, set: toArray(set) };\n }\n\n // { disconnect}\n if (relation.disconnect) {\n const disconnect: any = await mapRelation(callback, relation.disconnect, true);\n relation = { ...relation, disconnect: toArray(disconnect) };\n }\n\n // { connect }\n if (relation.connect) {\n // Transform the relation to connect\n const connect: any = await mapRelation(callback, relation.connect, true);\n relation = { ...relation, connect: toArray(connect) };\n }\n\n return relation;\n }\n\n // ShortHand\n if (isNumeric(relation)) {\n const result = await callback({ id: relation });\n return wrapInSet(result);\n }\n\n if (typeof relation === 'string') {\n const result = await callback({ documentId: relation });\n return wrapInSet(result);\n }\n\n // Anything else\n return callback(relation);\n};\n\ntype TraverseEntity = Parameters<typeof traverseEntity>;\n\n/**\n * Utility function, same as `traverseEntity` but only for relations.\n */\nconst traverseEntityRelations = async (\n visitor: TraverseEntity[0],\n options: TraverseEntity[1],\n data: TraverseEntity[2]\n) => {\n return traverseEntity(\n async (options, utils) => {\n const { attribute } = options;\n\n if (!attribute) {\n return;\n }\n\n if (attribute.type !== 'relation') {\n return;\n }\n\n // TODO: Handle join columns\n if (attribute.useJoinTable === false) {\n return;\n }\n\n // TODO: Handle morph relations (they have multiple targets)\n const target = attribute.target as UID.Schema | undefined;\n if (!target) {\n return;\n }\n\n return visitor(options, utils);\n },\n options,\n data\n );\n};\n\nconst mapRelationCurried = curry(mapRelation);\nconst traverseEntityRelationsCurried = curry(traverseEntityRelations);\n\nexport {\n mapRelationCurried as mapRelation,\n traverseEntityRelationsCurried as traverseEntityRelations,\n};\n"],"names":["isNil","async","isObject","traverseEntity","options","curry"],"mappings":";;;;AAQA,MAAM,YAAY,CAAC,UAAgC;AAC7C,MAAA,MAAM,QAAQ,KAAK;AAAU,WAAA;AAC3B,QAAA,SAAS,SAAS,OAAO,EAAE;AAC1B,SAAA,CAAC,OAAO,MAAM,MAAM;AAC7B;AAEA,MAAM,UAAU,CAAC,UAAe;AAE9B,MAAIA,GAAAA,MAAM,KAAK;AAAU,WAAA;AACrB,MAAA,MAAM,QAAQ,KAAK;AAAU,WAAA;AAEjC,SAAO,CAAC,KAAK;AACf;AAkBA,MAAM,cAAc,OAClB,UACA,KACA,cAAc,UACQ;AACtB,MAAI,WAAqB;AAEnB,QAAA,YAAY,CAAC,UAAe;AAEhC,QAAI,aAAa;AACR,aAAA;AAAA,IACT;AACA,WAAO,EAAE,KAAK,QAAQ,KAAK,EAAE;AAAA,EAAA;AAI3B,MAAAA,GAAAA,MAAM,QAAQ,GAAG;AACnB,WAAO,SAAS,QAAQ;AAAA,EAC1B;AAGI,MAAA,MAAM,QAAQ,QAAQ,GAAG;AACpB,WAAAC,YAAA,MACJ,IAAI,UAAU,CAAC,MAAgB,YAAY,UAAU,GAAG,IAAI,CAAC,EAC7D,KAAK,CAAC,WAAgB,OAAO,OAAO,OAAO,OAAO,CAAC,EACnD,KAAK,SAAS;AAAA,EACnB;AAGI,MAAAC,GAAAA,SAAS,QAAQ,GAAG;AAElB,QAAA,QAAQ,YAAY,gBAAgB,UAAU;AAC1C,YAAA,SAAS,MAAM,SAAS,QAAQ;AACtC,aAAO,UAAU,MAAM;AAAA,IACzB;AAGI,QAAA,CAAC,SAAS,OAAO,CAAC,SAAS,cAAc,CAAC,SAAS,SAAS;AAC9D,aAAO,SAAS,QAAQ;AAAA,IAC1B;AAGA,QAAI,SAAS,KAAK;AAChB,YAAM,MAAW,MAAM,YAAY,UAAU,SAAS,KAAK,IAAI;AAC/D,iBAAW,EAAE,GAAG,UAAU,KAAK,QAAQ,GAAG;IAC5C;AAGA,QAAI,SAAS,YAAY;AACvB,YAAM,aAAkB,MAAM,YAAY,UAAU,SAAS,YAAY,IAAI;AAC7E,iBAAW,EAAE,GAAG,UAAU,YAAY,QAAQ,UAAU;IAC1D;AAGA,QAAI,SAAS,SAAS;AAEpB,YAAM,UAAe,MAAM,YAAY,UAAU,SAAS,SAAS,IAAI;AACvE,iBAAW,EAAE,GAAG,UAAU,SAAS,QAAQ,OAAO;IACpD;AAEO,WAAA;AAAA,EACT;AAGI,MAAA,UAAU,QAAQ,GAAG;AACvB,UAAM,SAAS,MAAM,SAAS,EAAE,IAAI,SAAU,CAAA;AAC9C,WAAO,UAAU,MAAM;AAAA,EACzB;AAEI,MAAA,OAAO,aAAa,UAAU;AAChC,UAAM,SAAS,MAAM,SAAS,EAAE,YAAY,SAAU,CAAA;AACtD,WAAO,UAAU,MAAM;AAAA,EACzB;AAGA,SAAO,SAAS,QAAQ;AAC1B;AAOA,MAAM,0BAA0B,OAC9B,SACA,SACA,SACG;AACI,SAAAC,YAAA;AAAA,IACL,OAAOC,UAAS,UAAU;AAClB,YAAA,EAAE,UAAcA,IAAAA;AAEtB,UAAI,CAAC,WAAW;AACd;AAAA,MACF;AAEI,UAAA,UAAU,SAAS,YAAY;AACjC;AAAA,MACF;AAGI,UAAA,UAAU,iBAAiB,OAAO;AACpC;AAAA,MACF;AAGA,YAAM,SAAS,UAAU;AACzB,UAAI,CAAC,QAAQ;AACX;AAAA,MACF;AAEO,aAAA,QAAQA,UAAS,KAAK;AAAA,IAC/B;AAAA,IACA;AAAA,IACA;AAAA,EAAA;AAEJ;AAEM,MAAA,qBAAqBC,SAAM,WAAW;AACtC,MAAA,iCAAiCA,SAAM,uBAAuB;;;"}
@@ -1,91 +0,0 @@
1
- import { curry, isNil, isObject } from "lodash/fp";
2
- import { async, traverseEntity } from "@strapi/utils";
3
- const isNumeric = (value) => {
4
- if (Array.isArray(value))
5
- return false;
6
- const parsed = parseInt(value, 10);
7
- return !Number.isNaN(parsed);
8
- };
9
- const toArray = (value) => {
10
- if (isNil(value))
11
- return value;
12
- if (Array.isArray(value))
13
- return value;
14
- return [value];
15
- };
16
- const mapRelation = async (callback, rel, isRecursive = false) => {
17
- let relation = rel;
18
- const wrapInSet = (value) => {
19
- if (isRecursive) {
20
- return value;
21
- }
22
- return { set: toArray(value) };
23
- };
24
- if (isNil(relation)) {
25
- return callback(relation);
26
- }
27
- if (Array.isArray(relation)) {
28
- return async.map(relation, (r) => mapRelation(callback, r, true)).then((result) => result.flat().filter(Boolean)).then(wrapInSet);
29
- }
30
- if (isObject(relation)) {
31
- if ("id" in relation || "documentId" in relation) {
32
- const result = await callback(relation);
33
- return wrapInSet(result);
34
- }
35
- if (!relation.set && !relation.disconnect && !relation.connect) {
36
- return callback(relation);
37
- }
38
- if (relation.set) {
39
- const set = await mapRelation(callback, relation.set, true);
40
- relation = { ...relation, set: toArray(set) };
41
- }
42
- if (relation.disconnect) {
43
- const disconnect = await mapRelation(callback, relation.disconnect, true);
44
- relation = { ...relation, disconnect: toArray(disconnect) };
45
- }
46
- if (relation.connect) {
47
- const connect = await mapRelation(callback, relation.connect, true);
48
- relation = { ...relation, connect: toArray(connect) };
49
- }
50
- return relation;
51
- }
52
- if (isNumeric(relation)) {
53
- const result = await callback({ id: relation });
54
- return wrapInSet(result);
55
- }
56
- if (typeof relation === "string") {
57
- const result = await callback({ documentId: relation });
58
- return wrapInSet(result);
59
- }
60
- return callback(relation);
61
- };
62
- const traverseEntityRelations = async (visitor, options, data) => {
63
- return traverseEntity(
64
- async (options2, utils) => {
65
- const { attribute } = options2;
66
- if (!attribute) {
67
- return;
68
- }
69
- if (attribute.type !== "relation") {
70
- return;
71
- }
72
- if (attribute.useJoinTable === false) {
73
- return;
74
- }
75
- const target = attribute.target;
76
- if (!target) {
77
- return;
78
- }
79
- return visitor(options2, utils);
80
- },
81
- options,
82
- data
83
- );
84
- };
85
- const mapRelationCurried = curry(mapRelation);
86
- const traverseEntityRelationsCurried = curry(traverseEntityRelations);
87
- export {
88
- mapRelationCurried as mapRelation,
89
- traverseEntityRelationsCurried as traverseEntityRelations
90
- };
91
- //# sourceMappingURL=map-relation.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"map-relation.mjs","sources":["../../../../../../src/services/document-service/transform/relations/utils/map-relation.ts"],"sourcesContent":["/* eslint-disable node/no-callback-literal */\nimport { isObject, curry, isNil } from 'lodash/fp';\n\nimport type { UID } from '@strapi/types';\nimport { traverseEntity, async } from '@strapi/utils';\n\nimport { Relation } from './types';\n\nconst isNumeric = (value: any): value is number => {\n if (Array.isArray(value)) return false; // Handle [1, 'docId'] case\n const parsed = parseInt(value, 10);\n return !Number.isNaN(parsed);\n};\n\nconst toArray = (value: any) => {\n // Keep value as it is if it's a nullish value\n if (isNil(value)) return value;\n if (Array.isArray(value)) return value;\n\n return [value];\n};\n\n/**\n * There are multiple ways to create Strapi relations.\n * This is a utility to traverse and transform relation data\n *\n *\n * For consistency and ease of use, the response will always be an object with the following shape:\n * { set: [{...}], connect: [{...}], disconnect: [{...}] }\n *\n * @example\n * transformRelationData({\n * onLongHand: (relation) => {\n * // Change the id of the relation\n * return { id: 'other' };\n * },\n * }, relation)\n */\nconst mapRelation = async (\n callback: (relation: any) => any,\n rel: Relation,\n isRecursive = false\n): Promise<Relation> => {\n let relation: Relation = rel;\n\n const wrapInSet = (value: any) => {\n // Ignore wrapping if it's a recursive call\n if (isRecursive) {\n return value;\n }\n return { set: toArray(value) };\n };\n\n // undefined | null\n if (isNil(relation)) {\n return callback(relation);\n }\n\n // LongHand[] | ShortHand[]\n if (Array.isArray(relation)) {\n return async\n .map(relation, (r: Relation) => mapRelation(callback, r, true))\n .then((result: any) => result.flat().filter(Boolean))\n .then(wrapInSet);\n }\n\n // LongHand\n if (isObject(relation)) {\n // { id: 1 } || { documentId: 1 }\n if ('id' in relation || 'documentId' in relation) {\n const result = await callback(relation);\n return wrapInSet(result);\n }\n\n // If not connecting anything, return default visitor\n if (!relation.set && !relation.disconnect && !relation.connect) {\n return callback(relation);\n }\n\n // { set }\n if (relation.set) {\n const set: any = await mapRelation(callback, relation.set, true);\n relation = { ...relation, set: toArray(set) };\n }\n\n // { disconnect}\n if (relation.disconnect) {\n const disconnect: any = await mapRelation(callback, relation.disconnect, true);\n relation = { ...relation, disconnect: toArray(disconnect) };\n }\n\n // { connect }\n if (relation.connect) {\n // Transform the relation to connect\n const connect: any = await mapRelation(callback, relation.connect, true);\n relation = { ...relation, connect: toArray(connect) };\n }\n\n return relation;\n }\n\n // ShortHand\n if (isNumeric(relation)) {\n const result = await callback({ id: relation });\n return wrapInSet(result);\n }\n\n if (typeof relation === 'string') {\n const result = await callback({ documentId: relation });\n return wrapInSet(result);\n }\n\n // Anything else\n return callback(relation);\n};\n\ntype TraverseEntity = Parameters<typeof traverseEntity>;\n\n/**\n * Utility function, same as `traverseEntity` but only for relations.\n */\nconst traverseEntityRelations = async (\n visitor: TraverseEntity[0],\n options: TraverseEntity[1],\n data: TraverseEntity[2]\n) => {\n return traverseEntity(\n async (options, utils) => {\n const { attribute } = options;\n\n if (!attribute) {\n return;\n }\n\n if (attribute.type !== 'relation') {\n return;\n }\n\n // TODO: Handle join columns\n if (attribute.useJoinTable === false) {\n return;\n }\n\n // TODO: Handle morph relations (they have multiple targets)\n const target = attribute.target as UID.Schema | undefined;\n if (!target) {\n return;\n }\n\n return visitor(options, utils);\n },\n options,\n data\n );\n};\n\nconst mapRelationCurried = curry(mapRelation);\nconst traverseEntityRelationsCurried = curry(traverseEntityRelations);\n\nexport {\n mapRelationCurried as mapRelation,\n traverseEntityRelationsCurried as traverseEntityRelations,\n};\n"],"names":["options"],"mappings":";;AAQA,MAAM,YAAY,CAAC,UAAgC;AAC7C,MAAA,MAAM,QAAQ,KAAK;AAAU,WAAA;AAC3B,QAAA,SAAS,SAAS,OAAO,EAAE;AAC1B,SAAA,CAAC,OAAO,MAAM,MAAM;AAC7B;AAEA,MAAM,UAAU,CAAC,UAAe;AAE9B,MAAI,MAAM,KAAK;AAAU,WAAA;AACrB,MAAA,MAAM,QAAQ,KAAK;AAAU,WAAA;AAEjC,SAAO,CAAC,KAAK;AACf;AAkBA,MAAM,cAAc,OAClB,UACA,KACA,cAAc,UACQ;AACtB,MAAI,WAAqB;AAEnB,QAAA,YAAY,CAAC,UAAe;AAEhC,QAAI,aAAa;AACR,aAAA;AAAA,IACT;AACA,WAAO,EAAE,KAAK,QAAQ,KAAK,EAAE;AAAA,EAAA;AAI3B,MAAA,MAAM,QAAQ,GAAG;AACnB,WAAO,SAAS,QAAQ;AAAA,EAC1B;AAGI,MAAA,MAAM,QAAQ,QAAQ,GAAG;AACpB,WAAA,MACJ,IAAI,UAAU,CAAC,MAAgB,YAAY,UAAU,GAAG,IAAI,CAAC,EAC7D,KAAK,CAAC,WAAgB,OAAO,OAAO,OAAO,OAAO,CAAC,EACnD,KAAK,SAAS;AAAA,EACnB;AAGI,MAAA,SAAS,QAAQ,GAAG;AAElB,QAAA,QAAQ,YAAY,gBAAgB,UAAU;AAC1C,YAAA,SAAS,MAAM,SAAS,QAAQ;AACtC,aAAO,UAAU,MAAM;AAAA,IACzB;AAGI,QAAA,CAAC,SAAS,OAAO,CAAC,SAAS,cAAc,CAAC,SAAS,SAAS;AAC9D,aAAO,SAAS,QAAQ;AAAA,IAC1B;AAGA,QAAI,SAAS,KAAK;AAChB,YAAM,MAAW,MAAM,YAAY,UAAU,SAAS,KAAK,IAAI;AAC/D,iBAAW,EAAE,GAAG,UAAU,KAAK,QAAQ,GAAG;IAC5C;AAGA,QAAI,SAAS,YAAY;AACvB,YAAM,aAAkB,MAAM,YAAY,UAAU,SAAS,YAAY,IAAI;AAC7E,iBAAW,EAAE,GAAG,UAAU,YAAY,QAAQ,UAAU;IAC1D;AAGA,QAAI,SAAS,SAAS;AAEpB,YAAM,UAAe,MAAM,YAAY,UAAU,SAAS,SAAS,IAAI;AACvE,iBAAW,EAAE,GAAG,UAAU,SAAS,QAAQ,OAAO;IACpD;AAEO,WAAA;AAAA,EACT;AAGI,MAAA,UAAU,QAAQ,GAAG;AACvB,UAAM,SAAS,MAAM,SAAS,EAAE,IAAI,SAAU,CAAA;AAC9C,WAAO,UAAU,MAAM;AAAA,EACzB;AAEI,MAAA,OAAO,aAAa,UAAU;AAChC,UAAM,SAAS,MAAM,SAAS,EAAE,YAAY,SAAU,CAAA;AACtD,WAAO,UAAU,MAAM;AAAA,EACzB;AAGA,SAAO,SAAS,QAAQ;AAC1B;AAOA,MAAM,0BAA0B,OAC9B,SACA,SACA,SACG;AACI,SAAA;AAAA,IACL,OAAOA,UAAS,UAAU;AAClB,YAAA,EAAE,UAAcA,IAAAA;AAEtB,UAAI,CAAC,WAAW;AACd;AAAA,MACF;AAEI,UAAA,UAAU,SAAS,YAAY;AACjC;AAAA,MACF;AAGI,UAAA,UAAU,iBAAiB,OAAO;AACpC;AAAA,MACF;AAGA,YAAM,SAAS,UAAU;AACzB,UAAI,CAAC,QAAQ;AACX;AAAA,MACF;AAEO,aAAA,QAAQA,UAAS,KAAK;AAAA,IAC/B;AAAA,IACA;AAAA,IACA;AAAA,EAAA;AAEJ;AAEM,MAAA,qBAAqB,MAAM,WAAW;AACtC,MAAA,iCAAiC,MAAM,uBAAuB;"}
@@ -1,47 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const strapiUtils = require("@strapi/utils");
4
- const { CREATED_BY_ATTRIBUTE, UPDATED_BY_ATTRIBUTE } = strapiUtils.contentTypes.constants;
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
- const isMorphRelation = attribute.relation.toLowerCase().startsWith("morph");
12
- if (isMorphRelation) {
13
- break;
14
- }
15
- const isVisible = strapiUtils.contentTypes.isVisibleAttribute(model, attributeName);
16
- const isCreatorField = [CREATED_BY_ATTRIBUTE, UPDATED_BY_ATTRIBUTE].includes(attributeName);
17
- if (isVisible || isCreatorField) {
18
- acc[attributeName] = { select: opts.relationalFields };
19
- }
20
- break;
21
- }
22
- case "media": {
23
- acc[attributeName] = { select: ["id"] };
24
- break;
25
- }
26
- case "component": {
27
- const populate = getDeepPopulate(attribute.component, opts);
28
- acc[attributeName] = { populate };
29
- break;
30
- }
31
- case "dynamiczone": {
32
- const populatedComponents = (attribute.components || []).reduce(
33
- (acc2, componentUID) => {
34
- acc2[componentUID] = { populate: getDeepPopulate(componentUID, opts) };
35
- return acc2;
36
- },
37
- {}
38
- );
39
- acc[attributeName] = { on: populatedComponents };
40
- break;
41
- }
42
- }
43
- return acc;
44
- }, {});
45
- };
46
- exports.getDeepPopulate = getDeepPopulate;
47
- //# sourceMappingURL=populate.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"populate.js","sources":["../../../../src/services/document-service/utils/populate.ts"],"sourcesContent":["import { UID } from '@strapi/types';\nimport { contentTypes } from '@strapi/utils';\n\ninterface Options {\n /**\n * Fields to select when populating relations\n */\n relationalFields?: string[];\n}\n\nconst { CREATED_BY_ATTRIBUTE, UPDATED_BY_ATTRIBUTE } = contentTypes.constants;\n\n// We want to build a populate object based on the schema\nexport const getDeepPopulate = (uid: UID.Schema, opts: Options = {}) => {\n const model = strapi.getModel(uid);\n const attributes = Object.entries(model.attributes);\n\n return attributes.reduce((acc: any, [attributeName, attribute]) => {\n switch (attribute.type) {\n case 'relation': {\n // TODO: Support polymorphic relations\n const isMorphRelation = attribute.relation.toLowerCase().startsWith('morph');\n if (isMorphRelation) {\n break;\n }\n\n // Ignore not visible fields other than createdBy and updatedBy\n const isVisible = contentTypes.isVisibleAttribute(model, attributeName);\n const isCreatorField = [CREATED_BY_ATTRIBUTE, UPDATED_BY_ATTRIBUTE].includes(attributeName);\n\n if (isVisible || isCreatorField) {\n acc[attributeName] = { select: opts.relationalFields };\n }\n\n break;\n }\n\n case 'media': {\n acc[attributeName] = { select: ['id'] };\n break;\n }\n\n case 'component': {\n const populate = getDeepPopulate(attribute.component, opts);\n acc[attributeName] = { populate };\n break;\n }\n\n case 'dynamiczone': {\n // Use fragments to populate the dynamic zone components\n const populatedComponents = (attribute.components || []).reduce(\n (acc: any, componentUID: UID.Component) => {\n acc[componentUID] = { populate: getDeepPopulate(componentUID, opts) };\n return acc;\n },\n {}\n );\n\n acc[attributeName] = { on: populatedComponents };\n break;\n }\n default:\n break;\n }\n\n return acc;\n }, {});\n};\n"],"names":["contentTypes","acc"],"mappings":";;;AAUA,MAAM,EAAE,sBAAsB,yBAAyBA,YAAAA,aAAa;AAG7D,MAAM,kBAAkB,CAAC,KAAiB,OAAgB,OAAO;AAChE,QAAA,QAAQ,OAAO,SAAS,GAAG;AACjC,QAAM,aAAa,OAAO,QAAQ,MAAM,UAAU;AAElD,SAAO,WAAW,OAAO,CAAC,KAAU,CAAC,eAAe,SAAS,MAAM;AACjE,YAAQ,UAAU,MAAM;AAAA,MACtB,KAAK,YAAY;AAEf,cAAM,kBAAkB,UAAU,SAAS,YAAY,EAAE,WAAW,OAAO;AAC3E,YAAI,iBAAiB;AACnB;AAAA,QACF;AAGA,cAAM,YAAYA,YAAA,aAAa,mBAAmB,OAAO,aAAa;AACtE,cAAM,iBAAiB,CAAC,sBAAsB,oBAAoB,EAAE,SAAS,aAAa;AAE1F,YAAI,aAAa,gBAAgB;AAC/B,cAAI,aAAa,IAAI,EAAE,QAAQ,KAAK,iBAAiB;AAAA,QACvD;AAEA;AAAA,MACF;AAAA,MAEA,KAAK,SAAS;AACZ,YAAI,aAAa,IAAI,EAAE,QAAQ,CAAC,IAAI,EAAE;AACtC;AAAA,MACF;AAAA,MAEA,KAAK,aAAa;AAChB,cAAM,WAAW,gBAAgB,UAAU,WAAW,IAAI;AACtD,YAAA,aAAa,IAAI,EAAE;AACvB;AAAA,MACF;AAAA,MAEA,KAAK,eAAe;AAElB,cAAM,uBAAuB,UAAU,cAAc,CAAI,GAAA;AAAA,UACvD,CAACC,MAAU,iBAAgC;AACzCA,iBAAI,YAAY,IAAI,EAAE,UAAU,gBAAgB,cAAc,IAAI;AAC3DA,mBAAAA;AAAAA,UACT;AAAA,UACA,CAAC;AAAA,QAAA;AAGH,YAAI,aAAa,IAAI,EAAE,IAAI,oBAAoB;AAC/C;AAAA,MACF;AAAA,IAGF;AAEO,WAAA;AAAA,EACT,GAAG,CAAE,CAAA;AACP;;"}
@@ -1,47 +0,0 @@
1
- import { contentTypes } from "@strapi/utils";
2
- const { CREATED_BY_ATTRIBUTE, UPDATED_BY_ATTRIBUTE } = contentTypes.constants;
3
- const getDeepPopulate = (uid, opts = {}) => {
4
- const model = strapi.getModel(uid);
5
- const attributes = Object.entries(model.attributes);
6
- return attributes.reduce((acc, [attributeName, attribute]) => {
7
- switch (attribute.type) {
8
- case "relation": {
9
- const isMorphRelation = attribute.relation.toLowerCase().startsWith("morph");
10
- if (isMorphRelation) {
11
- break;
12
- }
13
- const isVisible = contentTypes.isVisibleAttribute(model, attributeName);
14
- const isCreatorField = [CREATED_BY_ATTRIBUTE, UPDATED_BY_ATTRIBUTE].includes(attributeName);
15
- if (isVisible || isCreatorField) {
16
- acc[attributeName] = { select: opts.relationalFields };
17
- }
18
- break;
19
- }
20
- case "media": {
21
- acc[attributeName] = { select: ["id"] };
22
- break;
23
- }
24
- case "component": {
25
- const populate = getDeepPopulate(attribute.component, opts);
26
- acc[attributeName] = { populate };
27
- break;
28
- }
29
- case "dynamiczone": {
30
- const populatedComponents = (attribute.components || []).reduce(
31
- (acc2, componentUID) => {
32
- acc2[componentUID] = { populate: getDeepPopulate(componentUID, opts) };
33
- return acc2;
34
- },
35
- {}
36
- );
37
- acc[attributeName] = { on: populatedComponents };
38
- break;
39
- }
40
- }
41
- return acc;
42
- }, {});
43
- };
44
- export {
45
- getDeepPopulate
46
- };
47
- //# sourceMappingURL=populate.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"populate.mjs","sources":["../../../../src/services/document-service/utils/populate.ts"],"sourcesContent":["import { UID } from '@strapi/types';\nimport { contentTypes } from '@strapi/utils';\n\ninterface Options {\n /**\n * Fields to select when populating relations\n */\n relationalFields?: string[];\n}\n\nconst { CREATED_BY_ATTRIBUTE, UPDATED_BY_ATTRIBUTE } = contentTypes.constants;\n\n// We want to build a populate object based on the schema\nexport const getDeepPopulate = (uid: UID.Schema, opts: Options = {}) => {\n const model = strapi.getModel(uid);\n const attributes = Object.entries(model.attributes);\n\n return attributes.reduce((acc: any, [attributeName, attribute]) => {\n switch (attribute.type) {\n case 'relation': {\n // TODO: Support polymorphic relations\n const isMorphRelation = attribute.relation.toLowerCase().startsWith('morph');\n if (isMorphRelation) {\n break;\n }\n\n // Ignore not visible fields other than createdBy and updatedBy\n const isVisible = contentTypes.isVisibleAttribute(model, attributeName);\n const isCreatorField = [CREATED_BY_ATTRIBUTE, UPDATED_BY_ATTRIBUTE].includes(attributeName);\n\n if (isVisible || isCreatorField) {\n acc[attributeName] = { select: opts.relationalFields };\n }\n\n break;\n }\n\n case 'media': {\n acc[attributeName] = { select: ['id'] };\n break;\n }\n\n case 'component': {\n const populate = getDeepPopulate(attribute.component, opts);\n acc[attributeName] = { populate };\n break;\n }\n\n case 'dynamiczone': {\n // Use fragments to populate the dynamic zone components\n const populatedComponents = (attribute.components || []).reduce(\n (acc: any, componentUID: UID.Component) => {\n acc[componentUID] = { populate: getDeepPopulate(componentUID, opts) };\n return acc;\n },\n {}\n );\n\n acc[attributeName] = { on: populatedComponents };\n break;\n }\n default:\n break;\n }\n\n return acc;\n }, {});\n};\n"],"names":["acc"],"mappings":";AAUA,MAAM,EAAE,sBAAsB,yBAAyB,aAAa;AAG7D,MAAM,kBAAkB,CAAC,KAAiB,OAAgB,OAAO;AAChE,QAAA,QAAQ,OAAO,SAAS,GAAG;AACjC,QAAM,aAAa,OAAO,QAAQ,MAAM,UAAU;AAElD,SAAO,WAAW,OAAO,CAAC,KAAU,CAAC,eAAe,SAAS,MAAM;AACjE,YAAQ,UAAU,MAAM;AAAA,MACtB,KAAK,YAAY;AAEf,cAAM,kBAAkB,UAAU,SAAS,YAAY,EAAE,WAAW,OAAO;AAC3E,YAAI,iBAAiB;AACnB;AAAA,QACF;AAGA,cAAM,YAAY,aAAa,mBAAmB,OAAO,aAAa;AACtE,cAAM,iBAAiB,CAAC,sBAAsB,oBAAoB,EAAE,SAAS,aAAa;AAE1F,YAAI,aAAa,gBAAgB;AAC/B,cAAI,aAAa,IAAI,EAAE,QAAQ,KAAK,iBAAiB;AAAA,QACvD;AAEA;AAAA,MACF;AAAA,MAEA,KAAK,SAAS;AACZ,YAAI,aAAa,IAAI,EAAE,QAAQ,CAAC,IAAI,EAAE;AACtC;AAAA,MACF;AAAA,MAEA,KAAK,aAAa;AAChB,cAAM,WAAW,gBAAgB,UAAU,WAAW,IAAI;AACtD,YAAA,aAAa,IAAI,EAAE;AACvB;AAAA,MACF;AAAA,MAEA,KAAK,eAAe;AAElB,cAAM,uBAAuB,UAAU,cAAc,CAAI,GAAA;AAAA,UACvD,CAACA,MAAU,iBAAgC;AACzCA,iBAAI,YAAY,IAAI,EAAE,UAAU,gBAAgB,cAAc,IAAI;AAC3DA,mBAAAA;AAAAA,UACT;AAAA,UACA,CAAC;AAAA,QAAA;AAGH,YAAI,aAAa,IAAI,EAAE,IAAI,oBAAoB;AAC/C;AAAA,MACF;AAAA,IAGF;AAEO,WAAA;AAAA,EACT,GAAG,CAAE,CAAA;AACP;"}
@@ -1,65 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const fp = require("lodash/fp");
4
- const load = async (uid, { publishedVersions, draftVersions }) => {
5
- const updates = [];
6
- await strapi.db.transaction(async ({ trx }) => {
7
- const contentTypes = Object.values(strapi.contentTypes);
8
- const components = Object.values(strapi.components);
9
- for (const model of [...contentTypes, ...components]) {
10
- const dbModel = strapi.db.metadata.get(model.uid);
11
- for (const attribute of Object.values(dbModel.attributes)) {
12
- if (attribute.type !== "relation" || attribute.target !== uid || attribute.inversedBy || attribute.mappedBy) {
13
- continue;
14
- }
15
- const joinTable = attribute.joinTable;
16
- if (!joinTable) {
17
- continue;
18
- }
19
- const { name } = joinTable.inverseJoinColumn;
20
- const oldPublishedByLocale = fp.keyBy("locale", publishedVersions);
21
- const oldEntriesIds = publishedVersions.map((entry) => entry.id);
22
- const oldPublishedRelations = await strapi.db.getConnection().select("*").from(joinTable.name).whereIn(name, oldEntriesIds).transacting(trx);
23
- if (oldPublishedRelations.length > 0) {
24
- updates.push({ joinTable, relations: oldPublishedRelations });
25
- }
26
- if (!model.options?.draftAndPublish) {
27
- const oldEntriesIds2 = draftVersions.filter((entry) => {
28
- return !oldPublishedByLocale[entry.locale];
29
- }).map((entry) => entry.id);
30
- const draftRelations = await strapi.db.getConnection().select("*").from(joinTable.name).whereIn(name, oldEntriesIds2).transacting(trx);
31
- if (draftRelations.length > 0) {
32
- updates.push({ joinTable, relations: draftRelations.map(fp.omit("id")) });
33
- }
34
- }
35
- }
36
- }
37
- });
38
- return updates;
39
- };
40
- const sync = async (oldEntries, newEntries, oldRelations) => {
41
- const newEntryByLocale = fp.keyBy("locale", newEntries);
42
- const oldEntriesMap = oldEntries.reduce(
43
- (acc, entry) => {
44
- const newEntry = newEntryByLocale[entry.locale];
45
- if (!newEntry)
46
- return acc;
47
- acc[entry.id] = newEntry.id;
48
- return acc;
49
- },
50
- {}
51
- );
52
- await strapi.db.transaction(async ({ trx }) => {
53
- for (const { joinTable, relations } of oldRelations) {
54
- const column = joinTable.inverseJoinColumn.name;
55
- const newRelations = relations.map((relation) => {
56
- const newId = oldEntriesMap[relation[column]];
57
- return { ...relation, [column]: newId };
58
- });
59
- await trx.batchInsert(joinTable.name, newRelations, 1e3);
60
- }
61
- });
62
- };
63
- exports.load = load;
64
- exports.sync = sync;
65
- //# sourceMappingURL=unidirectional-relations.js.map
@@ -1 +0,0 @@
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 { UID, Schema } from '@strapi/types';\n\ninterface LoadContext {\n publishedVersions: { id: string; locale: string }[];\n draftVersions: { id: string; locale: string }[];\n}\n\n/**\n * Loads lingering relations that need to be updated when overriding a published or draft entry.\n * This is necessary because the relations are uni-directional and the target entry is not aware of the source entry.\n * This is not the case for bi-directional relations, where the target entry is also linked to the source entry.\n */\nconst load = async (uid: UID.ContentType, { publishedVersions, draftVersions }: LoadContext) => {\n const updates = [] as any;\n\n // Iterate all components and content types to find relations that need to be updated\n await strapi.db.transaction(async ({ trx }) => {\n const contentTypes = Object.values(strapi.contentTypes) as Schema.ContentType[];\n const components = Object.values(strapi.components) as Schema.Component[];\n\n for (const model of [...contentTypes, ...components]) {\n const dbModel = strapi.db.metadata.get(model.uid);\n\n for (const attribute of Object.values(dbModel.attributes) as any) {\n /**\n * Only consider unidirectional relations\n */\n if (\n attribute.type !== 'relation' ||\n attribute.target !== uid ||\n attribute.inversedBy ||\n attribute.mappedBy\n ) {\n continue;\n }\n\n // TODO: joinColumn relations\n const joinTable = attribute.joinTable;\n if (!joinTable) {\n continue;\n }\n\n const { name } = joinTable.inverseJoinColumn;\n\n /**\n * Load all relations that need to be updated\n */\n\n const oldPublishedByLocale = keyBy('locale', publishedVersions);\n\n // NOTE: when the model has draft and publish, we can assume relation are only draft to draft & published to published\n const oldEntriesIds = publishedVersions.map((entry) => entry.id);\n\n const oldPublishedRelations = await strapi.db\n .getConnection()\n .select('*')\n .from(joinTable.name)\n .whereIn(name, oldEntriesIds)\n .transacting(trx);\n\n if (oldPublishedRelations.length > 0) {\n updates.push({ joinTable, relations: oldPublishedRelations });\n }\n\n if (!model.options?.draftAndPublish) {\n const oldEntriesIds = draftVersions\n .filter((entry) => {\n return !oldPublishedByLocale[entry.locale];\n })\n .map((entry) => entry.id);\n\n const draftRelations = await strapi.db\n .getConnection()\n .select('*')\n .from(joinTable.name)\n .whereIn(name, oldEntriesIds)\n .transacting(trx);\n\n if (draftRelations.length > 0) {\n updates.push({ joinTable, relations: draftRelations.map(omit('id')) });\n }\n }\n }\n }\n });\n\n return updates;\n};\n\n/**\n * Updates uni directional relations to target the right entries when overriding published or draft entries.\n *\n * @param oldEntries The old entries that are being overridden\n * @param newEntries The new entries that are overriding the old ones\n * @param oldRelations The relations that were previously loaded with `load` @see load\n */\nconst sync = async (\n oldEntries: { id: string; locale: string }[],\n newEntries: { id: string; locale: string }[],\n oldRelations: { joinTable: any; relations: any[]; replace?: boolean }[]\n) => {\n /**\n * Create a map of old entry ids to new entry ids\n *\n * Will be used to update the relation target ids\n */\n const newEntryByLocale = keyBy('locale', newEntries);\n const oldEntriesMap = oldEntries.reduce(\n (acc, entry) => {\n const newEntry = newEntryByLocale[entry.locale];\n if (!newEntry) return acc;\n acc[entry.id] = newEntry.id;\n return acc;\n },\n {} as Record<string, string>\n );\n\n await strapi.db.transaction(async ({ trx }) => {\n // Iterate old relations that are deleted and insert the new ones\n for (const { joinTable, relations } of oldRelations) {\n // Update old ids with the new ones\n const column = joinTable.inverseJoinColumn.name;\n\n const newRelations = relations.map((relation) => {\n const newId = oldEntriesMap[relation[column]];\n return { ...relation, [column]: newId };\n });\n\n // Insert those relations into the join table\n await trx.batchInsert(joinTable.name, newRelations, 1000);\n }\n });\n};\n\nexport { load, sync };\n"],"names":["keyBy","oldEntriesIds","omit"],"mappings":";;;AAeA,MAAM,OAAO,OAAO,KAAsB,EAAE,mBAAmB,oBAAiC;AAC9F,QAAM,UAAU,CAAA;AAGhB,QAAM,OAAO,GAAG,YAAY,OAAO,EAAE,UAAU;AAC7C,UAAM,eAAe,OAAO,OAAO,OAAO,YAAY;AACtD,UAAM,aAAa,OAAO,OAAO,OAAO,UAAU;AAElD,eAAW,SAAS,CAAC,GAAG,cAAc,GAAG,UAAU,GAAG;AACpD,YAAM,UAAU,OAAO,GAAG,SAAS,IAAI,MAAM,GAAG;AAEhD,iBAAW,aAAa,OAAO,OAAO,QAAQ,UAAU,GAAU;AAK9D,YAAA,UAAU,SAAS,cACnB,UAAU,WAAW,OACrB,UAAU,cACV,UAAU,UACV;AACA;AAAA,QACF;AAGA,cAAM,YAAY,UAAU;AAC5B,YAAI,CAAC,WAAW;AACd;AAAA,QACF;AAEM,cAAA,EAAE,KAAK,IAAI,UAAU;AAMrB,cAAA,uBAAuBA,GAAAA,MAAM,UAAU,iBAAiB;AAG9D,cAAM,gBAAgB,kBAAkB,IAAI,CAAC,UAAU,MAAM,EAAE;AAE/D,cAAM,wBAAwB,MAAM,OAAO,GACxC,gBACA,OAAO,GAAG,EACV,KAAK,UAAU,IAAI,EACnB,QAAQ,MAAM,aAAa,EAC3B,YAAY,GAAG;AAEd,YAAA,sBAAsB,SAAS,GAAG;AACpC,kBAAQ,KAAK,EAAE,WAAW,WAAW,sBAAuB,CAAA;AAAA,QAC9D;AAEI,YAAA,CAAC,MAAM,SAAS,iBAAiB;AACnC,gBAAMC,iBAAgB,cACnB,OAAO,CAAC,UAAU;AACV,mBAAA,CAAC,qBAAqB,MAAM,MAAM;AAAA,UAC1C,CAAA,EACA,IAAI,CAAC,UAAU,MAAM,EAAE;AAE1B,gBAAM,iBAAiB,MAAM,OAAO,GACjC,gBACA,OAAO,GAAG,EACV,KAAK,UAAU,IAAI,EACnB,QAAQ,MAAMA,cAAa,EAC3B,YAAY,GAAG;AAEd,cAAA,eAAe,SAAS,GAAG;AACrB,oBAAA,KAAK,EAAE,WAAW,WAAW,eAAe,IAAIC,QAAK,IAAI,CAAC,EAAA,CAAG;AAAA,UACvE;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAAA,EAAA,CACD;AAEM,SAAA;AACT;AASA,MAAM,OAAO,OACX,YACA,YACA,iBACG;AAMG,QAAA,mBAAmBF,GAAAA,MAAM,UAAU,UAAU;AACnD,QAAM,gBAAgB,WAAW;AAAA,IAC/B,CAAC,KAAK,UAAU;AACR,YAAA,WAAW,iBAAiB,MAAM,MAAM;AAC9C,UAAI,CAAC;AAAiB,eAAA;AAClB,UAAA,MAAM,EAAE,IAAI,SAAS;AAClB,aAAA;AAAA,IACT;AAAA,IACA,CAAC;AAAA,EAAA;AAGH,QAAM,OAAO,GAAG,YAAY,OAAO,EAAE,UAAU;AAE7C,eAAW,EAAE,WAAW,UAAU,KAAK,cAAc;AAE7C,YAAA,SAAS,UAAU,kBAAkB;AAE3C,YAAM,eAAe,UAAU,IAAI,CAAC,aAAa;AAC/C,cAAM,QAAQ,cAAc,SAAS,MAAM,CAAC;AAC5C,eAAO,EAAE,GAAG,UAAU,CAAC,MAAM,GAAG,MAAM;AAAA,MAAA,CACvC;AAGD,YAAM,IAAI,YAAY,UAAU,MAAM,cAAc,GAAI;AAAA,IAC1D;AAAA,EAAA,CACD;AACH;;;"}
@@ -1,65 +0,0 @@
1
- import { keyBy, omit } from "lodash/fp";
2
- const load = async (uid, { publishedVersions, draftVersions }) => {
3
- const updates = [];
4
- await strapi.db.transaction(async ({ trx }) => {
5
- const contentTypes = Object.values(strapi.contentTypes);
6
- const components = Object.values(strapi.components);
7
- for (const model of [...contentTypes, ...components]) {
8
- const dbModel = strapi.db.metadata.get(model.uid);
9
- for (const attribute of Object.values(dbModel.attributes)) {
10
- if (attribute.type !== "relation" || attribute.target !== uid || attribute.inversedBy || attribute.mappedBy) {
11
- continue;
12
- }
13
- const joinTable = attribute.joinTable;
14
- if (!joinTable) {
15
- continue;
16
- }
17
- const { name } = joinTable.inverseJoinColumn;
18
- const oldPublishedByLocale = keyBy("locale", publishedVersions);
19
- const oldEntriesIds = publishedVersions.map((entry) => entry.id);
20
- const oldPublishedRelations = await strapi.db.getConnection().select("*").from(joinTable.name).whereIn(name, oldEntriesIds).transacting(trx);
21
- if (oldPublishedRelations.length > 0) {
22
- updates.push({ joinTable, relations: oldPublishedRelations });
23
- }
24
- if (!model.options?.draftAndPublish) {
25
- const oldEntriesIds2 = draftVersions.filter((entry) => {
26
- return !oldPublishedByLocale[entry.locale];
27
- }).map((entry) => entry.id);
28
- const draftRelations = await strapi.db.getConnection().select("*").from(joinTable.name).whereIn(name, oldEntriesIds2).transacting(trx);
29
- if (draftRelations.length > 0) {
30
- updates.push({ joinTable, relations: draftRelations.map(omit("id")) });
31
- }
32
- }
33
- }
34
- }
35
- });
36
- return updates;
37
- };
38
- const sync = async (oldEntries, newEntries, oldRelations) => {
39
- const newEntryByLocale = keyBy("locale", newEntries);
40
- const oldEntriesMap = oldEntries.reduce(
41
- (acc, entry) => {
42
- const newEntry = newEntryByLocale[entry.locale];
43
- if (!newEntry)
44
- return acc;
45
- acc[entry.id] = newEntry.id;
46
- return acc;
47
- },
48
- {}
49
- );
50
- await strapi.db.transaction(async ({ trx }) => {
51
- for (const { joinTable, relations } of oldRelations) {
52
- const column = joinTable.inverseJoinColumn.name;
53
- const newRelations = relations.map((relation) => {
54
- const newId = oldEntriesMap[relation[column]];
55
- return { ...relation, [column]: newId };
56
- });
57
- await trx.batchInsert(joinTable.name, newRelations, 1e3);
58
- }
59
- });
60
- };
61
- export {
62
- load,
63
- sync
64
- };
65
- //# sourceMappingURL=unidirectional-relations.mjs.map
@@ -1 +0,0 @@
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 { UID, Schema } from '@strapi/types';\n\ninterface LoadContext {\n publishedVersions: { id: string; locale: string }[];\n draftVersions: { id: string; locale: string }[];\n}\n\n/**\n * Loads lingering relations that need to be updated when overriding a published or draft entry.\n * This is necessary because the relations are uni-directional and the target entry is not aware of the source entry.\n * This is not the case for bi-directional relations, where the target entry is also linked to the source entry.\n */\nconst load = async (uid: UID.ContentType, { publishedVersions, draftVersions }: LoadContext) => {\n const updates = [] as any;\n\n // Iterate all components and content types to find relations that need to be updated\n await strapi.db.transaction(async ({ trx }) => {\n const contentTypes = Object.values(strapi.contentTypes) as Schema.ContentType[];\n const components = Object.values(strapi.components) as Schema.Component[];\n\n for (const model of [...contentTypes, ...components]) {\n const dbModel = strapi.db.metadata.get(model.uid);\n\n for (const attribute of Object.values(dbModel.attributes) as any) {\n /**\n * Only consider unidirectional relations\n */\n if (\n attribute.type !== 'relation' ||\n attribute.target !== uid ||\n attribute.inversedBy ||\n attribute.mappedBy\n ) {\n continue;\n }\n\n // TODO: joinColumn relations\n const joinTable = attribute.joinTable;\n if (!joinTable) {\n continue;\n }\n\n const { name } = joinTable.inverseJoinColumn;\n\n /**\n * Load all relations that need to be updated\n */\n\n const oldPublishedByLocale = keyBy('locale', publishedVersions);\n\n // NOTE: when the model has draft and publish, we can assume relation are only draft to draft & published to published\n const oldEntriesIds = publishedVersions.map((entry) => entry.id);\n\n const oldPublishedRelations = await strapi.db\n .getConnection()\n .select('*')\n .from(joinTable.name)\n .whereIn(name, oldEntriesIds)\n .transacting(trx);\n\n if (oldPublishedRelations.length > 0) {\n updates.push({ joinTable, relations: oldPublishedRelations });\n }\n\n if (!model.options?.draftAndPublish) {\n const oldEntriesIds = draftVersions\n .filter((entry) => {\n return !oldPublishedByLocale[entry.locale];\n })\n .map((entry) => entry.id);\n\n const draftRelations = await strapi.db\n .getConnection()\n .select('*')\n .from(joinTable.name)\n .whereIn(name, oldEntriesIds)\n .transacting(trx);\n\n if (draftRelations.length > 0) {\n updates.push({ joinTable, relations: draftRelations.map(omit('id')) });\n }\n }\n }\n }\n });\n\n return updates;\n};\n\n/**\n * Updates uni directional relations to target the right entries when overriding published or draft entries.\n *\n * @param oldEntries The old entries that are being overridden\n * @param newEntries The new entries that are overriding the old ones\n * @param oldRelations The relations that were previously loaded with `load` @see load\n */\nconst sync = async (\n oldEntries: { id: string; locale: string }[],\n newEntries: { id: string; locale: string }[],\n oldRelations: { joinTable: any; relations: any[]; replace?: boolean }[]\n) => {\n /**\n * Create a map of old entry ids to new entry ids\n *\n * Will be used to update the relation target ids\n */\n const newEntryByLocale = keyBy('locale', newEntries);\n const oldEntriesMap = oldEntries.reduce(\n (acc, entry) => {\n const newEntry = newEntryByLocale[entry.locale];\n if (!newEntry) return acc;\n acc[entry.id] = newEntry.id;\n return acc;\n },\n {} as Record<string, string>\n );\n\n await strapi.db.transaction(async ({ trx }) => {\n // Iterate old relations that are deleted and insert the new ones\n for (const { joinTable, relations } of oldRelations) {\n // Update old ids with the new ones\n const column = joinTable.inverseJoinColumn.name;\n\n const newRelations = relations.map((relation) => {\n const newId = oldEntriesMap[relation[column]];\n return { ...relation, [column]: newId };\n });\n\n // Insert those relations into the join table\n await trx.batchInsert(joinTable.name, newRelations, 1000);\n }\n });\n};\n\nexport { load, sync };\n"],"names":["oldEntriesIds"],"mappings":";AAeA,MAAM,OAAO,OAAO,KAAsB,EAAE,mBAAmB,oBAAiC;AAC9F,QAAM,UAAU,CAAA;AAGhB,QAAM,OAAO,GAAG,YAAY,OAAO,EAAE,UAAU;AAC7C,UAAM,eAAe,OAAO,OAAO,OAAO,YAAY;AACtD,UAAM,aAAa,OAAO,OAAO,OAAO,UAAU;AAElD,eAAW,SAAS,CAAC,GAAG,cAAc,GAAG,UAAU,GAAG;AACpD,YAAM,UAAU,OAAO,GAAG,SAAS,IAAI,MAAM,GAAG;AAEhD,iBAAW,aAAa,OAAO,OAAO,QAAQ,UAAU,GAAU;AAK9D,YAAA,UAAU,SAAS,cACnB,UAAU,WAAW,OACrB,UAAU,cACV,UAAU,UACV;AACA;AAAA,QACF;AAGA,cAAM,YAAY,UAAU;AAC5B,YAAI,CAAC,WAAW;AACd;AAAA,QACF;AAEM,cAAA,EAAE,KAAK,IAAI,UAAU;AAMrB,cAAA,uBAAuB,MAAM,UAAU,iBAAiB;AAG9D,cAAM,gBAAgB,kBAAkB,IAAI,CAAC,UAAU,MAAM,EAAE;AAE/D,cAAM,wBAAwB,MAAM,OAAO,GACxC,gBACA,OAAO,GAAG,EACV,KAAK,UAAU,IAAI,EACnB,QAAQ,MAAM,aAAa,EAC3B,YAAY,GAAG;AAEd,YAAA,sBAAsB,SAAS,GAAG;AACpC,kBAAQ,KAAK,EAAE,WAAW,WAAW,sBAAuB,CAAA;AAAA,QAC9D;AAEI,YAAA,CAAC,MAAM,SAAS,iBAAiB;AACnC,gBAAMA,iBAAgB,cACnB,OAAO,CAAC,UAAU;AACV,mBAAA,CAAC,qBAAqB,MAAM,MAAM;AAAA,UAC1C,CAAA,EACA,IAAI,CAAC,UAAU,MAAM,EAAE;AAE1B,gBAAM,iBAAiB,MAAM,OAAO,GACjC,gBACA,OAAO,GAAG,EACV,KAAK,UAAU,IAAI,EACnB,QAAQ,MAAMA,cAAa,EAC3B,YAAY,GAAG;AAEd,cAAA,eAAe,SAAS,GAAG;AACrB,oBAAA,KAAK,EAAE,WAAW,WAAW,eAAe,IAAI,KAAK,IAAI,CAAC,EAAA,CAAG;AAAA,UACvE;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAAA,EAAA,CACD;AAEM,SAAA;AACT;AASA,MAAM,OAAO,OACX,YACA,YACA,iBACG;AAMG,QAAA,mBAAmB,MAAM,UAAU,UAAU;AACnD,QAAM,gBAAgB,WAAW;AAAA,IAC/B,CAAC,KAAK,UAAU;AACR,YAAA,WAAW,iBAAiB,MAAM,MAAM;AAC9C,UAAI,CAAC;AAAiB,eAAA;AAClB,UAAA,MAAM,EAAE,IAAI,SAAS;AAClB,aAAA;AAAA,IACT;AAAA,IACA,CAAC;AAAA,EAAA;AAGH,QAAM,OAAO,GAAG,YAAY,OAAO,EAAE,UAAU;AAE7C,eAAW,EAAE,WAAW,UAAU,KAAK,cAAc;AAE7C,YAAA,SAAS,UAAU,kBAAkB;AAE3C,YAAM,eAAe,UAAU,IAAI,CAAC,aAAa;AAC/C,cAAM,QAAQ,cAAc,SAAS,MAAM,CAAC;AAC5C,eAAO,EAAE,GAAG,UAAU,CAAC,MAAM,GAAG,MAAM;AAAA,MAAA,CACvC;AAGD,YAAM,IAAI,YAAY,UAAU,MAAM,cAAc,GAAI;AAAA,IAC1D;AAAA,EAAA,CACD;AACH;"}