@strapi/core 0.0.0-experimental.2363945b79274c79e6505e5a6c3cdec876ed8cec → 0.0.0-experimental.3f7595ce0400b451ca4947408046e7b9b9cd4885

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


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

Files changed (726) hide show
  1. package/dist/Strapi.d.ts +49 -58
  2. package/dist/Strapi.d.ts.map +1 -1
  3. package/dist/Strapi.js +148 -208
  4. package/dist/Strapi.js.map +1 -1
  5. package/dist/Strapi.mjs +139 -200
  6. package/dist/Strapi.mjs.map +1 -1
  7. package/dist/configuration/config-loader.d.ts.map +1 -1
  8. package/dist/configuration/config-loader.js +9 -5
  9. package/dist/configuration/config-loader.js.map +1 -1
  10. package/dist/configuration/config-loader.mjs +9 -5
  11. package/dist/configuration/config-loader.mjs.map +1 -1
  12. package/dist/configuration/get-dirs.d.ts +10 -0
  13. package/dist/configuration/get-dirs.d.ts.map +1 -0
  14. package/dist/{utils → configuration}/get-dirs.js +3 -2
  15. package/dist/configuration/get-dirs.js.map +1 -0
  16. package/dist/{utils → configuration}/get-dirs.mjs +3 -2
  17. package/dist/configuration/get-dirs.mjs.map +1 -0
  18. package/dist/configuration/index.d.ts +4 -7
  19. package/dist/configuration/index.d.ts.map +1 -1
  20. package/dist/configuration/index.js +10 -8
  21. package/dist/configuration/index.js.map +1 -1
  22. package/dist/configuration/index.mjs +6 -5
  23. package/dist/configuration/index.mjs.map +1 -1
  24. package/dist/configuration/urls.d.ts +8 -0
  25. package/dist/configuration/urls.d.ts.map +1 -0
  26. package/dist/configuration/urls.js +68 -0
  27. package/dist/configuration/urls.js.map +1 -0
  28. package/dist/configuration/urls.mjs +66 -0
  29. package/dist/configuration/urls.mjs.map +1 -0
  30. package/dist/container.d.ts +2 -2
  31. package/dist/container.d.ts.map +1 -1
  32. package/dist/container.js.map +1 -1
  33. package/dist/container.mjs.map +1 -1
  34. package/dist/core-api/controller/collection-type.d.ts +3 -3
  35. package/dist/core-api/controller/collection-type.d.ts.map +1 -1
  36. package/dist/core-api/controller/collection-type.js.map +1 -1
  37. package/dist/core-api/controller/collection-type.mjs.map +1 -1
  38. package/dist/core-api/controller/index.d.ts +3 -3
  39. package/dist/core-api/controller/index.d.ts.map +1 -1
  40. package/dist/core-api/controller/index.js +5 -5
  41. package/dist/core-api/controller/index.js.map +1 -1
  42. package/dist/core-api/controller/index.mjs +6 -6
  43. package/dist/core-api/controller/index.mjs.map +1 -1
  44. package/dist/core-api/controller/single-type.d.ts +3 -3
  45. package/dist/core-api/controller/single-type.d.ts.map +1 -1
  46. package/dist/core-api/controller/single-type.js.map +1 -1
  47. package/dist/core-api/controller/single-type.mjs.map +1 -1
  48. package/dist/core-api/controller/transform.d.ts +2 -2
  49. package/dist/core-api/controller/transform.d.ts.map +1 -1
  50. package/dist/core-api/controller/transform.js +2 -5
  51. package/dist/core-api/controller/transform.js.map +1 -1
  52. package/dist/core-api/controller/transform.mjs +2 -5
  53. package/dist/core-api/controller/transform.mjs.map +1 -1
  54. package/dist/core-api/service/collection-type.d.ts +10 -10
  55. package/dist/core-api/service/collection-type.d.ts.map +1 -1
  56. package/dist/core-api/service/collection-type.js +14 -5
  57. package/dist/core-api/service/collection-type.js.map +1 -1
  58. package/dist/core-api/service/collection-type.mjs +14 -5
  59. package/dist/core-api/service/collection-type.mjs.map +1 -1
  60. package/dist/core-api/service/index.d.ts +3 -3
  61. package/dist/core-api/service/index.d.ts.map +1 -1
  62. package/dist/core-api/service/index.js.map +1 -1
  63. package/dist/core-api/service/index.mjs.map +1 -1
  64. package/dist/core-api/service/single-type.d.ts +5 -5
  65. package/dist/core-api/service/single-type.d.ts.map +1 -1
  66. package/dist/core-api/service/single-type.js +11 -6
  67. package/dist/core-api/service/single-type.js.map +1 -1
  68. package/dist/core-api/service/single-type.mjs +11 -6
  69. package/dist/core-api/service/single-type.mjs.map +1 -1
  70. package/dist/domain/content-type/index.d.ts +1 -1
  71. package/dist/domain/content-type/index.d.ts.map +1 -1
  72. package/dist/domain/content-type/index.js +3 -0
  73. package/dist/domain/content-type/index.js.map +1 -1
  74. package/dist/domain/content-type/index.mjs +3 -0
  75. package/dist/domain/content-type/index.mjs.map +1 -1
  76. package/dist/domain/content-type/validator.d.ts.map +1 -1
  77. package/dist/domain/content-type/validator.js +1 -1
  78. package/dist/domain/content-type/validator.js.map +1 -1
  79. package/dist/domain/content-type/validator.mjs +2 -2
  80. package/dist/domain/content-type/validator.mjs.map +1 -1
  81. package/dist/domain/module/index.d.ts +24 -23
  82. package/dist/domain/module/index.d.ts.map +1 -1
  83. package/dist/domain/module/index.js +3 -3
  84. package/dist/domain/module/index.js.map +1 -1
  85. package/dist/domain/module/index.mjs +4 -4
  86. package/dist/domain/module/index.mjs.map +1 -1
  87. package/dist/ee/index.d.ts +4 -2
  88. package/dist/ee/index.d.ts.map +1 -1
  89. package/dist/ee/index.js.map +1 -1
  90. package/dist/ee/index.mjs.map +1 -1
  91. package/dist/ee/license.d.ts +2 -2
  92. package/dist/ee/license.d.ts.map +1 -1
  93. package/dist/ee/license.js.map +1 -1
  94. package/dist/ee/license.mjs.map +1 -1
  95. package/dist/factories.d.ts +10 -10
  96. package/dist/factories.d.ts.map +1 -1
  97. package/dist/factories.js +6 -2
  98. package/dist/factories.js.map +1 -1
  99. package/dist/factories.mjs +6 -2
  100. package/dist/factories.mjs.map +1 -1
  101. package/dist/index.d.ts +4 -2
  102. package/dist/index.d.ts.map +1 -1
  103. package/dist/index.js +25 -1
  104. package/dist/index.js.map +1 -1
  105. package/dist/index.mjs +27 -3
  106. package/dist/index.mjs.map +1 -1
  107. package/dist/loaders/admin.d.ts +2 -2
  108. package/dist/loaders/admin.d.ts.map +1 -1
  109. package/dist/loaders/admin.js +0 -1
  110. package/dist/loaders/admin.js.map +1 -1
  111. package/dist/loaders/admin.mjs +0 -1
  112. package/dist/loaders/admin.mjs.map +1 -1
  113. package/dist/loaders/apis.d.ts +2 -2
  114. package/dist/loaders/apis.d.ts.map +1 -1
  115. package/dist/loaders/apis.js +1 -1
  116. package/dist/loaders/apis.js.map +1 -1
  117. package/dist/loaders/apis.mjs +2 -2
  118. package/dist/loaders/apis.mjs.map +1 -1
  119. package/dist/loaders/components.d.ts +2 -2
  120. package/dist/loaders/components.d.ts.map +1 -1
  121. package/dist/loaders/components.js.map +1 -1
  122. package/dist/loaders/components.mjs.map +1 -1
  123. package/dist/loaders/index.d.ts +2 -2
  124. package/dist/loaders/index.d.ts.map +1 -1
  125. package/dist/loaders/index.js +0 -2
  126. package/dist/loaders/index.js.map +1 -1
  127. package/dist/loaders/index.mjs +0 -2
  128. package/dist/loaders/index.mjs.map +1 -1
  129. package/dist/loaders/middlewares.d.ts +2 -2
  130. package/dist/loaders/middlewares.d.ts.map +1 -1
  131. package/dist/loaders/middlewares.js.map +1 -1
  132. package/dist/loaders/middlewares.mjs.map +1 -1
  133. package/dist/loaders/plugins/get-enabled-plugins.d.ts +2 -2
  134. package/dist/loaders/plugins/get-enabled-plugins.d.ts.map +1 -1
  135. package/dist/loaders/plugins/get-enabled-plugins.js +4 -2
  136. package/dist/loaders/plugins/get-enabled-plugins.js.map +1 -1
  137. package/dist/loaders/plugins/get-enabled-plugins.mjs +5 -3
  138. package/dist/loaders/plugins/get-enabled-plugins.mjs.map +1 -1
  139. package/dist/loaders/plugins/index.d.ts +2 -2
  140. package/dist/loaders/plugins/index.d.ts.map +1 -1
  141. package/dist/loaders/plugins/index.js.map +1 -1
  142. package/dist/loaders/plugins/index.mjs.map +1 -1
  143. package/dist/loaders/policies.d.ts +2 -2
  144. package/dist/loaders/policies.d.ts.map +1 -1
  145. package/dist/loaders/policies.js.map +1 -1
  146. package/dist/loaders/policies.mjs.map +1 -1
  147. package/dist/loaders/sanitizers.d.ts +2 -2
  148. package/dist/loaders/sanitizers.d.ts.map +1 -1
  149. package/dist/loaders/sanitizers.js.map +1 -1
  150. package/dist/loaders/sanitizers.mjs.map +1 -1
  151. package/dist/loaders/src-index.d.ts +2 -2
  152. package/dist/loaders/src-index.d.ts.map +1 -1
  153. package/dist/loaders/src-index.js.map +1 -1
  154. package/dist/loaders/src-index.mjs.map +1 -1
  155. package/dist/loaders/validators.d.ts +2 -2
  156. package/dist/loaders/validators.d.ts.map +1 -1
  157. package/dist/loaders/validators.js.map +1 -1
  158. package/dist/loaders/validators.mjs.map +1 -1
  159. package/dist/middlewares/body.d.ts +4 -4
  160. package/dist/middlewares/body.d.ts.map +1 -1
  161. package/dist/middlewares/body.js +4 -4
  162. package/dist/middlewares/body.js.map +1 -1
  163. package/dist/middlewares/body.mjs +4 -4
  164. package/dist/middlewares/body.mjs.map +1 -1
  165. package/dist/middlewares/compression.d.ts +2 -2
  166. package/dist/middlewares/compression.d.ts.map +1 -1
  167. package/dist/middlewares/compression.js.map +1 -1
  168. package/dist/middlewares/compression.mjs.map +1 -1
  169. package/dist/middlewares/cors.d.ts +2 -2
  170. package/dist/middlewares/cors.d.ts.map +1 -1
  171. package/dist/middlewares/cors.js.map +1 -1
  172. package/dist/middlewares/cors.mjs.map +1 -1
  173. package/dist/middlewares/errors.d.ts +2 -2
  174. package/dist/middlewares/errors.d.ts.map +1 -1
  175. package/dist/middlewares/errors.js.map +1 -1
  176. package/dist/middlewares/errors.mjs.map +1 -1
  177. package/dist/middlewares/favicon.d.ts +2 -2
  178. package/dist/middlewares/favicon.d.ts.map +1 -1
  179. package/dist/middlewares/favicon.js.map +1 -1
  180. package/dist/middlewares/favicon.mjs.map +1 -1
  181. package/dist/middlewares/index.d.ts +2 -2
  182. package/dist/middlewares/index.d.ts.map +1 -1
  183. package/dist/middlewares/index.js.map +1 -1
  184. package/dist/middlewares/index.mjs.map +1 -1
  185. package/dist/middlewares/ip.d.ts +2 -2
  186. package/dist/middlewares/ip.d.ts.map +1 -1
  187. package/dist/middlewares/ip.js.map +1 -1
  188. package/dist/middlewares/ip.mjs.map +1 -1
  189. package/dist/middlewares/logger.d.ts +2 -2
  190. package/dist/middlewares/logger.d.ts.map +1 -1
  191. package/dist/middlewares/logger.js.map +1 -1
  192. package/dist/middlewares/logger.mjs.map +1 -1
  193. package/dist/middlewares/powered-by.d.ts +2 -2
  194. package/dist/middlewares/powered-by.d.ts.map +1 -1
  195. package/dist/middlewares/powered-by.js.map +1 -1
  196. package/dist/middlewares/powered-by.mjs.map +1 -1
  197. package/dist/middlewares/public.d.ts +2 -2
  198. package/dist/middlewares/public.d.ts.map +1 -1
  199. package/dist/middlewares/public.js +1 -1
  200. package/dist/middlewares/public.js.map +1 -1
  201. package/dist/middlewares/public.mjs +1 -1
  202. package/dist/middlewares/public.mjs.map +1 -1
  203. package/dist/middlewares/query.d.ts +2 -2
  204. package/dist/middlewares/query.d.ts.map +1 -1
  205. package/dist/middlewares/query.js.map +1 -1
  206. package/dist/middlewares/query.mjs.map +1 -1
  207. package/dist/middlewares/response-time.d.ts +2 -2
  208. package/dist/middlewares/response-time.d.ts.map +1 -1
  209. package/dist/middlewares/response-time.js.map +1 -1
  210. package/dist/middlewares/response-time.mjs.map +1 -1
  211. package/dist/middlewares/responses.d.ts +3 -3
  212. package/dist/middlewares/responses.d.ts.map +1 -1
  213. package/dist/middlewares/responses.js.map +1 -1
  214. package/dist/middlewares/responses.mjs.map +1 -1
  215. package/dist/middlewares/security.d.ts +2 -2
  216. package/dist/middlewares/security.d.ts.map +1 -1
  217. package/dist/middlewares/security.js +2 -2
  218. package/dist/middlewares/security.js.map +1 -1
  219. package/dist/middlewares/security.mjs +2 -2
  220. package/dist/middlewares/security.mjs.map +1 -1
  221. package/dist/middlewares/session.d.ts +2 -2
  222. package/dist/middlewares/session.d.ts.map +1 -1
  223. package/dist/middlewares/session.js.map +1 -1
  224. package/dist/middlewares/session.mjs.map +1 -1
  225. package/dist/migrations/database/5.0.0-discard-drafts.d.ts +12 -0
  226. package/dist/migrations/database/5.0.0-discard-drafts.d.ts.map +1 -0
  227. package/dist/migrations/database/5.0.0-discard-drafts.js +49 -0
  228. package/dist/migrations/database/5.0.0-discard-drafts.js.map +1 -0
  229. package/dist/migrations/database/5.0.0-discard-drafts.mjs +49 -0
  230. package/dist/migrations/database/5.0.0-discard-drafts.mjs.map +1 -0
  231. package/dist/migrations/draft-publish.d.ts +17 -0
  232. package/dist/migrations/draft-publish.d.ts.map +1 -0
  233. package/dist/migrations/draft-publish.js +59 -0
  234. package/dist/migrations/draft-publish.js.map +1 -0
  235. package/dist/migrations/draft-publish.mjs +59 -0
  236. package/dist/migrations/draft-publish.mjs.map +1 -0
  237. package/dist/providers/admin.d.ts +3 -0
  238. package/dist/providers/admin.d.ts.map +1 -0
  239. package/dist/providers/admin.js +20 -0
  240. package/dist/providers/admin.js.map +1 -0
  241. package/dist/providers/admin.mjs +21 -0
  242. package/dist/providers/admin.mjs.map +1 -0
  243. package/dist/providers/coreStore.d.ts +3 -0
  244. package/dist/providers/coreStore.d.ts.map +1 -0
  245. package/dist/providers/coreStore.js +11 -0
  246. package/dist/providers/coreStore.js.map +1 -0
  247. package/dist/providers/coreStore.mjs +12 -0
  248. package/dist/providers/coreStore.mjs.map +1 -0
  249. package/dist/providers/cron.d.ts +3 -0
  250. package/dist/providers/cron.d.ts.map +1 -0
  251. package/dist/providers/cron.js +20 -0
  252. package/dist/providers/cron.js.map +1 -0
  253. package/dist/providers/cron.mjs +21 -0
  254. package/dist/providers/cron.mjs.map +1 -0
  255. package/dist/providers/index.d.ts +3 -0
  256. package/dist/providers/index.d.ts.map +1 -0
  257. package/dist/providers/index.js +11 -0
  258. package/dist/providers/index.js.map +1 -0
  259. package/dist/providers/index.mjs +11 -0
  260. package/dist/providers/index.mjs.map +1 -0
  261. package/dist/providers/provider.d.ts +9 -0
  262. package/dist/providers/provider.d.ts.map +1 -0
  263. package/dist/providers/provider.js +5 -0
  264. package/dist/providers/provider.js.map +1 -0
  265. package/dist/providers/provider.mjs +5 -0
  266. package/dist/providers/provider.mjs.map +1 -0
  267. package/dist/providers/registries.d.ts +3 -0
  268. package/dist/providers/registries.d.ts.map +1 -0
  269. package/dist/providers/registries.js +35 -0
  270. package/dist/providers/registries.js.map +1 -0
  271. package/dist/providers/registries.mjs +36 -0
  272. package/dist/providers/registries.mjs.map +1 -0
  273. package/dist/providers/telemetry.d.ts +3 -0
  274. package/dist/providers/telemetry.d.ts.map +1 -0
  275. package/dist/providers/telemetry.js +19 -0
  276. package/dist/providers/telemetry.js.map +1 -0
  277. package/dist/providers/telemetry.mjs +20 -0
  278. package/dist/providers/telemetry.mjs.map +1 -0
  279. package/dist/providers/webhooks.d.ts +3 -0
  280. package/dist/providers/webhooks.d.ts.map +1 -0
  281. package/dist/providers/webhooks.js +30 -0
  282. package/dist/providers/webhooks.js.map +1 -0
  283. package/dist/providers/webhooks.mjs +31 -0
  284. package/dist/providers/webhooks.mjs.map +1 -0
  285. package/dist/registries/apis.d.ts +2 -2
  286. package/dist/registries/apis.d.ts.map +1 -1
  287. package/dist/registries/apis.js.map +1 -1
  288. package/dist/registries/apis.mjs.map +1 -1
  289. package/dist/registries/components.d.ts +6 -6
  290. package/dist/registries/components.d.ts.map +1 -1
  291. package/dist/registries/components.js.map +1 -1
  292. package/dist/registries/components.mjs.map +1 -1
  293. package/dist/registries/content-types.d.ts +5 -5
  294. package/dist/registries/content-types.d.ts.map +1 -1
  295. package/dist/registries/content-types.js.map +1 -1
  296. package/dist/registries/content-types.mjs.map +1 -1
  297. package/dist/registries/controllers.d.ts +10 -10
  298. package/dist/registries/controllers.d.ts.map +1 -1
  299. package/dist/registries/controllers.js.map +1 -1
  300. package/dist/registries/controllers.mjs.map +1 -1
  301. package/dist/registries/custom-fields.d.ts +3 -3
  302. package/dist/registries/custom-fields.d.ts.map +1 -1
  303. package/dist/registries/custom-fields.js.map +1 -1
  304. package/dist/registries/custom-fields.mjs.map +1 -1
  305. package/dist/registries/index.d.ts +0 -1
  306. package/dist/registries/index.d.ts.map +1 -1
  307. package/dist/registries/middlewares.d.ts +6 -6
  308. package/dist/registries/middlewares.d.ts.map +1 -1
  309. package/dist/registries/middlewares.js.map +1 -1
  310. package/dist/registries/middlewares.mjs.map +1 -1
  311. package/dist/registries/modules.d.ts +2 -2
  312. package/dist/registries/modules.d.ts.map +1 -1
  313. package/dist/registries/modules.js.map +1 -1
  314. package/dist/registries/modules.mjs.map +1 -1
  315. package/dist/registries/plugins.d.ts +5 -5
  316. package/dist/registries/plugins.d.ts.map +1 -1
  317. package/dist/registries/plugins.js.map +1 -1
  318. package/dist/registries/plugins.mjs.map +1 -1
  319. package/dist/registries/policies.d.ts +23 -11
  320. package/dist/registries/policies.d.ts.map +1 -1
  321. package/dist/registries/policies.js +64 -18
  322. package/dist/registries/policies.js.map +1 -1
  323. package/dist/registries/policies.mjs +65 -19
  324. package/dist/registries/policies.mjs.map +1 -1
  325. package/dist/registries/services.d.ts +8 -8
  326. package/dist/registries/services.d.ts.map +1 -1
  327. package/dist/registries/services.js.map +1 -1
  328. package/dist/registries/services.mjs.map +1 -1
  329. package/dist/services/auth/index.d.ts +4 -4
  330. package/dist/services/auth/index.d.ts.map +1 -1
  331. package/dist/services/auth/index.js.map +1 -1
  332. package/dist/services/auth/index.mjs.map +1 -1
  333. package/dist/services/config.d.ts +3 -0
  334. package/dist/services/config.d.ts.map +1 -0
  335. package/dist/services/config.js +47 -0
  336. package/dist/services/config.js.map +1 -0
  337. package/dist/services/config.mjs +47 -0
  338. package/dist/services/config.mjs.map +1 -0
  339. package/dist/services/content-api/index.d.ts +21 -3
  340. package/dist/services/content-api/index.d.ts.map +1 -1
  341. package/dist/services/content-api/index.js +28 -2
  342. package/dist/services/content-api/index.js.map +1 -1
  343. package/dist/services/content-api/index.mjs +28 -2
  344. package/dist/services/content-api/index.mjs.map +1 -1
  345. package/dist/services/content-api/permissions/index.d.ts +3 -3
  346. package/dist/services/content-api/permissions/index.d.ts.map +1 -1
  347. package/dist/services/content-api/permissions/index.js +1 -1
  348. package/dist/services/content-api/permissions/index.js.map +1 -1
  349. package/dist/services/content-api/permissions/index.mjs +1 -1
  350. package/dist/services/content-api/permissions/index.mjs.map +1 -1
  351. package/dist/services/cron.d.ts +2 -2
  352. package/dist/services/cron.d.ts.map +1 -1
  353. package/dist/services/cron.js.map +1 -1
  354. package/dist/services/cron.mjs.map +1 -1
  355. package/dist/services/custom-fields.d.ts +2 -2
  356. package/dist/services/custom-fields.d.ts.map +1 -1
  357. package/dist/services/custom-fields.js.map +1 -1
  358. package/dist/services/custom-fields.mjs.map +1 -1
  359. package/dist/services/document-service/attributes/index.d.ts +6 -0
  360. package/dist/services/document-service/attributes/index.d.ts.map +1 -0
  361. package/dist/services/document-service/attributes/index.js.map +1 -0
  362. package/dist/services/document-service/attributes/index.mjs.map +1 -0
  363. package/dist/services/document-service/attributes/transforms.d.ts +10 -0
  364. package/dist/services/document-service/attributes/transforms.d.ts.map +1 -0
  365. package/dist/services/document-service/attributes/transforms.js.map +1 -0
  366. package/dist/services/document-service/attributes/transforms.mjs.map +1 -0
  367. package/dist/services/document-service/common.d.ts +2 -2
  368. package/dist/services/document-service/common.d.ts.map +1 -1
  369. package/dist/services/document-service/common.js.map +1 -1
  370. package/dist/services/document-service/common.mjs.map +1 -1
  371. package/dist/services/document-service/components.d.ts +97 -1
  372. package/dist/services/document-service/components.d.ts.map +1 -1
  373. package/dist/services/{entity-service → document-service}/components.js +33 -128
  374. package/dist/services/document-service/components.js.map +1 -0
  375. package/dist/services/{entity-service → document-service}/components.mjs +34 -129
  376. package/dist/services/document-service/components.mjs.map +1 -0
  377. package/dist/services/document-service/draft-and-publish.d.ts +9 -23
  378. package/dist/services/document-service/draft-and-publish.d.ts.map +1 -1
  379. package/dist/services/document-service/draft-and-publish.js +37 -9
  380. package/dist/services/document-service/draft-and-publish.js.map +1 -1
  381. package/dist/services/document-service/draft-and-publish.mjs +38 -10
  382. package/dist/services/document-service/draft-and-publish.mjs.map +1 -1
  383. package/dist/services/document-service/entries.d.ts +8 -0
  384. package/dist/services/document-service/entries.d.ts.map +1 -0
  385. package/dist/services/document-service/entries.js +62 -0
  386. package/dist/services/document-service/entries.js.map +1 -0
  387. package/dist/services/document-service/entries.mjs +62 -0
  388. package/dist/services/document-service/entries.mjs.map +1 -0
  389. package/dist/services/document-service/index.d.ts +2 -4
  390. package/dist/services/document-service/index.d.ts.map +1 -1
  391. package/dist/services/document-service/index.js +19 -4
  392. package/dist/services/document-service/index.js.map +1 -1
  393. package/dist/services/document-service/index.mjs +17 -2
  394. package/dist/services/document-service/index.mjs.map +1 -1
  395. package/dist/services/document-service/internationalization.d.ts +5 -5
  396. package/dist/services/document-service/internationalization.d.ts.map +1 -1
  397. package/dist/services/document-service/internationalization.js.map +1 -1
  398. package/dist/services/document-service/internationalization.mjs.map +1 -1
  399. package/dist/services/document-service/middlewares/errors.d.ts +6 -0
  400. package/dist/services/document-service/middlewares/errors.d.ts.map +1 -0
  401. package/dist/services/document-service/middlewares/errors.js +25 -0
  402. package/dist/services/document-service/middlewares/errors.js.map +1 -0
  403. package/dist/services/document-service/middlewares/errors.mjs +25 -0
  404. package/dist/services/document-service/middlewares/errors.mjs.map +1 -0
  405. package/dist/services/document-service/middlewares/index.d.ts +3 -0
  406. package/dist/services/document-service/middlewares/index.d.ts.map +1 -0
  407. package/dist/services/document-service/middlewares/middleware-manager.d.ts +10 -0
  408. package/dist/services/document-service/middlewares/middleware-manager.d.ts.map +1 -0
  409. package/dist/services/document-service/{middlewares.js → middlewares/middleware-manager.js} +9 -6
  410. package/dist/services/document-service/middlewares/middleware-manager.js.map +1 -0
  411. package/dist/services/document-service/{middlewares.mjs → middlewares/middleware-manager.mjs} +9 -6
  412. package/dist/services/document-service/middlewares/middleware-manager.mjs.map +1 -0
  413. package/dist/services/document-service/params.d.ts +7 -1
  414. package/dist/services/document-service/params.d.ts.map +1 -1
  415. package/dist/services/{entity-service → document-service}/params.js +1 -1
  416. package/dist/services/document-service/params.js.map +1 -0
  417. package/dist/services/{entity-service → document-service}/params.mjs +1 -1
  418. package/dist/services/document-service/params.mjs.map +1 -0
  419. package/dist/services/document-service/repository.d.ts.map +1 -1
  420. package/dist/services/document-service/repository.js +132 -165
  421. package/dist/services/document-service/repository.js.map +1 -1
  422. package/dist/services/document-service/repository.mjs +128 -161
  423. package/dist/services/document-service/repository.mjs.map +1 -1
  424. package/dist/services/document-service/transform/data.d.ts.map +1 -1
  425. package/dist/services/document-service/transform/data.js +4 -2
  426. package/dist/services/document-service/transform/data.js.map +1 -1
  427. package/dist/services/document-service/transform/data.mjs +4 -2
  428. package/dist/services/document-service/transform/data.mjs.map +1 -1
  429. package/dist/services/document-service/transform/fields.d.ts +2 -2
  430. package/dist/services/document-service/transform/fields.d.ts.map +1 -1
  431. package/dist/services/document-service/transform/fields.js.map +1 -1
  432. package/dist/services/document-service/transform/fields.mjs.map +1 -1
  433. package/dist/services/document-service/transform/id-map.d.ts +4 -4
  434. package/dist/services/document-service/transform/id-map.d.ts.map +1 -1
  435. package/dist/services/document-service/transform/id-map.js +15 -9
  436. package/dist/services/document-service/transform/id-map.js.map +1 -1
  437. package/dist/services/document-service/transform/id-map.mjs +16 -10
  438. package/dist/services/document-service/transform/id-map.mjs.map +1 -1
  439. package/dist/services/document-service/transform/id-transform.d.ts +4 -18
  440. package/dist/services/document-service/transform/id-transform.d.ts.map +1 -1
  441. package/dist/services/document-service/transform/id-transform.js +18 -12
  442. package/dist/services/document-service/transform/id-transform.js.map +1 -1
  443. package/dist/services/document-service/transform/id-transform.mjs +18 -12
  444. package/dist/services/document-service/transform/id-transform.mjs.map +1 -1
  445. package/dist/services/document-service/transform/populate.d.ts +5 -2
  446. package/dist/services/document-service/transform/populate.d.ts.map +1 -1
  447. package/dist/services/document-service/transform/populate.js +1 -1
  448. package/dist/services/document-service/transform/populate.js.map +1 -1
  449. package/dist/services/document-service/transform/populate.mjs +1 -1
  450. package/dist/services/document-service/transform/populate.mjs.map +1 -1
  451. package/dist/services/document-service/transform/query.d.ts +5 -0
  452. package/dist/services/document-service/transform/query.d.ts.map +1 -0
  453. package/dist/services/document-service/transform/query.js +9 -0
  454. package/dist/services/document-service/transform/query.js.map +1 -0
  455. package/dist/services/document-service/transform/query.mjs +9 -0
  456. package/dist/services/document-service/transform/query.mjs.map +1 -0
  457. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +8 -7
  458. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -1
  459. package/dist/services/document-service/transform/relations/extract/data-ids.js +43 -68
  460. package/dist/services/document-service/transform/relations/extract/data-ids.js.map +1 -1
  461. package/dist/services/document-service/transform/relations/extract/data-ids.mjs +43 -68
  462. package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +1 -1
  463. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts +9 -5
  464. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts.map +1 -1
  465. package/dist/services/document-service/transform/relations/transform/data-ids.js +61 -105
  466. package/dist/services/document-service/transform/relations/transform/data-ids.js.map +1 -1
  467. package/dist/services/document-service/transform/relations/transform/data-ids.mjs +62 -106
  468. package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +1 -1
  469. package/dist/services/document-service/transform/relations/transform/default-locale.d.ts +9 -0
  470. package/dist/services/document-service/transform/relations/transform/default-locale.d.ts.map +1 -0
  471. package/dist/services/document-service/transform/relations/transform/default-locale.js +32 -0
  472. package/dist/services/document-service/transform/relations/transform/default-locale.js.map +1 -0
  473. package/dist/services/document-service/transform/relations/transform/default-locale.mjs +32 -0
  474. package/dist/services/document-service/transform/relations/transform/default-locale.mjs.map +1 -0
  475. package/dist/services/document-service/transform/relations/utils/dp.d.ts +10 -0
  476. package/dist/services/document-service/transform/relations/utils/dp.d.ts.map +1 -0
  477. package/dist/services/document-service/transform/relations/utils/dp.js +30 -0
  478. package/dist/services/document-service/transform/relations/utils/dp.js.map +1 -0
  479. package/dist/services/document-service/transform/relations/utils/dp.mjs +30 -0
  480. package/dist/services/document-service/transform/relations/utils/dp.mjs.map +1 -0
  481. package/dist/services/document-service/transform/relations/utils/i18n.d.ts +6 -6
  482. package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -1
  483. package/dist/services/document-service/transform/relations/utils/i18n.js +3 -9
  484. package/dist/services/document-service/transform/relations/utils/i18n.js.map +1 -1
  485. package/dist/services/document-service/transform/relations/utils/i18n.mjs +3 -9
  486. package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +1 -1
  487. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts +6 -0
  488. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts.map +1 -0
  489. package/dist/services/document-service/transform/relations/utils/map-relation.js +87 -0
  490. package/dist/services/document-service/transform/relations/utils/map-relation.js.map +1 -0
  491. package/dist/services/document-service/transform/relations/utils/map-relation.mjs +87 -0
  492. package/dist/services/document-service/transform/relations/utils/map-relation.mjs.map +1 -0
  493. package/dist/services/document-service/transform/relations/utils/types.d.ts +10 -1
  494. package/dist/services/document-service/transform/relations/utils/types.d.ts.map +1 -1
  495. package/dist/services/document-service/transform/types.d.ts +4 -4
  496. package/dist/services/document-service/transform/types.d.ts.map +1 -1
  497. package/dist/services/document-service/utils/populate.d.ts +9 -2
  498. package/dist/services/document-service/utils/populate.d.ts.map +1 -1
  499. package/dist/services/document-service/utils/populate.js +5 -5
  500. package/dist/services/document-service/utils/populate.js.map +1 -1
  501. package/dist/services/document-service/utils/populate.mjs +5 -5
  502. package/dist/services/document-service/utils/populate.mjs.map +1 -1
  503. package/dist/services/entity-service/index.d.ts +4 -6
  504. package/dist/services/entity-service/index.d.ts.map +1 -1
  505. package/dist/services/entity-service/index.js +44 -203
  506. package/dist/services/entity-service/index.js.map +1 -1
  507. package/dist/services/entity-service/index.mjs +38 -197
  508. package/dist/services/entity-service/index.mjs.map +1 -1
  509. package/dist/services/entity-validator/index.d.ts +2 -2
  510. package/dist/services/entity-validator/index.d.ts.map +1 -1
  511. package/dist/services/entity-validator/index.js +101 -90
  512. package/dist/services/entity-validator/index.js.map +1 -1
  513. package/dist/services/entity-validator/index.mjs +101 -90
  514. package/dist/services/entity-validator/index.mjs.map +1 -1
  515. package/dist/services/entity-validator/validators.d.ts +18 -18
  516. package/dist/services/entity-validator/validators.d.ts.map +1 -1
  517. package/dist/services/entity-validator/validators.js +6 -1
  518. package/dist/services/entity-validator/validators.js.map +1 -1
  519. package/dist/services/entity-validator/validators.mjs +6 -1
  520. package/dist/services/entity-validator/validators.mjs.map +1 -1
  521. package/dist/services/features.d.ts +3 -3
  522. package/dist/services/features.d.ts.map +1 -1
  523. package/dist/services/features.js.map +1 -1
  524. package/dist/services/features.mjs.map +1 -1
  525. package/dist/services/fs.d.ts +2 -2
  526. package/dist/services/fs.d.ts.map +1 -1
  527. package/dist/services/fs.js.map +1 -1
  528. package/dist/services/fs.mjs.map +1 -1
  529. package/dist/services/metrics/admin-user-hash.d.ts +2 -2
  530. package/dist/services/metrics/admin-user-hash.d.ts.map +1 -1
  531. package/dist/services/metrics/admin-user-hash.js.map +1 -1
  532. package/dist/services/metrics/admin-user-hash.mjs.map +1 -1
  533. package/dist/services/metrics/index.d.ts +2 -2
  534. package/dist/services/metrics/index.d.ts.map +1 -1
  535. package/dist/services/metrics/index.js.map +1 -1
  536. package/dist/services/metrics/index.mjs.map +1 -1
  537. package/dist/services/metrics/middleware.d.ts +2 -2
  538. package/dist/services/metrics/middleware.d.ts.map +1 -1
  539. package/dist/services/metrics/middleware.js.map +1 -1
  540. package/dist/services/metrics/middleware.mjs.map +1 -1
  541. package/dist/services/metrics/rate-limiter.d.ts.map +1 -1
  542. package/dist/services/metrics/rate-limiter.js.map +1 -1
  543. package/dist/services/metrics/rate-limiter.mjs.map +1 -1
  544. package/dist/services/metrics/sender.d.ts +3 -3
  545. package/dist/services/metrics/sender.d.ts.map +1 -1
  546. package/dist/services/metrics/sender.js.map +1 -1
  547. package/dist/services/metrics/sender.mjs.map +1 -1
  548. package/dist/services/query-params.d.ts +7 -0
  549. package/dist/services/query-params.d.ts.map +1 -0
  550. package/dist/services/query-params.js +12 -0
  551. package/dist/services/query-params.js.map +1 -0
  552. package/dist/services/query-params.mjs +13 -0
  553. package/dist/services/query-params.mjs.map +1 -0
  554. package/dist/services/reloader.d.ts +7 -0
  555. package/dist/services/reloader.d.ts.map +1 -0
  556. package/dist/services/reloader.js +36 -0
  557. package/dist/services/reloader.js.map +1 -0
  558. package/dist/services/reloader.mjs +36 -0
  559. package/dist/services/reloader.mjs.map +1 -0
  560. package/dist/services/server/admin-api.d.ts +3 -3
  561. package/dist/services/server/admin-api.d.ts.map +1 -1
  562. package/dist/services/server/admin-api.js.map +1 -1
  563. package/dist/services/server/admin-api.mjs.map +1 -1
  564. package/dist/services/server/api.d.ts +3 -3
  565. package/dist/services/server/api.d.ts.map +1 -1
  566. package/dist/services/server/api.js.map +1 -1
  567. package/dist/services/server/api.mjs.map +1 -1
  568. package/dist/services/server/compose-endpoint.d.ts +2 -2
  569. package/dist/services/server/compose-endpoint.d.ts.map +1 -1
  570. package/dist/services/server/compose-endpoint.js +1 -2
  571. package/dist/services/server/compose-endpoint.js.map +1 -1
  572. package/dist/services/server/compose-endpoint.mjs +2 -3
  573. package/dist/services/server/compose-endpoint.mjs.map +1 -1
  574. package/dist/services/server/content-api.d.ts +3 -3
  575. package/dist/services/server/content-api.d.ts.map +1 -1
  576. package/dist/services/server/content-api.js.map +1 -1
  577. package/dist/services/server/content-api.mjs.map +1 -1
  578. package/dist/services/server/http-server.d.ts +2 -2
  579. package/dist/services/server/http-server.d.ts.map +1 -1
  580. package/dist/services/server/http-server.js.map +1 -1
  581. package/dist/services/server/http-server.mjs.map +1 -1
  582. package/dist/services/server/index.d.ts +2 -2
  583. package/dist/services/server/index.d.ts.map +1 -1
  584. package/dist/services/server/index.js +1 -2
  585. package/dist/services/server/index.js.map +1 -1
  586. package/dist/services/server/index.mjs +1 -2
  587. package/dist/services/server/index.mjs.map +1 -1
  588. package/dist/services/server/middleware.d.ts +4 -4
  589. package/dist/services/server/middleware.d.ts.map +1 -1
  590. package/dist/services/server/middleware.js.map +1 -1
  591. package/dist/services/server/middleware.mjs.map +1 -1
  592. package/dist/services/server/policy.d.ts +3 -3
  593. package/dist/services/server/policy.d.ts.map +1 -1
  594. package/dist/services/server/policy.js +4 -4
  595. package/dist/services/server/policy.js.map +1 -1
  596. package/dist/services/server/policy.mjs +4 -4
  597. package/dist/services/server/policy.mjs.map +1 -1
  598. package/dist/services/server/register-middlewares.d.ts +2 -2
  599. package/dist/services/server/register-middlewares.d.ts.map +1 -1
  600. package/dist/services/server/register-middlewares.js.map +1 -1
  601. package/dist/services/server/register-middlewares.mjs.map +1 -1
  602. package/dist/services/server/register-routes.d.ts +2 -2
  603. package/dist/services/server/register-routes.d.ts.map +1 -1
  604. package/dist/services/server/register-routes.js +3 -3
  605. package/dist/services/server/register-routes.js.map +1 -1
  606. package/dist/services/server/register-routes.mjs +3 -3
  607. package/dist/services/server/register-routes.mjs.map +1 -1
  608. package/dist/services/server/routing.d.ts +5 -5
  609. package/dist/services/server/routing.d.ts.map +1 -1
  610. package/dist/services/server/routing.js.map +1 -1
  611. package/dist/services/server/routing.mjs.map +1 -1
  612. package/dist/services/utils/dynamic-zones.d.ts.map +1 -1
  613. package/dist/services/utils/dynamic-zones.js +2 -1
  614. package/dist/services/utils/dynamic-zones.js.map +1 -1
  615. package/dist/services/utils/dynamic-zones.mjs +2 -1
  616. package/dist/services/utils/dynamic-zones.mjs.map +1 -1
  617. package/dist/services/webhook-runner.js.map +1 -1
  618. package/dist/services/webhook-runner.mjs.map +1 -1
  619. package/dist/services/webhook-store.d.ts.map +1 -1
  620. package/dist/services/webhook-store.js +5 -6
  621. package/dist/services/webhook-store.js.map +1 -1
  622. package/dist/services/webhook-store.mjs +5 -6
  623. package/dist/services/webhook-store.mjs.map +1 -1
  624. package/dist/utils/convert-custom-field-type.d.ts +2 -2
  625. package/dist/utils/convert-custom-field-type.d.ts.map +1 -1
  626. package/dist/utils/convert-custom-field-type.js.map +1 -1
  627. package/dist/utils/convert-custom-field-type.mjs.map +1 -1
  628. package/dist/utils/fetch.d.ts +3 -3
  629. package/dist/utils/fetch.d.ts.map +1 -1
  630. package/dist/utils/fetch.js.map +1 -1
  631. package/dist/utils/fetch.mjs.map +1 -1
  632. package/dist/utils/index.d.ts +2 -1
  633. package/dist/utils/index.d.ts.map +1 -1
  634. package/dist/utils/is-initialized.d.ts +2 -2
  635. package/dist/utils/is-initialized.d.ts.map +1 -1
  636. package/dist/utils/is-initialized.js +1 -1
  637. package/dist/utils/is-initialized.js.map +1 -1
  638. package/dist/utils/is-initialized.mjs +1 -1
  639. package/dist/utils/is-initialized.mjs.map +1 -1
  640. package/dist/utils/load-config-file.js +1 -1
  641. package/dist/utils/load-config-file.js.map +1 -1
  642. package/dist/utils/load-config-file.mjs +2 -2
  643. package/dist/utils/load-config-file.mjs.map +1 -1
  644. package/dist/utils/open-browser.d.ts +2 -2
  645. package/dist/utils/open-browser.d.ts.map +1 -1
  646. package/dist/utils/open-browser.js.map +1 -1
  647. package/dist/utils/open-browser.mjs.map +1 -1
  648. package/dist/utils/resolve-working-dirs.d.ts +19 -0
  649. package/dist/utils/resolve-working-dirs.d.ts.map +1 -0
  650. package/dist/utils/resolve-working-dirs.js +13 -0
  651. package/dist/utils/resolve-working-dirs.js.map +1 -0
  652. package/dist/utils/resolve-working-dirs.mjs +11 -0
  653. package/dist/utils/resolve-working-dirs.mjs.map +1 -0
  654. package/dist/utils/signals.d.ts +2 -2
  655. package/dist/utils/signals.d.ts.map +1 -1
  656. package/dist/utils/signals.js.map +1 -1
  657. package/dist/utils/signals.mjs.map +1 -1
  658. package/dist/utils/startup-logger.d.ts +2 -2
  659. package/dist/utils/startup-logger.d.ts.map +1 -1
  660. package/dist/utils/startup-logger.js.map +1 -1
  661. package/dist/utils/startup-logger.mjs.map +1 -1
  662. package/dist/utils/transform-content-types-to-models.d.ts +54 -99
  663. package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
  664. package/dist/utils/transform-content-types-to-models.js +95 -57
  665. package/dist/utils/transform-content-types-to-models.js.map +1 -1
  666. package/dist/utils/transform-content-types-to-models.mjs +95 -57
  667. package/dist/utils/transform-content-types-to-models.mjs.map +1 -1
  668. package/dist/utils/update-notifier/index.d.ts +2 -7
  669. package/dist/utils/update-notifier/index.d.ts.map +1 -1
  670. package/dist/utils/update-notifier/index.js +11 -14
  671. package/dist/utils/update-notifier/index.js.map +1 -1
  672. package/dist/utils/update-notifier/index.mjs +11 -14
  673. package/dist/utils/update-notifier/index.mjs.map +1 -1
  674. package/package.json +22 -22
  675. package/dist/registries/config.d.ts +0 -4
  676. package/dist/registries/config.d.ts.map +0 -1
  677. package/dist/registries/config.js +0 -23
  678. package/dist/registries/config.js.map +0 -1
  679. package/dist/registries/config.mjs +0 -22
  680. package/dist/registries/config.mjs.map +0 -1
  681. package/dist/services/document-service/middlewares.d.ts +0 -8
  682. package/dist/services/document-service/middlewares.d.ts.map +0 -1
  683. package/dist/services/document-service/middlewares.js.map +0 -1
  684. package/dist/services/document-service/middlewares.mjs.map +0 -1
  685. package/dist/services/document-service/transform/filters.d.ts +0 -3
  686. package/dist/services/document-service/transform/filters.d.ts.map +0 -1
  687. package/dist/services/document-service/transform/relations/transform/output-ids.d.ts +0 -4
  688. package/dist/services/document-service/transform/relations/transform/output-ids.d.ts.map +0 -1
  689. package/dist/services/document-service/transform/relations/utils/data.js +0 -12
  690. package/dist/services/document-service/transform/relations/utils/data.js.map +0 -1
  691. package/dist/services/document-service/transform/relations/utils/data.mjs +0 -12
  692. package/dist/services/document-service/transform/relations/utils/data.mjs.map +0 -1
  693. package/dist/services/document-service/transform/sort.d.ts +0 -5
  694. package/dist/services/document-service/transform/sort.d.ts.map +0 -1
  695. package/dist/services/document-service/transform/utils.d.ts +0 -9
  696. package/dist/services/document-service/transform/utils.d.ts.map +0 -1
  697. package/dist/services/entity-service/attributes/index.d.ts +0 -6
  698. package/dist/services/entity-service/attributes/index.d.ts.map +0 -1
  699. package/dist/services/entity-service/attributes/index.js.map +0 -1
  700. package/dist/services/entity-service/attributes/index.mjs.map +0 -1
  701. package/dist/services/entity-service/attributes/transforms.d.ts +0 -10
  702. package/dist/services/entity-service/attributes/transforms.d.ts.map +0 -1
  703. package/dist/services/entity-service/attributes/transforms.js.map +0 -1
  704. package/dist/services/entity-service/attributes/transforms.mjs.map +0 -1
  705. package/dist/services/entity-service/components.d.ts +0 -23
  706. package/dist/services/entity-service/components.d.ts.map +0 -1
  707. package/dist/services/entity-service/components.js.map +0 -1
  708. package/dist/services/entity-service/components.mjs.map +0 -1
  709. package/dist/services/entity-service/params.d.ts +0 -8
  710. package/dist/services/entity-service/params.d.ts.map +0 -1
  711. package/dist/services/entity-service/params.js.map +0 -1
  712. package/dist/services/entity-service/params.mjs.map +0 -1
  713. package/dist/services/utils/upload-files.d.ts +0 -8
  714. package/dist/services/utils/upload-files.d.ts.map +0 -1
  715. package/dist/services/utils/upload-files.js +0 -64
  716. package/dist/services/utils/upload-files.js.map +0 -1
  717. package/dist/services/utils/upload-files.mjs +0 -63
  718. package/dist/services/utils/upload-files.mjs.map +0 -1
  719. package/dist/utils/get-dirs.d.ts +0 -9
  720. package/dist/utils/get-dirs.d.ts.map +0 -1
  721. package/dist/utils/get-dirs.js.map +0 -1
  722. package/dist/utils/get-dirs.mjs.map +0 -1
  723. /package/dist/services/{entity-service → document-service}/attributes/index.js +0 -0
  724. /package/dist/services/{entity-service → document-service}/attributes/index.mjs +0 -0
  725. /package/dist/services/{entity-service → document-service}/attributes/transforms.js +0 -0
  726. /package/dist/services/{entity-service → document-service}/attributes/transforms.mjs +0 -0
