@strapi/core 0.0.0 → 5.0.0-alpha.1

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 (881) hide show
  1. package/dist/Strapi.d.ts +9 -4
  2. package/dist/Strapi.d.ts.map +1 -1
  3. package/dist/Strapi.js +78 -52
  4. package/dist/Strapi.js.map +1 -1
  5. package/dist/Strapi.mjs +80 -53
  6. package/dist/Strapi.mjs.map +1 -1
  7. package/dist/configuration/config-loader.d.ts.map +1 -0
  8. package/dist/configuration/config-loader.js +102 -0
  9. package/dist/configuration/config-loader.js.map +1 -0
  10. package/dist/configuration/config-loader.mjs +100 -0
  11. package/dist/configuration/config-loader.mjs.map +1 -0
  12. package/dist/{core/app-configuration → configuration}/index.d.ts +20 -5
  13. package/dist/configuration/index.d.ts.map +1 -0
  14. package/dist/{core/app-configuration → configuration}/index.js +28 -5
  15. package/dist/configuration/index.js.map +1 -0
  16. package/dist/{core/app-configuration → configuration}/index.mjs +28 -5
  17. package/dist/configuration/index.mjs.map +1 -0
  18. package/dist/configuration/urls.d.ts +8 -0
  19. package/dist/configuration/urls.d.ts.map +1 -0
  20. package/dist/configuration/urls.js +68 -0
  21. package/dist/configuration/urls.js.map +1 -0
  22. package/dist/configuration/urls.mjs +66 -0
  23. package/dist/configuration/urls.mjs.map +1 -0
  24. package/dist/core-api/controller/collection-type.d.ts +1 -1
  25. package/dist/core-api/controller/collection-type.d.ts.map +1 -1
  26. package/dist/core-api/controller/collection-type.js +9 -20
  27. package/dist/core-api/controller/collection-type.js.map +1 -1
  28. package/dist/core-api/controller/collection-type.mjs +8 -20
  29. package/dist/core-api/controller/collection-type.mjs.map +1 -1
  30. package/dist/core-api/controller/index.d.ts.map +1 -1
  31. package/dist/core-api/controller/index.js +8 -3
  32. package/dist/core-api/controller/index.js.map +1 -1
  33. package/dist/core-api/controller/index.mjs +8 -3
  34. package/dist/core-api/controller/index.mjs.map +1 -1
  35. package/dist/core-api/controller/single-type.d.ts +1 -1
  36. package/dist/core-api/controller/single-type.d.ts.map +1 -1
  37. package/dist/core-api/controller/single-type.js +6 -11
  38. package/dist/core-api/controller/single-type.js.map +1 -1
  39. package/dist/core-api/controller/single-type.mjs +5 -11
  40. package/dist/core-api/controller/single-type.mjs.map +1 -1
  41. package/dist/core-api/controller/transform.d.ts +9 -17
  42. package/dist/core-api/controller/transform.d.ts.map +1 -1
  43. package/dist/core-api/controller/transform.js +9 -14
  44. package/dist/core-api/controller/transform.js.map +1 -1
  45. package/dist/core-api/controller/transform.mjs +9 -14
  46. package/dist/core-api/controller/transform.mjs.map +1 -1
  47. package/dist/core-api/service/collection-type.d.ts +28 -5
  48. package/dist/core-api/service/collection-type.d.ts.map +1 -1
  49. package/dist/core-api/service/collection-type.js +47 -49
  50. package/dist/core-api/service/collection-type.js.map +1 -1
  51. package/dist/core-api/service/collection-type.mjs +47 -50
  52. package/dist/core-api/service/collection-type.mjs.map +1 -1
  53. package/dist/core-api/service/core-service.d.ts +4 -0
  54. package/dist/core-api/service/core-service.d.ts.map +1 -0
  55. package/dist/core-api/service/core-service.js +12 -0
  56. package/dist/core-api/service/core-service.js.map +1 -0
  57. package/dist/core-api/service/core-service.mjs +12 -0
  58. package/dist/core-api/service/core-service.mjs.map +1 -0
  59. package/dist/core-api/service/index.js +2 -2
  60. package/dist/core-api/service/index.js.map +1 -1
  61. package/dist/core-api/service/index.mjs +4 -4
  62. package/dist/core-api/service/index.mjs.map +1 -1
  63. package/dist/core-api/service/pagination.d.ts +1 -5
  64. package/dist/core-api/service/pagination.d.ts.map +1 -1
  65. package/dist/core-api/service/pagination.js +0 -11
  66. package/dist/core-api/service/pagination.js.map +1 -1
  67. package/dist/core-api/service/pagination.mjs +0 -11
  68. package/dist/core-api/service/pagination.mjs.map +1 -1
  69. package/dist/core-api/service/single-type.d.ts +14 -8
  70. package/dist/core-api/service/single-type.d.ts.map +1 -1
  71. package/dist/core-api/service/single-type.js +35 -50
  72. package/dist/core-api/service/single-type.js.map +1 -1
  73. package/dist/core-api/service/single-type.mjs +34 -50
  74. package/dist/core-api/service/single-type.mjs.map +1 -1
  75. package/dist/{core/domain → domain}/content-type/index.d.ts +2 -1
  76. package/dist/domain/content-type/index.d.ts.map +1 -0
  77. package/dist/{core/domain → domain}/content-type/index.js +23 -34
  78. package/dist/domain/content-type/index.js.map +1 -0
  79. package/dist/{core/domain → domain}/content-type/index.mjs +24 -35
  80. package/dist/domain/content-type/index.mjs.map +1 -0
  81. package/dist/domain/content-type/validator.d.ts.map +1 -0
  82. package/dist/{core/domain → domain}/content-type/validator.js +1 -1
  83. package/dist/domain/content-type/validator.js.map +1 -0
  84. package/dist/{core/domain → domain}/content-type/validator.mjs +2 -2
  85. package/dist/domain/content-type/validator.mjs.map +1 -0
  86. package/dist/domain/module/index.d.ts.map +1 -0
  87. package/dist/{core/domain → domain}/module/index.js +30 -31
  88. package/dist/domain/module/index.js.map +1 -0
  89. package/dist/{core/domain → domain}/module/index.mjs +3 -4
  90. package/dist/domain/module/index.mjs.map +1 -0
  91. package/dist/domain/module/validation.d.ts.map +1 -0
  92. package/dist/domain/module/validation.js.map +1 -0
  93. package/dist/domain/module/validation.mjs.map +1 -0
  94. package/dist/ee/index.js +2 -2
  95. package/dist/ee/index.js.map +1 -1
  96. package/dist/ee/index.mjs +2 -2
  97. package/dist/ee/index.mjs.map +1 -1
  98. package/dist/ee/license.d.ts.map +1 -1
  99. package/dist/ee/license.js +2 -1
  100. package/dist/ee/license.js.map +1 -1
  101. package/dist/ee/license.mjs +2 -1
  102. package/dist/ee/license.mjs.map +1 -1
  103. package/dist/factories.d.ts +2 -1
  104. package/dist/factories.d.ts.map +1 -1
  105. package/dist/factories.js +16 -11
  106. package/dist/factories.js.map +1 -1
  107. package/dist/factories.mjs +17 -12
  108. package/dist/factories.mjs.map +1 -1
  109. package/dist/index.d.ts +3 -2
  110. package/dist/index.d.ts.map +1 -1
  111. package/dist/index.js +3 -1
  112. package/dist/index.js.map +1 -1
  113. package/dist/index.mjs +3 -1
  114. package/dist/index.mjs.map +1 -1
  115. package/dist/loaders/admin.d.ts.map +1 -0
  116. package/dist/{core/loaders → loaders}/admin.js +12 -1
  117. package/dist/loaders/admin.js.map +1 -0
  118. package/dist/{core/loaders → loaders}/admin.mjs +12 -1
  119. package/dist/loaders/admin.mjs.map +1 -0
  120. package/dist/loaders/apis.d.ts.map +1 -0
  121. package/dist/{core/loaders → loaders}/apis.js +20 -13
  122. package/dist/loaders/apis.js.map +1 -0
  123. package/dist/{core/loaders → loaders}/apis.mjs +19 -12
  124. package/dist/loaders/apis.mjs.map +1 -0
  125. package/dist/loaders/components.d.ts.map +1 -0
  126. package/dist/{core/loaders → loaders}/components.js +2 -2
  127. package/dist/loaders/components.js.map +1 -0
  128. package/dist/{core/loaders → loaders}/components.mjs +1 -1
  129. package/dist/loaders/components.mjs.map +1 -0
  130. package/dist/loaders/index.d.ts.map +1 -0
  131. package/dist/loaders/index.js.map +1 -0
  132. package/dist/loaders/index.mjs.map +1 -0
  133. package/dist/loaders/middlewares.d.ts.map +1 -0
  134. package/dist/{core/loaders → loaders}/middlewares.js +1 -1
  135. package/dist/loaders/middlewares.js.map +1 -0
  136. package/dist/{core/loaders → loaders}/middlewares.mjs +1 -1
  137. package/dist/loaders/middlewares.mjs.map +1 -0
  138. package/dist/loaders/plugins/get-enabled-plugins.d.ts.map +1 -0
  139. package/dist/{core/loaders → loaders}/plugins/get-enabled-plugins.js +4 -2
  140. package/dist/loaders/plugins/get-enabled-plugins.js.map +1 -0
  141. package/dist/{core/loaders → loaders}/plugins/get-enabled-plugins.mjs +5 -3
  142. package/dist/loaders/plugins/get-enabled-plugins.mjs.map +1 -0
  143. package/dist/loaders/plugins/get-user-plugins-config.d.ts.map +1 -0
  144. package/dist/{core/loaders → loaders}/plugins/get-user-plugins-config.js +3 -3
  145. package/dist/loaders/plugins/get-user-plugins-config.js.map +1 -0
  146. package/dist/{core/loaders → loaders}/plugins/get-user-plugins-config.mjs +3 -3
  147. package/dist/loaders/plugins/get-user-plugins-config.mjs.map +1 -0
  148. package/dist/loaders/plugins/index.d.ts.map +1 -0
  149. package/dist/{core/loaders → loaders}/plugins/index.js +18 -5
  150. package/dist/loaders/plugins/index.js.map +1 -0
  151. package/dist/{core/loaders → loaders}/plugins/index.mjs +16 -3
  152. package/dist/loaders/plugins/index.mjs.map +1 -0
  153. package/dist/loaders/policies.d.ts.map +1 -0
  154. package/dist/loaders/policies.js.map +1 -0
  155. package/dist/loaders/policies.mjs.map +1 -0
  156. package/dist/loaders/sanitizers.d.ts.map +1 -0
  157. package/dist/loaders/sanitizers.js.map +1 -0
  158. package/dist/loaders/sanitizers.mjs.map +1 -0
  159. package/dist/loaders/src-index.d.ts.map +1 -0
  160. package/dist/loaders/src-index.js.map +1 -0
  161. package/dist/loaders/src-index.mjs.map +1 -0
  162. package/dist/loaders/validators.d.ts.map +1 -0
  163. package/dist/loaders/validators.js.map +1 -0
  164. package/dist/loaders/validators.mjs.map +1 -0
  165. package/dist/middlewares/favicon.d.ts +1 -0
  166. package/dist/middlewares/favicon.d.ts.map +1 -1
  167. package/dist/middlewares/index.js +2 -2
  168. package/dist/middlewares/index.js.map +1 -1
  169. package/dist/middlewares/index.mjs +1 -1
  170. package/dist/middlewares/{public/index.d.ts → public.d.ts} +1 -1
  171. package/dist/middlewares/public.d.ts.map +1 -0
  172. package/dist/middlewares/public.js +34 -0
  173. package/dist/middlewares/public.js.map +1 -0
  174. package/dist/middlewares/public.mjs +32 -0
  175. package/dist/middlewares/public.mjs.map +1 -0
  176. package/dist/middlewares/security.d.ts.map +1 -1
  177. package/dist/middlewares/security.js +24 -3
  178. package/dist/middlewares/security.js.map +1 -1
  179. package/dist/middlewares/security.mjs +24 -3
  180. package/dist/middlewares/security.mjs.map +1 -1
  181. package/dist/migrations/draft-publish.d.ts +17 -0
  182. package/dist/migrations/draft-publish.d.ts.map +1 -0
  183. package/dist/migrations/draft-publish.js +59 -0
  184. package/dist/migrations/draft-publish.js.map +1 -0
  185. package/dist/migrations/draft-publish.mjs +59 -0
  186. package/dist/migrations/draft-publish.mjs.map +1 -0
  187. package/dist/registries/apis.d.ts.map +1 -0
  188. package/dist/registries/apis.js.map +1 -0
  189. package/dist/registries/apis.mjs.map +1 -0
  190. package/dist/registries/components.d.ts.map +1 -0
  191. package/dist/registries/components.js.map +1 -0
  192. package/dist/registries/components.mjs.map +1 -0
  193. package/dist/registries/config.d.ts +4 -0
  194. package/dist/registries/config.d.ts.map +1 -0
  195. package/dist/registries/config.js +31 -0
  196. package/dist/registries/config.js.map +1 -0
  197. package/dist/registries/config.mjs +32 -0
  198. package/dist/registries/config.mjs.map +1 -0
  199. package/dist/registries/content-types.d.ts.map +1 -0
  200. package/dist/{core/registries → registries}/content-types.js +6 -7
  201. package/dist/registries/content-types.js.map +1 -0
  202. package/dist/{core/registries → registries}/content-types.mjs +2 -3
  203. package/dist/registries/content-types.mjs.map +1 -0
  204. package/dist/registries/controllers.d.ts.map +1 -0
  205. package/dist/{core/registries → registries}/controllers.js +5 -5
  206. package/dist/registries/controllers.js.map +1 -0
  207. package/dist/{core/registries → registries}/controllers.mjs +1 -1
  208. package/dist/registries/controllers.mjs.map +1 -0
  209. package/dist/registries/custom-fields.d.ts.map +1 -0
  210. package/dist/registries/custom-fields.js.map +1 -0
  211. package/dist/registries/custom-fields.mjs.map +1 -0
  212. package/dist/registries/hooks.d.ts.map +1 -0
  213. package/dist/{core/registries → registries}/hooks.js +5 -5
  214. package/dist/registries/hooks.js.map +1 -0
  215. package/dist/{core/registries → registries}/hooks.mjs +1 -1
  216. package/dist/registries/hooks.mjs.map +1 -0
  217. package/dist/{core/registries → registries}/index.d.ts +1 -0
  218. package/dist/registries/index.d.ts.map +1 -0
  219. package/dist/registries/middlewares.d.ts.map +1 -0
  220. package/dist/{core/registries → registries}/middlewares.js +5 -5
  221. package/dist/registries/middlewares.js.map +1 -0
  222. package/dist/{core/registries → registries}/middlewares.mjs +1 -1
  223. package/dist/registries/middlewares.mjs.map +1 -0
  224. package/dist/registries/models.d.ts +6 -0
  225. package/dist/registries/models.d.ts.map +1 -0
  226. package/dist/registries/models.js +16 -0
  227. package/dist/registries/models.js.map +1 -0
  228. package/dist/registries/models.mjs +16 -0
  229. package/dist/registries/models.mjs.map +1 -0
  230. package/dist/registries/modules.d.ts.map +1 -0
  231. package/dist/registries/modules.js.map +1 -0
  232. package/dist/registries/modules.mjs.map +1 -0
  233. package/dist/{core/utils.d.ts → registries/namespace.d.ts} +1 -1
  234. package/dist/registries/namespace.d.ts.map +1 -0
  235. package/dist/{core/utils.js → registries/namespace.js} +1 -1
  236. package/dist/registries/namespace.js.map +1 -0
  237. package/dist/{core/utils.mjs → registries/namespace.mjs} +1 -1
  238. package/dist/registries/namespace.mjs.map +1 -0
  239. package/dist/registries/plugins.d.ts.map +1 -0
  240. package/dist/registries/plugins.js.map +1 -0
  241. package/dist/registries/plugins.mjs.map +1 -0
  242. package/dist/registries/policies.d.ts.map +1 -0
  243. package/dist/{core/registries → registries}/policies.js +5 -5
  244. package/dist/registries/policies.js.map +1 -0
  245. package/dist/{core/registries → registries}/policies.mjs +1 -1
  246. package/dist/registries/policies.mjs.map +1 -0
  247. package/dist/registries/sanitizers.d.ts.map +1 -0
  248. package/dist/registries/sanitizers.js.map +1 -0
  249. package/dist/registries/sanitizers.mjs.map +1 -0
  250. package/dist/registries/services.d.ts.map +1 -0
  251. package/dist/{core/registries → registries}/services.js +5 -5
  252. package/dist/registries/services.js.map +1 -0
  253. package/dist/{core/registries → registries}/services.mjs +1 -1
  254. package/dist/registries/services.mjs.map +1 -0
  255. package/dist/registries/validators.d.ts.map +1 -0
  256. package/dist/registries/validators.js.map +1 -0
  257. package/dist/registries/validators.mjs.map +1 -0
  258. package/dist/services/core-store.d.ts +2 -22
  259. package/dist/services/core-store.d.ts.map +1 -1
  260. package/dist/services/core-store.js +5 -1
  261. package/dist/services/core-store.js.map +1 -1
  262. package/dist/services/core-store.mjs +5 -1
  263. package/dist/services/core-store.mjs.map +1 -1
  264. package/dist/services/document-service/common.d.ts +4 -0
  265. package/dist/services/document-service/common.d.ts.map +1 -0
  266. package/dist/services/document-service/common.js +7 -0
  267. package/dist/services/document-service/common.js.map +1 -0
  268. package/dist/services/document-service/common.mjs +7 -0
  269. package/dist/services/document-service/common.mjs.map +1 -0
  270. package/dist/services/document-service/draft-and-publish.d.ts +10 -0
  271. package/dist/services/document-service/draft-and-publish.d.ts.map +1 -0
  272. package/dist/services/document-service/draft-and-publish.js +69 -0
  273. package/dist/services/document-service/draft-and-publish.js.map +1 -0
  274. package/dist/services/document-service/draft-and-publish.mjs +69 -0
  275. package/dist/services/document-service/draft-and-publish.mjs.map +1 -0
  276. package/dist/services/document-service/index.d.ts +18 -7
  277. package/dist/services/document-service/index.d.ts.map +1 -1
  278. package/dist/services/document-service/index.js +20 -190
  279. package/dist/services/document-service/index.js.map +1 -1
  280. package/dist/services/document-service/index.mjs +19 -190
  281. package/dist/services/document-service/index.mjs.map +1 -1
  282. package/dist/services/document-service/internationalization.d.ts +8 -0
  283. package/dist/services/document-service/internationalization.d.ts.map +1 -0
  284. package/dist/services/document-service/internationalization.js +54 -0
  285. package/dist/services/document-service/internationalization.js.map +1 -0
  286. package/dist/services/document-service/internationalization.mjs +54 -0
  287. package/dist/services/document-service/internationalization.mjs.map +1 -0
  288. package/dist/services/document-service/middlewares/errors.d.ts +6 -0
  289. package/dist/services/document-service/middlewares/errors.d.ts.map +1 -0
  290. package/dist/services/document-service/middlewares/errors.js +25 -0
  291. package/dist/services/document-service/middlewares/errors.js.map +1 -0
  292. package/dist/services/document-service/middlewares/errors.mjs +25 -0
  293. package/dist/services/document-service/middlewares/errors.mjs.map +1 -0
  294. package/dist/services/document-service/middlewares/index.d.ts +2 -10
  295. package/dist/services/document-service/middlewares/index.d.ts.map +1 -1
  296. package/dist/services/document-service/middlewares/middleware-manager.d.ts +7 -0
  297. package/dist/services/document-service/middlewares/middleware-manager.d.ts.map +1 -0
  298. package/dist/services/document-service/middlewares/middleware-manager.js +46 -0
  299. package/dist/services/document-service/middlewares/middleware-manager.js.map +1 -0
  300. package/dist/services/document-service/middlewares/middleware-manager.mjs +46 -0
  301. package/dist/services/document-service/middlewares/middleware-manager.mjs.map +1 -0
  302. package/dist/services/document-service/repository.d.ts +3 -0
  303. package/dist/services/document-service/repository.d.ts.map +1 -0
  304. package/dist/services/document-service/repository.js +295 -0
  305. package/dist/services/document-service/repository.js.map +1 -0
  306. package/dist/services/document-service/repository.mjs +295 -0
  307. package/dist/services/document-service/repository.mjs.map +1 -0
  308. package/dist/services/document-service/transform/data.d.ts +5 -0
  309. package/dist/services/document-service/transform/data.d.ts.map +1 -0
  310. package/dist/services/document-service/transform/data.js +13 -0
  311. package/dist/services/document-service/transform/data.js.map +1 -0
  312. package/dist/services/document-service/transform/data.mjs +13 -0
  313. package/dist/services/document-service/transform/data.mjs.map +1 -0
  314. package/dist/services/document-service/transform/fields.d.ts +5 -0
  315. package/dist/services/document-service/transform/fields.d.ts.map +1 -0
  316. package/dist/services/document-service/transform/fields.js +24 -0
  317. package/dist/services/document-service/transform/fields.js.map +1 -0
  318. package/dist/services/document-service/transform/fields.mjs +24 -0
  319. package/dist/services/document-service/transform/fields.mjs.map +1 -0
  320. package/dist/services/document-service/transform/id-map.d.ts +23 -0
  321. package/dist/services/document-service/transform/id-map.d.ts.map +1 -0
  322. package/dist/services/document-service/transform/id-map.js +78 -0
  323. package/dist/services/document-service/transform/id-map.js.map +1 -0
  324. package/dist/services/document-service/transform/id-map.mjs +78 -0
  325. package/dist/services/document-service/transform/id-map.mjs.map +1 -0
  326. package/dist/services/document-service/transform/id-transform.d.ts +5 -0
  327. package/dist/services/document-service/transform/id-transform.d.ts.map +1 -0
  328. package/dist/services/document-service/transform/id-transform.js +33 -0
  329. package/dist/services/document-service/transform/id-transform.js.map +1 -0
  330. package/dist/services/document-service/transform/id-transform.mjs +33 -0
  331. package/dist/services/document-service/transform/id-transform.mjs.map +1 -0
  332. package/dist/services/document-service/transform/populate.d.ts +6 -0
  333. package/dist/services/document-service/transform/populate.d.ts.map +1 -0
  334. package/dist/services/document-service/transform/populate.js +21 -0
  335. package/dist/services/document-service/transform/populate.js.map +1 -0
  336. package/dist/services/document-service/transform/populate.mjs +21 -0
  337. package/dist/services/document-service/transform/populate.mjs.map +1 -0
  338. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +13 -0
  339. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -0
  340. package/dist/services/document-service/transform/relations/extract/data-ids.js +90 -0
  341. package/dist/services/document-service/transform/relations/extract/data-ids.js.map +1 -0
  342. package/dist/services/document-service/transform/relations/extract/data-ids.mjs +90 -0
  343. package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +1 -0
  344. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts +10 -0
  345. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts.map +1 -0
  346. package/dist/services/document-service/transform/relations/transform/data-ids.js +141 -0
  347. package/dist/services/document-service/transform/relations/transform/data-ids.js.map +1 -0
  348. package/dist/services/document-service/transform/relations/transform/data-ids.mjs +141 -0
  349. package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +1 -0
  350. package/dist/services/document-service/transform/relations/utils/data.d.ts +4 -0
  351. package/dist/services/document-service/transform/relations/utils/data.d.ts.map +1 -0
  352. package/dist/services/document-service/transform/relations/utils/data.js +12 -0
  353. package/dist/services/document-service/transform/relations/utils/data.js.map +1 -0
  354. package/dist/services/document-service/transform/relations/utils/data.mjs +12 -0
  355. package/dist/services/document-service/transform/relations/utils/data.mjs.map +1 -0
  356. package/dist/services/document-service/transform/relations/utils/dp.d.ts +10 -0
  357. package/dist/services/document-service/transform/relations/utils/dp.d.ts.map +1 -0
  358. package/dist/services/document-service/transform/relations/utils/dp.js +30 -0
  359. package/dist/services/document-service/transform/relations/utils/dp.js.map +1 -0
  360. package/dist/services/document-service/transform/relations/utils/dp.mjs +30 -0
  361. package/dist/services/document-service/transform/relations/utils/dp.mjs.map +1 -0
  362. package/dist/services/document-service/transform/relations/utils/i18n.d.ts +10 -0
  363. package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -0
  364. package/dist/services/document-service/transform/relations/utils/i18n.js +31 -0
  365. package/dist/services/document-service/transform/relations/utils/i18n.js.map +1 -0
  366. package/dist/services/document-service/transform/relations/utils/i18n.mjs +31 -0
  367. package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +1 -0
  368. package/dist/services/document-service/transform/relations/utils/types.d.ts +15 -0
  369. package/dist/services/document-service/transform/relations/utils/types.d.ts.map +1 -0
  370. package/dist/services/document-service/transform/types.d.ts +13 -0
  371. package/dist/services/document-service/transform/types.d.ts.map +1 -0
  372. package/dist/services/document-service/utils/populate.d.ts +10 -0
  373. package/dist/services/document-service/utils/populate.d.ts.map +1 -0
  374. package/dist/services/document-service/utils/populate.js +41 -0
  375. package/dist/services/document-service/utils/populate.js.map +1 -0
  376. package/dist/services/document-service/utils/populate.mjs +41 -0
  377. package/dist/services/document-service/utils/populate.mjs.map +1 -0
  378. package/dist/services/entity-service/components.d.ts +1 -4
  379. package/dist/services/entity-service/components.d.ts.map +1 -1
  380. package/dist/services/entity-service/components.js +13 -99
  381. package/dist/services/entity-service/components.js.map +1 -1
  382. package/dist/services/entity-service/components.mjs +14 -100
  383. package/dist/services/entity-service/components.mjs.map +1 -1
  384. package/dist/services/entity-service/index.d.ts +1 -3
  385. package/dist/services/entity-service/index.d.ts.map +1 -1
  386. package/dist/services/entity-service/index.js +34 -199
  387. package/dist/services/entity-service/index.js.map +1 -1
  388. package/dist/services/entity-service/index.mjs +27 -192
  389. package/dist/services/entity-service/index.mjs.map +1 -1
  390. package/dist/services/entity-service/params.d.ts +4 -4
  391. package/dist/services/entity-service/params.d.ts.map +1 -1
  392. package/dist/services/entity-service/params.js +1 -1
  393. package/dist/services/entity-service/params.js.map +1 -1
  394. package/dist/services/entity-service/params.mjs +1 -1
  395. package/dist/services/entity-service/params.mjs.map +1 -1
  396. package/dist/services/entity-validator/blocks-validator.d.ts.map +1 -1
  397. package/dist/services/entity-validator/blocks-validator.js +22 -2
  398. package/dist/services/entity-validator/blocks-validator.js.map +1 -1
  399. package/dist/services/entity-validator/blocks-validator.mjs +22 -2
  400. package/dist/services/entity-validator/blocks-validator.mjs.map +1 -1
  401. package/dist/services/entity-validator/index.d.ts.map +1 -1
  402. package/dist/services/entity-validator/index.js +5 -2
  403. package/dist/services/entity-validator/index.js.map +1 -1
  404. package/dist/services/entity-validator/index.mjs +5 -2
  405. package/dist/services/entity-validator/index.mjs.map +1 -1
  406. package/dist/services/entity-validator/validators.d.ts +14 -13
  407. package/dist/services/entity-validator/validators.d.ts.map +1 -1
  408. package/dist/services/entity-validator/validators.js +20 -16
  409. package/dist/services/entity-validator/validators.js.map +1 -1
  410. package/dist/services/entity-validator/validators.mjs +20 -16
  411. package/dist/services/entity-validator/validators.mjs.map +1 -1
  412. package/dist/services/features.d.ts +10 -0
  413. package/dist/services/features.d.ts.map +1 -0
  414. package/dist/services/features.js +17 -0
  415. package/dist/services/features.js.map +1 -0
  416. package/dist/services/features.mjs +17 -0
  417. package/dist/services/features.mjs.map +1 -0
  418. package/dist/services/server/compose-endpoint.d.ts.map +1 -1
  419. package/dist/services/server/compose-endpoint.js +3 -0
  420. package/dist/services/server/compose-endpoint.js.map +1 -1
  421. package/dist/services/server/compose-endpoint.mjs +3 -0
  422. package/dist/services/server/compose-endpoint.mjs.map +1 -1
  423. package/dist/services/server/middleware.d.ts +1 -5
  424. package/dist/services/server/middleware.d.ts.map +1 -1
  425. package/dist/services/server/middleware.js.map +1 -1
  426. package/dist/services/server/middleware.mjs.map +1 -1
  427. package/dist/services/server/register-middlewares.js +1 -1
  428. package/dist/services/server/register-middlewares.js.map +1 -1
  429. package/dist/services/server/register-middlewares.mjs +1 -1
  430. package/dist/services/server/register-middlewares.mjs.map +1 -1
  431. package/dist/services/webhook-runner.d.ts +10 -1
  432. package/dist/services/webhook-runner.d.ts.map +1 -1
  433. package/dist/services/webhook-store.d.ts +2 -22
  434. package/dist/services/webhook-store.d.ts.map +1 -1
  435. package/dist/services/webhook-store.js +7 -3
  436. package/dist/services/webhook-store.js.map +1 -1
  437. package/dist/services/webhook-store.mjs +7 -3
  438. package/dist/services/webhook-store.mjs.map +1 -1
  439. package/dist/utils/convert-custom-field-type.d.ts +1 -2
  440. package/dist/utils/convert-custom-field-type.d.ts.map +1 -1
  441. package/dist/utils/convert-custom-field-type.js +2 -1
  442. package/dist/utils/convert-custom-field-type.js.map +1 -1
  443. package/dist/utils/convert-custom-field-type.mjs +1 -1
  444. package/dist/utils/convert-custom-field-type.mjs.map +1 -1
  445. package/dist/utils/ee.d.ts +1 -2
  446. package/dist/utils/ee.d.ts.map +1 -1
  447. package/dist/utils/fetch.d.ts +2 -1
  448. package/dist/utils/fetch.d.ts.map +1 -1
  449. package/dist/utils/fetch.js +2 -2
  450. package/dist/utils/fetch.js.map +1 -1
  451. package/dist/utils/fetch.mjs +2 -2
  452. package/dist/utils/fetch.mjs.map +1 -1
  453. package/dist/utils/filepath-to-prop-path.d.ts +5 -0
  454. package/dist/utils/filepath-to-prop-path.d.ts.map +1 -0
  455. package/dist/{load → utils}/filepath-to-prop-path.js +3 -2
  456. package/dist/utils/filepath-to-prop-path.js.map +1 -0
  457. package/dist/{load → utils}/filepath-to-prop-path.mjs +2 -2
  458. package/dist/utils/filepath-to-prop-path.mjs.map +1 -0
  459. package/dist/utils/get-dirs.d.ts +1 -2
  460. package/dist/utils/get-dirs.d.ts.map +1 -1
  461. package/dist/utils/get-dirs.js +2 -1
  462. package/dist/utils/get-dirs.js.map +1 -1
  463. package/dist/utils/get-dirs.mjs +1 -1
  464. package/dist/utils/get-dirs.mjs.map +1 -1
  465. package/dist/utils/index.d.ts +11 -4
  466. package/dist/utils/index.d.ts.map +1 -1
  467. package/dist/utils/is-initialized.d.ts +1 -1
  468. package/dist/utils/is-initialized.d.ts.map +1 -1
  469. package/dist/utils/is-initialized.js +5 -4
  470. package/dist/utils/is-initialized.js.map +1 -1
  471. package/dist/utils/is-initialized.mjs +4 -4
  472. package/dist/utils/is-initialized.mjs.map +1 -1
  473. package/dist/utils/load-config-file.d.ts +2 -0
  474. package/dist/utils/load-config-file.d.ts.map +1 -0
  475. package/dist/{core/app-configuration → utils}/load-config-file.js +3 -3
  476. package/dist/utils/load-config-file.js.map +1 -0
  477. package/dist/{core/app-configuration → utils}/load-config-file.mjs +4 -4
  478. package/dist/utils/load-config-file.mjs.map +1 -0
  479. package/dist/{load → utils}/load-files.d.ts +2 -2
  480. package/dist/utils/load-files.d.ts.map +1 -0
  481. package/dist/{load → utils}/load-files.js +7 -6
  482. package/dist/utils/load-files.js.map +1 -0
  483. package/dist/{load → utils}/load-files.mjs +7 -7
  484. package/dist/utils/load-files.mjs.map +1 -0
  485. package/dist/utils/open-browser.d.ts +1 -2
  486. package/dist/utils/open-browser.d.ts.map +1 -1
  487. package/dist/utils/open-browser.js +5 -5
  488. package/dist/utils/open-browser.js.map +1 -1
  489. package/dist/utils/open-browser.mjs +4 -5
  490. package/dist/utils/open-browser.mjs.map +1 -1
  491. package/dist/utils/startup-logger.d.ts +1 -2
  492. package/dist/utils/startup-logger.d.ts.map +1 -1
  493. package/dist/utils/startup-logger.js +19 -13
  494. package/dist/utils/startup-logger.js.map +1 -1
  495. package/dist/utils/startup-logger.mjs +18 -13
  496. package/dist/utils/startup-logger.mjs.map +1 -1
  497. package/dist/utils/transform-content-types-to-models.d.ts +176 -4
  498. package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
  499. package/dist/utils/transform-content-types-to-models.js +202 -15
  500. package/dist/utils/transform-content-types-to-models.js.map +1 -1
  501. package/dist/utils/transform-content-types-to-models.mjs +199 -15
  502. package/dist/utils/transform-content-types-to-models.mjs.map +1 -1
  503. package/dist/utils/update-notifier/index.d.ts +1 -2
  504. package/dist/utils/update-notifier/index.d.ts.map +1 -1
  505. package/dist/utils/update-notifier/index.js +8 -2
  506. package/dist/utils/update-notifier/index.js.map +1 -1
  507. package/dist/utils/update-notifier/index.mjs +7 -2
  508. package/dist/utils/update-notifier/index.mjs.map +1 -1
  509. package/package.json +19 -26
  510. package/bin/strapi.js +0 -2
  511. package/dist/admin.d.ts +0 -5
  512. package/dist/admin.d.ts.map +0 -1
  513. package/dist/cli.d.ts +0 -2
  514. package/dist/cli.d.ts.map +0 -1
  515. package/dist/commands/actions/admin/create-user/action.d.ts +0 -12
  516. package/dist/commands/actions/admin/create-user/action.d.ts.map +0 -1
  517. package/dist/commands/actions/admin/create-user/command.d.ts +0 -7
  518. package/dist/commands/actions/admin/create-user/command.d.ts.map +0 -1
  519. package/dist/commands/actions/admin/reset-user-password/action.d.ts +0 -10
  520. package/dist/commands/actions/admin/reset-user-password/action.d.ts.map +0 -1
  521. package/dist/commands/actions/admin/reset-user-password/command.d.ts +0 -7
  522. package/dist/commands/actions/admin/reset-user-password/command.d.ts.map +0 -1
  523. package/dist/commands/actions/components/list/action.d.ts +0 -3
  524. package/dist/commands/actions/components/list/action.d.ts.map +0 -1
  525. package/dist/commands/actions/components/list/command.d.ts +0 -7
  526. package/dist/commands/actions/components/list/command.d.ts.map +0 -1
  527. package/dist/commands/actions/configuration/dump/action.d.ts +0 -11
  528. package/dist/commands/actions/configuration/dump/action.d.ts.map +0 -1
  529. package/dist/commands/actions/configuration/dump/command.d.ts +0 -7
  530. package/dist/commands/actions/configuration/dump/command.d.ts.map +0 -1
  531. package/dist/commands/actions/configuration/restore/action.d.ts +0 -11
  532. package/dist/commands/actions/configuration/restore/action.d.ts.map +0 -1
  533. package/dist/commands/actions/configuration/restore/command.d.ts +0 -7
  534. package/dist/commands/actions/configuration/restore/command.d.ts.map +0 -1
  535. package/dist/commands/actions/console/action.d.ts +0 -6
  536. package/dist/commands/actions/console/action.d.ts.map +0 -1
  537. package/dist/commands/actions/console/command.d.ts +0 -7
  538. package/dist/commands/actions/console/command.d.ts.map +0 -1
  539. package/dist/commands/actions/content-types/list/action.d.ts +0 -3
  540. package/dist/commands/actions/content-types/list/action.d.ts.map +0 -1
  541. package/dist/commands/actions/content-types/list/command.d.ts +0 -7
  542. package/dist/commands/actions/content-types/list/command.d.ts.map +0 -1
  543. package/dist/commands/actions/controllers/list/action.d.ts +0 -3
  544. package/dist/commands/actions/controllers/list/action.d.ts.map +0 -1
  545. package/dist/commands/actions/controllers/list/command.d.ts +0 -7
  546. package/dist/commands/actions/controllers/list/command.d.ts.map +0 -1
  547. package/dist/commands/actions/generate/command.d.ts +0 -7
  548. package/dist/commands/actions/generate/command.d.ts.map +0 -1
  549. package/dist/commands/actions/hooks/list/action.d.ts +0 -3
  550. package/dist/commands/actions/hooks/list/action.d.ts.map +0 -1
  551. package/dist/commands/actions/hooks/list/command.d.ts +0 -7
  552. package/dist/commands/actions/hooks/list/command.d.ts.map +0 -1
  553. package/dist/commands/actions/install/action.d.ts +0 -3
  554. package/dist/commands/actions/install/action.d.ts.map +0 -1
  555. package/dist/commands/actions/install/command.d.ts +0 -7
  556. package/dist/commands/actions/install/command.d.ts.map +0 -1
  557. package/dist/commands/actions/middlewares/list/action.d.ts +0 -3
  558. package/dist/commands/actions/middlewares/list/action.d.ts.map +0 -1
  559. package/dist/commands/actions/middlewares/list/command.d.ts +0 -7
  560. package/dist/commands/actions/middlewares/list/command.d.ts.map +0 -1
  561. package/dist/commands/actions/new/action.d.ts +0 -8
  562. package/dist/commands/actions/new/action.d.ts.map +0 -1
  563. package/dist/commands/actions/new/command.d.ts +0 -7
  564. package/dist/commands/actions/new/command.d.ts.map +0 -1
  565. package/dist/commands/actions/plugin/build-command/action.d.ts +0 -7
  566. package/dist/commands/actions/plugin/build-command/action.d.ts.map +0 -1
  567. package/dist/commands/actions/plugin/build-command/command.d.ts +0 -7
  568. package/dist/commands/actions/plugin/build-command/command.d.ts.map +0 -1
  569. package/dist/commands/actions/plugin/watch/action.d.ts +0 -7
  570. package/dist/commands/actions/plugin/watch/action.d.ts.map +0 -1
  571. package/dist/commands/actions/plugin/watch/command.d.ts +0 -7
  572. package/dist/commands/actions/plugin/watch/command.d.ts.map +0 -1
  573. package/dist/commands/actions/policies/list/action.d.ts +0 -3
  574. package/dist/commands/actions/policies/list/action.d.ts.map +0 -1
  575. package/dist/commands/actions/policies/list/command.d.ts +0 -7
  576. package/dist/commands/actions/policies/list/command.d.ts.map +0 -1
  577. package/dist/commands/actions/report/action.d.ts +0 -8
  578. package/dist/commands/actions/report/action.d.ts.map +0 -1
  579. package/dist/commands/actions/report/command.d.ts +0 -7
  580. package/dist/commands/actions/report/command.d.ts.map +0 -1
  581. package/dist/commands/actions/routes/list/action.d.ts +0 -3
  582. package/dist/commands/actions/routes/list/action.d.ts.map +0 -1
  583. package/dist/commands/actions/routes/list/command.d.ts +0 -7
  584. package/dist/commands/actions/routes/list/command.d.ts.map +0 -1
  585. package/dist/commands/actions/services/list/action.d.ts +0 -3
  586. package/dist/commands/actions/services/list/action.d.ts.map +0 -1
  587. package/dist/commands/actions/services/list/command.d.ts +0 -7
  588. package/dist/commands/actions/services/list/command.d.ts.map +0 -1
  589. package/dist/commands/actions/start/action.d.ts +0 -6
  590. package/dist/commands/actions/start/action.d.ts.map +0 -1
  591. package/dist/commands/actions/start/command.d.ts +0 -7
  592. package/dist/commands/actions/start/command.d.ts.map +0 -1
  593. package/dist/commands/actions/telemetry/disable/action.d.ts +0 -2
  594. package/dist/commands/actions/telemetry/disable/action.d.ts.map +0 -1
  595. package/dist/commands/actions/telemetry/disable/command.d.ts +0 -7
  596. package/dist/commands/actions/telemetry/disable/command.d.ts.map +0 -1
  597. package/dist/commands/actions/telemetry/enable/action.d.ts +0 -3
  598. package/dist/commands/actions/telemetry/enable/action.d.ts.map +0 -1
  599. package/dist/commands/actions/telemetry/enable/command.d.ts +0 -7
  600. package/dist/commands/actions/telemetry/enable/command.d.ts.map +0 -1
  601. package/dist/commands/actions/templates/generate/action.d.ts +0 -2
  602. package/dist/commands/actions/templates/generate/action.d.ts.map +0 -1
  603. package/dist/commands/actions/templates/generate/command.d.ts +0 -7
  604. package/dist/commands/actions/templates/generate/command.d.ts.map +0 -1
  605. package/dist/commands/actions/ts/generate-types/action.d.ts +0 -9
  606. package/dist/commands/actions/ts/generate-types/action.d.ts.map +0 -1
  607. package/dist/commands/actions/ts/generate-types/command.d.ts +0 -7
  608. package/dist/commands/actions/ts/generate-types/command.d.ts.map +0 -1
  609. package/dist/commands/actions/uninstall/action.d.ts +0 -6
  610. package/dist/commands/actions/uninstall/action.d.ts.map +0 -1
  611. package/dist/commands/actions/uninstall/command.d.ts +0 -7
  612. package/dist/commands/actions/uninstall/command.d.ts.map +0 -1
  613. package/dist/commands/actions/version/command.d.ts +0 -7
  614. package/dist/commands/actions/version/command.d.ts.map +0 -1
  615. package/dist/commands/actions/watch-admin/action.d.ts +0 -7
  616. package/dist/commands/actions/watch-admin/action.d.ts.map +0 -1
  617. package/dist/commands/actions/watch-admin/command.d.ts +0 -7
  618. package/dist/commands/actions/watch-admin/command.d.ts.map +0 -1
  619. package/dist/commands/index.d.ts +0 -37
  620. package/dist/commands/index.d.ts.map +0 -1
  621. package/dist/commands/types.d.ts +0 -14
  622. package/dist/commands/types.d.ts.map +0 -1
  623. package/dist/commands/utils/commander.d.ts +0 -36
  624. package/dist/commands/utils/commander.d.ts.map +0 -1
  625. package/dist/commands/utils/helpers.d.ts +0 -49
  626. package/dist/commands/utils/helpers.d.ts.map +0 -1
  627. package/dist/commands/utils/logger.d.ts +0 -19
  628. package/dist/commands/utils/logger.d.ts.map +0 -1
  629. package/dist/commands/utils/pkg.d.ts +0 -119
  630. package/dist/commands/utils/pkg.d.ts.map +0 -1
  631. package/dist/commands/utils/tsconfig.d.ts +0 -19
  632. package/dist/commands/utils/tsconfig.d.ts.map +0 -1
  633. package/dist/core/app-configuration/config-loader.d.ts.map +0 -1
  634. package/dist/core/app-configuration/config-loader.js +0 -19
  635. package/dist/core/app-configuration/config-loader.js.map +0 -1
  636. package/dist/core/app-configuration/config-loader.mjs +0 -17
  637. package/dist/core/app-configuration/config-loader.mjs.map +0 -1
  638. package/dist/core/app-configuration/index.d.ts.map +0 -1
  639. package/dist/core/app-configuration/index.js.map +0 -1
  640. package/dist/core/app-configuration/index.mjs.map +0 -1
  641. package/dist/core/app-configuration/load-config-file.d.ts +0 -2
  642. package/dist/core/app-configuration/load-config-file.d.ts.map +0 -1
  643. package/dist/core/app-configuration/load-config-file.js.map +0 -1
  644. package/dist/core/app-configuration/load-config-file.mjs.map +0 -1
  645. package/dist/core/bootstrap.d.ts +0 -5
  646. package/dist/core/bootstrap.d.ts.map +0 -1
  647. package/dist/core/bootstrap.js +0 -28
  648. package/dist/core/bootstrap.js.map +0 -1
  649. package/dist/core/bootstrap.mjs +0 -27
  650. package/dist/core/bootstrap.mjs.map +0 -1
  651. package/dist/core/domain/content-type/index.d.ts.map +0 -1
  652. package/dist/core/domain/content-type/index.js.map +0 -1
  653. package/dist/core/domain/content-type/index.mjs.map +0 -1
  654. package/dist/core/domain/content-type/validator.d.ts.map +0 -1
  655. package/dist/core/domain/content-type/validator.js.map +0 -1
  656. package/dist/core/domain/content-type/validator.mjs.map +0 -1
  657. package/dist/core/domain/module/index.d.ts.map +0 -1
  658. package/dist/core/domain/module/index.js.map +0 -1
  659. package/dist/core/domain/module/index.mjs.map +0 -1
  660. package/dist/core/domain/module/validation.d.ts.map +0 -1
  661. package/dist/core/domain/module/validation.js.map +0 -1
  662. package/dist/core/domain/module/validation.mjs.map +0 -1
  663. package/dist/core/loaders/admin.d.ts.map +0 -1
  664. package/dist/core/loaders/admin.js.map +0 -1
  665. package/dist/core/loaders/admin.mjs.map +0 -1
  666. package/dist/core/loaders/apis.d.ts.map +0 -1
  667. package/dist/core/loaders/apis.js.map +0 -1
  668. package/dist/core/loaders/apis.mjs.map +0 -1
  669. package/dist/core/loaders/components.d.ts.map +0 -1
  670. package/dist/core/loaders/components.js.map +0 -1
  671. package/dist/core/loaders/components.mjs.map +0 -1
  672. package/dist/core/loaders/index.d.ts.map +0 -1
  673. package/dist/core/loaders/index.js.map +0 -1
  674. package/dist/core/loaders/index.mjs.map +0 -1
  675. package/dist/core/loaders/middlewares.d.ts.map +0 -1
  676. package/dist/core/loaders/middlewares.js.map +0 -1
  677. package/dist/core/loaders/middlewares.mjs.map +0 -1
  678. package/dist/core/loaders/plugins/get-enabled-plugins.d.ts.map +0 -1
  679. package/dist/core/loaders/plugins/get-enabled-plugins.js.map +0 -1
  680. package/dist/core/loaders/plugins/get-enabled-plugins.mjs.map +0 -1
  681. package/dist/core/loaders/plugins/get-user-plugins-config.d.ts.map +0 -1
  682. package/dist/core/loaders/plugins/get-user-plugins-config.js.map +0 -1
  683. package/dist/core/loaders/plugins/get-user-plugins-config.mjs.map +0 -1
  684. package/dist/core/loaders/plugins/index.d.ts.map +0 -1
  685. package/dist/core/loaders/plugins/index.js.map +0 -1
  686. package/dist/core/loaders/plugins/index.mjs.map +0 -1
  687. package/dist/core/loaders/policies.d.ts.map +0 -1
  688. package/dist/core/loaders/policies.js.map +0 -1
  689. package/dist/core/loaders/policies.mjs.map +0 -1
  690. package/dist/core/loaders/sanitizers.d.ts.map +0 -1
  691. package/dist/core/loaders/sanitizers.js.map +0 -1
  692. package/dist/core/loaders/sanitizers.mjs.map +0 -1
  693. package/dist/core/loaders/src-index.d.ts.map +0 -1
  694. package/dist/core/loaders/src-index.js.map +0 -1
  695. package/dist/core/loaders/src-index.mjs.map +0 -1
  696. package/dist/core/loaders/validators.d.ts.map +0 -1
  697. package/dist/core/loaders/validators.js.map +0 -1
  698. package/dist/core/loaders/validators.mjs.map +0 -1
  699. package/dist/core/registries/apis.d.ts.map +0 -1
  700. package/dist/core/registries/apis.js.map +0 -1
  701. package/dist/core/registries/apis.mjs.map +0 -1
  702. package/dist/core/registries/components.d.ts.map +0 -1
  703. package/dist/core/registries/components.js.map +0 -1
  704. package/dist/core/registries/components.mjs.map +0 -1
  705. package/dist/core/registries/config.d.ts +0 -4
  706. package/dist/core/registries/config.d.ts.map +0 -1
  707. package/dist/core/registries/config.js +0 -23
  708. package/dist/core/registries/config.js.map +0 -1
  709. package/dist/core/registries/config.mjs +0 -22
  710. package/dist/core/registries/config.mjs.map +0 -1
  711. package/dist/core/registries/content-types.d.ts.map +0 -1
  712. package/dist/core/registries/content-types.js.map +0 -1
  713. package/dist/core/registries/content-types.mjs.map +0 -1
  714. package/dist/core/registries/controllers.d.ts.map +0 -1
  715. package/dist/core/registries/controllers.js.map +0 -1
  716. package/dist/core/registries/controllers.mjs.map +0 -1
  717. package/dist/core/registries/custom-fields.d.ts.map +0 -1
  718. package/dist/core/registries/custom-fields.js.map +0 -1
  719. package/dist/core/registries/custom-fields.mjs.map +0 -1
  720. package/dist/core/registries/hooks.d.ts.map +0 -1
  721. package/dist/core/registries/hooks.js.map +0 -1
  722. package/dist/core/registries/hooks.mjs.map +0 -1
  723. package/dist/core/registries/index.d.ts.map +0 -1
  724. package/dist/core/registries/middlewares.d.ts.map +0 -1
  725. package/dist/core/registries/middlewares.js.map +0 -1
  726. package/dist/core/registries/middlewares.mjs.map +0 -1
  727. package/dist/core/registries/modules.d.ts.map +0 -1
  728. package/dist/core/registries/modules.js.map +0 -1
  729. package/dist/core/registries/modules.mjs.map +0 -1
  730. package/dist/core/registries/plugins.d.ts.map +0 -1
  731. package/dist/core/registries/plugins.js.map +0 -1
  732. package/dist/core/registries/plugins.mjs.map +0 -1
  733. package/dist/core/registries/policies.d.ts.map +0 -1
  734. package/dist/core/registries/policies.js.map +0 -1
  735. package/dist/core/registries/policies.mjs.map +0 -1
  736. package/dist/core/registries/sanitizers.d.ts.map +0 -1
  737. package/dist/core/registries/sanitizers.js.map +0 -1
  738. package/dist/core/registries/sanitizers.mjs.map +0 -1
  739. package/dist/core/registries/services.d.ts.map +0 -1
  740. package/dist/core/registries/services.js.map +0 -1
  741. package/dist/core/registries/services.mjs.map +0 -1
  742. package/dist/core/registries/validators.d.ts.map +0 -1
  743. package/dist/core/registries/validators.js.map +0 -1
  744. package/dist/core/registries/validators.mjs.map +0 -1
  745. package/dist/core/utils.d.ts.map +0 -1
  746. package/dist/core/utils.js.map +0 -1
  747. package/dist/core/utils.mjs.map +0 -1
  748. package/dist/core-api/service/get-fetch-params.d.ts +0 -7
  749. package/dist/core-api/service/get-fetch-params.d.ts.map +0 -1
  750. package/dist/core-api/service/get-fetch-params.js +0 -14
  751. package/dist/core-api/service/get-fetch-params.js.map +0 -1
  752. package/dist/core-api/service/get-fetch-params.mjs +0 -14
  753. package/dist/core-api/service/get-fetch-params.mjs.map +0 -1
  754. package/dist/load/filepath-to-prop-path.d.ts +0 -6
  755. package/dist/load/filepath-to-prop-path.d.ts.map +0 -1
  756. package/dist/load/filepath-to-prop-path.js.map +0 -1
  757. package/dist/load/filepath-to-prop-path.mjs.map +0 -1
  758. package/dist/load/glob.d.ts +0 -7
  759. package/dist/load/glob.d.ts.map +0 -1
  760. package/dist/load/glob.js +0 -15
  761. package/dist/load/glob.js.map +0 -1
  762. package/dist/load/glob.mjs +0 -14
  763. package/dist/load/glob.mjs.map +0 -1
  764. package/dist/load/index.d.ts +0 -3
  765. package/dist/load/index.d.ts.map +0 -1
  766. package/dist/load/load-files.d.ts.map +0 -1
  767. package/dist/load/load-files.js.map +0 -1
  768. package/dist/load/load-files.mjs.map +0 -1
  769. package/dist/load/package-path.d.ts +0 -6
  770. package/dist/load/package-path.d.ts.map +0 -1
  771. package/dist/middlewares/public/assets/images/group_people_1.png +0 -0
  772. package/dist/middlewares/public/assets/images/group_people_2.png +0 -0
  773. package/dist/middlewares/public/assets/images/group_people_3.png +0 -0
  774. package/dist/middlewares/public/assets/images/logo_login.png +0 -0
  775. package/dist/middlewares/public/index.d.ts.map +0 -1
  776. package/dist/middlewares/public/index.html +0 -66
  777. package/dist/middlewares/public/index.js +0 -91
  778. package/dist/middlewares/public/index.js.map +0 -1
  779. package/dist/middlewares/public/index.mjs +0 -85
  780. package/dist/middlewares/public/index.mjs.map +0 -1
  781. package/dist/middlewares/public/serve-static.d.ts +0 -4
  782. package/dist/middlewares/public/serve-static.d.ts.map +0 -1
  783. package/dist/middlewares/public/serve-static.js +0 -24
  784. package/dist/middlewares/public/serve-static.js.map +0 -1
  785. package/dist/middlewares/public/serve-static.mjs +0 -21
  786. package/dist/middlewares/public/serve-static.mjs.map +0 -1
  787. package/dist/services/document-service/document-repository.d.ts +0 -21
  788. package/dist/services/document-service/document-repository.d.ts.map +0 -1
  789. package/dist/services/document-service/document-repository.js +0 -132
  790. package/dist/services/document-service/document-repository.js.map +0 -1
  791. package/dist/services/document-service/document-repository.mjs +0 -132
  792. package/dist/services/document-service/document-repository.mjs.map +0 -1
  793. package/dist/services/document-service/middlewares/defaults/draft-and-publish.d.ts +0 -26
  794. package/dist/services/document-service/middlewares/defaults/draft-and-publish.d.ts.map +0 -1
  795. package/dist/services/document-service/middlewares/defaults/draft-and-publish.js +0 -58
  796. package/dist/services/document-service/middlewares/defaults/draft-and-publish.js.map +0 -1
  797. package/dist/services/document-service/middlewares/defaults/draft-and-publish.mjs +0 -58
  798. package/dist/services/document-service/middlewares/defaults/draft-and-publish.mjs.map +0 -1
  799. package/dist/services/document-service/middlewares/defaults/index.d.ts +0 -3
  800. package/dist/services/document-service/middlewares/defaults/index.d.ts.map +0 -1
  801. package/dist/services/document-service/middlewares/defaults/index.js +0 -82
  802. package/dist/services/document-service/middlewares/defaults/index.js.map +0 -1
  803. package/dist/services/document-service/middlewares/defaults/index.mjs +0 -82
  804. package/dist/services/document-service/middlewares/defaults/index.mjs.map +0 -1
  805. package/dist/services/document-service/middlewares/defaults/locales.d.ts +0 -18
  806. package/dist/services/document-service/middlewares/defaults/locales.d.ts.map +0 -1
  807. package/dist/services/document-service/middlewares/defaults/locales.js +0 -40
  808. package/dist/services/document-service/middlewares/defaults/locales.js.map +0 -1
  809. package/dist/services/document-service/middlewares/defaults/locales.mjs +0 -40
  810. package/dist/services/document-service/middlewares/defaults/locales.mjs.map +0 -1
  811. package/dist/services/document-service/middlewares/index.js +0 -59
  812. package/dist/services/document-service/middlewares/index.js.map +0 -1
  813. package/dist/services/document-service/middlewares/index.mjs +0 -59
  814. package/dist/services/document-service/middlewares/index.mjs.map +0 -1
  815. package/dist/services/utils/upload-files.d.ts +0 -8
  816. package/dist/services/utils/upload-files.d.ts.map +0 -1
  817. package/dist/services/utils/upload-files.js +0 -64
  818. package/dist/services/utils/upload-files.js.map +0 -1
  819. package/dist/services/utils/upload-files.mjs +0 -63
  820. package/dist/services/utils/upload-files.mjs.map +0 -1
  821. package/dist/utils/addSlash.d.ts +0 -3
  822. package/dist/utils/addSlash.d.ts.map +0 -1
  823. package/dist/utils/ee.js +0 -4
  824. package/dist/utils/ee.js.map +0 -1
  825. package/dist/utils/ee.mjs +0 -5
  826. package/dist/utils/ee.mjs.map +0 -1
  827. /package/dist/{core/app-configuration → configuration}/config-loader.d.ts +0 -0
  828. /package/dist/{core/domain → domain}/content-type/validator.d.ts +0 -0
  829. /package/dist/{core/domain → domain}/module/index.d.ts +0 -0
  830. /package/dist/{core/domain → domain}/module/validation.d.ts +0 -0
  831. /package/dist/{core/domain → domain}/module/validation.js +0 -0
  832. /package/dist/{core/domain → domain}/module/validation.mjs +0 -0
  833. /package/dist/{core/loaders → loaders}/admin.d.ts +0 -0
  834. /package/dist/{core/loaders → loaders}/apis.d.ts +0 -0
  835. /package/dist/{core/loaders → loaders}/components.d.ts +0 -0
  836. /package/dist/{core/loaders → loaders}/index.d.ts +0 -0
  837. /package/dist/{core/loaders → loaders}/index.js +0 -0
  838. /package/dist/{core/loaders → loaders}/index.mjs +0 -0
  839. /package/dist/{core/loaders → loaders}/middlewares.d.ts +0 -0
  840. /package/dist/{core/loaders → loaders}/plugins/get-enabled-plugins.d.ts +0 -0
  841. /package/dist/{core/loaders → loaders}/plugins/get-user-plugins-config.d.ts +0 -0
  842. /package/dist/{core/loaders → loaders}/plugins/index.d.ts +0 -0
  843. /package/dist/{core/loaders → loaders}/policies.d.ts +0 -0
  844. /package/dist/{core/loaders → loaders}/policies.js +0 -0
  845. /package/dist/{core/loaders → loaders}/policies.mjs +0 -0
  846. /package/dist/{core/loaders → loaders}/sanitizers.d.ts +0 -0
  847. /package/dist/{core/loaders → loaders}/sanitizers.js +0 -0
  848. /package/dist/{core/loaders → loaders}/sanitizers.mjs +0 -0
  849. /package/dist/{core/loaders → loaders}/src-index.d.ts +0 -0
  850. /package/dist/{core/loaders → loaders}/src-index.js +0 -0
  851. /package/dist/{core/loaders → loaders}/src-index.mjs +0 -0
  852. /package/dist/{core/loaders → loaders}/validators.d.ts +0 -0
  853. /package/dist/{core/loaders → loaders}/validators.js +0 -0
  854. /package/dist/{core/loaders → loaders}/validators.mjs +0 -0
  855. /package/dist/{core/registries → registries}/apis.d.ts +0 -0
  856. /package/dist/{core/registries → registries}/apis.js +0 -0
  857. /package/dist/{core/registries → registries}/apis.mjs +0 -0
  858. /package/dist/{core/registries → registries}/components.d.ts +0 -0
  859. /package/dist/{core/registries → registries}/components.js +0 -0
  860. /package/dist/{core/registries → registries}/components.mjs +0 -0
  861. /package/dist/{core/registries → registries}/content-types.d.ts +0 -0
  862. /package/dist/{core/registries → registries}/controllers.d.ts +0 -0
  863. /package/dist/{core/registries → registries}/custom-fields.d.ts +0 -0
  864. /package/dist/{core/registries → registries}/custom-fields.js +0 -0
  865. /package/dist/{core/registries → registries}/custom-fields.mjs +0 -0
  866. /package/dist/{core/registries → registries}/hooks.d.ts +0 -0
  867. /package/dist/{core/registries → registries}/middlewares.d.ts +0 -0
  868. /package/dist/{core/registries → registries}/modules.d.ts +0 -0
  869. /package/dist/{core/registries → registries}/modules.js +0 -0
  870. /package/dist/{core/registries → registries}/modules.mjs +0 -0
  871. /package/dist/{core/registries → registries}/plugins.d.ts +0 -0
  872. /package/dist/{core/registries → registries}/plugins.js +0 -0
  873. /package/dist/{core/registries → registries}/plugins.mjs +0 -0
  874. /package/dist/{core/registries → registries}/policies.d.ts +0 -0
  875. /package/dist/{core/registries → registries}/sanitizers.d.ts +0 -0
  876. /package/dist/{core/registries → registries}/sanitizers.js +0 -0
  877. /package/dist/{core/registries → registries}/sanitizers.mjs +0 -0
  878. /package/dist/{core/registries → registries}/services.d.ts +0 -0
  879. /package/dist/{core/registries → registries}/validators.d.ts +0 -0
  880. /package/dist/{core/registries → registries}/validators.js +0 -0
  881. /package/dist/{core/registries → registries}/validators.mjs +0 -0
