@strapi/core 0.0.0-experimental.e02b4637b3906c6d31048d00600d09a23a0edc3d → 0.0.0-experimental.e12978dcee698470990e9c5c63384faf2c307443

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 +12 -9
  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 +27 -28
  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 -314
  453. package/dist/services/document-service/repository.js.map +0 -1
  454. package/dist/services/document-service/repository.mjs +0 -314
  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 -57
  509. package/dist/services/document-service/utils/unidirectional-relations.js.map +0 -1
  510. package/dist/services/document-service/utils/unidirectional-relations.mjs +0 -57
  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,288 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const _ = require("lodash");
4
- const fp = require("lodash/fp");
5
- const strapiUtils = require("@strapi/utils");
6
- const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
7
- const ___default = /* @__PURE__ */ _interopDefault(_);
8
- const omitComponentData = fp.curry(
9
- (schema, data) => {
10
- const { attributes } = schema;
11
- const componentAttributes = Object.keys(attributes).filter(
12
- (attributeName) => strapiUtils.contentTypes.isComponentAttribute(attributes[attributeName])
13
- );
14
- return fp.omit(componentAttributes, data);
15
- }
16
- );
17
- const createComponents = async (uid, data) => {
18
- const { attributes = {} } = strapi.getModel(uid);
19
- const componentBody = {};
20
- const attributeNames = Object.keys(attributes);
21
- for (const attributeName of attributeNames) {
22
- const attribute = attributes[attributeName];
23
- if (!fp.has(attributeName, data) || !strapiUtils.contentTypes.isComponentAttribute(attribute)) {
24
- continue;
25
- }
26
- if (attribute.type === "component") {
27
- const { component: componentUID, repeatable = false } = attribute;
28
- const componentValue = data[attributeName];
29
- if (componentValue === null) {
30
- continue;
31
- }
32
- if (repeatable === true) {
33
- if (!Array.isArray(componentValue)) {
34
- throw new Error("Expected an array to create repeatable component");
35
- }
36
- const components = await strapiUtils.async.map(
37
- componentValue,
38
- (value) => createComponent(componentUID, value)
39
- );
40
- componentBody[attributeName] = components.map(({ id }) => {
41
- return {
42
- id,
43
- __pivot: {
44
- field: attributeName,
45
- component_type: componentUID
46
- }
47
- };
48
- });
49
- } else {
50
- const component = await createComponent(
51
- componentUID,
52
- componentValue
53
- );
54
- componentBody[attributeName] = {
55
- id: component.id,
56
- __pivot: {
57
- field: attributeName,
58
- component_type: componentUID
59
- }
60
- };
61
- }
62
- continue;
63
- }
64
- if (attribute.type === "dynamiczone") {
65
- const dynamiczoneValues = data[attributeName];
66
- if (!Array.isArray(dynamiczoneValues)) {
67
- throw new Error("Expected an array to create repeatable component");
68
- }
69
- const createDynamicZoneComponents = async (value) => {
70
- const { id } = await createComponent(value.__component, value);
71
- return {
72
- id,
73
- __component: value.__component,
74
- __pivot: {
75
- field: attributeName
76
- }
77
- };
78
- };
79
- componentBody[attributeName] = await strapiUtils.async.map(
80
- dynamiczoneValues,
81
- createDynamicZoneComponents
82
- );
83
- continue;
84
- }
85
- }
86
- return componentBody;
87
- };
88
- const getComponents = async (uid, entity) => {
89
- const componentAttributes = strapiUtils.contentTypes.getComponentAttributes(strapi.getModel(uid));
90
- if (___default.default.isEmpty(componentAttributes)) {
91
- return {};
92
- }
93
- return strapi.db.query(uid).load(entity, componentAttributes);
94
- };
95
- const updateComponents = async (uid, entityToUpdate, data) => {
96
- const { attributes = {} } = strapi.getModel(uid);
97
- const componentBody = {};
98
- for (const attributeName of Object.keys(attributes)) {
99
- const attribute = attributes[attributeName];
100
- if (!fp.has(attributeName, data)) {
101
- continue;
102
- }
103
- if (attribute.type === "component") {
104
- const { component: componentUID, repeatable = false } = attribute;
105
- const componentValue = data[attributeName];
106
- await deleteOldComponents(uid, componentUID, entityToUpdate, attributeName, componentValue);
107
- if (repeatable === true) {
108
- if (!Array.isArray(componentValue)) {
109
- throw new Error("Expected an array to create repeatable component");
110
- }
111
- const components = await strapiUtils.async.map(
112
- componentValue,
113
- (value) => updateOrCreateComponent(componentUID, value)
114
- );
115
- componentBody[attributeName] = components.filter(___default.default.negate(___default.default.isNil)).map(({ id }) => {
116
- return {
117
- id,
118
- __pivot: {
119
- field: attributeName,
120
- component_type: componentUID
121
- }
122
- };
123
- });
124
- } else {
125
- const component = await updateOrCreateComponent(componentUID, componentValue);
126
- componentBody[attributeName] = component && {
127
- id: component.id,
128
- __pivot: {
129
- field: attributeName,
130
- component_type: componentUID
131
- }
132
- };
133
- }
134
- } else if (attribute.type === "dynamiczone") {
135
- const dynamiczoneValues = data[attributeName];
136
- await deleteOldDZComponents(uid, entityToUpdate, attributeName, dynamiczoneValues);
137
- if (!Array.isArray(dynamiczoneValues)) {
138
- throw new Error("Expected an array to create repeatable component");
139
- }
140
- componentBody[attributeName] = await strapiUtils.async.map(dynamiczoneValues, async (value) => {
141
- const { id } = await updateOrCreateComponent(value.__component, value);
142
- return {
143
- id,
144
- __component: value.__component,
145
- __pivot: {
146
- field: attributeName
147
- }
148
- };
149
- });
150
- }
151
- }
152
- return componentBody;
153
- };
154
- const pickStringifiedId = ({
155
- id
156
- }) => {
157
- if (typeof id === "string") {
158
- return id;
159
- }
160
- return `${id}`;
161
- };
162
- const deleteOldComponents = async (uid, componentUID, entityToUpdate, attributeName, componentValue) => {
163
- const previousValue = await strapi.db.query(uid).load(entityToUpdate, attributeName);
164
- const idsToKeep = ___default.default.castArray(componentValue).filter(fp.has("id")).map(pickStringifiedId);
165
- const allIds = ___default.default.castArray(previousValue).filter(fp.has("id")).map(pickStringifiedId);
166
- idsToKeep.forEach((id) => {
167
- if (!allIds.includes(id)) {
168
- throw new strapiUtils.errors.ApplicationError(
169
- `Some of the provided components in ${attributeName} are not related to the entity`
170
- );
171
- }
172
- });
173
- const idsToDelete = ___default.default.difference(allIds, idsToKeep);
174
- if (idsToDelete.length > 0) {
175
- for (const idToDelete of idsToDelete) {
176
- await deleteComponent(componentUID, { id: idToDelete });
177
- }
178
- }
179
- };
180
- const deleteOldDZComponents = async (uid, entityToUpdate, attributeName, dynamiczoneValues) => {
181
- const previousValue = await strapi.db.query(uid).load(entityToUpdate, attributeName);
182
- const idsToKeep = ___default.default.castArray(dynamiczoneValues).filter(fp.has("id")).map((v) => ({
183
- id: pickStringifiedId(v),
184
- __component: v.__component
185
- }));
186
- const allIds = ___default.default.castArray(previousValue).filter(fp.has("id")).map((v) => ({
187
- id: pickStringifiedId(v),
188
- __component: v.__component
189
- }));
190
- idsToKeep.forEach(({ id, __component }) => {
191
- if (!allIds.find((el) => el.id === id && el.__component === __component)) {
192
- const err = new Error(
193
- `Some of the provided components in ${attributeName} are not related to the entity`
194
- );
195
- Object.assign(err, { status: 400 });
196
- throw err;
197
- }
198
- });
199
- const idsToDelete = allIds.reduce((acc, { id, __component }) => {
200
- if (!idsToKeep.find((el) => el.id === id && el.__component === __component)) {
201
- acc.push({ id, __component });
202
- }
203
- return acc;
204
- }, []);
205
- if (idsToDelete.length > 0) {
206
- for (const idToDelete of idsToDelete) {
207
- const { id, __component } = idToDelete;
208
- await deleteComponent(__component, { id });
209
- }
210
- }
211
- };
212
- const deleteComponents = async (uid, entityToDelete, { loadComponents = true } = {}) => {
213
- const { attributes = {} } = strapi.getModel(uid);
214
- const attributeNames = Object.keys(attributes);
215
- for (const attributeName of attributeNames) {
216
- const attribute = attributes[attributeName];
217
- if (attribute.type === "component" || attribute.type === "dynamiczone") {
218
- let value;
219
- if (loadComponents) {
220
- value = await strapi.db.query(uid).load(entityToDelete, attributeName);
221
- } else {
222
- value = entityToDelete[attributeName];
223
- }
224
- if (!value) {
225
- continue;
226
- }
227
- if (attribute.type === "component") {
228
- const { component: componentUID } = attribute;
229
- await strapiUtils.async.map(
230
- ___default.default.castArray(value),
231
- (subValue) => deleteComponent(componentUID, subValue)
232
- );
233
- } else {
234
- await strapiUtils.async.map(
235
- ___default.default.castArray(value),
236
- (subValue) => deleteComponent(subValue.__component, subValue)
237
- );
238
- }
239
- continue;
240
- }
241
- }
242
- };
243
- const createComponent = async (uid, data) => {
244
- const schema = strapi.getModel(uid);
245
- const componentData = await createComponents(uid, data);
246
- const transform = fp.pipe(
247
- // Make sure we don't save the component with a pre-defined ID
248
- fp.omit("id"),
249
- assignComponentData(schema, componentData)
250
- );
251
- return strapi.db.query(uid).create({ data: transform(data) });
252
- };
253
- const updateComponent = async (uid, componentToUpdate, data) => {
254
- const schema = strapi.getModel(uid);
255
- const componentData = await updateComponents(uid, componentToUpdate, data);
256
- return strapi.db.query(uid).update({
257
- where: {
258
- id: componentToUpdate.id
259
- },
260
- data: assignComponentData(schema, componentData, data)
261
- });
262
- };
263
- const updateOrCreateComponent = (componentUID, value) => {
264
- if (value === null) {
265
- return null;
266
- }
267
- if ("id" in value && typeof value.id !== "undefined") {
268
- return updateComponent(componentUID, { id: value.id }, value);
269
- }
270
- return createComponent(componentUID, value);
271
- };
272
- const deleteComponent = async (uid, componentToDelete) => {
273
- await deleteComponents(uid, componentToDelete);
274
- await strapi.db.query(uid).delete({ where: { id: componentToDelete.id } });
275
- };
276
- const assignComponentData = fp.curry(
277
- (schema, componentData, data) => {
278
- return fp.pipe(omitComponentData(schema), fp.assign(componentData))(data);
279
- }
280
- );
281
- exports.assignComponentData = assignComponentData;
282
- exports.createComponents = createComponents;
283
- exports.deleteComponent = deleteComponent;
284
- exports.deleteComponents = deleteComponents;
285
- exports.getComponents = getComponents;
286
- exports.omitComponentData = omitComponentData;
287
- exports.updateComponents = updateComponents;
288
- //# sourceMappingURL=components.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"components.js","sources":["../../../src/services/document-service/components.ts"],"sourcesContent":["import _ from 'lodash';\nimport { has, omit, pipe, assign, curry } from 'lodash/fp';\nimport type { Utils, UID, Schema, Data, Modules } from '@strapi/types';\nimport { contentTypes as contentTypesUtils, async, errors } from '@strapi/utils';\n\n// type aliases for readability\ntype Input<T extends UID.Schema> = Modules.Documents.Params.Data.Input<T>;\n\ntype LoadedComponents<TUID extends UID.Schema> = Data.Entity<\n TUID,\n Schema.AttributeNamesByType<TUID, 'component' | 'dynamiczone'>\n>;\n\ntype SingleComponentValue = Schema.Attribute.ComponentValue<UID.Component, false>;\ntype RepeatableComponentValue = Schema.Attribute.ComponentValue<UID.Component, true>;\n\ntype ComponentValue = SingleComponentValue | RepeatableComponentValue;\n\ntype DynamicZoneValue = Schema.Attribute.DynamicZoneValue<UID.Component[]>;\n\ntype ComponentBody = {\n [key: string]: ComponentValue | DynamicZoneValue;\n};\n\nconst omitComponentData = curry(\n (schema: Schema.Schema, data: Input<UID.Schema>): Partial<Input<UID.Schema>> => {\n const { attributes } = schema;\n const componentAttributes = Object.keys(attributes).filter((attributeName) =>\n contentTypesUtils.isComponentAttribute(attributes[attributeName])\n );\n\n return omit(componentAttributes, data);\n }\n);\n\n// NOTE: we could generalize the logic to allow CRUD of relation directly in the DB layer\nconst createComponents = async <TUID extends UID.Schema, TData extends Input<TUID>>(\n uid: TUID,\n data: TData\n) => {\n const { attributes = {} } = strapi.getModel(uid);\n\n const componentBody: ComponentBody = {};\n\n const attributeNames = Object.keys(attributes);\n\n for (const attributeName of attributeNames) {\n const attribute = attributes[attributeName];\n\n if (!has(attributeName, data) || !contentTypesUtils.isComponentAttribute(attribute)) {\n continue;\n }\n\n if (attribute.type === 'component') {\n const { component: componentUID, repeatable = false } = attribute;\n\n const componentValue = data[attributeName as keyof TData];\n\n if (componentValue === null) {\n continue;\n }\n\n if (repeatable === true) {\n if (!Array.isArray(componentValue)) {\n throw new Error('Expected an array to create repeatable component');\n }\n\n const components: RepeatableComponentValue = await async.map(componentValue, (value: any) =>\n createComponent(componentUID, value)\n );\n\n componentBody[attributeName] = components.map(({ id }) => {\n return {\n id,\n __pivot: {\n field: attributeName,\n component_type: componentUID,\n },\n };\n });\n } else {\n const component = await createComponent(\n componentUID,\n componentValue as Input<UID.Component>\n );\n\n componentBody[attributeName] = {\n id: component.id,\n __pivot: {\n field: attributeName,\n component_type: componentUID,\n },\n };\n }\n\n continue;\n }\n\n if (attribute.type === 'dynamiczone') {\n const dynamiczoneValues = data[\n attributeName as keyof TData\n ] as Modules.EntityService.Params.Attribute.GetValue<Schema.Attribute.DynamicZone>;\n\n if (!Array.isArray(dynamiczoneValues)) {\n throw new Error('Expected an array to create repeatable component');\n }\n\n const createDynamicZoneComponents = async (\n value: Utils.Array.Values<typeof dynamiczoneValues>\n ) => {\n const { id } = await createComponent(value.__component, value);\n return {\n id,\n __component: value.__component,\n __pivot: {\n field: attributeName,\n },\n };\n };\n\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n componentBody[attributeName] = await async.map(\n dynamiczoneValues,\n createDynamicZoneComponents\n );\n\n continue;\n }\n }\n\n return componentBody;\n};\n\nconst getComponents = async <TUID extends UID.Schema>(\n uid: TUID,\n entity: { id: Modules.EntityService.Params.Attribute.ID }\n): Promise<LoadedComponents<TUID>> => {\n const componentAttributes = contentTypesUtils.getComponentAttributes(strapi.getModel(uid));\n\n if (_.isEmpty(componentAttributes)) {\n return {} as LoadedComponents<TUID>;\n }\n\n return strapi.db.query(uid).load(entity, componentAttributes) as Promise<LoadedComponents<TUID>>;\n};\n\n/*\n delete old components\n create or update\n*/\nconst updateComponents = async <TUID extends UID.Schema, TData extends Partial<Input<TUID>>>(\n uid: TUID,\n entityToUpdate: { id: Modules.EntityService.Params.Attribute.ID },\n data: TData\n) => {\n const { attributes = {} } = strapi.getModel(uid);\n\n const componentBody: ComponentBody = {};\n\n for (const attributeName of Object.keys(attributes)) {\n const attribute = attributes[attributeName];\n\n if (!has(attributeName, data)) {\n continue;\n }\n\n if (attribute.type === 'component') {\n const { component: componentUID, repeatable = false } = attribute;\n\n const componentValue = data[attributeName as keyof TData] as ComponentValue;\n\n await deleteOldComponents(uid, componentUID, entityToUpdate, attributeName, componentValue);\n\n if (repeatable === true) {\n if (!Array.isArray(componentValue)) {\n throw new Error('Expected an array to create repeatable component');\n }\n\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n const components: RepeatableComponentValue = await async.map(componentValue, (value: any) =>\n updateOrCreateComponent(componentUID, value)\n );\n\n componentBody[attributeName] = components.filter(_.negate(_.isNil)).map(({ id }) => {\n return {\n id,\n __pivot: {\n field: attributeName,\n component_type: componentUID,\n },\n };\n });\n } else {\n const component = await updateOrCreateComponent(componentUID, componentValue);\n componentBody[attributeName] = component && {\n id: component.id,\n __pivot: {\n field: attributeName,\n component_type: componentUID,\n },\n };\n }\n } else if (attribute.type === 'dynamiczone') {\n const dynamiczoneValues = data[attributeName as keyof TData] as DynamicZoneValue;\n\n await deleteOldDZComponents(uid, entityToUpdate, attributeName, dynamiczoneValues);\n\n if (!Array.isArray(dynamiczoneValues)) {\n throw new Error('Expected an array to create repeatable component');\n }\n\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n componentBody[attributeName] = await async.map(dynamiczoneValues, async (value: any) => {\n const { id } = await updateOrCreateComponent(value.__component, value);\n\n return {\n id,\n __component: value.__component,\n __pivot: {\n field: attributeName,\n },\n };\n });\n }\n }\n\n return componentBody;\n};\n\nconst pickStringifiedId = ({\n id,\n}: {\n id: Modules.EntityService.Params.Attribute.ID;\n}): Modules.EntityService.Params.Attribute.ID & string => {\n if (typeof id === 'string') {\n return id;\n }\n\n return `${id}`;\n};\n\nconst deleteOldComponents = async <TUID extends UID.Schema>(\n uid: TUID,\n componentUID: UID.Component,\n entityToUpdate: { id: Modules.EntityService.Params.Attribute.ID },\n attributeName: string,\n componentValue: ComponentValue\n) => {\n const previousValue = (await strapi.db\n .query(uid)\n .load(entityToUpdate, attributeName)) as ComponentValue;\n\n const idsToKeep = _.castArray(componentValue).filter(has('id')).map(pickStringifiedId);\n const allIds = _.castArray(previousValue).filter(has('id')).map(pickStringifiedId);\n\n idsToKeep.forEach((id) => {\n if (!allIds.includes(id)) {\n throw new errors.ApplicationError(\n `Some of the provided components in ${attributeName} are not related to the entity`\n );\n }\n });\n\n const idsToDelete = _.difference(allIds, idsToKeep);\n\n if (idsToDelete.length > 0) {\n for (const idToDelete of idsToDelete) {\n await deleteComponent(componentUID, { id: idToDelete });\n }\n }\n};\n\nconst deleteOldDZComponents = async <TUID extends UID.Schema>(\n uid: TUID,\n entityToUpdate: { id: Modules.EntityService.Params.Attribute.ID },\n attributeName: string,\n dynamiczoneValues: DynamicZoneValue\n) => {\n const previousValue = (await strapi.db\n .query(uid)\n .load(entityToUpdate, attributeName)) as DynamicZoneValue;\n\n const idsToKeep = _.castArray(dynamiczoneValues)\n .filter(has('id'))\n .map((v) => ({\n id: pickStringifiedId(v),\n __component: v.__component,\n }));\n\n const allIds = _.castArray(previousValue)\n .filter(has('id'))\n .map((v) => ({\n id: pickStringifiedId(v),\n __component: v.__component,\n }));\n\n idsToKeep.forEach(({ id, __component }) => {\n if (!allIds.find((el) => el.id === id && el.__component === __component)) {\n const err = new Error(\n `Some of the provided components in ${attributeName} are not related to the entity`\n );\n\n Object.assign(err, { status: 400 });\n throw err;\n }\n });\n\n type IdsToDelete = DynamicZoneValue;\n\n const idsToDelete = allIds.reduce((acc, { id, __component }) => {\n if (!idsToKeep.find((el) => el.id === id && el.__component === __component)) {\n acc.push({ id, __component });\n }\n\n return acc;\n }, [] as IdsToDelete);\n\n if (idsToDelete.length > 0) {\n for (const idToDelete of idsToDelete) {\n const { id, __component } = idToDelete;\n await deleteComponent(__component, { id });\n }\n }\n};\n\nconst deleteComponents = async <TUID extends UID.Schema, TEntity extends Data.Entity<TUID>>(\n uid: TUID,\n entityToDelete: TEntity,\n { loadComponents = true } = {}\n) => {\n const { attributes = {} } = strapi.getModel(uid);\n\n const attributeNames = Object.keys(attributes);\n\n for (const attributeName of attributeNames) {\n const attribute = attributes[attributeName];\n\n if (attribute.type === 'component' || attribute.type === 'dynamiczone') {\n let value;\n\n if (loadComponents) {\n value = await strapi.db.query(uid).load(entityToDelete, attributeName);\n } else {\n value = entityToDelete[attributeName as keyof TEntity];\n }\n\n if (!value) {\n continue;\n }\n\n if (attribute.type === 'component') {\n const { component: componentUID } = attribute;\n await async.map(_.castArray(value), (subValue: any) =>\n deleteComponent(componentUID, subValue)\n );\n } else {\n await async.map(_.castArray(value), (subValue: any) =>\n deleteComponent(subValue.__component, subValue)\n );\n }\n\n continue;\n }\n }\n};\n\n/** *************************\n Component queries\n************************** */\n\n// components can have nested compos so this must be recursive\nconst createComponent = async <TUID extends UID.Component>(uid: TUID, data: Input<TUID>) => {\n const schema = strapi.getModel(uid);\n\n const componentData = await createComponents(uid, data);\n\n const transform = pipe(\n // Make sure we don't save the component with a pre-defined ID\n omit('id'),\n assignComponentData(schema, componentData)\n );\n\n return strapi.db.query(uid).create({ data: transform(data) });\n};\n\n// components can have nested compos so this must be recursive\nconst updateComponent = async <TUID extends UID.Component>(\n uid: TUID,\n componentToUpdate: { id: Modules.EntityService.Params.Attribute.ID },\n data: Input<TUID>\n) => {\n const schema = strapi.getModel(uid);\n\n const componentData = await updateComponents(uid, componentToUpdate, data);\n\n return strapi.db.query(uid).update({\n where: {\n id: componentToUpdate.id,\n },\n data: assignComponentData(schema, componentData, data),\n });\n};\n\nconst updateOrCreateComponent = <TUID extends UID.Component>(\n componentUID: TUID,\n value: Input<TUID>\n) => {\n if (value === null) {\n return null;\n }\n\n // update\n if ('id' in value && typeof value.id !== 'undefined') {\n // TODO: verify the compo is associated with the entity\n return updateComponent(componentUID, { id: value.id }, value);\n }\n\n // create\n return createComponent(componentUID, value);\n};\n\nconst deleteComponent = async <TUID extends UID.Component>(\n uid: TUID,\n componentToDelete: Data.Component<TUID>\n) => {\n await deleteComponents(uid, componentToDelete);\n await strapi.db.query(uid).delete({ where: { id: componentToDelete.id } });\n};\n\nconst assignComponentData = curry(\n (schema: Schema.Schema, componentData: ComponentBody, data: Input<UID.Schema>) => {\n return pipe(omitComponentData(schema), assign(componentData))(data);\n }\n);\n\nexport {\n omitComponentData,\n assignComponentData,\n getComponents,\n createComponents,\n updateComponents,\n deleteComponents,\n deleteComponent,\n};\n"],"names":["curry","contentTypesUtils","omit","has","async","_","errors","pipe","assign"],"mappings":"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"}
@@ -1,286 +0,0 @@
1
- import _ from "lodash";
2
- import { curry, omit, pipe, assign, has } from "lodash/fp";
3
- import { contentTypes, async, errors } from "@strapi/utils";
4
- const omitComponentData = curry(
5
- (schema, data) => {
6
- const { attributes } = schema;
7
- const componentAttributes = Object.keys(attributes).filter(
8
- (attributeName) => contentTypes.isComponentAttribute(attributes[attributeName])
9
- );
10
- return omit(componentAttributes, data);
11
- }
12
- );
13
- const createComponents = async (uid, data) => {
14
- const { attributes = {} } = strapi.getModel(uid);
15
- const componentBody = {};
16
- const attributeNames = Object.keys(attributes);
17
- for (const attributeName of attributeNames) {
18
- const attribute = attributes[attributeName];
19
- if (!has(attributeName, data) || !contentTypes.isComponentAttribute(attribute)) {
20
- continue;
21
- }
22
- if (attribute.type === "component") {
23
- const { component: componentUID, repeatable = false } = attribute;
24
- const componentValue = data[attributeName];
25
- if (componentValue === null) {
26
- continue;
27
- }
28
- if (repeatable === true) {
29
- if (!Array.isArray(componentValue)) {
30
- throw new Error("Expected an array to create repeatable component");
31
- }
32
- const components = await async.map(
33
- componentValue,
34
- (value) => createComponent(componentUID, value)
35
- );
36
- componentBody[attributeName] = components.map(({ id }) => {
37
- return {
38
- id,
39
- __pivot: {
40
- field: attributeName,
41
- component_type: componentUID
42
- }
43
- };
44
- });
45
- } else {
46
- const component = await createComponent(
47
- componentUID,
48
- componentValue
49
- );
50
- componentBody[attributeName] = {
51
- id: component.id,
52
- __pivot: {
53
- field: attributeName,
54
- component_type: componentUID
55
- }
56
- };
57
- }
58
- continue;
59
- }
60
- if (attribute.type === "dynamiczone") {
61
- const dynamiczoneValues = data[attributeName];
62
- if (!Array.isArray(dynamiczoneValues)) {
63
- throw new Error("Expected an array to create repeatable component");
64
- }
65
- const createDynamicZoneComponents = async (value) => {
66
- const { id } = await createComponent(value.__component, value);
67
- return {
68
- id,
69
- __component: value.__component,
70
- __pivot: {
71
- field: attributeName
72
- }
73
- };
74
- };
75
- componentBody[attributeName] = await async.map(
76
- dynamiczoneValues,
77
- createDynamicZoneComponents
78
- );
79
- continue;
80
- }
81
- }
82
- return componentBody;
83
- };
84
- const getComponents = async (uid, entity) => {
85
- const componentAttributes = contentTypes.getComponentAttributes(strapi.getModel(uid));
86
- if (_.isEmpty(componentAttributes)) {
87
- return {};
88
- }
89
- return strapi.db.query(uid).load(entity, componentAttributes);
90
- };
91
- const updateComponents = async (uid, entityToUpdate, data) => {
92
- const { attributes = {} } = strapi.getModel(uid);
93
- const componentBody = {};
94
- for (const attributeName of Object.keys(attributes)) {
95
- const attribute = attributes[attributeName];
96
- if (!has(attributeName, data)) {
97
- continue;
98
- }
99
- if (attribute.type === "component") {
100
- const { component: componentUID, repeatable = false } = attribute;
101
- const componentValue = data[attributeName];
102
- await deleteOldComponents(uid, componentUID, entityToUpdate, attributeName, componentValue);
103
- if (repeatable === true) {
104
- if (!Array.isArray(componentValue)) {
105
- throw new Error("Expected an array to create repeatable component");
106
- }
107
- const components = await async.map(
108
- componentValue,
109
- (value) => updateOrCreateComponent(componentUID, value)
110
- );
111
- componentBody[attributeName] = components.filter(_.negate(_.isNil)).map(({ id }) => {
112
- return {
113
- id,
114
- __pivot: {
115
- field: attributeName,
116
- component_type: componentUID
117
- }
118
- };
119
- });
120
- } else {
121
- const component = await updateOrCreateComponent(componentUID, componentValue);
122
- componentBody[attributeName] = component && {
123
- id: component.id,
124
- __pivot: {
125
- field: attributeName,
126
- component_type: componentUID
127
- }
128
- };
129
- }
130
- } else if (attribute.type === "dynamiczone") {
131
- const dynamiczoneValues = data[attributeName];
132
- await deleteOldDZComponents(uid, entityToUpdate, attributeName, dynamiczoneValues);
133
- if (!Array.isArray(dynamiczoneValues)) {
134
- throw new Error("Expected an array to create repeatable component");
135
- }
136
- componentBody[attributeName] = await async.map(dynamiczoneValues, async (value) => {
137
- const { id } = await updateOrCreateComponent(value.__component, value);
138
- return {
139
- id,
140
- __component: value.__component,
141
- __pivot: {
142
- field: attributeName
143
- }
144
- };
145
- });
146
- }
147
- }
148
- return componentBody;
149
- };
150
- const pickStringifiedId = ({
151
- id
152
- }) => {
153
- if (typeof id === "string") {
154
- return id;
155
- }
156
- return `${id}`;
157
- };
158
- const deleteOldComponents = async (uid, componentUID, entityToUpdate, attributeName, componentValue) => {
159
- const previousValue = await strapi.db.query(uid).load(entityToUpdate, attributeName);
160
- const idsToKeep = _.castArray(componentValue).filter(has("id")).map(pickStringifiedId);
161
- const allIds = _.castArray(previousValue).filter(has("id")).map(pickStringifiedId);
162
- idsToKeep.forEach((id) => {
163
- if (!allIds.includes(id)) {
164
- throw new errors.ApplicationError(
165
- `Some of the provided components in ${attributeName} are not related to the entity`
166
- );
167
- }
168
- });
169
- const idsToDelete = _.difference(allIds, idsToKeep);
170
- if (idsToDelete.length > 0) {
171
- for (const idToDelete of idsToDelete) {
172
- await deleteComponent(componentUID, { id: idToDelete });
173
- }
174
- }
175
- };
176
- const deleteOldDZComponents = async (uid, entityToUpdate, attributeName, dynamiczoneValues) => {
177
- const previousValue = await strapi.db.query(uid).load(entityToUpdate, attributeName);
178
- const idsToKeep = _.castArray(dynamiczoneValues).filter(has("id")).map((v) => ({
179
- id: pickStringifiedId(v),
180
- __component: v.__component
181
- }));
182
- const allIds = _.castArray(previousValue).filter(has("id")).map((v) => ({
183
- id: pickStringifiedId(v),
184
- __component: v.__component
185
- }));
186
- idsToKeep.forEach(({ id, __component }) => {
187
- if (!allIds.find((el) => el.id === id && el.__component === __component)) {
188
- const err = new Error(
189
- `Some of the provided components in ${attributeName} are not related to the entity`
190
- );
191
- Object.assign(err, { status: 400 });
192
- throw err;
193
- }
194
- });
195
- const idsToDelete = allIds.reduce((acc, { id, __component }) => {
196
- if (!idsToKeep.find((el) => el.id === id && el.__component === __component)) {
197
- acc.push({ id, __component });
198
- }
199
- return acc;
200
- }, []);
201
- if (idsToDelete.length > 0) {
202
- for (const idToDelete of idsToDelete) {
203
- const { id, __component } = idToDelete;
204
- await deleteComponent(__component, { id });
205
- }
206
- }
207
- };
208
- const deleteComponents = async (uid, entityToDelete, { loadComponents = true } = {}) => {
209
- const { attributes = {} } = strapi.getModel(uid);
210
- const attributeNames = Object.keys(attributes);
211
- for (const attributeName of attributeNames) {
212
- const attribute = attributes[attributeName];
213
- if (attribute.type === "component" || attribute.type === "dynamiczone") {
214
- let value;
215
- if (loadComponents) {
216
- value = await strapi.db.query(uid).load(entityToDelete, attributeName);
217
- } else {
218
- value = entityToDelete[attributeName];
219
- }
220
- if (!value) {
221
- continue;
222
- }
223
- if (attribute.type === "component") {
224
- const { component: componentUID } = attribute;
225
- await async.map(
226
- _.castArray(value),
227
- (subValue) => deleteComponent(componentUID, subValue)
228
- );
229
- } else {
230
- await async.map(
231
- _.castArray(value),
232
- (subValue) => deleteComponent(subValue.__component, subValue)
233
- );
234
- }
235
- continue;
236
- }
237
- }
238
- };
239
- const createComponent = async (uid, data) => {
240
- const schema = strapi.getModel(uid);
241
- const componentData = await createComponents(uid, data);
242
- const transform = pipe(
243
- // Make sure we don't save the component with a pre-defined ID
244
- omit("id"),
245
- assignComponentData(schema, componentData)
246
- );
247
- return strapi.db.query(uid).create({ data: transform(data) });
248
- };
249
- const updateComponent = async (uid, componentToUpdate, data) => {
250
- const schema = strapi.getModel(uid);
251
- const componentData = await updateComponents(uid, componentToUpdate, data);
252
- return strapi.db.query(uid).update({
253
- where: {
254
- id: componentToUpdate.id
255
- },
256
- data: assignComponentData(schema, componentData, data)
257
- });
258
- };
259
- const updateOrCreateComponent = (componentUID, value) => {
260
- if (value === null) {
261
- return null;
262
- }
263
- if ("id" in value && typeof value.id !== "undefined") {
264
- return updateComponent(componentUID, { id: value.id }, value);
265
- }
266
- return createComponent(componentUID, value);
267
- };
268
- const deleteComponent = async (uid, componentToDelete) => {
269
- await deleteComponents(uid, componentToDelete);
270
- await strapi.db.query(uid).delete({ where: { id: componentToDelete.id } });
271
- };
272
- const assignComponentData = curry(
273
- (schema, componentData, data) => {
274
- return pipe(omitComponentData(schema), assign(componentData))(data);
275
- }
276
- );
277
- export {
278
- assignComponentData,
279
- createComponents,
280
- deleteComponent,
281
- deleteComponents,
282
- getComponents,
283
- omitComponentData,
284
- updateComponents
285
- };
286
- //# sourceMappingURL=components.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"components.mjs","sources":["../../../src/services/document-service/components.ts"],"sourcesContent":["import _ from 'lodash';\nimport { has, omit, pipe, assign, curry } from 'lodash/fp';\nimport type { Utils, UID, Schema, Data, Modules } from '@strapi/types';\nimport { contentTypes as contentTypesUtils, async, errors } from '@strapi/utils';\n\n// type aliases for readability\ntype Input<T extends UID.Schema> = Modules.Documents.Params.Data.Input<T>;\n\ntype LoadedComponents<TUID extends UID.Schema> = Data.Entity<\n TUID,\n Schema.AttributeNamesByType<TUID, 'component' | 'dynamiczone'>\n>;\n\ntype SingleComponentValue = Schema.Attribute.ComponentValue<UID.Component, false>;\ntype RepeatableComponentValue = Schema.Attribute.ComponentValue<UID.Component, true>;\n\ntype ComponentValue = SingleComponentValue | RepeatableComponentValue;\n\ntype DynamicZoneValue = Schema.Attribute.DynamicZoneValue<UID.Component[]>;\n\ntype ComponentBody = {\n [key: string]: ComponentValue | DynamicZoneValue;\n};\n\nconst omitComponentData = curry(\n (schema: Schema.Schema, data: Input<UID.Schema>): Partial<Input<UID.Schema>> => {\n const { attributes } = schema;\n const componentAttributes = Object.keys(attributes).filter((attributeName) =>\n contentTypesUtils.isComponentAttribute(attributes[attributeName])\n );\n\n return omit(componentAttributes, data);\n }\n);\n\n// NOTE: we could generalize the logic to allow CRUD of relation directly in the DB layer\nconst createComponents = async <TUID extends UID.Schema, TData extends Input<TUID>>(\n uid: TUID,\n data: TData\n) => {\n const { attributes = {} } = strapi.getModel(uid);\n\n const componentBody: ComponentBody = {};\n\n const attributeNames = Object.keys(attributes);\n\n for (const attributeName of attributeNames) {\n const attribute = attributes[attributeName];\n\n if (!has(attributeName, data) || !contentTypesUtils.isComponentAttribute(attribute)) {\n continue;\n }\n\n if (attribute.type === 'component') {\n const { component: componentUID, repeatable = false } = attribute;\n\n const componentValue = data[attributeName as keyof TData];\n\n if (componentValue === null) {\n continue;\n }\n\n if (repeatable === true) {\n if (!Array.isArray(componentValue)) {\n throw new Error('Expected an array to create repeatable component');\n }\n\n const components: RepeatableComponentValue = await async.map(componentValue, (value: any) =>\n createComponent(componentUID, value)\n );\n\n componentBody[attributeName] = components.map(({ id }) => {\n return {\n id,\n __pivot: {\n field: attributeName,\n component_type: componentUID,\n },\n };\n });\n } else {\n const component = await createComponent(\n componentUID,\n componentValue as Input<UID.Component>\n );\n\n componentBody[attributeName] = {\n id: component.id,\n __pivot: {\n field: attributeName,\n component_type: componentUID,\n },\n };\n }\n\n continue;\n }\n\n if (attribute.type === 'dynamiczone') {\n const dynamiczoneValues = data[\n attributeName as keyof TData\n ] as Modules.EntityService.Params.Attribute.GetValue<Schema.Attribute.DynamicZone>;\n\n if (!Array.isArray(dynamiczoneValues)) {\n throw new Error('Expected an array to create repeatable component');\n }\n\n const createDynamicZoneComponents = async (\n value: Utils.Array.Values<typeof dynamiczoneValues>\n ) => {\n const { id } = await createComponent(value.__component, value);\n return {\n id,\n __component: value.__component,\n __pivot: {\n field: attributeName,\n },\n };\n };\n\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n componentBody[attributeName] = await async.map(\n dynamiczoneValues,\n createDynamicZoneComponents\n );\n\n continue;\n }\n }\n\n return componentBody;\n};\n\nconst getComponents = async <TUID extends UID.Schema>(\n uid: TUID,\n entity: { id: Modules.EntityService.Params.Attribute.ID }\n): Promise<LoadedComponents<TUID>> => {\n const componentAttributes = contentTypesUtils.getComponentAttributes(strapi.getModel(uid));\n\n if (_.isEmpty(componentAttributes)) {\n return {} as LoadedComponents<TUID>;\n }\n\n return strapi.db.query(uid).load(entity, componentAttributes) as Promise<LoadedComponents<TUID>>;\n};\n\n/*\n delete old components\n create or update\n*/\nconst updateComponents = async <TUID extends UID.Schema, TData extends Partial<Input<TUID>>>(\n uid: TUID,\n entityToUpdate: { id: Modules.EntityService.Params.Attribute.ID },\n data: TData\n) => {\n const { attributes = {} } = strapi.getModel(uid);\n\n const componentBody: ComponentBody = {};\n\n for (const attributeName of Object.keys(attributes)) {\n const attribute = attributes[attributeName];\n\n if (!has(attributeName, data)) {\n continue;\n }\n\n if (attribute.type === 'component') {\n const { component: componentUID, repeatable = false } = attribute;\n\n const componentValue = data[attributeName as keyof TData] as ComponentValue;\n\n await deleteOldComponents(uid, componentUID, entityToUpdate, attributeName, componentValue);\n\n if (repeatable === true) {\n if (!Array.isArray(componentValue)) {\n throw new Error('Expected an array to create repeatable component');\n }\n\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n const components: RepeatableComponentValue = await async.map(componentValue, (value: any) =>\n updateOrCreateComponent(componentUID, value)\n );\n\n componentBody[attributeName] = components.filter(_.negate(_.isNil)).map(({ id }) => {\n return {\n id,\n __pivot: {\n field: attributeName,\n component_type: componentUID,\n },\n };\n });\n } else {\n const component = await updateOrCreateComponent(componentUID, componentValue);\n componentBody[attributeName] = component && {\n id: component.id,\n __pivot: {\n field: attributeName,\n component_type: componentUID,\n },\n };\n }\n } else if (attribute.type === 'dynamiczone') {\n const dynamiczoneValues = data[attributeName as keyof TData] as DynamicZoneValue;\n\n await deleteOldDZComponents(uid, entityToUpdate, attributeName, dynamiczoneValues);\n\n if (!Array.isArray(dynamiczoneValues)) {\n throw new Error('Expected an array to create repeatable component');\n }\n\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n componentBody[attributeName] = await async.map(dynamiczoneValues, async (value: any) => {\n const { id } = await updateOrCreateComponent(value.__component, value);\n\n return {\n id,\n __component: value.__component,\n __pivot: {\n field: attributeName,\n },\n };\n });\n }\n }\n\n return componentBody;\n};\n\nconst pickStringifiedId = ({\n id,\n}: {\n id: Modules.EntityService.Params.Attribute.ID;\n}): Modules.EntityService.Params.Attribute.ID & string => {\n if (typeof id === 'string') {\n return id;\n }\n\n return `${id}`;\n};\n\nconst deleteOldComponents = async <TUID extends UID.Schema>(\n uid: TUID,\n componentUID: UID.Component,\n entityToUpdate: { id: Modules.EntityService.Params.Attribute.ID },\n attributeName: string,\n componentValue: ComponentValue\n) => {\n const previousValue = (await strapi.db\n .query(uid)\n .load(entityToUpdate, attributeName)) as ComponentValue;\n\n const idsToKeep = _.castArray(componentValue).filter(has('id')).map(pickStringifiedId);\n const allIds = _.castArray(previousValue).filter(has('id')).map(pickStringifiedId);\n\n idsToKeep.forEach((id) => {\n if (!allIds.includes(id)) {\n throw new errors.ApplicationError(\n `Some of the provided components in ${attributeName} are not related to the entity`\n );\n }\n });\n\n const idsToDelete = _.difference(allIds, idsToKeep);\n\n if (idsToDelete.length > 0) {\n for (const idToDelete of idsToDelete) {\n await deleteComponent(componentUID, { id: idToDelete });\n }\n }\n};\n\nconst deleteOldDZComponents = async <TUID extends UID.Schema>(\n uid: TUID,\n entityToUpdate: { id: Modules.EntityService.Params.Attribute.ID },\n attributeName: string,\n dynamiczoneValues: DynamicZoneValue\n) => {\n const previousValue = (await strapi.db\n .query(uid)\n .load(entityToUpdate, attributeName)) as DynamicZoneValue;\n\n const idsToKeep = _.castArray(dynamiczoneValues)\n .filter(has('id'))\n .map((v) => ({\n id: pickStringifiedId(v),\n __component: v.__component,\n }));\n\n const allIds = _.castArray(previousValue)\n .filter(has('id'))\n .map((v) => ({\n id: pickStringifiedId(v),\n __component: v.__component,\n }));\n\n idsToKeep.forEach(({ id, __component }) => {\n if (!allIds.find((el) => el.id === id && el.__component === __component)) {\n const err = new Error(\n `Some of the provided components in ${attributeName} are not related to the entity`\n );\n\n Object.assign(err, { status: 400 });\n throw err;\n }\n });\n\n type IdsToDelete = DynamicZoneValue;\n\n const idsToDelete = allIds.reduce((acc, { id, __component }) => {\n if (!idsToKeep.find((el) => el.id === id && el.__component === __component)) {\n acc.push({ id, __component });\n }\n\n return acc;\n }, [] as IdsToDelete);\n\n if (idsToDelete.length > 0) {\n for (const idToDelete of idsToDelete) {\n const { id, __component } = idToDelete;\n await deleteComponent(__component, { id });\n }\n }\n};\n\nconst deleteComponents = async <TUID extends UID.Schema, TEntity extends Data.Entity<TUID>>(\n uid: TUID,\n entityToDelete: TEntity,\n { loadComponents = true } = {}\n) => {\n const { attributes = {} } = strapi.getModel(uid);\n\n const attributeNames = Object.keys(attributes);\n\n for (const attributeName of attributeNames) {\n const attribute = attributes[attributeName];\n\n if (attribute.type === 'component' || attribute.type === 'dynamiczone') {\n let value;\n\n if (loadComponents) {\n value = await strapi.db.query(uid).load(entityToDelete, attributeName);\n } else {\n value = entityToDelete[attributeName as keyof TEntity];\n }\n\n if (!value) {\n continue;\n }\n\n if (attribute.type === 'component') {\n const { component: componentUID } = attribute;\n await async.map(_.castArray(value), (subValue: any) =>\n deleteComponent(componentUID, subValue)\n );\n } else {\n await async.map(_.castArray(value), (subValue: any) =>\n deleteComponent(subValue.__component, subValue)\n );\n }\n\n continue;\n }\n }\n};\n\n/** *************************\n Component queries\n************************** */\n\n// components can have nested compos so this must be recursive\nconst createComponent = async <TUID extends UID.Component>(uid: TUID, data: Input<TUID>) => {\n const schema = strapi.getModel(uid);\n\n const componentData = await createComponents(uid, data);\n\n const transform = pipe(\n // Make sure we don't save the component with a pre-defined ID\n omit('id'),\n assignComponentData(schema, componentData)\n );\n\n return strapi.db.query(uid).create({ data: transform(data) });\n};\n\n// components can have nested compos so this must be recursive\nconst updateComponent = async <TUID extends UID.Component>(\n uid: TUID,\n componentToUpdate: { id: Modules.EntityService.Params.Attribute.ID },\n data: Input<TUID>\n) => {\n const schema = strapi.getModel(uid);\n\n const componentData = await updateComponents(uid, componentToUpdate, data);\n\n return strapi.db.query(uid).update({\n where: {\n id: componentToUpdate.id,\n },\n data: assignComponentData(schema, componentData, data),\n });\n};\n\nconst updateOrCreateComponent = <TUID extends UID.Component>(\n componentUID: TUID,\n value: Input<TUID>\n) => {\n if (value === null) {\n return null;\n }\n\n // update\n if ('id' in value && typeof value.id !== 'undefined') {\n // TODO: verify the compo is associated with the entity\n return updateComponent(componentUID, { id: value.id }, value);\n }\n\n // create\n return createComponent(componentUID, value);\n};\n\nconst deleteComponent = async <TUID extends UID.Component>(\n uid: TUID,\n componentToDelete: Data.Component<TUID>\n) => {\n await deleteComponents(uid, componentToDelete);\n await strapi.db.query(uid).delete({ where: { id: componentToDelete.id } });\n};\n\nconst assignComponentData = curry(\n (schema: Schema.Schema, componentData: ComponentBody, data: Input<UID.Schema>) => {\n return pipe(omitComponentData(schema), assign(componentData))(data);\n }\n);\n\nexport {\n omitComponentData,\n assignComponentData,\n getComponents,\n createComponents,\n updateComponents,\n deleteComponents,\n deleteComponent,\n};\n"],"names":["contentTypesUtils"],"mappings":"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"}