@strapi/core 0.0.0-experimental.c592deb623aed3f74ef7fdacfad9757ed59d34f7 → 0.0.0-experimental.c72b48da735f44a3ccafb7a6dc9ba5213f3844db

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 (718) hide show
  1. package/dist/Strapi.d.ts.map +1 -1
  2. package/dist/Strapi.js +427 -403
  3. package/dist/Strapi.js.map +1 -1
  4. package/dist/Strapi.mjs +426 -402
  5. package/dist/Strapi.mjs.map +1 -1
  6. package/dist/compile.js +23 -14
  7. package/dist/compile.js.map +1 -1
  8. package/dist/compile.mjs +22 -14
  9. package/dist/compile.mjs.map +1 -1
  10. package/dist/configuration/config-loader.js +110 -97
  11. package/dist/configuration/config-loader.js.map +1 -1
  12. package/dist/configuration/config-loader.mjs +109 -96
  13. package/dist/configuration/config-loader.mjs.map +1 -1
  14. package/dist/configuration/get-dirs.js +31 -29
  15. package/dist/configuration/get-dirs.js.map +1 -1
  16. package/dist/configuration/get-dirs.mjs +30 -30
  17. package/dist/configuration/get-dirs.mjs.map +1 -1
  18. package/dist/configuration/index.d.ts +1 -0
  19. package/dist/configuration/index.d.ts.map +1 -1
  20. package/dist/configuration/index.js +85 -73
  21. package/dist/configuration/index.js.map +1 -1
  22. package/dist/configuration/index.mjs +84 -69
  23. package/dist/configuration/index.mjs.map +1 -1
  24. package/dist/configuration/urls.d.ts.map +1 -1
  25. package/dist/configuration/urls.js +74 -61
  26. package/dist/configuration/urls.js.map +1 -1
  27. package/dist/configuration/urls.mjs +73 -62
  28. package/dist/configuration/urls.mjs.map +1 -1
  29. package/dist/container.js +27 -23
  30. package/dist/container.js.map +1 -1
  31. package/dist/container.mjs +26 -24
  32. package/dist/container.mjs.map +1 -1
  33. package/dist/core-api/controller/collection-type.js +77 -76
  34. package/dist/core-api/controller/collection-type.js.map +1 -1
  35. package/dist/core-api/controller/collection-type.mjs +76 -77
  36. package/dist/core-api/controller/collection-type.mjs.map +1 -1
  37. package/dist/core-api/controller/index.js +63 -48
  38. package/dist/core-api/controller/index.js.map +1 -1
  39. package/dist/core-api/controller/index.mjs +62 -49
  40. package/dist/core-api/controller/index.mjs.map +1 -1
  41. package/dist/core-api/controller/single-type.js +41 -40
  42. package/dist/core-api/controller/single-type.js.map +1 -1
  43. package/dist/core-api/controller/single-type.mjs +40 -41
  44. package/dist/core-api/controller/single-type.mjs.map +1 -1
  45. package/dist/core-api/controller/transform.js +72 -63
  46. package/dist/core-api/controller/transform.js.map +1 -1
  47. package/dist/core-api/controller/transform.mjs +71 -64
  48. package/dist/core-api/controller/transform.mjs.map +1 -1
  49. package/dist/core-api/routes/index.js +64 -62
  50. package/dist/core-api/routes/index.js.map +1 -1
  51. package/dist/core-api/routes/index.mjs +62 -62
  52. package/dist/core-api/routes/index.mjs.map +1 -1
  53. package/dist/core-api/service/collection-type.js +73 -60
  54. package/dist/core-api/service/collection-type.js.map +1 -1
  55. package/dist/core-api/service/collection-type.mjs +72 -62
  56. package/dist/core-api/service/collection-type.mjs.map +1 -1
  57. package/dist/core-api/service/core-service.js +9 -8
  58. package/dist/core-api/service/core-service.js.map +1 -1
  59. package/dist/core-api/service/core-service.mjs +8 -9
  60. package/dist/core-api/service/core-service.mjs.map +1 -1
  61. package/dist/core-api/service/index.js +13 -13
  62. package/dist/core-api/service/index.js.map +1 -1
  63. package/dist/core-api/service/index.mjs +12 -14
  64. package/dist/core-api/service/index.mjs.map +1 -1
  65. package/dist/core-api/service/pagination.js +69 -43
  66. package/dist/core-api/service/pagination.js.map +1 -1
  67. package/dist/core-api/service/pagination.mjs +68 -47
  68. package/dist/core-api/service/pagination.mjs.map +1 -1
  69. package/dist/core-api/service/single-type.js +43 -39
  70. package/dist/core-api/service/single-type.js.map +1 -1
  71. package/dist/core-api/service/single-type.mjs +42 -41
  72. package/dist/core-api/service/single-type.mjs.map +1 -1
  73. package/dist/domain/content-type/index.js +95 -100
  74. package/dist/domain/content-type/index.js.map +1 -1
  75. package/dist/domain/content-type/index.mjs +94 -100
  76. package/dist/domain/content-type/index.mjs.map +1 -1
  77. package/dist/domain/content-type/validator.js +84 -69
  78. package/dist/domain/content-type/validator.js.map +1 -1
  79. package/dist/domain/content-type/validator.mjs +83 -68
  80. package/dist/domain/content-type/validator.mjs.map +1 -1
  81. package/dist/domain/module/index.js +109 -100
  82. package/dist/domain/module/index.js.map +1 -1
  83. package/dist/domain/module/index.mjs +108 -99
  84. package/dist/domain/module/index.mjs.map +1 -1
  85. package/dist/domain/module/validation.js +25 -20
  86. package/dist/domain/module/validation.js.map +1 -1
  87. package/dist/domain/module/validation.mjs +24 -21
  88. package/dist/domain/module/validation.mjs.map +1 -1
  89. package/dist/ee/index.d.ts +1 -0
  90. package/dist/ee/index.d.ts.map +1 -1
  91. package/dist/ee/index.js +171 -132
  92. package/dist/ee/index.js.map +1 -1
  93. package/dist/ee/index.mjs +170 -134
  94. package/dist/ee/index.mjs.map +1 -1
  95. package/dist/ee/license.d.ts.map +1 -1
  96. package/dist/ee/license.js +100 -75
  97. package/dist/ee/license.js.map +1 -1
  98. package/dist/ee/license.mjs +99 -76
  99. package/dist/ee/license.mjs.map +1 -1
  100. package/dist/factories.js +72 -67
  101. package/dist/factories.js.map +1 -1
  102. package/dist/factories.mjs +71 -71
  103. package/dist/factories.mjs.map +1 -1
  104. package/dist/index.js +29 -26
  105. package/dist/index.js.map +1 -1
  106. package/dist/index.mjs +29 -29
  107. package/dist/index.mjs.map +1 -1
  108. package/dist/loaders/admin.d.ts.map +1 -1
  109. package/dist/loaders/admin.js +21 -20
  110. package/dist/loaders/admin.js.map +1 -1
  111. package/dist/loaders/admin.mjs +20 -20
  112. package/dist/loaders/admin.mjs.map +1 -1
  113. package/dist/loaders/apis.js +143 -120
  114. package/dist/loaders/apis.js.map +1 -1
  115. package/dist/loaders/apis.mjs +142 -119
  116. package/dist/loaders/apis.mjs.map +1 -1
  117. package/dist/loaders/components.js +33 -34
  118. package/dist/loaders/components.js.map +1 -1
  119. package/dist/loaders/components.mjs +32 -34
  120. package/dist/loaders/components.mjs.map +1 -1
  121. package/dist/loaders/index.js +22 -20
  122. package/dist/loaders/index.js.map +1 -1
  123. package/dist/loaders/index.mjs +21 -21
  124. package/dist/loaders/index.mjs.map +1 -1
  125. package/dist/loaders/middlewares.js +29 -25
  126. package/dist/loaders/middlewares.js.map +1 -1
  127. package/dist/loaders/middlewares.mjs +28 -25
  128. package/dist/loaders/middlewares.mjs.map +1 -1
  129. package/dist/loaders/plugins/get-enabled-plugins.js +126 -131
  130. package/dist/loaders/plugins/get-enabled-plugins.js.map +1 -1
  131. package/dist/loaders/plugins/get-enabled-plugins.mjs +125 -108
  132. package/dist/loaders/plugins/get-enabled-plugins.mjs.map +1 -1
  133. package/dist/loaders/plugins/get-user-plugins-config.js +25 -24
  134. package/dist/loaders/plugins/get-user-plugins-config.js.map +1 -1
  135. package/dist/loaders/plugins/get-user-plugins-config.mjs +24 -23
  136. package/dist/loaders/plugins/get-user-plugins-config.mjs.map +1 -1
  137. package/dist/loaders/plugins/index.js +132 -122
  138. package/dist/loaders/plugins/index.js.map +1 -1
  139. package/dist/loaders/plugins/index.mjs +121 -112
  140. package/dist/loaders/plugins/index.mjs.map +1 -1
  141. package/dist/loaders/policies.js +24 -20
  142. package/dist/loaders/policies.js.map +1 -1
  143. package/dist/loaders/policies.mjs +23 -20
  144. package/dist/loaders/policies.mjs.map +1 -1
  145. package/dist/loaders/sanitizers.js +10 -4
  146. package/dist/loaders/sanitizers.js.map +1 -1
  147. package/dist/loaders/sanitizers.mjs +9 -6
  148. package/dist/loaders/sanitizers.mjs.map +1 -1
  149. package/dist/loaders/src-index.js +35 -27
  150. package/dist/loaders/src-index.js.map +1 -1
  151. package/dist/loaders/src-index.mjs +34 -29
  152. package/dist/loaders/src-index.mjs.map +1 -1
  153. package/dist/loaders/validators.js +9 -4
  154. package/dist/loaders/validators.js.map +1 -1
  155. package/dist/loaders/validators.mjs +8 -6
  156. package/dist/loaders/validators.mjs.map +1 -1
  157. package/dist/middlewares/body.d.ts.map +1 -1
  158. package/dist/middlewares/body.js +58 -54
  159. package/dist/middlewares/body.js.map +1 -1
  160. package/dist/middlewares/body.mjs +57 -51
  161. package/dist/middlewares/body.mjs.map +1 -1
  162. package/dist/middlewares/compression.js +6 -6
  163. package/dist/middlewares/compression.js.map +1 -1
  164. package/dist/middlewares/compression.mjs +5 -5
  165. package/dist/middlewares/compression.mjs.map +1 -1
  166. package/dist/middlewares/cors.js +59 -48
  167. package/dist/middlewares/cors.js.map +1 -1
  168. package/dist/middlewares/cors.mjs +58 -47
  169. package/dist/middlewares/cors.mjs.map +1 -1
  170. package/dist/middlewares/errors.js +32 -30
  171. package/dist/middlewares/errors.js.map +1 -1
  172. package/dist/middlewares/errors.mjs +31 -31
  173. package/dist/middlewares/errors.mjs.map +1 -1
  174. package/dist/middlewares/favicon.js +27 -17
  175. package/dist/middlewares/favicon.js.map +1 -1
  176. package/dist/middlewares/favicon.mjs +26 -16
  177. package/dist/middlewares/favicon.mjs.map +1 -1
  178. package/dist/middlewares/index.js +32 -30
  179. package/dist/middlewares/index.js.map +1 -1
  180. package/dist/middlewares/index.mjs +31 -31
  181. package/dist/middlewares/index.mjs.map +1 -1
  182. package/dist/middlewares/ip.js +6 -6
  183. package/dist/middlewares/ip.js.map +1 -1
  184. package/dist/middlewares/ip.mjs +5 -5
  185. package/dist/middlewares/ip.mjs.map +1 -1
  186. package/dist/middlewares/logger.js +10 -9
  187. package/dist/middlewares/logger.js.map +1 -1
  188. package/dist/middlewares/logger.mjs +9 -10
  189. package/dist/middlewares/logger.mjs.map +1 -1
  190. package/dist/middlewares/powered-by.js +13 -9
  191. package/dist/middlewares/powered-by.js.map +1 -1
  192. package/dist/middlewares/powered-by.mjs +12 -10
  193. package/dist/middlewares/powered-by.mjs.map +1 -1
  194. package/dist/middlewares/public.js +33 -29
  195. package/dist/middlewares/public.js.map +1 -1
  196. package/dist/middlewares/public.mjs +32 -28
  197. package/dist/middlewares/public.mjs.map +1 -1
  198. package/dist/middlewares/query.js +35 -32
  199. package/dist/middlewares/query.js.map +1 -1
  200. package/dist/middlewares/query.mjs +34 -31
  201. package/dist/middlewares/query.mjs.map +1 -1
  202. package/dist/middlewares/response-time.js +10 -9
  203. package/dist/middlewares/response-time.js.map +1 -1
  204. package/dist/middlewares/response-time.mjs +9 -10
  205. package/dist/middlewares/response-time.mjs.map +1 -1
  206. package/dist/middlewares/responses.js +14 -12
  207. package/dist/middlewares/responses.js.map +1 -1
  208. package/dist/middlewares/responses.mjs +13 -13
  209. package/dist/middlewares/responses.mjs.map +1 -1
  210. package/dist/middlewares/security.js +109 -71
  211. package/dist/middlewares/security.js.map +1 -1
  212. package/dist/middlewares/security.mjs +108 -70
  213. package/dist/middlewares/security.mjs.map +1 -1
  214. package/dist/middlewares/session.js +26 -25
  215. package/dist/middlewares/session.js.map +1 -1
  216. package/dist/middlewares/session.mjs +25 -24
  217. package/dist/middlewares/session.mjs.map +1 -1
  218. package/dist/migrations/database/5.0.0-discard-drafts.d.ts +2 -2
  219. package/dist/migrations/database/5.0.0-discard-drafts.d.ts.map +1 -1
  220. package/dist/migrations/database/5.0.0-discard-drafts.js +154 -80
  221. package/dist/migrations/database/5.0.0-discard-drafts.js.map +1 -1
  222. package/dist/migrations/database/5.0.0-discard-drafts.mjs +153 -82
  223. package/dist/migrations/database/5.0.0-discard-drafts.mjs.map +1 -1
  224. package/dist/migrations/draft-publish.d.ts +2 -2
  225. package/dist/migrations/draft-publish.d.ts.map +1 -1
  226. package/dist/migrations/draft-publish.js +61 -34
  227. package/dist/migrations/draft-publish.js.map +1 -1
  228. package/dist/migrations/draft-publish.mjs +60 -36
  229. package/dist/migrations/draft-publish.mjs.map +1 -1
  230. package/dist/migrations/i18n.d.ts +5 -0
  231. package/dist/migrations/i18n.d.ts.map +1 -0
  232. package/dist/migrations/i18n.js +71 -0
  233. package/dist/migrations/i18n.js.map +1 -0
  234. package/dist/migrations/i18n.mjs +68 -0
  235. package/dist/migrations/i18n.mjs.map +1 -0
  236. package/dist/migrations/index.d.ts +5 -0
  237. package/dist/migrations/index.d.ts.map +1 -0
  238. package/dist/migrations/index.js +29 -0
  239. package/dist/migrations/index.js.map +1 -0
  240. package/dist/migrations/index.mjs +26 -0
  241. package/dist/migrations/index.mjs.map +1 -0
  242. package/dist/package.json.js +182 -0
  243. package/dist/package.json.js.map +1 -0
  244. package/dist/package.json.mjs +159 -0
  245. package/dist/package.json.mjs.map +1 -0
  246. package/dist/providers/admin.js +27 -17
  247. package/dist/providers/admin.js.map +1 -1
  248. package/dist/providers/admin.mjs +26 -19
  249. package/dist/providers/admin.mjs.map +1 -1
  250. package/dist/providers/coreStore.js +13 -8
  251. package/dist/providers/coreStore.js.map +1 -1
  252. package/dist/providers/coreStore.mjs +12 -10
  253. package/dist/providers/coreStore.mjs.map +1 -1
  254. package/dist/providers/cron.js +19 -16
  255. package/dist/providers/cron.js.map +1 -1
  256. package/dist/providers/cron.mjs +18 -18
  257. package/dist/providers/cron.mjs.map +1 -1
  258. package/dist/providers/index.js +18 -9
  259. package/dist/providers/index.js.map +1 -1
  260. package/dist/providers/index.mjs +17 -10
  261. package/dist/providers/index.mjs.map +1 -1
  262. package/dist/providers/provider.js +4 -3
  263. package/dist/providers/provider.js.map +1 -1
  264. package/dist/providers/provider.mjs +3 -4
  265. package/dist/providers/provider.mjs.map +1 -1
  266. package/dist/providers/registries.js +37 -32
  267. package/dist/providers/registries.js.map +1 -1
  268. package/dist/providers/registries.mjs +36 -34
  269. package/dist/providers/registries.mjs.map +1 -1
  270. package/dist/providers/telemetry.js +19 -16
  271. package/dist/providers/telemetry.js.map +1 -1
  272. package/dist/providers/telemetry.mjs +18 -18
  273. package/dist/providers/telemetry.mjs.map +1 -1
  274. package/dist/providers/webhooks.js +28 -26
  275. package/dist/providers/webhooks.js.map +1 -1
  276. package/dist/providers/webhooks.mjs +27 -28
  277. package/dist/providers/webhooks.mjs.map +1 -1
  278. package/dist/registries/apis.js +23 -20
  279. package/dist/registries/apis.js.map +1 -1
  280. package/dist/registries/apis.mjs +22 -22
  281. package/dist/registries/apis.mjs.map +1 -1
  282. package/dist/registries/components.js +35 -37
  283. package/dist/registries/components.js.map +1 -1
  284. package/dist/registries/components.mjs +34 -39
  285. package/dist/registries/components.mjs.map +1 -1
  286. package/dist/registries/content-types.js +54 -59
  287. package/dist/registries/content-types.js.map +1 -1
  288. package/dist/registries/content-types.mjs +53 -61
  289. package/dist/registries/content-types.mjs.map +1 -1
  290. package/dist/registries/controllers.js +70 -71
  291. package/dist/registries/controllers.js.map +1 -1
  292. package/dist/registries/controllers.mjs +69 -73
  293. package/dist/registries/controllers.mjs.map +1 -1
  294. package/dist/registries/custom-fields.js +75 -65
  295. package/dist/registries/custom-fields.js.map +1 -1
  296. package/dist/registries/custom-fields.mjs +74 -67
  297. package/dist/registries/custom-fields.mjs.map +1 -1
  298. package/dist/registries/hooks.js +46 -49
  299. package/dist/registries/hooks.js.map +1 -1
  300. package/dist/registries/hooks.mjs +45 -51
  301. package/dist/registries/hooks.mjs.map +1 -1
  302. package/dist/registries/middlewares.js +49 -51
  303. package/dist/registries/middlewares.js.map +1 -1
  304. package/dist/registries/middlewares.mjs +48 -53
  305. package/dist/registries/middlewares.mjs.map +1 -1
  306. package/dist/registries/models.js +14 -13
  307. package/dist/registries/models.js.map +1 -1
  308. package/dist/registries/models.mjs +13 -14
  309. package/dist/registries/models.mjs.map +1 -1
  310. package/dist/registries/modules.js +39 -36
  311. package/dist/registries/modules.js.map +1 -1
  312. package/dist/registries/modules.mjs +38 -38
  313. package/dist/registries/modules.mjs.map +1 -1
  314. package/dist/registries/namespace.js +21 -20
  315. package/dist/registries/namespace.js.map +1 -1
  316. package/dist/registries/namespace.mjs +20 -23
  317. package/dist/registries/namespace.mjs.map +1 -1
  318. package/dist/registries/plugins.js +23 -20
  319. package/dist/registries/plugins.js.map +1 -1
  320. package/dist/registries/plugins.mjs +22 -22
  321. package/dist/registries/plugins.mjs.map +1 -1
  322. package/dist/registries/policies.js +103 -96
  323. package/dist/registries/policies.js.map +1 -1
  324. package/dist/registries/policies.mjs +102 -98
  325. package/dist/registries/policies.mjs.map +1 -1
  326. package/dist/registries/sanitizers.js +23 -22
  327. package/dist/registries/sanitizers.js.map +1 -1
  328. package/dist/registries/sanitizers.mjs +22 -22
  329. package/dist/registries/sanitizers.mjs.map +1 -1
  330. package/dist/registries/services.js +71 -71
  331. package/dist/registries/services.js.map +1 -1
  332. package/dist/registries/services.mjs +70 -73
  333. package/dist/registries/services.mjs.map +1 -1
  334. package/dist/registries/validators.js +23 -22
  335. package/dist/registries/validators.js.map +1 -1
  336. package/dist/registries/validators.mjs +22 -22
  337. package/dist/registries/validators.mjs.map +1 -1
  338. package/dist/services/auth/index.js +74 -74
  339. package/dist/services/auth/index.js.map +1 -1
  340. package/dist/services/auth/index.mjs +73 -74
  341. package/dist/services/auth/index.mjs.map +1 -1
  342. package/dist/services/config.js +47 -43
  343. package/dist/services/config.js.map +1 -1
  344. package/dist/services/config.mjs +46 -44
  345. package/dist/services/config.mjs.map +1 -1
  346. package/dist/services/content-api/index.js +80 -79
  347. package/dist/services/content-api/index.js.map +1 -1
  348. package/dist/services/content-api/index.mjs +79 -79
  349. package/dist/services/content-api/index.mjs.map +1 -1
  350. package/dist/services/content-api/permissions/engine.js +8 -5
  351. package/dist/services/content-api/permissions/engine.js.map +1 -1
  352. package/dist/services/content-api/permissions/engine.mjs +7 -5
  353. package/dist/services/content-api/permissions/engine.mjs.map +1 -1
  354. package/dist/services/content-api/permissions/index.js +101 -81
  355. package/dist/services/content-api/permissions/index.js.map +1 -1
  356. package/dist/services/content-api/permissions/index.mjs +100 -81
  357. package/dist/services/content-api/permissions/index.mjs.map +1 -1
  358. package/dist/services/content-api/permissions/providers/action.js +17 -14
  359. package/dist/services/content-api/permissions/providers/action.js.map +1 -1
  360. package/dist/services/content-api/permissions/providers/action.mjs +16 -16
  361. package/dist/services/content-api/permissions/providers/action.mjs.map +1 -1
  362. package/dist/services/content-api/permissions/providers/condition.js +17 -14
  363. package/dist/services/content-api/permissions/providers/condition.js.map +1 -1
  364. package/dist/services/content-api/permissions/providers/condition.mjs +16 -16
  365. package/dist/services/content-api/permissions/providers/condition.mjs.map +1 -1
  366. package/dist/services/core-store.js +115 -95
  367. package/dist/services/core-store.js.map +1 -1
  368. package/dist/services/core-store.mjs +114 -97
  369. package/dist/services/core-store.mjs.map +1 -1
  370. package/dist/services/cron.js +74 -60
  371. package/dist/services/cron.js.map +1 -1
  372. package/dist/services/cron.mjs +73 -62
  373. package/dist/services/cron.mjs.map +1 -1
  374. package/dist/services/custom-fields.js +9 -7
  375. package/dist/services/custom-fields.js.map +1 -1
  376. package/dist/services/custom-fields.mjs +8 -9
  377. package/dist/services/custom-fields.mjs.map +1 -1
  378. package/dist/services/document-service/attributes/index.js +23 -18
  379. package/dist/services/document-service/attributes/index.js.map +1 -1
  380. package/dist/services/document-service/attributes/index.mjs +22 -19
  381. package/dist/services/document-service/attributes/index.mjs.map +1 -1
  382. package/dist/services/document-service/attributes/transforms.js +16 -15
  383. package/dist/services/document-service/attributes/transforms.js.map +1 -1
  384. package/dist/services/document-service/attributes/transforms.mjs +15 -15
  385. package/dist/services/document-service/attributes/transforms.mjs.map +1 -1
  386. package/dist/services/document-service/common.d.ts +1 -1
  387. package/dist/services/document-service/common.d.ts.map +1 -1
  388. package/dist/services/document-service/common.js +5 -4
  389. package/dist/services/document-service/common.js.map +1 -1
  390. package/dist/services/document-service/common.mjs +4 -5
  391. package/dist/services/document-service/common.mjs.map +1 -1
  392. package/dist/services/document-service/components.d.ts.map +1 -1
  393. package/dist/services/document-service/components.js +255 -257
  394. package/dist/services/document-service/components.js.map +1 -1
  395. package/dist/services/document-service/components.mjs +254 -262
  396. package/dist/services/document-service/components.mjs.map +1 -1
  397. package/dist/services/document-service/draft-and-publish.d.ts +1 -1
  398. package/dist/services/document-service/draft-and-publish.d.ts.map +1 -1
  399. package/dist/services/document-service/draft-and-publish.js +88 -48
  400. package/dist/services/document-service/draft-and-publish.js.map +1 -1
  401. package/dist/services/document-service/draft-and-publish.mjs +87 -54
  402. package/dist/services/document-service/draft-and-publish.mjs.map +1 -1
  403. package/dist/services/document-service/entries.d.ts +2 -2
  404. package/dist/services/document-service/entries.d.ts.map +1 -1
  405. package/dist/services/document-service/entries.js +109 -92
  406. package/dist/services/document-service/entries.js.map +1 -1
  407. package/dist/services/document-service/entries.mjs +108 -93
  408. package/dist/services/document-service/entries.mjs.map +1 -1
  409. package/dist/services/document-service/events.d.ts +1 -1
  410. package/dist/services/document-service/events.d.ts.map +1 -1
  411. package/dist/services/document-service/events.js +52 -40
  412. package/dist/services/document-service/events.js.map +1 -1
  413. package/dist/services/document-service/events.mjs +51 -41
  414. package/dist/services/document-service/events.mjs.map +1 -1
  415. package/dist/services/document-service/index.d.ts +2 -1
  416. package/dist/services/document-service/index.d.ts.map +1 -1
  417. package/dist/services/document-service/index.js +53 -32
  418. package/dist/services/document-service/index.js.map +1 -1
  419. package/dist/services/document-service/index.mjs +52 -33
  420. package/dist/services/document-service/index.mjs.map +1 -1
  421. package/dist/services/document-service/internationalization.js +62 -46
  422. package/dist/services/document-service/internationalization.js.map +1 -1
  423. package/dist/services/document-service/internationalization.mjs +61 -50
  424. package/dist/services/document-service/internationalization.mjs.map +1 -1
  425. package/dist/services/document-service/middlewares/errors.js +23 -19
  426. package/dist/services/document-service/middlewares/errors.js.map +1 -1
  427. package/dist/services/document-service/middlewares/errors.mjs +22 -20
  428. package/dist/services/document-service/middlewares/errors.mjs.map +1 -1
  429. package/dist/services/document-service/middlewares/middleware-manager.js +46 -44
  430. package/dist/services/document-service/middlewares/middleware-manager.js.map +1 -1
  431. package/dist/services/document-service/middlewares/middleware-manager.mjs +45 -45
  432. package/dist/services/document-service/middlewares/middleware-manager.mjs.map +1 -1
  433. package/dist/services/document-service/params.js +11 -5
  434. package/dist/services/document-service/params.js.map +1 -1
  435. package/dist/services/document-service/params.mjs +10 -6
  436. package/dist/services/document-service/params.mjs.map +1 -1
  437. package/dist/services/document-service/repository.d.ts.map +1 -1
  438. package/dist/services/document-service/repository.js +354 -304
  439. package/dist/services/document-service/repository.js.map +1 -1
  440. package/dist/services/document-service/repository.mjs +353 -305
  441. package/dist/services/document-service/repository.mjs.map +1 -1
  442. package/dist/services/document-service/transform/data.js +22 -12
  443. package/dist/services/document-service/transform/data.js.map +1 -1
  444. package/dist/services/document-service/transform/data.mjs +21 -13
  445. package/dist/services/document-service/transform/data.mjs.map +1 -1
  446. package/dist/services/document-service/transform/fields.js +26 -17
  447. package/dist/services/document-service/transform/fields.js.map +1 -1
  448. package/dist/services/document-service/transform/fields.mjs +25 -18
  449. package/dist/services/document-service/transform/fields.mjs.map +1 -1
  450. package/dist/services/document-service/transform/id-map.d.ts +1 -1
  451. package/dist/services/document-service/transform/id-map.d.ts.map +1 -1
  452. package/dist/services/document-service/transform/id-map.js +116 -69
  453. package/dist/services/document-service/transform/id-map.js.map +1 -1
  454. package/dist/services/document-service/transform/id-map.mjs +115 -70
  455. package/dist/services/document-service/transform/id-map.mjs.map +1 -1
  456. package/dist/services/document-service/transform/id-transform.d.ts +1 -1
  457. package/dist/services/document-service/transform/id-transform.d.ts.map +1 -1
  458. package/dist/services/document-service/transform/id-transform.js +37 -29
  459. package/dist/services/document-service/transform/id-transform.js.map +1 -1
  460. package/dist/services/document-service/transform/id-transform.mjs +36 -30
  461. package/dist/services/document-service/transform/id-transform.mjs.map +1 -1
  462. package/dist/services/document-service/transform/populate.js +23 -18
  463. package/dist/services/document-service/transform/populate.js.map +1 -1
  464. package/dist/services/document-service/transform/populate.mjs +22 -19
  465. package/dist/services/document-service/transform/populate.mjs.map +1 -1
  466. package/dist/services/document-service/transform/query.js +11 -6
  467. package/dist/services/document-service/transform/query.js.map +1 -1
  468. package/dist/services/document-service/transform/query.mjs +10 -7
  469. package/dist/services/document-service/transform/query.mjs.map +1 -1
  470. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +1 -1
  471. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -1
  472. package/dist/services/document-service/transform/relations/extract/data-ids.js +71 -48
  473. package/dist/services/document-service/transform/relations/extract/data-ids.js.map +1 -1
  474. package/dist/services/document-service/transform/relations/extract/data-ids.mjs +70 -49
  475. package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +1 -1
  476. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts.map +1 -1
  477. package/dist/services/document-service/transform/relations/transform/data-ids.js +97 -63
  478. package/dist/services/document-service/transform/relations/transform/data-ids.js.map +1 -1
  479. package/dist/services/document-service/transform/relations/transform/data-ids.mjs +96 -64
  480. package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +1 -1
  481. package/dist/services/document-service/transform/relations/transform/default-locale.js +47 -29
  482. package/dist/services/document-service/transform/relations/transform/default-locale.js.map +1 -1
  483. package/dist/services/document-service/transform/relations/transform/default-locale.mjs +46 -30
  484. package/dist/services/document-service/transform/relations/transform/default-locale.mjs.map +1 -1
  485. package/dist/services/document-service/transform/relations/utils/dp.d.ts +1 -1
  486. package/dist/services/document-service/transform/relations/utils/dp.d.ts.map +1 -1
  487. package/dist/services/document-service/transform/relations/utils/dp.js +52 -26
  488. package/dist/services/document-service/transform/relations/utils/dp.js.map +1 -1
  489. package/dist/services/document-service/transform/relations/utils/dp.mjs +51 -27
  490. package/dist/services/document-service/transform/relations/utils/dp.mjs.map +1 -1
  491. package/dist/services/document-service/transform/relations/utils/i18n.d.ts +1 -1
  492. package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -1
  493. package/dist/services/document-service/transform/relations/utils/i18n.js +20 -18
  494. package/dist/services/document-service/transform/relations/utils/i18n.js.map +1 -1
  495. package/dist/services/document-service/transform/relations/utils/i18n.mjs +19 -21
  496. package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +1 -1
  497. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts.map +1 -1
  498. package/dist/services/document-service/transform/relations/utils/map-relation.js +116 -77
  499. package/dist/services/document-service/transform/relations/utils/map-relation.js.map +1 -1
  500. package/dist/services/document-service/transform/relations/utils/map-relation.mjs +115 -79
  501. package/dist/services/document-service/transform/relations/utils/map-relation.mjs.map +1 -1
  502. package/dist/services/document-service/utils/bidirectional-relations.d.ts +95 -0
  503. package/dist/services/document-service/utils/bidirectional-relations.d.ts.map +1 -0
  504. package/dist/services/document-service/utils/bidirectional-relations.js +148 -0
  505. package/dist/services/document-service/utils/bidirectional-relations.js.map +1 -0
  506. package/dist/services/document-service/utils/bidirectional-relations.mjs +145 -0
  507. package/dist/services/document-service/utils/bidirectional-relations.mjs.map +1 -0
  508. package/dist/services/document-service/utils/populate.d.ts +1 -1
  509. package/dist/services/document-service/utils/populate.d.ts.map +1 -1
  510. package/dist/services/document-service/utils/populate.js +66 -42
  511. package/dist/services/document-service/utils/populate.js.map +1 -1
  512. package/dist/services/document-service/utils/populate.mjs +65 -43
  513. package/dist/services/document-service/utils/populate.mjs.map +1 -1
  514. package/dist/services/document-service/utils/unidirectional-relations.d.ts +12 -9
  515. package/dist/services/document-service/utils/unidirectional-relations.d.ts.map +1 -1
  516. package/dist/services/document-service/utils/unidirectional-relations.js +110 -52
  517. package/dist/services/document-service/utils/unidirectional-relations.js.map +1 -1
  518. package/dist/services/document-service/utils/unidirectional-relations.mjs +109 -54
  519. package/dist/services/document-service/utils/unidirectional-relations.mjs.map +1 -1
  520. package/dist/services/entity-service/index.js +230 -161
  521. package/dist/services/entity-service/index.js.map +1 -1
  522. package/dist/services/entity-service/index.mjs +229 -160
  523. package/dist/services/entity-service/index.mjs.map +1 -1
  524. package/dist/services/entity-validator/blocks-validator.js +135 -103
  525. package/dist/services/entity-validator/blocks-validator.js.map +1 -1
  526. package/dist/services/entity-validator/blocks-validator.mjs +134 -104
  527. package/dist/services/entity-validator/blocks-validator.mjs.map +1 -1
  528. package/dist/services/entity-validator/index.d.ts +1 -1
  529. package/dist/services/entity-validator/index.d.ts.map +1 -1
  530. package/dist/services/entity-validator/index.js +362 -363
  531. package/dist/services/entity-validator/index.js.map +1 -1
  532. package/dist/services/entity-validator/index.mjs +358 -360
  533. package/dist/services/entity-validator/index.mjs.map +1 -1
  534. package/dist/services/entity-validator/validators.js +268 -210
  535. package/dist/services/entity-validator/validators.js.map +1 -1
  536. package/dist/services/entity-validator/validators.mjs +267 -216
  537. package/dist/services/entity-validator/validators.mjs.map +1 -1
  538. package/dist/services/errors.js +65 -65
  539. package/dist/services/errors.js.map +1 -1
  540. package/dist/services/errors.mjs +64 -66
  541. package/dist/services/errors.mjs.map +1 -1
  542. package/dist/services/event-hub.js +82 -69
  543. package/dist/services/event-hub.js.map +1 -1
  544. package/dist/services/event-hub.mjs +81 -71
  545. package/dist/services/event-hub.mjs.map +1 -1
  546. package/dist/services/features.js +19 -14
  547. package/dist/services/features.js.map +1 -1
  548. package/dist/services/features.mjs +18 -15
  549. package/dist/services/features.mjs.map +1 -1
  550. package/dist/services/fs.js +41 -40
  551. package/dist/services/fs.js.map +1 -1
  552. package/dist/services/fs.mjs +40 -39
  553. package/dist/services/fs.mjs.map +1 -1
  554. package/dist/services/metrics/admin-user-hash.d.ts.map +1 -1
  555. package/dist/services/metrics/admin-user-hash.js +13 -11
  556. package/dist/services/metrics/admin-user-hash.js.map +1 -1
  557. package/dist/services/metrics/admin-user-hash.mjs +12 -10
  558. package/dist/services/metrics/admin-user-hash.mjs.map +1 -1
  559. package/dist/services/metrics/index.js +46 -40
  560. package/dist/services/metrics/index.js.map +1 -1
  561. package/dist/services/metrics/index.mjs +45 -42
  562. package/dist/services/metrics/index.mjs.map +1 -1
  563. package/dist/services/metrics/is-truthy.js +13 -6
  564. package/dist/services/metrics/is-truthy.js.map +1 -1
  565. package/dist/services/metrics/is-truthy.mjs +12 -6
  566. package/dist/services/metrics/is-truthy.mjs.map +1 -1
  567. package/dist/services/metrics/middleware.d.ts.map +1 -1
  568. package/dist/services/metrics/middleware.js +37 -22
  569. package/dist/services/metrics/middleware.js.map +1 -1
  570. package/dist/services/metrics/middleware.mjs +36 -24
  571. package/dist/services/metrics/middleware.mjs.map +1 -1
  572. package/dist/services/metrics/rate-limiter.d.ts.map +1 -1
  573. package/dist/services/metrics/rate-limiter.js +24 -19
  574. package/dist/services/metrics/rate-limiter.js.map +1 -1
  575. package/dist/services/metrics/rate-limiter.mjs +23 -21
  576. package/dist/services/metrics/rate-limiter.mjs.map +1 -1
  577. package/dist/services/metrics/sender.d.ts.map +1 -1
  578. package/dist/services/metrics/sender.js +78 -69
  579. package/dist/services/metrics/sender.js.map +1 -1
  580. package/dist/services/metrics/sender.mjs +77 -64
  581. package/dist/services/metrics/sender.mjs.map +1 -1
  582. package/dist/services/query-params.js +13 -10
  583. package/dist/services/query-params.js.map +1 -1
  584. package/dist/services/query-params.mjs +12 -12
  585. package/dist/services/query-params.mjs.map +1 -1
  586. package/dist/services/reloader.js +35 -32
  587. package/dist/services/reloader.js.map +1 -1
  588. package/dist/services/reloader.mjs +34 -33
  589. package/dist/services/reloader.mjs.map +1 -1
  590. package/dist/services/request-context.js +11 -8
  591. package/dist/services/request-context.js.map +1 -1
  592. package/dist/services/request-context.mjs +10 -10
  593. package/dist/services/request-context.mjs.map +1 -1
  594. package/dist/services/server/admin-api.js +11 -10
  595. package/dist/services/server/admin-api.js.map +1 -1
  596. package/dist/services/server/admin-api.mjs +10 -11
  597. package/dist/services/server/admin-api.mjs.map +1 -1
  598. package/dist/services/server/api.js +33 -27
  599. package/dist/services/server/api.js.map +1 -1
  600. package/dist/services/server/api.mjs +32 -26
  601. package/dist/services/server/api.mjs.map +1 -1
  602. package/dist/services/server/compose-endpoint.js +116 -105
  603. package/dist/services/server/compose-endpoint.js.map +1 -1
  604. package/dist/services/server/compose-endpoint.mjs +115 -105
  605. package/dist/services/server/compose-endpoint.mjs.map +1 -1
  606. package/dist/services/server/content-api.js +11 -9
  607. package/dist/services/server/content-api.js.map +1 -1
  608. package/dist/services/server/content-api.mjs +10 -10
  609. package/dist/services/server/content-api.mjs.map +1 -1
  610. package/dist/services/server/http-server.js +48 -44
  611. package/dist/services/server/http-server.js.map +1 -1
  612. package/dist/services/server/http-server.mjs +47 -43
  613. package/dist/services/server/http-server.mjs.map +1 -1
  614. package/dist/services/server/index.js +85 -82
  615. package/dist/services/server/index.js.map +1 -1
  616. package/dist/services/server/index.mjs +84 -81
  617. package/dist/services/server/index.mjs.map +1 -1
  618. package/dist/services/server/koa.js +49 -47
  619. package/dist/services/server/koa.js.map +1 -1
  620. package/dist/services/server/koa.mjs +48 -44
  621. package/dist/services/server/koa.mjs.map +1 -1
  622. package/dist/services/server/middleware.js +86 -82
  623. package/dist/services/server/middleware.js.map +1 -1
  624. package/dist/services/server/middleware.mjs +85 -82
  625. package/dist/services/server/middleware.mjs.map +1 -1
  626. package/dist/services/server/policy.js +24 -17
  627. package/dist/services/server/policy.js.map +1 -1
  628. package/dist/services/server/policy.mjs +23 -18
  629. package/dist/services/server/policy.mjs.map +1 -1
  630. package/dist/services/server/register-middlewares.js +68 -61
  631. package/dist/services/server/register-middlewares.js.map +1 -1
  632. package/dist/services/server/register-middlewares.mjs +67 -63
  633. package/dist/services/server/register-middlewares.mjs.map +1 -1
  634. package/dist/services/server/register-routes.js +90 -67
  635. package/dist/services/server/register-routes.js.map +1 -1
  636. package/dist/services/server/register-routes.mjs +89 -67
  637. package/dist/services/server/register-routes.mjs.map +1 -1
  638. package/dist/services/server/routing.js +94 -81
  639. package/dist/services/server/routing.js.map +1 -1
  640. package/dist/services/server/routing.mjs +93 -81
  641. package/dist/services/server/routing.mjs.map +1 -1
  642. package/dist/services/utils/dynamic-zones.js +13 -14
  643. package/dist/services/utils/dynamic-zones.js.map +1 -1
  644. package/dist/services/utils/dynamic-zones.mjs +12 -16
  645. package/dist/services/utils/dynamic-zones.mjs.map +1 -1
  646. package/dist/services/webhook-runner.js +124 -122
  647. package/dist/services/webhook-runner.js.map +1 -1
  648. package/dist/services/webhook-runner.mjs +123 -121
  649. package/dist/services/webhook-runner.mjs.map +1 -1
  650. package/dist/services/webhook-store.js +132 -99
  651. package/dist/services/webhook-store.js.map +1 -1
  652. package/dist/services/webhook-store.mjs +131 -101
  653. package/dist/services/webhook-store.mjs.map +1 -1
  654. package/dist/services/worker-queue.js +44 -49
  655. package/dist/services/worker-queue.js.map +1 -1
  656. package/dist/services/worker-queue.mjs +43 -49
  657. package/dist/services/worker-queue.mjs.map +1 -1
  658. package/dist/utils/convert-custom-field-type.js +17 -20
  659. package/dist/utils/convert-custom-field-type.js.map +1 -1
  660. package/dist/utils/convert-custom-field-type.mjs +16 -21
  661. package/dist/utils/convert-custom-field-type.mjs.map +1 -1
  662. package/dist/utils/cron.js +64 -30
  663. package/dist/utils/cron.js.map +1 -1
  664. package/dist/utils/cron.mjs +63 -31
  665. package/dist/utils/cron.mjs.map +1 -1
  666. package/dist/utils/fetch.js +24 -18
  667. package/dist/utils/fetch.js.map +1 -1
  668. package/dist/utils/fetch.mjs +23 -19
  669. package/dist/utils/fetch.mjs.map +1 -1
  670. package/dist/utils/filepath-to-prop-path.js +20 -28
  671. package/dist/utils/filepath-to-prop-path.js.map +1 -1
  672. package/dist/utils/filepath-to-prop-path.mjs +19 -26
  673. package/dist/utils/filepath-to-prop-path.mjs.map +1 -1
  674. package/dist/utils/is-initialized.js +21 -12
  675. package/dist/utils/is-initialized.js.map +1 -1
  676. package/dist/utils/is-initialized.mjs +20 -13
  677. package/dist/utils/is-initialized.mjs.map +1 -1
  678. package/dist/utils/lifecycles.js +6 -5
  679. package/dist/utils/lifecycles.js.map +1 -1
  680. package/dist/utils/lifecycles.mjs +5 -6
  681. package/dist/utils/lifecycles.mjs.map +1 -1
  682. package/dist/utils/load-config-file.js +40 -38
  683. package/dist/utils/load-config-file.js.map +1 -1
  684. package/dist/utils/load-config-file.mjs +39 -36
  685. package/dist/utils/load-config-file.mjs.map +1 -1
  686. package/dist/utils/load-files.js +40 -35
  687. package/dist/utils/load-files.js.map +1 -1
  688. package/dist/utils/load-files.mjs +39 -32
  689. package/dist/utils/load-files.mjs.map +1 -1
  690. package/dist/utils/open-browser.js +8 -8
  691. package/dist/utils/open-browser.js.map +1 -1
  692. package/dist/utils/open-browser.mjs +7 -7
  693. package/dist/utils/open-browser.mjs.map +1 -1
  694. package/dist/utils/resolve-working-dirs.js +23 -10
  695. package/dist/utils/resolve-working-dirs.js.map +1 -1
  696. package/dist/utils/resolve-working-dirs.mjs +22 -9
  697. package/dist/utils/resolve-working-dirs.mjs.map +1 -1
  698. package/dist/utils/signals.js +20 -14
  699. package/dist/utils/signals.js.map +1 -1
  700. package/dist/utils/signals.mjs +19 -15
  701. package/dist/utils/signals.mjs.map +1 -1
  702. package/dist/utils/startup-logger.d.ts.map +1 -1
  703. package/dist/utils/startup-logger.js +107 -78
  704. package/dist/utils/startup-logger.js.map +1 -1
  705. package/dist/utils/startup-logger.mjs +106 -75
  706. package/dist/utils/startup-logger.mjs.map +1 -1
  707. package/dist/utils/transform-content-types-to-models.d.ts +353 -21
  708. package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
  709. package/dist/utils/transform-content-types-to-models.js +350 -261
  710. package/dist/utils/transform-content-types-to-models.js.map +1 -1
  711. package/dist/utils/transform-content-types-to-models.mjs +349 -269
  712. package/dist/utils/transform-content-types-to-models.mjs.map +1 -1
  713. package/dist/utils/update-notifier/index.d.ts.map +1 -1
  714. package/dist/utils/update-notifier/index.js +68 -73
  715. package/dist/utils/update-notifier/index.js.map +1 -1
  716. package/dist/utils/update-notifier/index.mjs +67 -67
  717. package/dist/utils/update-notifier/index.mjs.map +1 -1
  718. package/package.json +27 -28