@@ -32,7 +32,7 @@ const createComponents = async (uid, data) => {
32
32
  if (!Array.isArray(componentValue)) {
33
33
  throw new Error("Expected an array to create repeatable component");
34
34
  }
35
- const components = await strapiUtils.mapAsync(
35
+ const components = await strapiUtils.async.map(
36
36
  componentValue,
37
37
  (value) => createComponent(componentUID, value),
38
38
  { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
@@ -76,7 +76,7 @@ const createComponents = async (uid, data) => {
76
76
  }
77
77
  };
78
78
  };
79
- componentBody[attributeName] = await strapiUtils.mapAsync(
79
+ componentBody[attributeName] = await strapiUtils.async.map(
80
80
  dynamiczoneValues,
81
81
  createDynamicZoneComponents,
82
82
  { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
@@ -91,7 +91,7 @@ const getComponents = async (uid, entity) => {
91
91
  if (___default.default.isEmpty(componentAttributes)) {
92
92
  return {};
93
93
  }
94
- return strapi.query(uid).load(entity, componentAttributes);
94
+ return strapi.db.query(uid).load(entity, componentAttributes);
95
95
  };
96
96
  const updateComponents = async (uid, entityToUpdate, data) => {
97
97
  const { attributes = {} } = strapi.getModel(uid);
@@ -109,7 +109,7 @@ const updateComponents = async (uid, entityToUpdate, data) => {
109
109
  if (!Array.isArray(componentValue)) {
110
110
  throw new Error("Expected an array to create repeatable component");
111
111
  }
112
- const components = await strapiUtils.mapAsync(
112
+ const components = await strapiUtils.async.map(
113
113
  componentValue,
114
114
  (value) => updateOrCreateComponent(componentUID, value),
115
115
  { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
@@ -141,7 +141,7 @@ const updateComponents = async (uid, entityToUpdate, data) => {
141
141
  if (!Array.isArray(dynamiczoneValues)) {
142
142
  throw new Error("Expected an array to create repeatable component");
143
143
  }
144
- componentBody[attributeName] = await strapiUtils.mapAsync(
144
+ componentBody[attributeName] = await strapiUtils.async.map(
145
145
  dynamiczoneValues,
146
146
  async (value) => {
147
147
  const { id } = await updateOrCreateComponent(value.__component, value);
@@ -169,7 +169,7 @@ const pickStringifiedId = ({
169
169
  return `${id}`;
170
170
  };
171
171
  const deleteOldComponents = async (uid, componentUID, entityToUpdate, attributeName, componentValue) => {
172
- const previousValue = await strapi.query(uid).load(entityToUpdate, attributeName);
172
+ const previousValue = await strapi.db.query(uid).load(entityToUpdate, attributeName);
173
173
  const idsToKeep = ___default.default.castArray(componentValue).filter(_.has("id")).map(pickStringifiedId);
174
174
  const allIds = ___default.default.castArray(previousValue).filter(_.has("id")).map(pickStringifiedId);
175
175
  idsToKeep.forEach((id) => {
@@ -187,7 +187,7 @@ const deleteOldComponents = async (uid, componentUID, entityToUpdate, attributeN
187
187
  }
188
188
  };
189
189
  const deleteOldDZComponents = async (uid, entityToUpdate, attributeName, dynamiczoneValues) => {
190
- const previousValue = await strapi.query(uid).load(entityToUpdate, attributeName);
190
+ const previousValue = await strapi.db.query(uid).load(entityToUpdate, attributeName);
191
191
  const idsToKeep = ___default.default.castArray(dynamiczoneValues).filter(_.has("id")).map((v) => ({
192
192
  id: pickStringifiedId(v),
193
193
  __component: v.__component
@@ -226,7 +226,7 @@ const deleteComponents = async (uid, entityToDelete, { loadComponents = true } =
226
226
  if (attribute.type === "component" || attribute.type === "dynamiczone") {
227
227
  let value;
228
228
  if (loadComponents) {
229
- value = await strapi.query(uid).load(entityToDelete, attributeName);
229
+ value = await strapi.db.query(uid).load(entityToDelete, attributeName);
230
230
  } else {
231
231
  value = entityToDelete[attributeName];
232
232
  }
@@ -235,7 +235,7 @@ const deleteComponents = async (uid, entityToDelete, { loadComponents = true } =
235
235
  }
236
236
  if (attribute.type === "component") {
237
237
  const { component: componentUID } = attribute;
238
- await strapiUtils.mapAsync(
238
+ await strapiUtils.async.map(
239
239
  ___default.default.castArray(value),
240
240
  (subValue) => deleteComponent(componentUID, subValue),
241
241
  {
@@ -243,7 +243,7 @@ const deleteComponents = async (uid, entityToDelete, { loadComponents = true } =
243
243
  }
244
244
  );
245
245
  } else {
246
- await strapiUtils.mapAsync(
246
+ await strapiUtils.async.map(
247
247
  ___default.default.castArray(value),
248
248
  (subValue) => deleteComponent(subValue.__component, subValue),
249
249
  { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
@@ -253,75 +253,6 @@ const deleteComponents = async (uid, entityToDelete, { loadComponents = true } =
253
253
  }
254
254
  }
255
255
  };
256
- const cloneComponents = async (uid, entityToClone, data) => {
257
- const { attributes = {} } = strapi.getModel(uid);
258
- const componentBody = {};
259
- const componentData = await getComponents(uid, entityToClone);
260
- for (const attributeName of Object.keys(attributes)) {
261
- const attribute = attributes[attributeName];
262
- if (!_.has(attributeName, data) && !_.has(attributeName, componentData)) {
263
- continue;
264
- }
265
- if (attribute.type === "component") {
266
- const { component: componentUID, repeatable = false } = attribute;
267
- const componentValue = attributeName in data ? data[attributeName] : componentData[attributeName];
268
- if (componentValue === null) {
269
- continue;
270
- }
271
- if (repeatable === true) {
272
- if (!Array.isArray(componentValue)) {
273
- throw new Error("Expected an array to create repeatable component");
274
- }
275
- const components = await strapiUtils.mapAsync(
276
- componentValue,
277
- (value) => cloneComponent(componentUID, value),
278
- { concurrency: isDialectMySQL() ? 1 : Infinity }
279
- );
280
- componentBody[attributeName] = components.filter(___default.default.negate(___default.default.isNil)).map(({ id }) => {
281
- return {
282
- id,
283
- __pivot: {
284
- field: attributeName,
285
- component_type: componentUID
286
- }
287
- };
288
- });
289
- } else {
290
- const component = await cloneComponent(componentUID, componentValue);
291
- componentBody[attributeName] = component && {
292
- id: component.id,
293
- __pivot: {
294
- field: attributeName,
295
- component_type: componentUID
296
- }
297
- };
298
- }
299
- continue;
300
- }
301
- if (attribute.type === "dynamiczone") {
302
- const dynamiczoneValues = _.has(attributeName, data) ? data[attributeName] : componentData[attributeName];
303
- if (!Array.isArray(dynamiczoneValues)) {
304
- throw new Error("Expected an array to create repeatable component");
305
- }
306
- componentBody[attributeName] = await strapiUtils.mapAsync(
307
- dynamiczoneValues,
308
- async (value) => {
309
- const { id } = await cloneComponent(value.__component, value);
310
- return {
311
- id,
312
- __component: value.__component,
313
- __pivot: {
314
- field: attributeName
315
- }
316
- };
317
- },
318
- { concurrency: isDialectMySQL() ? 1 : Infinity }
319
- );
320
- continue;
321
- }
322
- }
323
- return componentBody;
324
- };
325
256
  const createComponent = async (uid, data) => {
326
257
  const model = strapi.getModel(uid);
327
258
  const componentData = await createComponents(uid, data);
@@ -333,12 +264,12 @@ const createComponent = async (uid, data) => {
333
264
  // ... and assign the newly created component instead
334
265
  _.assign(componentData)
335
266
  );
336
- return strapi.query(uid).create({ data: transform(data) });
267
+ return strapi.db.query(uid).create({ data: transform(data) });
337
268
  };
338
269
  const updateComponent = async (uid, componentToUpdate, data) => {
339
270
  const model = strapi.getModel(uid);
340
271
  const componentData = await updateComponents(uid, componentToUpdate, data);
341
- return strapi.query(uid).update({
272
+ return strapi.db.query(uid).update({
342
273
  where: {
343
274
  id: componentToUpdate.id
344
275
  },
@@ -356,25 +287,8 @@ const updateOrCreateComponent = (componentUID, value) => {
356
287
  };
357
288
  const deleteComponent = async (uid, componentToDelete) => {
358
289
  await deleteComponents(uid, componentToDelete);
359
- await strapi.query(uid).delete({ where: { id: componentToDelete.id } });
360
- };
361
- const cloneComponent = async (uid, data) => {
362
- const model = strapi.getModel(uid);
363
- if (!("id" in data) || typeof data.id === "undefined") {
364
- return createComponent(uid, data);
365
- }
366
- const componentData = await cloneComponents(uid, { id: data.id }, data);
367
- const transform = _.pipe(
368
- // Make sure we don't save the component with a pre-defined ID
369
- _.omit("id"),
370
- // Remove the component data from the original data object ...
371
- (payload) => omitComponentData(model, payload),
372
- // ... and assign the newly created component instead
373
- _.assign(componentData)
374
- );
375
- return strapi.query(uid).clone(data.id, { data: transform(data) });
290
+ await strapi.db.query(uid).delete({ where: { id: componentToDelete.id } });
376
291
  };
377
- exports.cloneComponents = cloneComponents;
378
292
  exports.createComponents = createComponents;
379
293
  exports.deleteComponent = deleteComponent;
380
294
  exports.deleteComponents = deleteComponents;
@@ -1 +1 @@
1
- {"version":3,"file":"components.js","sources":["../../../src/services/entity-service/components.ts"],"sourcesContent":["import _ from 'lodash';\nimport { has, omit, pipe, assign } from 'lodash/fp';\nimport type { Attribute, Common, Schema, Utils, EntityService } from '@strapi/types';\nimport { contentTypes as contentTypesUtils, mapAsync, errors } from '@strapi/utils';\n\ntype LoadedComponents<TUID extends Common.UID.Schema> = Attribute.GetValues<\n TUID,\n Attribute.GetKeysByType<TUID, 'component' | 'dynamiczone'>\n>;\n\ntype ComponentValue = Attribute.GetValue<\n Attribute.Component<Common.UID.Component, false> | Attribute.Component<Common.UID.Component, true>\n>;\n\ntype ComponentBody = {\n [key: string]: Attribute.GetValue<\n | Attribute.Component<Common.UID.Component, false>\n | Attribute.Component<Common.UID.Component, true>\n | Attribute.DynamicZone\n >;\n};\n\nconst isDialectMySQL = () => strapi.db?.dialect.client === 'mysql';\n\nfunction omitComponentData(\n contentType: Schema.ContentType,\n data: EntityService.Params.Data.Input<Schema.ContentType['uid']>\n): Partial<EntityService.Params.Data.Input<Schema.ContentType['uid']>>;\nfunction omitComponentData(\n contentType: Schema.Component,\n data: EntityService.Params.Data.Input<Schema.Component['uid']>\n): Partial<EntityService.Params.Data.Input<Schema.Component['uid']>>;\nfunction omitComponentData(\n contentType: Schema.ContentType | Schema.Component,\n data: EntityService.Params.Data.Input<Schema.ContentType['uid'] | Schema.Component['uid']>\n): Partial<EntityService.Params.Data.Input<Schema.ContentType['uid'] | Schema.Component['uid']>> {\n const { attributes } = contentType;\n const componentAttributes = Object.keys(attributes).filter((attributeName) =>\n contentTypesUtils.isComponentAttribute(attributes[attributeName])\n );\n\n return omit(componentAttributes, data);\n}\n\n// NOTE: we could generalize the logic to allow CRUD of relation directly in the DB layer\nconst createComponents = async <\n TUID extends Common.UID.Schema,\n TData extends EntityService.Params.Data.Input<TUID>\n>(\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 // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n const components = (await mapAsync(\n componentValue,\n (value: any) => createComponent(componentUID, value),\n { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }\n )) as Attribute.GetValue<Attribute.Component<Common.UID.Component, true>>;\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 EntityService.Params.Data.Input<Common.UID.Component>\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 EntityService.Params.Attribute.GetValue<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 mapAsync(\n dynamiczoneValues,\n createDynamicZoneComponents,\n { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }\n );\n\n continue;\n }\n }\n\n return componentBody;\n};\n\nconst getComponents = async <TUID extends Common.UID.Schema>(\n uid: TUID,\n entity: { id: 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.query(uid).load(entity, componentAttributes) as Promise<LoadedComponents<TUID>>;\n};\n\n/*\n delete old components\n create or update\n*/\nconst updateComponents = async <\n TUID extends Common.UID.Schema,\n TData extends Partial<EntityService.Params.Data.Input<TUID>>\n>(\n uid: TUID,\n entityToUpdate: { id: 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[\n attributeName as keyof TData\n ] as Attribute.GetValue<Attribute.Component>;\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 = (await mapAsync(\n componentValue,\n (value: any) => updateOrCreateComponent(componentUID, value),\n { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }\n )) as Attribute.GetValue<Attribute.Component<Common.UID.Component, true>>;\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\n continue;\n }\n\n if (attribute.type === 'dynamiczone') {\n const dynamiczoneValues = data[\n attributeName as keyof TData\n ] as Attribute.GetValue<Attribute.DynamicZone>;\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 mapAsync(\n dynamiczoneValues,\n 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 { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }\n );\n\n continue;\n }\n }\n\n return componentBody;\n};\n\nconst pickStringifiedId = ({\n id,\n}: {\n id: EntityService.Params.Attribute.ID;\n}): 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 Common.UID.Schema>(\n uid: TUID,\n componentUID: Common.UID.Component,\n entityToUpdate: { id: EntityService.Params.Attribute.ID },\n attributeName: string,\n componentValue: Attribute.GetValue<Attribute.Component>\n) => {\n const previousValue = (await strapi\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 Common.UID.Schema>(\n uid: TUID,\n entityToUpdate: { id: EntityService.Params.Attribute.ID },\n attributeName: string,\n dynamiczoneValues: Attribute.GetValue<Attribute.DynamicZone>\n) => {\n const previousValue = (await strapi\n .query(uid)\n .load(entityToUpdate, attributeName)) as Attribute.GetValue<Attribute.DynamicZone>;\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 = Attribute.GetValue<Attribute.DynamicZone>;\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 <\n TUID extends Common.UID.Schema,\n TEntity extends Attribute.GetValues<TUID>\n>(\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 if (loadComponents) {\n value = await strapi.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 // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n await mapAsync(\n _.castArray(value),\n (subValue: any) => deleteComponent(componentUID, subValue),\n {\n concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity,\n }\n );\n } else {\n // delete dynamic zone components\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n await mapAsync(\n _.castArray(value),\n (subValue: any) => deleteComponent(subValue.__component, subValue),\n { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }\n );\n }\n\n continue;\n }\n }\n};\n\nconst cloneComponents = async <TUID extends Common.UID.Schema>(\n uid: TUID,\n entityToClone: { id: EntityService.Params.Attribute.ID },\n data: EntityService.Params.Data.Input<TUID>\n) => {\n const { attributes = {} } = strapi.getModel(uid);\n\n const componentBody: ComponentBody = {};\n const componentData = await getComponents(uid, entityToClone);\n\n for (const attributeName of Object.keys(attributes)) {\n const attribute = attributes[attributeName];\n\n // If the attribute is not set or on the component to clone, skip it\n if (!has(attributeName, data) && !has(attributeName, componentData)) {\n continue;\n }\n\n if (attribute.type === 'component') {\n const { component: componentUID, repeatable = false } = attribute;\n\n const componentValue = (\n attributeName in data\n ? data[attributeName as keyof typeof data]\n : componentData[attributeName as keyof typeof componentData]\n ) as ComponentValue;\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 // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n const components = (await mapAsync(\n componentValue,\n (value: any) => cloneComponent(componentUID, value),\n { concurrency: isDialectMySQL() ? 1 : Infinity }\n )) as Attribute.GetValue<Attribute.Component<Common.UID.Component, true>>;\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 cloneComponent(componentUID, componentValue);\n componentBody[attributeName] = component && {\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 = has(attributeName, data)\n ? data[attributeName as keyof typeof data]\n : componentData[attributeName as keyof typeof componentData];\n\n if (!Array.isArray(dynamiczoneValues)) {\n throw new Error('Expected an array to create repeatable component');\n }\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n componentBody[attributeName] = await mapAsync(\n dynamiczoneValues,\n async (value: any) => {\n const { id } = await cloneComponent(value.__component, value);\n return {\n id,\n __component: value.__component,\n __pivot: {\n field: attributeName,\n },\n };\n },\n { concurrency: isDialectMySQL() ? 1 : Infinity }\n );\n continue;\n }\n }\n\n return componentBody;\n};\n/** *************************\n Component queries\n************************** */\n\n// components can have nested compos so this must be recursive\nconst createComponent = async <TUID extends Common.UID.Component>(\n uid: TUID,\n data: EntityService.Params.Data.Input<TUID>\n) => {\n const model = strapi.getModel(uid);\n\n const componentData = await createComponents(uid, data);\n const transform = pipe(\n // Make sure we don't save the component with a pre-defined ID\n omit('id'),\n // Remove the component data from the original data object ...\n (payload) => omitComponentData(model, payload),\n // ... and assign the newly created component instead\n assign(componentData)\n );\n\n return strapi.query(uid).create({ data: transform(data) });\n};\n\n// components can have nested compos so this must be recursive\nconst updateComponent = async <TUID extends Common.UID.Component>(\n uid: TUID,\n componentToUpdate: { id: EntityService.Params.Attribute.ID },\n data: EntityService.Params.Data.Input<TUID>\n) => {\n const model = strapi.getModel(uid);\n\n const componentData = await updateComponents(uid, componentToUpdate, data);\n\n return strapi.query(uid).update({\n where: {\n id: componentToUpdate.id,\n },\n data: Object.assign(omitComponentData(model, data), componentData),\n });\n};\n\nconst updateOrCreateComponent = <TUID extends Common.UID.Component>(\n componentUID: TUID,\n value: EntityService.Params.Data.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 Common.UID.Component>(\n uid: TUID,\n componentToDelete: Attribute.GetValues<TUID>\n) => {\n await deleteComponents(uid, componentToDelete);\n await strapi.query(uid).delete({ where: { id: componentToDelete.id } });\n};\n\nconst cloneComponent = async <TUID extends Common.UID.Component>(\n uid: TUID,\n data: EntityService.Params.Data.Input<TUID>\n) => {\n const model = strapi.getModel(uid);\n\n if (!('id' in data) || typeof data.id === 'undefined') {\n return createComponent(uid, data);\n }\n\n const componentData = await cloneComponents(uid, { id: data.id }, data);\n const transform = pipe(\n // Make sure we don't save the component with a pre-defined ID\n omit('id'),\n // Remove the component data from the original data object ...\n (payload) => omitComponentData(model, payload),\n // ... and assign the newly created component instead\n assign(componentData)\n );\n\n return strapi.query(uid).clone(data.id, { data: transform(data) });\n};\n\nexport {\n omitComponentData,\n getComponents,\n createComponents,\n updateComponents,\n deleteComponents,\n deleteComponent,\n cloneComponents,\n};\n"],"names":["contentTypesUtils","omit","has","mapAsync","_","errors","pipe","assign"],"mappings":"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"}
1
+ {"version":3,"file":"components.js","sources":["../../../src/services/entity-service/components.ts"],"sourcesContent":["import _ from 'lodash';\nimport { has, omit, pipe, assign } from 'lodash/fp';\nimport type { Attribute, Common, Schema, Utils, EntityService } from '@strapi/types';\nimport { contentTypes as contentTypesUtils, async, errors } from '@strapi/utils';\n\ntype LoadedComponents<TUID extends Common.UID.Schema> = Attribute.GetValues<\n TUID,\n Attribute.GetKeysByType<TUID, 'component' | 'dynamiczone'>\n>;\n\ntype ComponentValue = Attribute.GetValue<\n Attribute.Component<Common.UID.Component, false> | Attribute.Component<Common.UID.Component, true>\n>;\n\ntype ComponentBody = {\n [key: string]: Attribute.GetValue<\n | Attribute.Component<Common.UID.Component, false>\n | Attribute.Component<Common.UID.Component, true>\n | Attribute.DynamicZone\n >;\n};\n\nconst isDialectMySQL = () => strapi.db?.dialect.client === 'mysql';\n\nfunction omitComponentData(\n contentType: Schema.ContentType,\n data: EntityService.Params.Data.Input<Schema.ContentType['uid']>\n): Partial<EntityService.Params.Data.Input<Schema.ContentType['uid']>>;\nfunction omitComponentData(\n contentType: Schema.Component,\n data: EntityService.Params.Data.Input<Schema.Component['uid']>\n): Partial<EntityService.Params.Data.Input<Schema.Component['uid']>>;\nfunction omitComponentData(\n contentType: Schema.ContentType | Schema.Component,\n data: EntityService.Params.Data.Input<Schema.ContentType['uid'] | Schema.Component['uid']>\n): Partial<EntityService.Params.Data.Input<Schema.ContentType['uid'] | Schema.Component['uid']>> {\n const { attributes } = contentType;\n const componentAttributes = Object.keys(attributes).filter((attributeName) =>\n contentTypesUtils.isComponentAttribute(attributes[attributeName])\n );\n\n return omit(componentAttributes, data);\n}\n\n// NOTE: we could generalize the logic to allow CRUD of relation directly in the DB layer\nconst createComponents = async <\n TUID extends Common.UID.Schema,\n TData extends EntityService.Params.Data.Input<TUID>\n>(\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 // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n const components = (await async.map(\n componentValue,\n (value: any) => createComponent(componentUID, value),\n { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }\n )) as Attribute.GetValue<Attribute.Component<Common.UID.Component, true>>;\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 EntityService.Params.Data.Input<Common.UID.Component>\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 EntityService.Params.Attribute.GetValue<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 { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }\n );\n\n continue;\n }\n }\n\n return componentBody;\n};\n\nconst getComponents = async <TUID extends Common.UID.Schema>(\n uid: TUID,\n entity: { id: 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 <\n TUID extends Common.UID.Schema,\n TData extends Partial<EntityService.Params.Data.Input<TUID>>\n>(\n uid: TUID,\n entityToUpdate: { id: 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[\n attributeName as keyof TData\n ] as Attribute.GetValue<Attribute.Component>;\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 = (await async.map(\n componentValue,\n (value: any) => updateOrCreateComponent(componentUID, value),\n { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }\n )) as Attribute.GetValue<Attribute.Component<Common.UID.Component, true>>;\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\n continue;\n }\n\n if (attribute.type === 'dynamiczone') {\n const dynamiczoneValues = data[\n attributeName as keyof TData\n ] as Attribute.GetValue<Attribute.DynamicZone>;\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(\n dynamiczoneValues,\n 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 { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }\n );\n\n continue;\n }\n }\n\n return componentBody;\n};\n\nconst pickStringifiedId = ({\n id,\n}: {\n id: EntityService.Params.Attribute.ID;\n}): 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 Common.UID.Schema>(\n uid: TUID,\n componentUID: Common.UID.Component,\n entityToUpdate: { id: EntityService.Params.Attribute.ID },\n attributeName: string,\n componentValue: Attribute.GetValue<Attribute.Component>\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 Common.UID.Schema>(\n uid: TUID,\n entityToUpdate: { id: EntityService.Params.Attribute.ID },\n attributeName: string,\n dynamiczoneValues: Attribute.GetValue<Attribute.DynamicZone>\n) => {\n const previousValue = (await strapi.db\n .query(uid)\n .load(entityToUpdate, attributeName)) as Attribute.GetValue<Attribute.DynamicZone>;\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 = Attribute.GetValue<Attribute.DynamicZone>;\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 <\n TUID extends Common.UID.Schema,\n TEntity extends Attribute.GetValues<TUID>\n>(\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 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 // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n await async.map(\n _.castArray(value),\n (subValue: any) => deleteComponent(componentUID, subValue),\n {\n concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity,\n }\n );\n } else {\n // delete dynamic zone components\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n await async.map(\n _.castArray(value),\n (subValue: any) => deleteComponent(subValue.__component, subValue),\n { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }\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 Common.UID.Component>(\n uid: TUID,\n data: EntityService.Params.Data.Input<TUID>\n) => {\n const model = strapi.getModel(uid);\n\n const componentData = await createComponents(uid, data);\n const transform = pipe(\n // Make sure we don't save the component with a pre-defined ID\n omit('id'),\n // Remove the component data from the original data object ...\n (payload) => omitComponentData(model, payload),\n // ... and assign the newly created component instead\n assign(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 Common.UID.Component>(\n uid: TUID,\n componentToUpdate: { id: EntityService.Params.Attribute.ID },\n data: EntityService.Params.Data.Input<TUID>\n) => {\n const model = 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: Object.assign(omitComponentData(model, data), componentData),\n });\n};\n\nconst updateOrCreateComponent = <TUID extends Common.UID.Component>(\n componentUID: TUID,\n value: EntityService.Params.Data.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 Common.UID.Component>(\n uid: TUID,\n componentToDelete: Attribute.GetValues<TUID>\n) => {\n await deleteComponents(uid, componentToDelete);\n await strapi.db.query(uid).delete({ where: { id: componentToDelete.id } });\n};\n\nexport {\n omitComponentData,\n getComponents,\n createComponents,\n updateComponents,\n deleteComponents,\n deleteComponent,\n};\n"],"names":["contentTypesUtils","omit","has","async","_","errors","pipe","assign"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  import _ from "lodash";
2
2
  import { omit, has, pipe, assign } from "lodash/fp";
3
- import { contentTypes, mapAsync, errors } from "@strapi/utils";
3
+ import { contentTypes, async, errors } from "@strapi/utils";
4
4
  const isDialectMySQL = () => strapi.db?.dialect.client === "mysql";
5
5
  function omitComponentData(contentType, data) {
6
6
  const { attributes } = contentType;
@@ -28,7 +28,7 @@ const createComponents = async (uid, data) => {
28
28
  if (!Array.isArray(componentValue)) {
29
29
  throw new Error("Expected an array to create repeatable component");
30
30
  }
31
- const components = await mapAsync(
31
+ const components = await async.map(
32
32
  componentValue,
33
33
  (value) => createComponent(componentUID, value),
34
34
  { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
@@ -72,7 +72,7 @@ const createComponents = async (uid, data) => {
72
72
  }
73
73
  };
74
74
  };
75
- componentBody[attributeName] = await mapAsync(
75
+ componentBody[attributeName] = await async.map(
76
76
  dynamiczoneValues,
77
77
  createDynamicZoneComponents,
78
78
  { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
@@ -87,7 +87,7 @@ const getComponents = async (uid, entity) => {
87
87
  if (_.isEmpty(componentAttributes)) {
88
88
  return {};
89
89
  }
90
- return strapi.query(uid).load(entity, componentAttributes);
90
+ return strapi.db.query(uid).load(entity, componentAttributes);
91
91
  };
92
92
  const updateComponents = async (uid, entityToUpdate, data) => {
93
93
  const { attributes = {} } = strapi.getModel(uid);
@@ -105,7 +105,7 @@ const updateComponents = async (uid, entityToUpdate, data) => {
105
105
  if (!Array.isArray(componentValue)) {
106
106
  throw new Error("Expected an array to create repeatable component");
107
107
  }
108
- const components = await mapAsync(
108
+ const components = await async.map(
109
109
  componentValue,
110
110
  (value) => updateOrCreateComponent(componentUID, value),
111
111
  { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
@@ -137,7 +137,7 @@ const updateComponents = async (uid, entityToUpdate, data) => {
137
137
  if (!Array.isArray(dynamiczoneValues)) {
138
138
  throw new Error("Expected an array to create repeatable component");
139
139
  }
140
- componentBody[attributeName] = await mapAsync(
140
+ componentBody[attributeName] = await async.map(
141
141
  dynamiczoneValues,
142
142
  async (value) => {
143
143
  const { id } = await updateOrCreateComponent(value.__component, value);
@@ -165,7 +165,7 @@ const pickStringifiedId = ({
165
165
  return `${id}`;
166
166
  };
167
167
  const deleteOldComponents = async (uid, componentUID, entityToUpdate, attributeName, componentValue) => {
168
- const previousValue = await strapi.query(uid).load(entityToUpdate, attributeName);
168
+ const previousValue = await strapi.db.query(uid).load(entityToUpdate, attributeName);
169
169
  const idsToKeep = _.castArray(componentValue).filter(has("id")).map(pickStringifiedId);
170
170
  const allIds = _.castArray(previousValue).filter(has("id")).map(pickStringifiedId);
171
171
  idsToKeep.forEach((id) => {
@@ -183,7 +183,7 @@ const deleteOldComponents = async (uid, componentUID, entityToUpdate, attributeN
183
183
  }
184
184
  };
185
185
  const deleteOldDZComponents = async (uid, entityToUpdate, attributeName, dynamiczoneValues) => {
186
- const previousValue = await strapi.query(uid).load(entityToUpdate, attributeName);
186
+ const previousValue = await strapi.db.query(uid).load(entityToUpdate, attributeName);
187
187
  const idsToKeep = _.castArray(dynamiczoneValues).filter(has("id")).map((v) => ({
188
188
  id: pickStringifiedId(v),
189
189
  __component: v.__component
@@ -222,7 +222,7 @@ const deleteComponents = async (uid, entityToDelete, { loadComponents = true } =
222
222
  if (attribute.type === "component" || attribute.type === "dynamiczone") {
223
223
  let value;
224
224
  if (loadComponents) {
225
- value = await strapi.query(uid).load(entityToDelete, attributeName);
225
+ value = await strapi.db.query(uid).load(entityToDelete, attributeName);
226
226
  } else {
227
227
  value = entityToDelete[attributeName];
228
228
  }
@@ -231,7 +231,7 @@ const deleteComponents = async (uid, entityToDelete, { loadComponents = true } =
231
231
  }
232
232
  if (attribute.type === "component") {
233
233
  const { component: componentUID } = attribute;
234
- await mapAsync(
234
+ await async.map(
235
235
  _.castArray(value),
236
236
  (subValue) => deleteComponent(componentUID, subValue),
237
237
  {
@@ -239,7 +239,7 @@ const deleteComponents = async (uid, entityToDelete, { loadComponents = true } =
239
239
  }
240
240
  );
241
241
  } else {
242
- await mapAsync(
242
+ await async.map(
243
243
  _.castArray(value),
244
244
  (subValue) => deleteComponent(subValue.__component, subValue),
245
245
  { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
@@ -249,75 +249,6 @@ const deleteComponents = async (uid, entityToDelete, { loadComponents = true } =
249
249
  }
250
250
  }
251
251
  };
252
- const cloneComponents = async (uid, entityToClone, data) => {
253
- const { attributes = {} } = strapi.getModel(uid);
254
- const componentBody = {};
255
- const componentData = await getComponents(uid, entityToClone);
256
- for (const attributeName of Object.keys(attributes)) {
257
- const attribute = attributes[attributeName];
258
- if (!has(attributeName, data) && !has(attributeName, componentData)) {
259
- continue;
260
- }
261
- if (attribute.type === "component") {
262
- const { component: componentUID, repeatable = false } = attribute;
263
- const componentValue = attributeName in data ? data[attributeName] : componentData[attributeName];
264
- if (componentValue === null) {
265
- continue;
266
- }
267
- if (repeatable === true) {
268
- if (!Array.isArray(componentValue)) {
269
- throw new Error("Expected an array to create repeatable component");
270
- }
271
- const components = await mapAsync(
272
- componentValue,
273
- (value) => cloneComponent(componentUID, value),
274
- { concurrency: isDialectMySQL() ? 1 : Infinity }
275
- );
276
- componentBody[attributeName] = components.filter(_.negate(_.isNil)).map(({ id }) => {
277
- return {
278
- id,
279
- __pivot: {
280
- field: attributeName,
281
- component_type: componentUID
282
- }
283
- };
284
- });
285
- } else {
286
- const component = await cloneComponent(componentUID, componentValue);
287
- componentBody[attributeName] = component && {
288
- id: component.id,
289
- __pivot: {
290
- field: attributeName,
291
- component_type: componentUID
292
- }
293
- };
294
- }
295
- continue;
296
- }
297
- if (attribute.type === "dynamiczone") {
298
- const dynamiczoneValues = has(attributeName, data) ? data[attributeName] : componentData[attributeName];
299
- if (!Array.isArray(dynamiczoneValues)) {
300
- throw new Error("Expected an array to create repeatable component");
301
- }
302
- componentBody[attributeName] = await mapAsync(
303
- dynamiczoneValues,
304
- async (value) => {
305
- const { id } = await cloneComponent(value.__component, value);
306
- return {
307
- id,
308
- __component: value.__component,
309
- __pivot: {
310
- field: attributeName
311
- }
312
- };
313
- },
314
- { concurrency: isDialectMySQL() ? 1 : Infinity }
315
- );
316
- continue;
317
- }
318
- }
319
- return componentBody;
320
- };
321
252
  const createComponent = async (uid, data) => {
322
253
  const model = strapi.getModel(uid);
323
254
  const componentData = await createComponents(uid, data);
@@ -329,12 +260,12 @@ const createComponent = async (uid, data) => {
329
260
  // ... and assign the newly created component instead
330
261
  assign(componentData)
331
262
  );
332
- return strapi.query(uid).create({ data: transform(data) });
263
+ return strapi.db.query(uid).create({ data: transform(data) });
333
264
  };
334
265
  const updateComponent = async (uid, componentToUpdate, data) => {
335
266
  const model = strapi.getModel(uid);
336
267
  const componentData = await updateComponents(uid, componentToUpdate, data);
337
- return strapi.query(uid).update({
268
+ return strapi.db.query(uid).update({
338
269
  where: {
339
270
  id: componentToUpdate.id
340
271
  },
@@ -352,26 +283,9 @@ const updateOrCreateComponent = (componentUID, value) => {
352
283
  };
353
284
  const deleteComponent = async (uid, componentToDelete) => {
354
285
  await deleteComponents(uid, componentToDelete);
355
- await strapi.query(uid).delete({ where: { id: componentToDelete.id } });
356
- };
357
- const cloneComponent = async (uid, data) => {
358
- const model = strapi.getModel(uid);
359
- if (!("id" in data) || typeof data.id === "undefined") {
360
- return createComponent(uid, data);
361
- }
362
- const componentData = await cloneComponents(uid, { id: data.id }, data);
363
- const transform = pipe(
364
- // Make sure we don't save the component with a pre-defined ID
365
- omit("id"),
366
- // Remove the component data from the original data object ...
367
- (payload) => omitComponentData(model, payload),
368
- // ... and assign the newly created component instead
369
- assign(componentData)
370
- );
371
- return strapi.query(uid).clone(data.id, { data: transform(data) });
286
+ await strapi.db.query(uid).delete({ where: { id: componentToDelete.id } });
372
287
  };
373
288
  export {
374
- cloneComponents,
375
289
  createComponents,
376
290
  deleteComponent,
377
291
  deleteComponents,