@@ -5,7 +5,6 @@ const _ = require("lodash/fp");
5
5
  const strapiUtils = require("@strapi/utils");
6
6
  const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
7
7
  const ___default = /* @__PURE__ */ _interopDefault(_$1);
8
- const isDialectMySQL = () => strapi.db?.dialect.client === "mysql";
9
8
  function omitComponentData(contentType, data) {
10
9
  const { attributes } = contentType;
11
10
  const componentAttributes = Object.keys(attributes).filter(
@@ -32,10 +31,9 @@ const createComponents = async (uid, data) => {
32
31
  if (!Array.isArray(componentValue)) {
33
32
  throw new Error("Expected an array to create repeatable component");
34
33
  }
35
- const components = await strapiUtils.mapAsync(
34
+ const components = await strapiUtils.async.map(
36
35
  componentValue,
37
- (value) => createComponent(componentUID, value),
38
- { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
36
+ (value) => createComponent(componentUID, value)
39
37
  );
40
38
  componentBody[attributeName] = components.map(({ id }) => {
41
39
  return {
@@ -76,10 +74,9 @@ const createComponents = async (uid, data) => {
76
74
  }
77
75
  };
78
76
  };
79
- componentBody[attributeName] = await strapiUtils.mapAsync(
77
+ componentBody[attributeName] = await strapiUtils.async.map(
80
78
  dynamiczoneValues,
81
- createDynamicZoneComponents,
82
- { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
79
+ createDynamicZoneComponents
83
80
  );
84
81
  continue;
85
82
  }
@@ -91,7 +88,7 @@ const getComponents = async (uid, entity) => {
91
88
  if (___default.default.isEmpty(componentAttributes)) {
92
89
  return {};
93
90
  }
94
- return strapi.query(uid).load(entity, componentAttributes);
91
+ return strapi.db.query(uid).load(entity, componentAttributes);
95
92
  };
96
93
  const updateComponents = async (uid, entityToUpdate, data) => {
97
94
  const { attributes = {} } = strapi.getModel(uid);
@@ -109,10 +106,9 @@ const updateComponents = async (uid, entityToUpdate, data) => {
109
106
  if (!Array.isArray(componentValue)) {
110
107
  throw new Error("Expected an array to create repeatable component");
111
108
  }
112
- const components = await strapiUtils.mapAsync(
109
+ const components = await strapiUtils.async.map(
113
110
  componentValue,
114
- (value) => updateOrCreateComponent(componentUID, value),
115
- { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
111
+ (value) => updateOrCreateComponent(componentUID, value)
116
112
  );
117
113
  componentBody[attributeName] = components.filter(___default.default.negate(___default.default.isNil)).map(({ id }) => {
118
114
  return {
@@ -133,29 +129,22 @@ const updateComponents = async (uid, entityToUpdate, data) => {
133
129
  }
134
130
  };
135
131
  }
136
- continue;
137
- }
138
- if (attribute.type === "dynamiczone") {
132
+ } else if (attribute.type === "dynamiczone") {
139
133
  const dynamiczoneValues = data[attributeName];
140
134
  await deleteOldDZComponents(uid, entityToUpdate, attributeName, dynamiczoneValues);
141
135
  if (!Array.isArray(dynamiczoneValues)) {
142
136
  throw new Error("Expected an array to create repeatable component");
143
137
  }
144
- componentBody[attributeName] = await strapiUtils.mapAsync(
145
- dynamiczoneValues,
146
- async (value) => {
147
- const { id } = await updateOrCreateComponent(value.__component, value);
148
- return {
149
- id,
150
- __component: value.__component,
151
- __pivot: {
152
- field: attributeName
153
- }
154
- };
155
- },
156
- { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
157
- );
158
- continue;
138
+ componentBody[attributeName] = await strapiUtils.async.map(dynamiczoneValues, async (value) => {
139
+ const { id } = await updateOrCreateComponent(value.__component, value);
140
+ return {
141
+ id,
142
+ __component: value.__component,
143
+ __pivot: {
144
+ field: attributeName
145
+ }
146
+ };
147
+ });
159
148
  }
160
149
  }
161
150
  return componentBody;
@@ -169,7 +158,7 @@ const pickStringifiedId = ({
169
158
  return `${id}`;
170
159
  };
171
160
  const deleteOldComponents = async (uid, componentUID, entityToUpdate, attributeName, componentValue) => {
172
- const previousValue = await strapi.query(uid).load(entityToUpdate, attributeName);
161
+ const previousValue = await strapi.db.query(uid).load(entityToUpdate, attributeName);
173
162
  const idsToKeep = ___default.default.castArray(componentValue).filter(_.has("id")).map(pickStringifiedId);
174
163
  const allIds = ___default.default.castArray(previousValue).filter(_.has("id")).map(pickStringifiedId);
175
164
  idsToKeep.forEach((id) => {
@@ -187,7 +176,7 @@ const deleteOldComponents = async (uid, componentUID, entityToUpdate, attributeN
187
176
  }
188
177
  };
189
178
  const deleteOldDZComponents = async (uid, entityToUpdate, attributeName, dynamiczoneValues) => {
190
- const previousValue = await strapi.query(uid).load(entityToUpdate, attributeName);
179
+ const previousValue = await strapi.db.query(uid).load(entityToUpdate, attributeName);
191
180
  const idsToKeep = ___default.default.castArray(dynamiczoneValues).filter(_.has("id")).map((v) => ({
192
181
  id: pickStringifiedId(v),
193
182
  __component: v.__component
@@ -226,7 +215,7 @@ const deleteComponents = async (uid, entityToDelete, { loadComponents = true } =
226
215
  if (attribute.type === "component" || attribute.type === "dynamiczone") {
227
216
  let value;
228
217
  if (loadComponents) {
229
- value = await strapi.query(uid).load(entityToDelete, attributeName);
218
+ value = await strapi.db.query(uid).load(entityToDelete, attributeName);
230
219
  } else {
231
220
  value = entityToDelete[attributeName];
232
221
  }
@@ -235,93 +224,20 @@ const deleteComponents = async (uid, entityToDelete, { loadComponents = true } =
235
224
  }
236
225
  if (attribute.type === "component") {
237
226
  const { component: componentUID } = attribute;
238
- await strapiUtils.mapAsync(
227
+ await strapiUtils.async.map(
239
228
  ___default.default.castArray(value),
240
- (subValue) => deleteComponent(componentUID, subValue),
241
- {
242
- concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity
243
- }
229
+ (subValue) => deleteComponent(componentUID, subValue)
244
230
  );
245
231
  } else {
246
- await strapiUtils.mapAsync(
232
+ await strapiUtils.async.map(
247
233
  ___default.default.castArray(value),
248
- (subValue) => deleteComponent(subValue.__component, subValue),
249
- { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
234
+ (subValue) => deleteComponent(subValue.__component, subValue)
250
235
  );
251
236
  }
252
237
  continue;
253
238
  }
254
239
  }
255
240
  };
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
241
  const createComponent = async (uid, data) => {
326
242
  const model = strapi.getModel(uid);
327
243
  const componentData = await createComponents(uid, data);
@@ -333,12 +249,12 @@ const createComponent = async (uid, data) => {
333
249
  // ... and assign the newly created component instead
334
250
  _.assign(componentData)
335
251
  );
336
- return strapi.query(uid).create({ data: transform(data) });
252
+ return strapi.db.query(uid).create({ data: transform(data) });
337
253
  };
338
254
  const updateComponent = async (uid, componentToUpdate, data) => {
339
255
  const model = strapi.getModel(uid);
340
256
  const componentData = await updateComponents(uid, componentToUpdate, data);
341
- return strapi.query(uid).update({
257
+ return strapi.db.query(uid).update({
342
258
  where: {
343
259
  id: componentToUpdate.id
344
260
  },
@@ -356,25 +272,14 @@ const updateOrCreateComponent = (componentUID, value) => {
356
272
  };
357
273
  const deleteComponent = async (uid, componentToDelete) => {
358
274
  await deleteComponents(uid, componentToDelete);
359
- await strapi.query(uid).delete({ where: { id: componentToDelete.id } });
275
+ await strapi.db.query(uid).delete({ where: { id: componentToDelete.id } });
360
276
  };
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) });
277
+ const assignComponentData = (data, componentData, {
278
+ contentType
279
+ }) => {
280
+ return Object.assign(omitComponentData(contentType, data), componentData);
376
281
  };
377
- exports.cloneComponents = cloneComponents;
282
+ exports.assignComponentData = assignComponentData;
378
283
  exports.createComponents = createComponents;
379
284
  exports.deleteComponent = deleteComponent;
380
285
  exports.deleteComponents = deleteComponents;
@@ -0,0 +1 @@
1
+ {"version":3,"file":"components.js","sources":["../../../src/services/document-service/components.ts"],"sourcesContent":["import _ from 'lodash';\nimport { has, omit, pipe, assign } from 'lodash/fp';\nimport type { Struct, Utils, UID, Schema, Data, Modules } from '@strapi/types';\nimport { contentTypes as contentTypesUtils, async, errors } from '@strapi/utils';\n\ntype LoadedComponents<TUID extends UID.Schema> = Data.Entity<\n TUID,\n Schema.AttributeNamesByType<TUID, 'component' | 'dynamiczone'>\n>;\n\ntype SingleComponentValue = Schema.Attribute.ComponentValue<UID.Component, false>;\ntype RepeatableComponentValue = Schema.Attribute.ComponentValue<UID.Component, true>;\n\ntype ComponentValue = SingleComponentValue | RepeatableComponentValue;\n\ntype DynamicZoneValue = Schema.Attribute.DynamicZoneValue<UID.Component[]>;\n\ntype ComponentBody = {\n [key: string]: ComponentValue | DynamicZoneValue;\n};\n\nfunction omitComponentData(\n contentType: Struct.ContentTypeSchema,\n data: Modules.EntityService.Params.Data.Input<Struct.ContentTypeSchema['uid']>\n): Partial<Modules.EntityService.Params.Data.Input<Struct.ContentTypeSchema['uid']>>;\nfunction omitComponentData(\n contentType: Struct.ComponentSchema,\n data: Modules.EntityService.Params.Data.Input<Struct.ComponentSchema['uid']>\n): Partial<Modules.EntityService.Params.Data.Input<Struct.ComponentSchema['uid']>>;\nfunction omitComponentData(\n contentType: Struct.Schema,\n data: Modules.EntityService.Params.Data.Input<\n Struct.ContentTypeSchema['uid'] | Struct.ComponentSchema['uid']\n >\n): Partial<\n Modules.EntityService.Params.Data.Input<\n Struct.ContentTypeSchema['uid'] | Struct.ComponentSchema['uid']\n >\n> {\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 UID.Schema,\n TData extends Modules.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: RepeatableComponentValue = await async.map(componentValue, (value: any) =>\n createComponent(componentUID, value)\n );\n\n componentBody[attributeName] = components.map(({ id }) => {\n return {\n id,\n __pivot: {\n field: attributeName,\n component_type: componentUID,\n },\n };\n });\n } else {\n const component = await createComponent(\n componentUID,\n componentValue as Modules.EntityService.Params.Data.Input<UID.Component>\n );\n\n componentBody[attributeName] = {\n id: component.id,\n __pivot: {\n field: attributeName,\n component_type: componentUID,\n },\n };\n }\n\n continue;\n }\n\n if (attribute.type === 'dynamiczone') {\n const dynamiczoneValues = data[\n attributeName as keyof TData\n ] as Modules.EntityService.Params.Attribute.GetValue<Schema.Attribute.DynamicZone>;\n\n if (!Array.isArray(dynamiczoneValues)) {\n throw new Error('Expected an array to create repeatable component');\n }\n\n const createDynamicZoneComponents = async (\n value: Utils.Array.Values<typeof dynamiczoneValues>\n ) => {\n const { id } = await createComponent(value.__component, value);\n return {\n id,\n __component: value.__component,\n __pivot: {\n field: attributeName,\n },\n };\n };\n\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n componentBody[attributeName] = await async.map(\n dynamiczoneValues,\n createDynamicZoneComponents\n );\n\n continue;\n }\n }\n\n return componentBody;\n};\n\nconst getComponents = async <TUID extends UID.Schema>(\n uid: TUID,\n entity: { id: Modules.EntityService.Params.Attribute.ID }\n): Promise<LoadedComponents<TUID>> => {\n const componentAttributes = contentTypesUtils.getComponentAttributes(strapi.getModel(uid));\n\n if (_.isEmpty(componentAttributes)) {\n return {} as LoadedComponents<TUID>;\n }\n\n return strapi.db.query(uid).load(entity, componentAttributes) as Promise<LoadedComponents<TUID>>;\n};\n\n/*\n delete old components\n create or update\n*/\nconst updateComponents = async <\n TUID extends UID.Schema,\n TData extends Partial<Modules.EntityService.Params.Data.Input<TUID>>,\n>(\n uid: TUID,\n entityToUpdate: { id: Modules.EntityService.Params.Attribute.ID },\n data: TData\n) => {\n const { attributes = {} } = strapi.getModel(uid);\n\n const componentBody: ComponentBody = {};\n\n for (const attributeName of Object.keys(attributes)) {\n const attribute = attributes[attributeName];\n\n if (!has(attributeName, data)) {\n continue;\n }\n\n if (attribute.type === 'component') {\n const { component: componentUID, repeatable = false } = attribute;\n\n const componentValue = data[attributeName as keyof TData] as ComponentValue;\n\n await deleteOldComponents(uid, componentUID, entityToUpdate, attributeName, componentValue);\n\n if (repeatable === true) {\n if (!Array.isArray(componentValue)) {\n throw new Error('Expected an array to create repeatable component');\n }\n\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n const components: RepeatableComponentValue = await async.map(componentValue, (value: any) =>\n updateOrCreateComponent(componentUID, value)\n );\n\n componentBody[attributeName] = components.filter(_.negate(_.isNil)).map(({ id }) => {\n return {\n id,\n __pivot: {\n field: attributeName,\n component_type: componentUID,\n },\n };\n });\n } else {\n const component = await updateOrCreateComponent(componentUID, componentValue);\n componentBody[attributeName] = component && {\n id: component.id,\n __pivot: {\n field: attributeName,\n component_type: componentUID,\n },\n };\n }\n } else if (attribute.type === 'dynamiczone') {\n const dynamiczoneValues = data[attributeName as keyof TData] as DynamicZoneValue;\n\n await deleteOldDZComponents(uid, entityToUpdate, attributeName, dynamiczoneValues);\n\n if (!Array.isArray(dynamiczoneValues)) {\n throw new Error('Expected an array to create repeatable component');\n }\n\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n componentBody[attributeName] = await async.map(dynamiczoneValues, async (value: any) => {\n const { id } = await updateOrCreateComponent(value.__component, value);\n\n return {\n id,\n __component: value.__component,\n __pivot: {\n field: attributeName,\n },\n };\n });\n }\n }\n\n return componentBody;\n};\n\nconst pickStringifiedId = ({\n id,\n}: {\n id: Modules.EntityService.Params.Attribute.ID;\n}): Modules.EntityService.Params.Attribute.ID & string => {\n if (typeof id === 'string') {\n return id;\n }\n\n return `${id}`;\n};\n\nconst deleteOldComponents = async <TUID extends UID.Schema>(\n uid: TUID,\n componentUID: UID.Component,\n entityToUpdate: { id: Modules.EntityService.Params.Attribute.ID },\n attributeName: string,\n componentValue: ComponentValue\n) => {\n const previousValue = (await strapi.db\n .query(uid)\n .load(entityToUpdate, attributeName)) as ComponentValue;\n\n const idsToKeep = _.castArray(componentValue).filter(has('id')).map(pickStringifiedId);\n const allIds = _.castArray(previousValue).filter(has('id')).map(pickStringifiedId);\n\n idsToKeep.forEach((id) => {\n if (!allIds.includes(id)) {\n throw new errors.ApplicationError(\n `Some of the provided components in ${attributeName} are not related to the entity`\n );\n }\n });\n\n const idsToDelete = _.difference(allIds, idsToKeep);\n\n if (idsToDelete.length > 0) {\n for (const idToDelete of idsToDelete) {\n await deleteComponent(componentUID, { id: idToDelete });\n }\n }\n};\n\nconst deleteOldDZComponents = async <TUID extends UID.Schema>(\n uid: TUID,\n entityToUpdate: { id: Modules.EntityService.Params.Attribute.ID },\n attributeName: string,\n dynamiczoneValues: DynamicZoneValue\n) => {\n const previousValue = (await strapi.db\n .query(uid)\n .load(entityToUpdate, attributeName)) as DynamicZoneValue;\n\n const idsToKeep = _.castArray(dynamiczoneValues)\n .filter(has('id'))\n .map((v) => ({\n id: pickStringifiedId(v),\n __component: v.__component,\n }));\n\n const allIds = _.castArray(previousValue)\n .filter(has('id'))\n .map((v) => ({\n id: pickStringifiedId(v),\n __component: v.__component,\n }));\n\n idsToKeep.forEach(({ id, __component }) => {\n if (!allIds.find((el) => el.id === id && el.__component === __component)) {\n const err = new Error(\n `Some of the provided components in ${attributeName} are not related to the entity`\n );\n\n Object.assign(err, { status: 400 });\n throw err;\n }\n });\n\n type IdsToDelete = DynamicZoneValue;\n\n const idsToDelete = allIds.reduce((acc, { id, __component }) => {\n if (!idsToKeep.find((el) => el.id === id && el.__component === __component)) {\n acc.push({ id, __component });\n }\n\n return acc;\n }, [] as IdsToDelete);\n\n if (idsToDelete.length > 0) {\n for (const idToDelete of idsToDelete) {\n const { id, __component } = idToDelete;\n await deleteComponent(__component, { id });\n }\n }\n};\n\nconst deleteComponents = async <TUID extends UID.Schema, TEntity extends Data.Entity<TUID>>(\n uid: TUID,\n entityToDelete: TEntity,\n { loadComponents = true } = {}\n) => {\n const { attributes = {} } = strapi.getModel(uid);\n\n const attributeNames = Object.keys(attributes);\n\n for (const attributeName of attributeNames) {\n const attribute = attributes[attributeName];\n\n if (attribute.type === 'component' || attribute.type === 'dynamiczone') {\n let value;\n 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(_.castArray(value), (subValue: any) =>\n deleteComponent(componentUID, subValue)\n );\n } else {\n // delete dynamic zone components\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n await async.map(_.castArray(value), (subValue: any) =>\n deleteComponent(subValue.__component, subValue)\n );\n }\n\n continue;\n }\n }\n};\n\n/** *************************\n Component queries\n************************** */\n\n// components can have nested compos so this must be recursive\nconst createComponent = async <TUID extends UID.Component>(\n uid: TUID,\n data: Modules.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 UID.Component>(\n uid: TUID,\n componentToUpdate: { id: Modules.EntityService.Params.Attribute.ID },\n data: Modules.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 UID.Component>(\n componentUID: TUID,\n value: Modules.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 UID.Component>(\n uid: TUID,\n componentToDelete: Data.Component<TUID>\n) => {\n await deleteComponents(uid, componentToDelete);\n await strapi.db.query(uid).delete({ where: { id: componentToDelete.id } });\n};\n\nconst assignComponentData = <TUID extends UID.ContentType>(\n data: Modules.EntityService.Params.Data.Input<TUID>,\n componentData: ComponentBody,\n {\n contentType,\n }: {\n contentType: Schema.ContentType<TUID>;\n }\n) => {\n return Object.assign(omitComponentData(contentType, data), componentData);\n};\n\nexport {\n omitComponentData,\n assignComponentData,\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,7 +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";
4
- const isDialectMySQL = () => strapi.db?.dialect.client === "mysql";
3
+ import { contentTypes, async, errors } from "@strapi/utils";
5
4
  function omitComponentData(contentType, data) {
6
5
  const { attributes } = contentType;
7
6
  const componentAttributes = Object.keys(attributes).filter(
@@ -28,10 +27,9 @@ const createComponents = async (uid, data) => {
28
27
  if (!Array.isArray(componentValue)) {
29
28
  throw new Error("Expected an array to create repeatable component");
30
29
  }
31
- const components = await mapAsync(
30
+ const components = await async.map(
32
31
  componentValue,
33
- (value) => createComponent(componentUID, value),
34
- { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
32
+ (value) => createComponent(componentUID, value)
35
33
  );
36
34
  componentBody[attributeName] = components.map(({ id }) => {
37
35
  return {
@@ -72,10 +70,9 @@ const createComponents = async (uid, data) => {
72
70
  }
73
71
  };
74
72
  };
75
- componentBody[attributeName] = await mapAsync(
73
+ componentBody[attributeName] = await async.map(
76
74
  dynamiczoneValues,
77
- createDynamicZoneComponents,
78
- { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
75
+ createDynamicZoneComponents
79
76
  );
80
77
  continue;
81
78
  }
@@ -87,7 +84,7 @@ const getComponents = async (uid, entity) => {
87
84
  if (_.isEmpty(componentAttributes)) {
88
85
  return {};
89
86
  }
90
- return strapi.query(uid).load(entity, componentAttributes);
87
+ return strapi.db.query(uid).load(entity, componentAttributes);
91
88
  };
92
89
  const updateComponents = async (uid, entityToUpdate, data) => {
93
90
  const { attributes = {} } = strapi.getModel(uid);
@@ -105,10 +102,9 @@ const updateComponents = async (uid, entityToUpdate, data) => {
105
102
  if (!Array.isArray(componentValue)) {
106
103
  throw new Error("Expected an array to create repeatable component");
107
104
  }
108
- const components = await mapAsync(
105
+ const components = await async.map(
109
106
  componentValue,
110
- (value) => updateOrCreateComponent(componentUID, value),
111
- { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
107
+ (value) => updateOrCreateComponent(componentUID, value)
112
108
  );
113
109
  componentBody[attributeName] = components.filter(_.negate(_.isNil)).map(({ id }) => {
114
110
  return {
@@ -129,29 +125,22 @@ const updateComponents = async (uid, entityToUpdate, data) => {
129
125
  }
130
126
  };
131
127
  }
132
- continue;
133
- }
134
- if (attribute.type === "dynamiczone") {
128
+ } else if (attribute.type === "dynamiczone") {
135
129
  const dynamiczoneValues = data[attributeName];
136
130
  await deleteOldDZComponents(uid, entityToUpdate, attributeName, dynamiczoneValues);
137
131
  if (!Array.isArray(dynamiczoneValues)) {
138
132
  throw new Error("Expected an array to create repeatable component");
139
133
  }
140
- componentBody[attributeName] = await mapAsync(
141
- dynamiczoneValues,
142
- async (value) => {
143
- const { id } = await updateOrCreateComponent(value.__component, value);
144
- return {
145
- id,
146
- __component: value.__component,
147
- __pivot: {
148
- field: attributeName
149
- }
150
- };
151
- },
152
- { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
153
- );
154
- continue;
134
+ componentBody[attributeName] = await async.map(dynamiczoneValues, async (value) => {
135
+ const { id } = await updateOrCreateComponent(value.__component, value);
136
+ return {
137
+ id,
138
+ __component: value.__component,
139
+ __pivot: {
140
+ field: attributeName
141
+ }
142
+ };
143
+ });
155
144
  }
156
145
  }
157
146
  return componentBody;
@@ -165,7 +154,7 @@ const pickStringifiedId = ({
165
154
  return `${id}`;
166
155
  };
167
156
  const deleteOldComponents = async (uid, componentUID, entityToUpdate, attributeName, componentValue) => {
168
- const previousValue = await strapi.query(uid).load(entityToUpdate, attributeName);
157
+ const previousValue = await strapi.db.query(uid).load(entityToUpdate, attributeName);
169
158
  const idsToKeep = _.castArray(componentValue).filter(has("id")).map(pickStringifiedId);
170
159
  const allIds = _.castArray(previousValue).filter(has("id")).map(pickStringifiedId);
171
160
  idsToKeep.forEach((id) => {
@@ -183,7 +172,7 @@ const deleteOldComponents = async (uid, componentUID, entityToUpdate, attributeN
183
172
  }
184
173
  };
185
174
  const deleteOldDZComponents = async (uid, entityToUpdate, attributeName, dynamiczoneValues) => {
186
- const previousValue = await strapi.query(uid).load(entityToUpdate, attributeName);
175
+ const previousValue = await strapi.db.query(uid).load(entityToUpdate, attributeName);
187
176
  const idsToKeep = _.castArray(dynamiczoneValues).filter(has("id")).map((v) => ({
188
177
  id: pickStringifiedId(v),
189
178
  __component: v.__component
@@ -222,7 +211,7 @@ const deleteComponents = async (uid, entityToDelete, { loadComponents = true } =
222
211
  if (attribute.type === "component" || attribute.type === "dynamiczone") {
223
212
  let value;
224
213
  if (loadComponents) {
225
- value = await strapi.query(uid).load(entityToDelete, attributeName);
214
+ value = await strapi.db.query(uid).load(entityToDelete, attributeName);
226
215
  } else {
227
216
  value = entityToDelete[attributeName];
228
217
  }
@@ -231,93 +220,20 @@ const deleteComponents = async (uid, entityToDelete, { loadComponents = true } =
231
220
  }
232
221
  if (attribute.type === "component") {
233
222
  const { component: componentUID } = attribute;
234
- await mapAsync(
223
+ await async.map(
235
224
  _.castArray(value),
236
- (subValue) => deleteComponent(componentUID, subValue),
237
- {
238
- concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity
239
- }
225
+ (subValue) => deleteComponent(componentUID, subValue)
240
226
  );
241
227
  } else {
242
- await mapAsync(
228
+ await async.map(
243
229
  _.castArray(value),
244
- (subValue) => deleteComponent(subValue.__component, subValue),
245
- { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
230
+ (subValue) => deleteComponent(subValue.__component, subValue)
246
231
  );
247
232
  }
248
233
  continue;
249
234
  }
250
235
  }
251
236
  };
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
237
  const createComponent = async (uid, data) => {
322
238
  const model = strapi.getModel(uid);
323
239
  const componentData = await createComponents(uid, data);
@@ -329,12 +245,12 @@ const createComponent = async (uid, data) => {
329
245
  // ... and assign the newly created component instead
330
246
  assign(componentData)
331
247
  );
332
- return strapi.query(uid).create({ data: transform(data) });
248
+ return strapi.db.query(uid).create({ data: transform(data) });
333
249
  };
334
250
  const updateComponent = async (uid, componentToUpdate, data) => {
335
251
  const model = strapi.getModel(uid);
336
252
  const componentData = await updateComponents(uid, componentToUpdate, data);
337
- return strapi.query(uid).update({
253
+ return strapi.db.query(uid).update({
338
254
  where: {
339
255
  id: componentToUpdate.id
340
256
  },
@@ -352,26 +268,15 @@ const updateOrCreateComponent = (componentUID, value) => {
352
268
  };
353
269
  const deleteComponent = async (uid, componentToDelete) => {
354
270
  await deleteComponents(uid, componentToDelete);
355
- await strapi.query(uid).delete({ where: { id: componentToDelete.id } });
271
+ await strapi.db.query(uid).delete({ where: { id: componentToDelete.id } });
356
272
  };
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) });
273
+ const assignComponentData = (data, componentData, {
274
+ contentType
275
+ }) => {
276
+ return Object.assign(omitComponentData(contentType, data), componentData);
372
277
  };
373
278
  export {
374
- cloneComponents,
279
+ assignComponentData,
375
280
  createComponents,
376
281
  deleteComponent,
377
282
  deleteComponents,
@@ -0,0 +1 @@
1
+ {"version":3,"file":"components.mjs","sources":["../../../src/services/document-service/components.ts"],"sourcesContent":["import _ from 'lodash';\nimport { has, omit, pipe, assign } from 'lodash/fp';\nimport type { Struct, Utils, UID, Schema, Data, Modules } from '@strapi/types';\nimport { contentTypes as contentTypesUtils, async, errors } from '@strapi/utils';\n\ntype LoadedComponents<TUID extends UID.Schema> = Data.Entity<\n TUID,\n Schema.AttributeNamesByType<TUID, 'component' | 'dynamiczone'>\n>;\n\ntype SingleComponentValue = Schema.Attribute.ComponentValue<UID.Component, false>;\ntype RepeatableComponentValue = Schema.Attribute.ComponentValue<UID.Component, true>;\n\ntype ComponentValue = SingleComponentValue | RepeatableComponentValue;\n\ntype DynamicZoneValue = Schema.Attribute.DynamicZoneValue<UID.Component[]>;\n\ntype ComponentBody = {\n [key: string]: ComponentValue | DynamicZoneValue;\n};\n\nfunction omitComponentData(\n contentType: Struct.ContentTypeSchema,\n data: Modules.EntityService.Params.Data.Input<Struct.ContentTypeSchema['uid']>\n): Partial<Modules.EntityService.Params.Data.Input<Struct.ContentTypeSchema['uid']>>;\nfunction omitComponentData(\n contentType: Struct.ComponentSchema,\n data: Modules.EntityService.Params.Data.Input<Struct.ComponentSchema['uid']>\n): Partial<Modules.EntityService.Params.Data.Input<Struct.ComponentSchema['uid']>>;\nfunction omitComponentData(\n contentType: Struct.Schema,\n data: Modules.EntityService.Params.Data.Input<\n Struct.ContentTypeSchema['uid'] | Struct.ComponentSchema['uid']\n >\n): Partial<\n Modules.EntityService.Params.Data.Input<\n Struct.ContentTypeSchema['uid'] | Struct.ComponentSchema['uid']\n >\n> {\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 UID.Schema,\n TData extends Modules.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: RepeatableComponentValue = await async.map(componentValue, (value: any) =>\n createComponent(componentUID, value)\n );\n\n componentBody[attributeName] = components.map(({ id }) => {\n return {\n id,\n __pivot: {\n field: attributeName,\n component_type: componentUID,\n },\n };\n });\n } else {\n const component = await createComponent(\n componentUID,\n componentValue as Modules.EntityService.Params.Data.Input<UID.Component>\n );\n\n componentBody[attributeName] = {\n id: component.id,\n __pivot: {\n field: attributeName,\n component_type: componentUID,\n },\n };\n }\n\n continue;\n }\n\n if (attribute.type === 'dynamiczone') {\n const dynamiczoneValues = data[\n attributeName as keyof TData\n ] as Modules.EntityService.Params.Attribute.GetValue<Schema.Attribute.DynamicZone>;\n\n if (!Array.isArray(dynamiczoneValues)) {\n throw new Error('Expected an array to create repeatable component');\n }\n\n const createDynamicZoneComponents = async (\n value: Utils.Array.Values<typeof dynamiczoneValues>\n ) => {\n const { id } = await createComponent(value.__component, value);\n return {\n id,\n __component: value.__component,\n __pivot: {\n field: attributeName,\n },\n };\n };\n\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n componentBody[attributeName] = await async.map(\n dynamiczoneValues,\n createDynamicZoneComponents\n );\n\n continue;\n }\n }\n\n return componentBody;\n};\n\nconst getComponents = async <TUID extends UID.Schema>(\n uid: TUID,\n entity: { id: Modules.EntityService.Params.Attribute.ID }\n): Promise<LoadedComponents<TUID>> => {\n const componentAttributes = contentTypesUtils.getComponentAttributes(strapi.getModel(uid));\n\n if (_.isEmpty(componentAttributes)) {\n return {} as LoadedComponents<TUID>;\n }\n\n return strapi.db.query(uid).load(entity, componentAttributes) as Promise<LoadedComponents<TUID>>;\n};\n\n/*\n delete old components\n create or update\n*/\nconst updateComponents = async <\n TUID extends UID.Schema,\n TData extends Partial<Modules.EntityService.Params.Data.Input<TUID>>,\n>(\n uid: TUID,\n entityToUpdate: { id: Modules.EntityService.Params.Attribute.ID },\n data: TData\n) => {\n const { attributes = {} } = strapi.getModel(uid);\n\n const componentBody: ComponentBody = {};\n\n for (const attributeName of Object.keys(attributes)) {\n const attribute = attributes[attributeName];\n\n if (!has(attributeName, data)) {\n continue;\n }\n\n if (attribute.type === 'component') {\n const { component: componentUID, repeatable = false } = attribute;\n\n const componentValue = data[attributeName as keyof TData] as ComponentValue;\n\n await deleteOldComponents(uid, componentUID, entityToUpdate, attributeName, componentValue);\n\n if (repeatable === true) {\n if (!Array.isArray(componentValue)) {\n throw new Error('Expected an array to create repeatable component');\n }\n\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n const components: RepeatableComponentValue = await async.map(componentValue, (value: any) =>\n updateOrCreateComponent(componentUID, value)\n );\n\n componentBody[attributeName] = components.filter(_.negate(_.isNil)).map(({ id }) => {\n return {\n id,\n __pivot: {\n field: attributeName,\n component_type: componentUID,\n },\n };\n });\n } else {\n const component = await updateOrCreateComponent(componentUID, componentValue);\n componentBody[attributeName] = component && {\n id: component.id,\n __pivot: {\n field: attributeName,\n component_type: componentUID,\n },\n };\n }\n } else if (attribute.type === 'dynamiczone') {\n const dynamiczoneValues = data[attributeName as keyof TData] as DynamicZoneValue;\n\n await deleteOldDZComponents(uid, entityToUpdate, attributeName, dynamiczoneValues);\n\n if (!Array.isArray(dynamiczoneValues)) {\n throw new Error('Expected an array to create repeatable component');\n }\n\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n componentBody[attributeName] = await async.map(dynamiczoneValues, async (value: any) => {\n const { id } = await updateOrCreateComponent(value.__component, value);\n\n return {\n id,\n __component: value.__component,\n __pivot: {\n field: attributeName,\n },\n };\n });\n }\n }\n\n return componentBody;\n};\n\nconst pickStringifiedId = ({\n id,\n}: {\n id: Modules.EntityService.Params.Attribute.ID;\n}): Modules.EntityService.Params.Attribute.ID & string => {\n if (typeof id === 'string') {\n return id;\n }\n\n return `${id}`;\n};\n\nconst deleteOldComponents = async <TUID extends UID.Schema>(\n uid: TUID,\n componentUID: UID.Component,\n entityToUpdate: { id: Modules.EntityService.Params.Attribute.ID },\n attributeName: string,\n componentValue: ComponentValue\n) => {\n const previousValue = (await strapi.db\n .query(uid)\n .load(entityToUpdate, attributeName)) as ComponentValue;\n\n const idsToKeep = _.castArray(componentValue).filter(has('id')).map(pickStringifiedId);\n const allIds = _.castArray(previousValue).filter(has('id')).map(pickStringifiedId);\n\n idsToKeep.forEach((id) => {\n if (!allIds.includes(id)) {\n throw new errors.ApplicationError(\n `Some of the provided components in ${attributeName} are not related to the entity`\n );\n }\n });\n\n const idsToDelete = _.difference(allIds, idsToKeep);\n\n if (idsToDelete.length > 0) {\n for (const idToDelete of idsToDelete) {\n await deleteComponent(componentUID, { id: idToDelete });\n }\n }\n};\n\nconst deleteOldDZComponents = async <TUID extends UID.Schema>(\n uid: TUID,\n entityToUpdate: { id: Modules.EntityService.Params.Attribute.ID },\n attributeName: string,\n dynamiczoneValues: DynamicZoneValue\n) => {\n const previousValue = (await strapi.db\n .query(uid)\n .load(entityToUpdate, attributeName)) as DynamicZoneValue;\n\n const idsToKeep = _.castArray(dynamiczoneValues)\n .filter(has('id'))\n .map((v) => ({\n id: pickStringifiedId(v),\n __component: v.__component,\n }));\n\n const allIds = _.castArray(previousValue)\n .filter(has('id'))\n .map((v) => ({\n id: pickStringifiedId(v),\n __component: v.__component,\n }));\n\n idsToKeep.forEach(({ id, __component }) => {\n if (!allIds.find((el) => el.id === id && el.__component === __component)) {\n const err = new Error(\n `Some of the provided components in ${attributeName} are not related to the entity`\n );\n\n Object.assign(err, { status: 400 });\n throw err;\n }\n });\n\n type IdsToDelete = DynamicZoneValue;\n\n const idsToDelete = allIds.reduce((acc, { id, __component }) => {\n if (!idsToKeep.find((el) => el.id === id && el.__component === __component)) {\n acc.push({ id, __component });\n }\n\n return acc;\n }, [] as IdsToDelete);\n\n if (idsToDelete.length > 0) {\n for (const idToDelete of idsToDelete) {\n const { id, __component } = idToDelete;\n await deleteComponent(__component, { id });\n }\n }\n};\n\nconst deleteComponents = async <TUID extends UID.Schema, TEntity extends Data.Entity<TUID>>(\n uid: TUID,\n entityToDelete: TEntity,\n { loadComponents = true } = {}\n) => {\n const { attributes = {} } = strapi.getModel(uid);\n\n const attributeNames = Object.keys(attributes);\n\n for (const attributeName of attributeNames) {\n const attribute = attributes[attributeName];\n\n if (attribute.type === 'component' || attribute.type === 'dynamiczone') {\n let value;\n 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(_.castArray(value), (subValue: any) =>\n deleteComponent(componentUID, subValue)\n );\n } else {\n // delete dynamic zone components\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n await async.map(_.castArray(value), (subValue: any) =>\n deleteComponent(subValue.__component, subValue)\n );\n }\n\n continue;\n }\n }\n};\n\n/** *************************\n Component queries\n************************** */\n\n// components can have nested compos so this must be recursive\nconst createComponent = async <TUID extends UID.Component>(\n uid: TUID,\n data: Modules.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 UID.Component>(\n uid: TUID,\n componentToUpdate: { id: Modules.EntityService.Params.Attribute.ID },\n data: Modules.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 UID.Component>(\n componentUID: TUID,\n value: Modules.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 UID.Component>(\n uid: TUID,\n componentToDelete: Data.Component<TUID>\n) => {\n await deleteComponents(uid, componentToDelete);\n await strapi.db.query(uid).delete({ where: { id: componentToDelete.id } });\n};\n\nconst assignComponentData = <TUID extends UID.ContentType>(\n data: Modules.EntityService.Params.Data.Input<TUID>,\n componentData: ComponentBody,\n {\n contentType,\n }: {\n contentType: Schema.ContentType<TUID>;\n }\n) => {\n return Object.assign(omitComponentData(contentType, data), componentData);\n};\n\nexport {\n omitComponentData,\n assignComponentData,\n getComponents,\n createComponents,\n updateComponents,\n deleteComponents,\n deleteComponent,\n};\n"],"names":["contentTypesUtils"],"mappings":"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"}