@@ -1,76 +1,108 @@
1
- import { curry } from "lodash/fp";
2
- import { errors } from "@strapi/utils";
3
- import { getRelationTargetLocale } from "../utils/i18n.mjs";
4
- import { getRelationTargetStatus } from "../utils/dp.mjs";
5
- import { traverseEntityRelations as traverseEntityRelationsCurried, mapRelation as mapRelationCurried } from "../utils/map-relation.mjs";
6
- const getRelationIds = curry(
7
- (idMap, targetUid, source, relation) => {
1
+ import { curry } from 'lodash/fp';
2
+ import { errors, relations } from '@strapi/utils';
3
+ import { getRelationTargetLocale } from '../utils/i18n.mjs';
4
+ import { getRelationTargetStatus } from '../utils/dp.mjs';
5
+ import { traverseEntityRelations as traverseEntityRelationsCurried, mapRelation as mapRelationCurried } from '../utils/map-relation.mjs';
6
+
7
+ const { isPolymorphic } = relations;
8
+ /**
9
+ * Get the entry ids for a given documentId.
10
+ */ const getRelationIds = curry((idMap, source, targetUid, relation)=>{
11
+ // locale to connect to
8
12
  const targetLocale = getRelationTargetLocale(relation, {
9
- targetUid,
10
- sourceUid: source.uid,
11
- sourceLocale: source.locale
13
+ targetUid,
14
+ sourceUid: source.uid,
15
+ sourceLocale: source.locale
12
16
  });
17
+ // status(es) to connect to
13
18
  const targetStatus = getRelationTargetStatus(relation, {
14
- targetUid,
15
- sourceUid: source.uid,
16
- sourceStatus: source.status
19
+ targetUid,
20
+ sourceUid: source.uid,
21
+ sourceStatus: source.status
17
22
  });
18
23
  const ids = [];
19
- for (const tStatus of targetStatus) {
20
- const entryId = idMap.get({
21
- uid: targetUid,
22
- documentId: relation.documentId,
23
- locale: targetLocale,
24
- status: tStatus
25
- });
26
- if (entryId)
27
- ids.push(entryId);
24
+ // Find mapping between documentID -> id(s).
25
+ // There are scenarios where a single documentID can map to multiple ids.
26
+ // e.g when connecting Non DP -> DP and connecting to both the draft and publish version at the same time
27
+ for (const tStatus of targetStatus){
28
+ const entryId = idMap.get({
29
+ uid: targetUid,
30
+ documentId: relation.documentId,
31
+ locale: targetLocale,
32
+ status: tStatus
33
+ });
34
+ if (entryId) ids.push(entryId);
28
35
  }
29
36
  if (!ids.length && !source.allowMissingId) {
30
- throw new errors.ValidationError(
31
- `Document with id "${relation.documentId}", locale "${targetLocale}" not found`
32
- );
37
+ throw new errors.ValidationError(`Document with id "${relation.documentId}", locale "${targetLocale}" not found`);
33
38
  }
34
39
  return ids;
35
- }
36
- );
37
- const transformDataIdsVisitor = (idMap, data, source) => {
38
- return traverseEntityRelationsCurried(
39
- async ({ key, value, attribute }, { set }) => {
40
- if (!attribute) {
41
- return;
42
- }
43
- const targetUid = attribute.target;
44
- const getIds = getRelationIds(idMap, targetUid, source);
45
- const newRelation = await mapRelationCurried((relation) => {
46
- if (!relation || !relation.documentId) {
47
- return relation;
48
- }
49
- const ids = getIds(relation);
50
- const position = { ...relation.position };
51
- if (position.before) {
52
- const beforeRelation = { ...relation, ...position, documentId: position.before };
53
- position.before = getIds(beforeRelation).at(0);
54
- }
55
- if (position.after) {
56
- const afterRelation = { ...relation, ...position, documentId: position.after };
57
- position.after = getIds(afterRelation).at(0);
40
+ });
41
+ /**
42
+ * Iterate over all relations of a data object and transform all relational document ids to entity ids.
43
+ */ const transformDataIdsVisitor = (idMap, data, source)=>{
44
+ return traverseEntityRelationsCurried(async ({ key, value, attribute }, { set })=>{
45
+ if (!attribute) {
46
+ return;
58
47
  }
59
- return ids?.map((id) => {
60
- const newRelation2 = { id };
61
- if (relation.position) {
62
- newRelation2.position = position;
63
- }
64
- return newRelation2;
65
- });
66
- }, value);
67
- set(key, newRelation);
68
- },
69
- { schema: strapi.getModel(source.uid), getModel: strapi.getModel.bind(strapi) },
70
- data
71
- );
72
- };
73
- export {
74
- transformDataIdsVisitor
48
+ const isPolymorphicRelation = isPolymorphic(attribute);
49
+ const getIds = getRelationIds(idMap, source);
50
+ // Transform the relation documentId to entity id
51
+ const newRelation = await mapRelationCurried((relation)=>{
52
+ if (!relation || !relation.documentId) {
53
+ return relation;
54
+ }
55
+ // Find relational attributes, and return the document ids
56
+ // if its a polymorphic relation we need to get it from the data itself
57
+ const targetUid = isPolymorphicRelation ? relation.__type : attribute.target;
58
+ const ids = getIds(targetUid, relation);
59
+ // Handle positional arguments
60
+ const position = {
61
+ ...relation.position
62
+ };
63
+ // The positional relation target uid can be different for polymorphic relations
64
+ let positionTargetUid = targetUid;
65
+ if (isPolymorphicRelation && position?.__type) {
66
+ positionTargetUid = position.__type;
67
+ }
68
+ if (position.before) {
69
+ const beforeRelation = {
70
+ ...relation,
71
+ ...position,
72
+ documentId: position.before
73
+ };
74
+ const beforeIds = getIds(positionTargetUid, beforeRelation);
75
+ position.before = beforeIds.at(0);
76
+ }
77
+ if (position.after) {
78
+ const afterRelation = {
79
+ ...relation,
80
+ ...position,
81
+ documentId: position.after
82
+ };
83
+ position.after = getIds(positionTargetUid, afterRelation).at(0);
84
+ }
85
+ // Transform all ids to new relations
86
+ return ids?.map((id)=>{
87
+ const newRelation = {
88
+ id
89
+ };
90
+ if (relation.position) {
91
+ newRelation.position = position;
92
+ }
93
+ // Insert type if its a polymorphic relation
94
+ if (isPolymorphicRelation) {
95
+ newRelation.__type = targetUid;
96
+ }
97
+ return newRelation;
98
+ });
99
+ }, value);
100
+ set(key, newRelation);
101
+ }, {
102
+ schema: strapi.getModel(source.uid),
103
+ getModel: strapi.getModel.bind(strapi)
104
+ }, data);
75
105
  };
106
+
107
+ export { transformDataIdsVisitor };
76
108
  //# sourceMappingURL=data-ids.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"data-ids.mjs","sources":["../../../../../../src/services/document-service/transform/relations/transform/data-ids.ts"],"sourcesContent":["import { curry } from 'lodash/fp';\n\nimport type { UID } from '@strapi/types';\nimport { errors } from '@strapi/utils';\n\nimport { ID, LongHandDocument } from '../utils/types';\nimport { IdMap } from '../../id-map';\nimport { getRelationTargetLocale } from '../utils/i18n';\nimport { getRelationTargetStatus } from '../utils/dp';\nimport { mapRelation, traverseEntityRelations } from '../utils/map-relation';\n\ninterface Options {\n uid: UID.Schema;\n locale?: string | null;\n status?: 'draft' | 'published';\n allowMissingId?: boolean; // Whether to ignore missing ids and not throw any error\n}\n\n/**\n * Get the entry ids for a given documentId.\n */\nconst getRelationIds = curry(\n (idMap: IdMap, targetUid: UID.Schema, source: Options, relation: LongHandDocument) => {\n // locale to connect to\n const targetLocale = getRelationTargetLocale(relation, {\n targetUid,\n sourceUid: source.uid,\n sourceLocale: source.locale,\n });\n\n // status(es) to connect to\n const targetStatus = getRelationTargetStatus(relation, {\n targetUid,\n sourceUid: source.uid,\n sourceStatus: source.status,\n });\n\n const ids: ID[] = [];\n\n // Find mapping between documentID -> id(s).\n // There are scenarios where a single documentID can map to multiple ids.\n // e.g when connecting Non DP -> DP and connecting to both the draft and publish version at the same time\n for (const tStatus of targetStatus) {\n const entryId = idMap.get({\n uid: targetUid,\n documentId: relation.documentId,\n locale: targetLocale,\n status: tStatus,\n });\n\n if (entryId) ids.push(entryId);\n }\n\n if (!ids.length && !source.allowMissingId) {\n throw new errors.ValidationError(\n `Document with id \"${relation.documentId}\", locale \"${targetLocale}\" not found`\n );\n }\n\n return ids;\n }\n);\n\n/**\n * Iterate over all relations of a data object and transform all relational document ids to entity ids.\n */\nconst transformDataIdsVisitor = (idMap: IdMap, data: Record<string, any>, source: Options) => {\n return traverseEntityRelations(\n async ({ key, value, attribute }, { set }) => {\n if (!attribute) {\n return;\n }\n\n // Find relational attributes, and return the document ids\n const targetUid = attribute.target!;\n const getIds = getRelationIds(idMap, targetUid, source);\n\n // Transform the relation documentId to entity id\n const newRelation = await mapRelation((relation) => {\n if (!relation || !relation.documentId) {\n return relation;\n }\n\n const ids = getIds(relation);\n\n // Handle positional arguments\n const position = { ...relation.position };\n\n if (position.before) {\n const beforeRelation = { ...relation, ...position, documentId: position.before };\n position.before = getIds(beforeRelation).at(0);\n }\n\n if (position.after) {\n const afterRelation = { ...relation, ...position, documentId: position.after };\n position.after = getIds(afterRelation).at(0);\n }\n\n // Transform all ids to new relations\n return ids?.map((id) => {\n const newRelation = { id } as typeof relation;\n if (relation.position) {\n newRelation.position = position;\n }\n\n return newRelation;\n });\n }, value as any);\n\n set(key, newRelation as any);\n },\n { schema: strapi.getModel(source.uid), getModel: strapi.getModel.bind(strapi) },\n data\n );\n};\n\nexport { transformDataIdsVisitor };\n"],"names":["traverseEntityRelations","mapRelation","newRelation"],"mappings":";;;;;AAqBA,MAAM,iBAAiB;AAAA,EACrB,CAAC,OAAc,WAAuB,QAAiB,aAA+B;AAE9E,UAAA,eAAe,wBAAwB,UAAU;AAAA,MACrD;AAAA,MACA,WAAW,OAAO;AAAA,MAClB,cAAc,OAAO;AAAA,IAAA,CACtB;AAGK,UAAA,eAAe,wBAAwB,UAAU;AAAA,MACrD;AAAA,MACA,WAAW,OAAO;AAAA,MAClB,cAAc,OAAO;AAAA,IAAA,CACtB;AAED,UAAM,MAAY,CAAA;AAKlB,eAAW,WAAW,cAAc;AAC5B,YAAA,UAAU,MAAM,IAAI;AAAA,QACxB,KAAK;AAAA,QACL,YAAY,SAAS;AAAA,QACrB,QAAQ;AAAA,QACR,QAAQ;AAAA,MAAA,CACT;AAEG,UAAA;AAAS,YAAI,KAAK,OAAO;AAAA,IAC/B;AAEA,QAAI,CAAC,IAAI,UAAU,CAAC,OAAO,gBAAgB;AACzC,YAAM,IAAI,OAAO;AAAA,QACf,qBAAqB,SAAS,UAAU,cAAc,YAAY;AAAA,MAAA;AAAA,IAEtE;AAEO,WAAA;AAAA,EACT;AACF;AAKA,MAAM,0BAA0B,CAAC,OAAc,MAA2B,WAAoB;AACrF,SAAAA;AAAAA,IACL,OAAO,EAAE,KAAK,OAAO,aAAa,EAAE,UAAU;AAC5C,UAAI,CAAC,WAAW;AACd;AAAA,MACF;AAGA,YAAM,YAAY,UAAU;AAC5B,YAAM,SAAS,eAAe,OAAO,WAAW,MAAM;AAGtD,YAAM,cAAc,MAAMC,mBAAY,CAAC,aAAa;AAClD,YAAI,CAAC,YAAY,CAAC,SAAS,YAAY;AAC9B,iBAAA;AAAA,QACT;AAEM,cAAA,MAAM,OAAO,QAAQ;AAG3B,cAAM,WAAW,EAAE,GAAG,SAAS,SAAS;AAExC,YAAI,SAAS,QAAQ;AACb,gBAAA,iBAAiB,EAAE,GAAG,UAAU,GAAG,UAAU,YAAY,SAAS;AACxE,mBAAS,SAAS,OAAO,cAAc,EAAE,GAAG,CAAC;AAAA,QAC/C;AAEA,YAAI,SAAS,OAAO;AACZ,gBAAA,gBAAgB,EAAE,GAAG,UAAU,GAAG,UAAU,YAAY,SAAS;AACvE,mBAAS,QAAQ,OAAO,aAAa,EAAE,GAAG,CAAC;AAAA,QAC7C;AAGO,eAAA,KAAK,IAAI,CAAC,OAAO;AAChBC,gBAAAA,eAAc,EAAE;AACtB,cAAI,SAAS,UAAU;AACrBA,yBAAY,WAAW;AAAA,UACzB;AAEOA,iBAAAA;AAAAA,QAAA,CACR;AAAA,SACA,KAAY;AAEf,UAAI,KAAK,WAAkB;AAAA,IAC7B;AAAA,IACA,EAAE,QAAQ,OAAO,SAAS,OAAO,GAAG,GAAG,UAAU,OAAO,SAAS,KAAK,MAAM,EAAE;AAAA,IAC9E;AAAA,EAAA;AAEJ;"}
1
+ {"version":3,"file":"data-ids.mjs","sources":["../../../../../../src/services/document-service/transform/relations/transform/data-ids.ts"],"sourcesContent":["import { curry } from 'lodash/fp';\n\nimport type { UID } from '@strapi/types';\nimport { errors, relations } from '@strapi/utils';\n\nimport { ID, LongHandDocument } from '../utils/types';\nimport { IdMap } from '../../id-map';\nimport { getRelationTargetLocale } from '../utils/i18n';\nimport { getRelationTargetStatus } from '../utils/dp';\nimport { mapRelation, traverseEntityRelations } from '../utils/map-relation';\n\nconst { isPolymorphic } = relations;\n\ninterface Options {\n uid: UID.Schema;\n locale?: string | null;\n status?: 'draft' | 'published';\n allowMissingId?: boolean; // Whether to ignore missing ids and not throw any error\n}\n\n/**\n * Get the entry ids for a given documentId.\n */\nconst getRelationIds = curry(\n (idMap: IdMap, source: Options, targetUid: UID.Schema, relation: LongHandDocument) => {\n // locale to connect to\n const targetLocale = getRelationTargetLocale(relation, {\n targetUid,\n sourceUid: source.uid,\n sourceLocale: source.locale,\n });\n\n // status(es) to connect to\n const targetStatus = getRelationTargetStatus(relation, {\n targetUid,\n sourceUid: source.uid,\n sourceStatus: source.status,\n });\n\n const ids: ID[] = [];\n\n // Find mapping between documentID -> id(s).\n // There are scenarios where a single documentID can map to multiple ids.\n // e.g when connecting Non DP -> DP and connecting to both the draft and publish version at the same time\n for (const tStatus of targetStatus) {\n const entryId = idMap.get({\n uid: targetUid,\n documentId: relation.documentId,\n locale: targetLocale,\n status: tStatus,\n });\n\n if (entryId) ids.push(entryId);\n }\n\n if (!ids.length && !source.allowMissingId) {\n throw new errors.ValidationError(\n `Document with id \"${relation.documentId}\", locale \"${targetLocale}\" not found`\n );\n }\n\n return ids;\n }\n);\n\n/**\n * Iterate over all relations of a data object and transform all relational document ids to entity ids.\n */\nconst transformDataIdsVisitor = (idMap: IdMap, data: Record<string, any>, source: Options) => {\n return traverseEntityRelations(\n async ({ key, value, attribute }, { set }) => {\n if (!attribute) {\n return;\n }\n const isPolymorphicRelation = isPolymorphic(attribute);\n const getIds = getRelationIds(idMap, source);\n\n // Transform the relation documentId to entity id\n const newRelation = await mapRelation((relation) => {\n if (!relation || !relation.documentId) {\n return relation;\n }\n\n // Find relational attributes, and return the document ids\n // if its a polymorphic relation we need to get it from the data itself\n const targetUid: UID.Schema = isPolymorphicRelation ? relation.__type : attribute.target;\n const ids: ID[] = getIds(targetUid, relation);\n\n // Handle positional arguments\n const position = { ...relation.position };\n\n // The positional relation target uid can be different for polymorphic relations\n let positionTargetUid: UID.Schema = targetUid;\n if (isPolymorphicRelation && position?.__type) {\n positionTargetUid = position.__type;\n }\n\n if (position.before) {\n const beforeRelation = { ...relation, ...position, documentId: position.before };\n const beforeIds: ID[] = getIds(positionTargetUid, beforeRelation);\n position.before = beforeIds.at(0);\n }\n\n if (position.after) {\n const afterRelation = { ...relation, ...position, documentId: position.after };\n position.after = getIds(positionTargetUid, afterRelation).at(0);\n }\n\n // Transform all ids to new relations\n return ids?.map((id) => {\n const newRelation = { id } as typeof relation;\n\n if (relation.position) {\n newRelation.position = position;\n }\n\n // Insert type if its a polymorphic relation\n if (isPolymorphicRelation) {\n newRelation.__type = targetUid;\n }\n\n return newRelation;\n });\n }, value as any);\n\n set(key, newRelation as any);\n },\n { schema: strapi.getModel(source.uid), getModel: strapi.getModel.bind(strapi) },\n data\n );\n};\n\nexport { transformDataIdsVisitor };\n"],"names":["isPolymorphic","relations","getRelationIds","curry","idMap","source","targetUid","relation","targetLocale","getRelationTargetLocale","sourceUid","uid","sourceLocale","locale","targetStatus","getRelationTargetStatus","sourceStatus","status","ids","tStatus","entryId","get","documentId","push","length","allowMissingId","errors","ValidationError","transformDataIdsVisitor","data","traverseEntityRelations","key","value","attribute","set","isPolymorphicRelation","getIds","newRelation","mapRelation","__type","target","position","positionTargetUid","before","beforeRelation","beforeIds","at","after","afterRelation","map","id","schema","strapi","getModel","bind"],"mappings":";;;;;;AAWA,MAAM,EAAEA,aAAa,EAAE,GAAGC,SAAAA;AAS1B;;AAEC,IACD,MAAMC,cAAiBC,GAAAA,KAAAA,CACrB,CAACC,KAAAA,EAAcC,QAAiBC,SAAuBC,EAAAA,QAAAA,GAAAA;;IAErD,MAAMC,YAAAA,GAAeC,wBAAwBF,QAAU,EAAA;AACrDD,QAAAA,SAAAA;AACAI,QAAAA,SAAAA,EAAWL,OAAOM,GAAG;AACrBC,QAAAA,YAAAA,EAAcP,OAAOQ;AACvB,KAAA,CAAA;;IAGA,MAAMC,YAAAA,GAAeC,wBAAwBR,QAAU,EAAA;AACrDD,QAAAA,SAAAA;AACAI,QAAAA,SAAAA,EAAWL,OAAOM,GAAG;AACrBK,QAAAA,YAAAA,EAAcX,OAAOY;AACvB,KAAA,CAAA;AAEA,IAAA,MAAMC,MAAY,EAAE;;;;IAKpB,KAAK,MAAMC,WAAWL,YAAc,CAAA;QAClC,MAAMM,OAAAA,GAAUhB,KAAMiB,CAAAA,GAAG,CAAC;YACxBV,GAAKL,EAAAA,SAAAA;AACLgB,YAAAA,UAAAA,EAAYf,SAASe,UAAU;YAC/BT,MAAQL,EAAAA,YAAAA;YACRS,MAAQE,EAAAA;AACV,SAAA,CAAA;QAEA,IAAIC,OAAAA,EAASF,GAAIK,CAAAA,IAAI,CAACH,OAAAA,CAAAA;AACxB;AAEA,IAAA,IAAI,CAACF,GAAIM,CAAAA,MAAM,IAAI,CAACnB,MAAAA,CAAOoB,cAAc,EAAE;AACzC,QAAA,MAAM,IAAIC,MAAAA,CAAOC,eAAe,CAC9B,CAAC,kBAAkB,EAAEpB,QAASe,CAAAA,UAAU,CAAC,WAAW,EAAEd,YAAAA,CAAa,WAAW,CAAC,CAAA;AAEnF;IAEA,OAAOU,GAAAA;AACT,CAAA,CAAA;AAGF;;AAEC,IACKU,MAAAA,uBAAAA,GAA0B,CAACxB,KAAAA,EAAcyB,IAA2BxB,EAAAA,MAAAA,GAAAA;AACxE,IAAA,OAAOyB,8BACL,CAAA,OAAO,EAAEC,GAAG,EAAEC,KAAK,EAAEC,SAAS,EAAE,EAAE,EAAEC,GAAG,EAAE,GAAA;AACvC,QAAA,IAAI,CAACD,SAAW,EAAA;AACd,YAAA;AACF;AACA,QAAA,MAAME,wBAAwBnC,aAAciC,CAAAA,SAAAA,CAAAA;QAC5C,MAAMG,MAAAA,GAASlC,eAAeE,KAAOC,EAAAA,MAAAA,CAAAA;;QAGrC,MAAMgC,WAAAA,GAAc,MAAMC,kBAAAA,CAAY,CAAC/B,QAAAA,GAAAA;AACrC,YAAA,IAAI,CAACA,QAAAA,IAAY,CAACA,QAAAA,CAASe,UAAU,EAAE;gBACrC,OAAOf,QAAAA;AACT;;;AAIA,YAAA,MAAMD,YAAwB6B,qBAAwB5B,GAAAA,QAAAA,CAASgC,MAAM,GAAGN,UAAUO,MAAM;YACxF,MAAMtB,GAAAA,GAAYkB,OAAO9B,SAAWC,EAAAA,QAAAA,CAAAA;;AAGpC,YAAA,MAAMkC,QAAW,GAAA;AAAE,gBAAA,GAAGlC,SAASkC;AAAS,aAAA;;AAGxC,YAAA,IAAIC,iBAAgCpC,GAAAA,SAAAA;YACpC,IAAI6B,qBAAAA,IAAyBM,UAAUF,MAAQ,EAAA;AAC7CG,gBAAAA,iBAAAA,GAAoBD,SAASF,MAAM;AACrC;YAEA,IAAIE,QAAAA,CAASE,MAAM,EAAE;AACnB,gBAAA,MAAMC,cAAiB,GAAA;AAAE,oBAAA,GAAGrC,QAAQ;AAAE,oBAAA,GAAGkC,QAAQ;AAAEnB,oBAAAA,UAAAA,EAAYmB,SAASE;AAAO,iBAAA;gBAC/E,MAAME,SAAAA,GAAkBT,OAAOM,iBAAmBE,EAAAA,cAAAA,CAAAA;AAClDH,gBAAAA,QAAAA,CAASE,MAAM,GAAGE,SAAUC,CAAAA,EAAE,CAAC,CAAA,CAAA;AACjC;YAEA,IAAIL,QAAAA,CAASM,KAAK,EAAE;AAClB,gBAAA,MAAMC,aAAgB,GAAA;AAAE,oBAAA,GAAGzC,QAAQ;AAAE,oBAAA,GAAGkC,QAAQ;AAAEnB,oBAAAA,UAAAA,EAAYmB,SAASM;AAAM,iBAAA;AAC7EN,gBAAAA,QAAAA,CAASM,KAAK,GAAGX,MAAAA,CAAOM,iBAAmBM,EAAAA,aAAAA,CAAAA,CAAeF,EAAE,CAAC,CAAA,CAAA;AAC/D;;YAGA,OAAO5B,GAAAA,EAAK+B,IAAI,CAACC,EAAAA,GAAAA;AACf,gBAAA,MAAMb,WAAc,GAAA;AAAEa,oBAAAA;AAAG,iBAAA;gBAEzB,IAAI3C,QAAAA,CAASkC,QAAQ,EAAE;AACrBJ,oBAAAA,WAAAA,CAAYI,QAAQ,GAAGA,QAAAA;AACzB;;AAGA,gBAAA,IAAIN,qBAAuB,EAAA;AACzBE,oBAAAA,WAAAA,CAAYE,MAAM,GAAGjC,SAAAA;AACvB;gBAEA,OAAO+B,WAAAA;AACT,aAAA,CAAA;SACCL,EAAAA,KAAAA,CAAAA;AAEHE,QAAAA,GAAAA,CAAIH,GAAKM,EAAAA,WAAAA,CAAAA;KAEX,EAAA;AAAEc,QAAAA,MAAAA,EAAQC,MAAOC,CAAAA,QAAQ,CAAChD,MAAAA,CAAOM,GAAG,CAAA;AAAG0C,QAAAA,QAAAA,EAAUD,MAAOC,CAAAA,QAAQ,CAACC,IAAI,CAACF,MAAAA;KACtEvB,EAAAA,IAAAA,CAAAA;AAEJ;;;;"}
@@ -1,32 +1,50 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const i18n = require("../utils/i18n.js");
4
- const mapRelation = require("../utils/map-relation.js");
5
- const setDefaultLocaleToRelations = (data, uid) => {
6
- if (i18n.isLocalizedContentType(uid)) {
7
- return data;
8
- }
9
- let defaultLocale;
10
- return mapRelation.traverseEntityRelations(
11
- async ({ key, value }, { set }) => {
12
- const relation = await mapRelation.mapRelation(async (relation2) => {
13
- if (!relation2 || !relation2?.documentId || relation2?.locale) {
14
- return relation2;
15
- }
16
- if (!defaultLocale) {
17
- defaultLocale = await i18n.getDefaultLocale();
18
- }
19
- const position = relation2.position;
20
- if (position && typeof position === "object" && !position.locale) {
21
- relation2.position.locale = defaultLocale;
22
- }
23
- return { ...relation2, locale: defaultLocale };
24
- }, value);
25
- set(key, relation);
26
- },
27
- { schema: strapi.getModel(uid), getModel: strapi.getModel.bind(strapi) },
28
- data
29
- );
1
+ 'use strict';
2
+
3
+ var i18n = require('../utils/i18n.js');
4
+ var mapRelation = require('../utils/map-relation.js');
5
+
6
+ /**
7
+ * In scenarios like Non i18n CT -> i18n CT
8
+ * relations can be connected to multiple locales,
9
+ * in case user does not provide the locale, this sets it to the default one.
10
+ */ const setDefaultLocaleToRelations = (data, uid)=>{
11
+ // I18n CT -> anything will already have a locale set (source locale)
12
+ if (i18n.isLocalizedContentType(uid)) {
13
+ return data;
14
+ }
15
+ // Store the default locale to avoid multiple calls
16
+ let defaultLocale;
17
+ /**
18
+ * Traverse the entity input data and set the default locale to relations
19
+ */ return mapRelation.traverseEntityRelations(async ({ key, value }, { set })=>{
20
+ /**
21
+ * Assign default locale on long hand expressed relations
22
+ * e.g { documentId } -> { documentId, locale }
23
+ */ const relation = await mapRelation.mapRelation(async (relation)=>{
24
+ if (!relation || !relation?.documentId || relation?.locale) {
25
+ return relation;
26
+ }
27
+ // Set default locale if not provided
28
+ if (!defaultLocale) {
29
+ defaultLocale = await i18n.getDefaultLocale();
30
+ }
31
+ // Assign default locale to the positional argument
32
+ const position = relation.position;
33
+ if (position && typeof position === 'object' && !position.locale) {
34
+ relation.position.locale = defaultLocale;
35
+ }
36
+ return {
37
+ ...relation,
38
+ locale: defaultLocale
39
+ };
40
+ }, value);
41
+ // @ts-expect-error - fix type
42
+ set(key, relation);
43
+ }, {
44
+ schema: strapi.getModel(uid),
45
+ getModel: strapi.getModel.bind(strapi)
46
+ }, data);
30
47
  };
48
+
31
49
  exports.setDefaultLocaleToRelations = setDefaultLocaleToRelations;
32
50
  //# sourceMappingURL=default-locale.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"default-locale.js","sources":["../../../../../../src/services/document-service/transform/relations/transform/default-locale.ts"],"sourcesContent":["import type { UID } from '@strapi/types';\n\nimport { getDefaultLocale, isLocalizedContentType } from '../utils/i18n';\nimport { mapRelation, traverseEntityRelations } from '../utils/map-relation';\n\n/**\n * In scenarios like Non i18n CT -> i18n CT\n * relations can be connected to multiple locales,\n * in case user does not provide the locale, this sets it to the default one.\n */\nconst setDefaultLocaleToRelations = (data: Record<string, any>, uid: UID.Schema) => {\n // I18n CT -> anything will already have a locale set (source locale)\n if (isLocalizedContentType(uid)) {\n return data;\n }\n\n // Store the default locale to avoid multiple calls\n let defaultLocale: string;\n\n /**\n * Traverse the entity input data and set the default locale to relations\n */\n return traverseEntityRelations(\n async ({ key, value }, { set }) => {\n /**\n * Assign default locale on long hand expressed relations\n * e.g { documentId } -> { documentId, locale }\n */\n const relation = await mapRelation(async (relation) => {\n if (!relation || !relation?.documentId || relation?.locale) {\n return relation;\n }\n\n // Set default locale if not provided\n if (!defaultLocale) {\n defaultLocale = await getDefaultLocale();\n }\n\n // Assign default locale to the positional argument\n const position = relation.position;\n if (position && typeof position === 'object' && !position.locale) {\n relation.position.locale = defaultLocale;\n }\n\n return { ...relation, locale: defaultLocale };\n }, value as any);\n\n // @ts-expect-error - fix type\n set(key, relation);\n },\n { schema: strapi.getModel(uid), getModel: strapi.getModel.bind(strapi) },\n data\n );\n};\n\nexport { setDefaultLocaleToRelations };\n"],"names":["isLocalizedContentType","traverseEntityRelations","mapRelation","relation","getDefaultLocale"],"mappings":";;;;AAUM,MAAA,8BAA8B,CAAC,MAA2B,QAAoB;AAE9E,MAAAA,KAAAA,uBAAuB,GAAG,GAAG;AACxB,WAAA;AAAA,EACT;AAGI,MAAA;AAKG,SAAAC,YAAA;AAAA,IACL,OAAO,EAAE,KAAK,SAAS,EAAE,UAAU;AAKjC,YAAM,WAAW,MAAMC,wBAAY,OAAOC,cAAa;AACrD,YAAI,CAACA,aAAY,CAACA,WAAU,cAAcA,WAAU,QAAQ;AACnDA,iBAAAA;AAAAA,QACT;AAGA,YAAI,CAAC,eAAe;AAClB,0BAAgB,MAAMC,KAAAA;QACxB;AAGA,cAAM,WAAWD,UAAS;AAC1B,YAAI,YAAY,OAAO,aAAa,YAAY,CAAC,SAAS,QAAQ;AAChEA,oBAAS,SAAS,SAAS;AAAA,QAC7B;AAEA,eAAO,EAAE,GAAGA,WAAU,QAAQ,cAAc;AAAA,SAC3C,KAAY;AAGf,UAAI,KAAK,QAAQ;AAAA,IACnB;AAAA,IACA,EAAE,QAAQ,OAAO,SAAS,GAAG,GAAG,UAAU,OAAO,SAAS,KAAK,MAAM,EAAE;AAAA,IACvE;AAAA,EAAA;AAEJ;;"}
1
+ {"version":3,"file":"default-locale.js","sources":["../../../../../../src/services/document-service/transform/relations/transform/default-locale.ts"],"sourcesContent":["import type { UID } from '@strapi/types';\n\nimport { getDefaultLocale, isLocalizedContentType } from '../utils/i18n';\nimport { mapRelation, traverseEntityRelations } from '../utils/map-relation';\n\n/**\n * In scenarios like Non i18n CT -> i18n CT\n * relations can be connected to multiple locales,\n * in case user does not provide the locale, this sets it to the default one.\n */\nconst setDefaultLocaleToRelations = (data: Record<string, any>, uid: UID.Schema) => {\n // I18n CT -> anything will already have a locale set (source locale)\n if (isLocalizedContentType(uid)) {\n return data;\n }\n\n // Store the default locale to avoid multiple calls\n let defaultLocale: string;\n\n /**\n * Traverse the entity input data and set the default locale to relations\n */\n return traverseEntityRelations(\n async ({ key, value }, { set }) => {\n /**\n * Assign default locale on long hand expressed relations\n * e.g { documentId } -> { documentId, locale }\n */\n const relation = await mapRelation(async (relation) => {\n if (!relation || !relation?.documentId || relation?.locale) {\n return relation;\n }\n\n // Set default locale if not provided\n if (!defaultLocale) {\n defaultLocale = await getDefaultLocale();\n }\n\n // Assign default locale to the positional argument\n const position = relation.position;\n if (position && typeof position === 'object' && !position.locale) {\n relation.position.locale = defaultLocale;\n }\n\n return { ...relation, locale: defaultLocale };\n }, value as any);\n\n // @ts-expect-error - fix type\n set(key, relation);\n },\n { schema: strapi.getModel(uid), getModel: strapi.getModel.bind(strapi) },\n data\n );\n};\n\nexport { setDefaultLocaleToRelations };\n"],"names":["setDefaultLocaleToRelations","data","uid","isLocalizedContentType","defaultLocale","traverseEntityRelations","key","value","set","relation","mapRelation","documentId","locale","getDefaultLocale","position","schema","strapi","getModel","bind"],"mappings":";;;;;AAKA;;;;IAKA,MAAMA,2BAA8B,GAAA,CAACC,IAA2BC,EAAAA,GAAAA,GAAAA;;AAE9D,IAAA,IAAIC,4BAAuBD,GAAM,CAAA,EAAA;QAC/B,OAAOD,IAAAA;AACT;;IAGA,IAAIG,aAAAA;AAEJ;;MAGA,OAAOC,mCACL,CAAA,OAAO,EAAEC,GAAG,EAAEC,KAAK,EAAE,EAAE,EAAEC,GAAG,EAAE,GAAA;AAC5B;;;AAGC,UACD,MAAMC,QAAAA,GAAW,MAAMC,uBAAAA,CAAY,OAAOD,QAAAA,GAAAA;AACxC,YAAA,IAAI,CAACA,QAAY,IAAA,CAACA,QAAUE,EAAAA,UAAAA,IAAcF,UAAUG,MAAQ,EAAA;gBAC1D,OAAOH,QAAAA;AACT;;AAGA,YAAA,IAAI,CAACL,aAAe,EAAA;AAClBA,gBAAAA,aAAAA,GAAgB,MAAMS,qBAAAA,EAAAA;AACxB;;YAGA,MAAMC,QAAAA,GAAWL,SAASK,QAAQ;AAClC,YAAA,IAAIA,YAAY,OAAOA,QAAAA,KAAa,YAAY,CAACA,QAAAA,CAASF,MAAM,EAAE;gBAChEH,QAASK,CAAAA,QAAQ,CAACF,MAAM,GAAGR,aAAAA;AAC7B;YAEA,OAAO;AAAE,gBAAA,GAAGK,QAAQ;gBAAEG,MAAQR,EAAAA;AAAc,aAAA;SAC3CG,EAAAA,KAAAA,CAAAA;;AAGHC,QAAAA,GAAAA,CAAIF,GAAKG,EAAAA,QAAAA,CAAAA;KAEX,EAAA;QAAEM,MAAQC,EAAAA,MAAAA,CAAOC,QAAQ,CAACf,GAAAA,CAAAA;AAAMe,QAAAA,QAAAA,EAAUD,MAAOC,CAAAA,QAAQ,CAACC,IAAI,CAACF,MAAAA;KAC/Df,EAAAA,IAAAA,CAAAA;AAEJ;;;;"}
@@ -1,32 +1,48 @@
1
- import { isLocalizedContentType, getDefaultLocale } from "../utils/i18n.mjs";
2
- import { traverseEntityRelations as traverseEntityRelationsCurried, mapRelation as mapRelationCurried } from "../utils/map-relation.mjs";
3
- const setDefaultLocaleToRelations = (data, uid) => {
4
- if (isLocalizedContentType(uid)) {
5
- return data;
6
- }
7
- let defaultLocale;
8
- return traverseEntityRelationsCurried(
9
- async ({ key, value }, { set }) => {
10
- const relation = await mapRelationCurried(async (relation2) => {
11
- if (!relation2 || !relation2?.documentId || relation2?.locale) {
12
- return relation2;
13
- }
14
- if (!defaultLocale) {
15
- defaultLocale = await getDefaultLocale();
16
- }
17
- const position = relation2.position;
18
- if (position && typeof position === "object" && !position.locale) {
19
- relation2.position.locale = defaultLocale;
20
- }
21
- return { ...relation2, locale: defaultLocale };
22
- }, value);
23
- set(key, relation);
24
- },
25
- { schema: strapi.getModel(uid), getModel: strapi.getModel.bind(strapi) },
26
- data
27
- );
28
- };
29
- export {
30
- setDefaultLocaleToRelations
1
+ import { isLocalizedContentType, getDefaultLocale } from '../utils/i18n.mjs';
2
+ import { traverseEntityRelations as traverseEntityRelationsCurried, mapRelation as mapRelationCurried } from '../utils/map-relation.mjs';
3
+
4
+ /**
5
+ * In scenarios like Non i18n CT -> i18n CT
6
+ * relations can be connected to multiple locales,
7
+ * in case user does not provide the locale, this sets it to the default one.
8
+ */ const setDefaultLocaleToRelations = (data, uid)=>{
9
+ // I18n CT -> anything will already have a locale set (source locale)
10
+ if (isLocalizedContentType(uid)) {
11
+ return data;
12
+ }
13
+ // Store the default locale to avoid multiple calls
14
+ let defaultLocale;
15
+ /**
16
+ * Traverse the entity input data and set the default locale to relations
17
+ */ return traverseEntityRelationsCurried(async ({ key, value }, { set })=>{
18
+ /**
19
+ * Assign default locale on long hand expressed relations
20
+ * e.g { documentId } -> { documentId, locale }
21
+ */ const relation = await mapRelationCurried(async (relation)=>{
22
+ if (!relation || !relation?.documentId || relation?.locale) {
23
+ return relation;
24
+ }
25
+ // Set default locale if not provided
26
+ if (!defaultLocale) {
27
+ defaultLocale = await getDefaultLocale();
28
+ }
29
+ // Assign default locale to the positional argument
30
+ const position = relation.position;
31
+ if (position && typeof position === 'object' && !position.locale) {
32
+ relation.position.locale = defaultLocale;
33
+ }
34
+ return {
35
+ ...relation,
36
+ locale: defaultLocale
37
+ };
38
+ }, value);
39
+ // @ts-expect-error - fix type
40
+ set(key, relation);
41
+ }, {
42
+ schema: strapi.getModel(uid),
43
+ getModel: strapi.getModel.bind(strapi)
44
+ }, data);
31
45
  };
46
+
47
+ export { setDefaultLocaleToRelations };
32
48
  //# sourceMappingURL=default-locale.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"default-locale.mjs","sources":["../../../../../../src/services/document-service/transform/relations/transform/default-locale.ts"],"sourcesContent":["import type { UID } from '@strapi/types';\n\nimport { getDefaultLocale, isLocalizedContentType } from '../utils/i18n';\nimport { mapRelation, traverseEntityRelations } from '../utils/map-relation';\n\n/**\n * In scenarios like Non i18n CT -> i18n CT\n * relations can be connected to multiple locales,\n * in case user does not provide the locale, this sets it to the default one.\n */\nconst setDefaultLocaleToRelations = (data: Record<string, any>, uid: UID.Schema) => {\n // I18n CT -> anything will already have a locale set (source locale)\n if (isLocalizedContentType(uid)) {\n return data;\n }\n\n // Store the default locale to avoid multiple calls\n let defaultLocale: string;\n\n /**\n * Traverse the entity input data and set the default locale to relations\n */\n return traverseEntityRelations(\n async ({ key, value }, { set }) => {\n /**\n * Assign default locale on long hand expressed relations\n * e.g { documentId } -> { documentId, locale }\n */\n const relation = await mapRelation(async (relation) => {\n if (!relation || !relation?.documentId || relation?.locale) {\n return relation;\n }\n\n // Set default locale if not provided\n if (!defaultLocale) {\n defaultLocale = await getDefaultLocale();\n }\n\n // Assign default locale to the positional argument\n const position = relation.position;\n if (position && typeof position === 'object' && !position.locale) {\n relation.position.locale = defaultLocale;\n }\n\n return { ...relation, locale: defaultLocale };\n }, value as any);\n\n // @ts-expect-error - fix type\n set(key, relation);\n },\n { schema: strapi.getModel(uid), getModel: strapi.getModel.bind(strapi) },\n data\n );\n};\n\nexport { setDefaultLocaleToRelations };\n"],"names":["traverseEntityRelations","mapRelation","relation"],"mappings":";;AAUM,MAAA,8BAA8B,CAAC,MAA2B,QAAoB;AAE9E,MAAA,uBAAuB,GAAG,GAAG;AACxB,WAAA;AAAA,EACT;AAGI,MAAA;AAKG,SAAAA;AAAAA,IACL,OAAO,EAAE,KAAK,SAAS,EAAE,UAAU;AAKjC,YAAM,WAAW,MAAMC,mBAAY,OAAOC,cAAa;AACrD,YAAI,CAACA,aAAY,CAACA,WAAU,cAAcA,WAAU,QAAQ;AACnDA,iBAAAA;AAAAA,QACT;AAGA,YAAI,CAAC,eAAe;AAClB,0BAAgB,MAAM;QACxB;AAGA,cAAM,WAAWA,UAAS;AAC1B,YAAI,YAAY,OAAO,aAAa,YAAY,CAAC,SAAS,QAAQ;AAChEA,oBAAS,SAAS,SAAS;AAAA,QAC7B;AAEA,eAAO,EAAE,GAAGA,WAAU,QAAQ,cAAc;AAAA,SAC3C,KAAY;AAGf,UAAI,KAAK,QAAQ;AAAA,IACnB;AAAA,IACA,EAAE,QAAQ,OAAO,SAAS,GAAG,GAAG,UAAU,OAAO,SAAS,KAAK,MAAM,EAAE;AAAA,IACvE;AAAA,EAAA;AAEJ;"}
1
+ {"version":3,"file":"default-locale.mjs","sources":["../../../../../../src/services/document-service/transform/relations/transform/default-locale.ts"],"sourcesContent":["import type { UID } from '@strapi/types';\n\nimport { getDefaultLocale, isLocalizedContentType } from '../utils/i18n';\nimport { mapRelation, traverseEntityRelations } from '../utils/map-relation';\n\n/**\n * In scenarios like Non i18n CT -> i18n CT\n * relations can be connected to multiple locales,\n * in case user does not provide the locale, this sets it to the default one.\n */\nconst setDefaultLocaleToRelations = (data: Record<string, any>, uid: UID.Schema) => {\n // I18n CT -> anything will already have a locale set (source locale)\n if (isLocalizedContentType(uid)) {\n return data;\n }\n\n // Store the default locale to avoid multiple calls\n let defaultLocale: string;\n\n /**\n * Traverse the entity input data and set the default locale to relations\n */\n return traverseEntityRelations(\n async ({ key, value }, { set }) => {\n /**\n * Assign default locale on long hand expressed relations\n * e.g { documentId } -> { documentId, locale }\n */\n const relation = await mapRelation(async (relation) => {\n if (!relation || !relation?.documentId || relation?.locale) {\n return relation;\n }\n\n // Set default locale if not provided\n if (!defaultLocale) {\n defaultLocale = await getDefaultLocale();\n }\n\n // Assign default locale to the positional argument\n const position = relation.position;\n if (position && typeof position === 'object' && !position.locale) {\n relation.position.locale = defaultLocale;\n }\n\n return { ...relation, locale: defaultLocale };\n }, value as any);\n\n // @ts-expect-error - fix type\n set(key, relation);\n },\n { schema: strapi.getModel(uid), getModel: strapi.getModel.bind(strapi) },\n data\n );\n};\n\nexport { setDefaultLocaleToRelations };\n"],"names":["setDefaultLocaleToRelations","data","uid","isLocalizedContentType","defaultLocale","traverseEntityRelations","key","value","set","relation","mapRelation","documentId","locale","getDefaultLocale","position","schema","strapi","getModel","bind"],"mappings":";;;AAKA;;;;IAKA,MAAMA,2BAA8B,GAAA,CAACC,IAA2BC,EAAAA,GAAAA,GAAAA;;AAE9D,IAAA,IAAIC,uBAAuBD,GAAM,CAAA,EAAA;QAC/B,OAAOD,IAAAA;AACT;;IAGA,IAAIG,aAAAA;AAEJ;;MAGA,OAAOC,8BACL,CAAA,OAAO,EAAEC,GAAG,EAAEC,KAAK,EAAE,EAAE,EAAEC,GAAG,EAAE,GAAA;AAC5B;;;AAGC,UACD,MAAMC,QAAAA,GAAW,MAAMC,kBAAAA,CAAY,OAAOD,QAAAA,GAAAA;AACxC,YAAA,IAAI,CAACA,QAAY,IAAA,CAACA,QAAUE,EAAAA,UAAAA,IAAcF,UAAUG,MAAQ,EAAA;gBAC1D,OAAOH,QAAAA;AACT;;AAGA,YAAA,IAAI,CAACL,aAAe,EAAA;AAClBA,gBAAAA,aAAAA,GAAgB,MAAMS,gBAAAA,EAAAA;AACxB;;YAGA,MAAMC,QAAAA,GAAWL,SAASK,QAAQ;AAClC,YAAA,IAAIA,YAAY,OAAOA,QAAAA,KAAa,YAAY,CAACA,QAAAA,CAASF,MAAM,EAAE;gBAChEH,QAASK,CAAAA,QAAQ,CAACF,MAAM,GAAGR,aAAAA;AAC7B;YAEA,OAAO;AAAE,gBAAA,GAAGK,QAAQ;gBAAEG,MAAQR,EAAAA;AAAc,aAAA;SAC3CG,EAAAA,KAAAA,CAAAA;;AAGHC,QAAAA,GAAAA,CAAIF,GAAKG,EAAAA,QAAAA,CAAAA;KAEX,EAAA;QAAEM,MAAQC,EAAAA,MAAAA,CAAOC,QAAQ,CAACf,GAAAA,CAAAA;AAAMe,QAAAA,QAAAA,EAAUD,MAAOC,CAAAA,QAAQ,CAACC,IAAI,CAACF,MAAAA;KAC/Df,EAAAA,IAAAA,CAAAA;AAEJ;;;;"}
@@ -1,4 +1,4 @@
1
- import { UID } from '@strapi/types';
1
+ import type { UID } from '@strapi/types';
2
2
  import { LongHandDocument } from './types';
3
3
  type Status = 'draft' | 'published';
4
4
  export declare const getRelationTargetStatus: (relation: Pick<LongHandDocument, 'documentId' | 'status'>, opts: {
@@ -1 +1 @@
1
- {"version":3,"file":"dp.d.ts","sourceRoot":"","sources":["../../../../../../src/services/document-service/transform/relations/utils/dp.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,GAAG,EAAE,MAAM,eAAe,CAAC;AAEpC,OAAO,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAE3C,KAAK,MAAM,GAAG,OAAO,GAAG,WAAW,CAAC;AAEpC,eAAO,MAAM,uBAAuB,aACxB,KAAK,gBAAgB,EAAE,YAAY,GAAG,QAAQ,CAAC,QACnD;IACJ,SAAS,EAAE,IAAI,MAAM,CAAC;IACtB,SAAS,EAAE,IAAI,MAAM,CAAC;IACtB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,KACA,MAAM,EA2CR,CAAC"}
1
+ {"version":3,"file":"dp.d.ts","sourceRoot":"","sources":["../../../../../../src/services/document-service/transform/relations/utils/dp.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,eAAe,CAAC;AAEzC,OAAO,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAE3C,KAAK,MAAM,GAAG,OAAO,GAAG,WAAW,CAAC;AAEpC,eAAO,MAAM,uBAAuB,aACxB,KAAK,gBAAgB,EAAE,YAAY,GAAG,QAAQ,CAAC,QACnD;IACJ,SAAS,EAAE,IAAI,MAAM,CAAC;IACtB,SAAS,EAAE,IAAI,MAAM,CAAC;IACtB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,KACA,MAAM,EA2CR,CAAC"}
@@ -1,30 +1,56 @@
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 getRelationTargetStatus = (relation, opts) => {
6
- const targetContentType = strapi.getModel(opts.targetUid);
7
- const sourceContentType = strapi.getModel(opts.sourceUid);
8
- const targetHasDP = strapiUtils.contentTypes.hasDraftAndPublish(targetContentType);
9
- const sourceHasDP = strapiUtils.contentTypes.hasDraftAndPublish(sourceContentType);
10
- if (!targetHasDP) {
11
- return ["published"];
12
- }
13
- if (sourceHasDP && !fp.isNil(opts.sourceStatus)) {
14
- return [opts.sourceStatus];
15
- }
16
- if (relation.status) {
17
- switch (relation.status) {
18
- case "published":
19
- return ["published"];
20
- default:
21
- return ["draft"];
1
+ 'use strict';
2
+
3
+ var fp = require('lodash/fp');
4
+ var strapiUtils = require('@strapi/utils');
5
+
6
+ const getRelationTargetStatus = (relation, opts)=>{
7
+ // Ignore if the target content type does not have draft and publish enabled
8
+ const targetContentType = strapi.getModel(opts.targetUid);
9
+ const sourceContentType = strapi.getModel(opts.sourceUid);
10
+ const targetHasDP = strapiUtils.contentTypes.hasDraftAndPublish(targetContentType);
11
+ const sourceHasDP = strapiUtils.contentTypes.hasDraftAndPublish(sourceContentType);
12
+ if (!targetHasDP) {
13
+ return [
14
+ 'published'
15
+ ];
22
16
  }
23
- }
24
- if (!sourceHasDP) {
25
- return ["draft", "published"];
26
- }
27
- return ["draft"];
17
+ /**
18
+ * If both source and target have DP enabled,
19
+ * connect it to the same status as the source status
20
+ */ if (sourceHasDP && !fp.isNil(opts.sourceStatus)) {
21
+ return [
22
+ opts.sourceStatus
23
+ ];
24
+ }
25
+ /**
26
+ * Use the status from the relation if it's set
27
+ */ if (relation.status) {
28
+ switch(relation.status){
29
+ case 'published':
30
+ return [
31
+ 'published'
32
+ ];
33
+ default:
34
+ // Default to draft if it's an invalid status (e.g. modified)
35
+ return [
36
+ 'draft'
37
+ ];
38
+ }
39
+ }
40
+ /**
41
+ * If DP is disabled and relation does not specify any status
42
+ * Connect to both draft and published versions
43
+ */ if (!sourceHasDP) {
44
+ return [
45
+ 'draft',
46
+ 'published'
47
+ ];
48
+ }
49
+ // Default to draft as a fallback
50
+ return [
51
+ 'draft'
52
+ ];
28
53
  };
54
+
29
55
  exports.getRelationTargetStatus = getRelationTargetStatus;
30
56
  //# sourceMappingURL=dp.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"dp.js","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":["contentTypes","isNil"],"mappings":";;;;AASa,MAAA,0BAA0B,CACrC,UACA,SAKa;AAEb,QAAM,oBAAoB,OAAO,SAAS,KAAK,SAAS;AACxD,QAAM,oBAAoB,OAAO,SAAS,KAAK,SAAS;AAElD,QAAA,cAAcA,YAAAA,aAAa,mBAAmB,iBAAiB;AAC/D,QAAA,cAAcA,YAAAA,aAAa,mBAAmB,iBAAiB;AAErE,MAAI,CAAC,aAAa;AAChB,WAAO,CAAC,WAAW;AAAA,EACrB;AAMA,MAAI,eAAe,CAACC,GAAAA,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
+ {"version":3,"file":"dp.js","sources":["../../../../../../src/services/document-service/transform/relations/utils/dp.ts"],"sourcesContent":["import { isNil } from 'lodash/fp';\n\nimport { contentTypes } from '@strapi/utils';\nimport type { 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":["getRelationTargetStatus","relation","opts","targetContentType","strapi","getModel","targetUid","sourceContentType","sourceUid","targetHasDP","contentTypes","hasDraftAndPublish","sourceHasDP","isNil","sourceStatus","status"],"mappings":";;;;;AASO,MAAMA,uBAA0B,GAAA,CACrCC,QACAC,EAAAA,IAAAA,GAAAA;;AAOA,IAAA,MAAMC,iBAAoBC,GAAAA,MAAAA,CAAOC,QAAQ,CAACH,KAAKI,SAAS,CAAA;AACxD,IAAA,MAAMC,iBAAoBH,GAAAA,MAAAA,CAAOC,QAAQ,CAACH,KAAKM,SAAS,CAAA;IAExD,MAAMC,WAAAA,GAAcC,wBAAaC,CAAAA,kBAAkB,CAACR,iBAAAA,CAAAA;IACpD,MAAMS,WAAAA,GAAcF,wBAAaC,CAAAA,kBAAkB,CAACJ,iBAAAA,CAAAA;AAEpD,IAAA,IAAI,CAACE,WAAa,EAAA;QAChB,OAAO;AAAC,YAAA;AAAY,SAAA;AACtB;AAEA;;;AAGC,MACD,IAAIG,WAAe,IAAA,CAACC,QAAMX,CAAAA,IAAAA,CAAKY,YAAY,CAAG,EAAA;QAC5C,OAAO;AAACZ,YAAAA,IAAAA,CAAKY;AAAa,SAAA;AAC5B;AAEA;;MAGA,IAAIb,QAASc,CAAAA,MAAM,EAAE;AACnB,QAAA,OAAQd,SAASc,MAAM;YACrB,KAAK,WAAA;gBACH,OAAO;AAAC,oBAAA;AAAY,iBAAA;AACtB,YAAA;;gBAEE,OAAO;AAAC,oBAAA;AAAQ,iBAAA;AACpB;AACF;AAEA;;;MAIA,IAAI,CAACH,WAAa,EAAA;QAChB,OAAO;AAAC,YAAA,OAAA;AAAS,YAAA;AAAY,SAAA;AAC/B;;IAGA,OAAO;AAAC,QAAA;AAAQ,KAAA;AAClB;;;;"}
@@ -1,30 +1,54 @@
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"];
1
+ import { isNil } from 'lodash/fp';
2
+ import { contentTypes } from '@strapi/utils';
3
+
4
+ const getRelationTargetStatus = (relation, opts)=>{
5
+ // Ignore if the target content type does not have draft and publish enabled
6
+ const targetContentType = strapi.getModel(opts.targetUid);
7
+ const sourceContentType = strapi.getModel(opts.sourceUid);
8
+ const targetHasDP = contentTypes.hasDraftAndPublish(targetContentType);
9
+ const sourceHasDP = contentTypes.hasDraftAndPublish(sourceContentType);
10
+ if (!targetHasDP) {
11
+ return [
12
+ 'published'
13
+ ];
20
14
  }
21
- }
22
- if (!sourceHasDP) {
23
- return ["draft", "published"];
24
- }
25
- return ["draft"];
26
- };
27
- export {
28
- getRelationTargetStatus
15
+ /**
16
+ * If both source and target have DP enabled,
17
+ * connect it to the same status as the source status
18
+ */ if (sourceHasDP && !isNil(opts.sourceStatus)) {
19
+ return [
20
+ opts.sourceStatus
21
+ ];
22
+ }
23
+ /**
24
+ * Use the status from the relation if it's set
25
+ */ if (relation.status) {
26
+ switch(relation.status){
27
+ case 'published':
28
+ return [
29
+ 'published'
30
+ ];
31
+ default:
32
+ // Default to draft if it's an invalid status (e.g. modified)
33
+ return [
34
+ 'draft'
35
+ ];
36
+ }
37
+ }
38
+ /**
39
+ * If DP is disabled and relation does not specify any status
40
+ * Connect to both draft and published versions
41
+ */ if (!sourceHasDP) {
42
+ return [
43
+ 'draft',
44
+ 'published'
45
+ ];
46
+ }
47
+ // Default to draft as a fallback
48
+ return [
49
+ 'draft'
50
+ ];
29
51
  };
52
+
53
+ export { getRelationTargetStatus };
30
54
  //# sourceMappingURL=dp.mjs.map