@strapi/core 0.0.0-experimental.3f7b2587c5e3d548262671895cf11d8bf8c9166e → 0.0.0-experimental.402a8c65252458d28f0c291ad2aaabec270b591d

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 (849) hide show
  1. package/LICENSE +18 -3
  2. package/dist/Strapi.d.ts +52 -59
  3. package/dist/Strapi.d.ts.map +1 -1
  4. package/dist/configuration/config-loader.d.ts.map +1 -1
  5. package/dist/configuration/get-dirs.d.ts +10 -0
  6. package/dist/configuration/get-dirs.d.ts.map +1 -0
  7. package/dist/configuration/index.d.ts +4 -7
  8. package/dist/configuration/index.d.ts.map +1 -1
  9. package/dist/configuration/urls.d.ts +8 -0
  10. package/dist/configuration/urls.d.ts.map +1 -0
  11. package/dist/container.d.ts +2 -2
  12. package/dist/container.d.ts.map +1 -1
  13. package/dist/core-api/controller/collection-type.d.ts +4 -4
  14. package/dist/core-api/controller/collection-type.d.ts.map +1 -1
  15. package/dist/core-api/controller/index.d.ts +3 -3
  16. package/dist/core-api/controller/index.d.ts.map +1 -1
  17. package/dist/core-api/controller/single-type.d.ts +4 -4
  18. package/dist/core-api/controller/single-type.d.ts.map +1 -1
  19. package/dist/core-api/controller/transform.d.ts +10 -18
  20. package/dist/core-api/controller/transform.d.ts.map +1 -1
  21. package/dist/core-api/routes/index.d.ts.map +1 -1
  22. package/dist/core-api/service/collection-type.d.ts +22 -5
  23. package/dist/core-api/service/collection-type.d.ts.map +1 -1
  24. package/dist/core-api/service/core-service.d.ts +4 -0
  25. package/dist/core-api/service/core-service.d.ts.map +1 -0
  26. package/dist/core-api/service/index.d.ts +3 -3
  27. package/dist/core-api/service/index.d.ts.map +1 -1
  28. package/dist/core-api/service/pagination.d.ts +4 -15
  29. package/dist/core-api/service/pagination.d.ts.map +1 -1
  30. package/dist/core-api/service/single-type.d.ts +14 -8
  31. package/dist/core-api/service/single-type.d.ts.map +1 -1
  32. package/dist/domain/content-type/index.d.ts +1 -1
  33. package/dist/domain/content-type/index.d.ts.map +1 -1
  34. package/dist/domain/content-type/validator.d.ts.map +1 -1
  35. package/dist/domain/module/index.d.ts +24 -23
  36. package/dist/domain/module/index.d.ts.map +1 -1
  37. package/dist/ee/index.d.ts +4 -2
  38. package/dist/ee/index.d.ts.map +1 -1
  39. package/dist/ee/license.d.ts +2 -2
  40. package/dist/ee/license.d.ts.map +1 -1
  41. package/dist/factories.d.ts +10 -10
  42. package/dist/factories.d.ts.map +1 -1
  43. package/dist/index.d.ts +18 -2
  44. package/dist/index.d.ts.map +1 -1
  45. package/dist/index.js +9956 -5
  46. package/dist/index.js.map +1 -1
  47. package/dist/index.mjs +9932 -5
  48. package/dist/index.mjs.map +1 -1
  49. package/dist/loaders/admin.d.ts +2 -2
  50. package/dist/loaders/admin.d.ts.map +1 -1
  51. package/dist/loaders/apis.d.ts +2 -2
  52. package/dist/loaders/apis.d.ts.map +1 -1
  53. package/dist/loaders/components.d.ts +2 -2
  54. package/dist/loaders/components.d.ts.map +1 -1
  55. package/dist/loaders/index.d.ts +2 -2
  56. package/dist/loaders/index.d.ts.map +1 -1
  57. package/dist/loaders/middlewares.d.ts +2 -2
  58. package/dist/loaders/middlewares.d.ts.map +1 -1
  59. package/dist/loaders/plugins/get-enabled-plugins.d.ts +2 -2
  60. package/dist/loaders/plugins/get-enabled-plugins.d.ts.map +1 -1
  61. package/dist/loaders/plugins/index.d.ts +2 -2
  62. package/dist/loaders/plugins/index.d.ts.map +1 -1
  63. package/dist/loaders/policies.d.ts +2 -2
  64. package/dist/loaders/policies.d.ts.map +1 -1
  65. package/dist/loaders/sanitizers.d.ts +2 -2
  66. package/dist/loaders/sanitizers.d.ts.map +1 -1
  67. package/dist/loaders/src-index.d.ts +2 -2
  68. package/dist/loaders/src-index.d.ts.map +1 -1
  69. package/dist/loaders/validators.d.ts +2 -2
  70. package/dist/loaders/validators.d.ts.map +1 -1
  71. package/dist/middlewares/body.d.ts +4 -4
  72. package/dist/middlewares/body.d.ts.map +1 -1
  73. package/dist/middlewares/compression.d.ts +2 -2
  74. package/dist/middlewares/compression.d.ts.map +1 -1
  75. package/dist/middlewares/cors.d.ts +2 -2
  76. package/dist/middlewares/cors.d.ts.map +1 -1
  77. package/dist/middlewares/errors.d.ts +2 -2
  78. package/dist/middlewares/errors.d.ts.map +1 -1
  79. package/dist/middlewares/favicon.d.ts +2 -2
  80. package/dist/middlewares/favicon.d.ts.map +1 -1
  81. package/dist/middlewares/index.d.ts +2 -2
  82. package/dist/middlewares/index.d.ts.map +1 -1
  83. package/dist/middlewares/ip.d.ts +2 -2
  84. package/dist/middlewares/ip.d.ts.map +1 -1
  85. package/dist/middlewares/logger.d.ts +2 -2
  86. package/dist/middlewares/logger.d.ts.map +1 -1
  87. package/dist/middlewares/powered-by.d.ts +2 -2
  88. package/dist/middlewares/powered-by.d.ts.map +1 -1
  89. package/dist/middlewares/public.d.ts +2 -2
  90. package/dist/middlewares/public.d.ts.map +1 -1
  91. package/dist/middlewares/query.d.ts +2 -2
  92. package/dist/middlewares/query.d.ts.map +1 -1
  93. package/dist/middlewares/response-time.d.ts +2 -2
  94. package/dist/middlewares/response-time.d.ts.map +1 -1
  95. package/dist/middlewares/responses.d.ts +3 -3
  96. package/dist/middlewares/responses.d.ts.map +1 -1
  97. package/dist/middlewares/security.d.ts +2 -2
  98. package/dist/middlewares/security.d.ts.map +1 -1
  99. package/dist/middlewares/session.d.ts +2 -2
  100. package/dist/middlewares/session.d.ts.map +1 -1
  101. package/dist/migrations/database/5.0.0-discard-drafts.d.ts +33 -0
  102. package/dist/migrations/database/5.0.0-discard-drafts.d.ts.map +1 -0
  103. package/dist/migrations/draft-publish.d.ts +17 -0
  104. package/dist/migrations/draft-publish.d.ts.map +1 -0
  105. package/dist/migrations/i18n.d.ts +5 -0
  106. package/dist/migrations/i18n.d.ts.map +1 -0
  107. package/dist/migrations/index.d.ts +5 -0
  108. package/dist/migrations/index.d.ts.map +1 -0
  109. package/dist/providers/admin.d.ts +3 -0
  110. package/dist/providers/admin.d.ts.map +1 -0
  111. package/dist/providers/coreStore.d.ts +3 -0
  112. package/dist/providers/coreStore.d.ts.map +1 -0
  113. package/dist/providers/cron.d.ts +3 -0
  114. package/dist/providers/cron.d.ts.map +1 -0
  115. package/dist/providers/index.d.ts +3 -0
  116. package/dist/providers/index.d.ts.map +1 -0
  117. package/dist/providers/provider.d.ts +9 -0
  118. package/dist/providers/provider.d.ts.map +1 -0
  119. package/dist/providers/registries.d.ts +3 -0
  120. package/dist/providers/registries.d.ts.map +1 -0
  121. package/dist/providers/telemetry.d.ts +3 -0
  122. package/dist/providers/telemetry.d.ts.map +1 -0
  123. package/dist/providers/webhooks.d.ts +3 -0
  124. package/dist/providers/webhooks.d.ts.map +1 -0
  125. package/dist/registries/apis.d.ts +2 -2
  126. package/dist/registries/apis.d.ts.map +1 -1
  127. package/dist/registries/components.d.ts +6 -6
  128. package/dist/registries/components.d.ts.map +1 -1
  129. package/dist/registries/content-types.d.ts +5 -5
  130. package/dist/registries/content-types.d.ts.map +1 -1
  131. package/dist/registries/controllers.d.ts +10 -10
  132. package/dist/registries/controllers.d.ts.map +1 -1
  133. package/dist/registries/custom-fields.d.ts +3 -3
  134. package/dist/registries/custom-fields.d.ts.map +1 -1
  135. package/dist/registries/index.d.ts +0 -1
  136. package/dist/registries/index.d.ts.map +1 -1
  137. package/dist/registries/middlewares.d.ts +6 -6
  138. package/dist/registries/middlewares.d.ts.map +1 -1
  139. package/dist/registries/modules.d.ts +2 -2
  140. package/dist/registries/modules.d.ts.map +1 -1
  141. package/dist/registries/plugins.d.ts +5 -5
  142. package/dist/registries/plugins.d.ts.map +1 -1
  143. package/dist/registries/policies.d.ts +22 -10
  144. package/dist/registries/policies.d.ts.map +1 -1
  145. package/dist/registries/services.d.ts +8 -8
  146. package/dist/registries/services.d.ts.map +1 -1
  147. package/dist/services/auth/index.d.ts +4 -4
  148. package/dist/services/auth/index.d.ts.map +1 -1
  149. package/dist/services/config.d.ts +3 -0
  150. package/dist/services/config.d.ts.map +1 -0
  151. package/dist/services/content-api/index.d.ts +31 -15
  152. package/dist/services/content-api/index.d.ts.map +1 -1
  153. package/dist/services/content-api/permissions/index.d.ts +13 -15
  154. package/dist/services/content-api/permissions/index.d.ts.map +1 -1
  155. package/dist/services/content-api/permissions/providers/action.d.ts +5 -6
  156. package/dist/services/content-api/permissions/providers/action.d.ts.map +1 -1
  157. package/dist/services/content-api/permissions/providers/condition.d.ts +5 -6
  158. package/dist/services/content-api/permissions/providers/condition.d.ts.map +1 -1
  159. package/dist/services/core-store.d.ts.map +1 -1
  160. package/dist/services/cron.d.ts +5 -5
  161. package/dist/services/cron.d.ts.map +1 -1
  162. package/dist/services/custom-fields.d.ts +2 -2
  163. package/dist/services/custom-fields.d.ts.map +1 -1
  164. package/dist/services/document-service/attributes/index.d.ts +6 -0
  165. package/dist/services/document-service/attributes/index.d.ts.map +1 -0
  166. package/dist/services/document-service/attributes/transforms.d.ts +10 -0
  167. package/dist/services/document-service/attributes/transforms.d.ts.map +1 -0
  168. package/dist/services/document-service/common.d.ts +4 -0
  169. package/dist/services/document-service/common.d.ts.map +1 -0
  170. package/dist/services/document-service/components.d.ts +25 -1
  171. package/dist/services/document-service/components.d.ts.map +1 -1
  172. package/dist/services/document-service/draft-and-publish.d.ts +10 -0
  173. package/dist/services/document-service/draft-and-publish.d.ts.map +1 -0
  174. package/dist/services/document-service/entries.d.ts +10 -0
  175. package/dist/services/document-service/entries.d.ts.map +1 -0
  176. package/dist/services/document-service/events.d.ts +25 -0
  177. package/dist/services/document-service/events.d.ts.map +1 -0
  178. package/dist/services/document-service/{document-service.d.ts → index.d.ts} +4 -7
  179. package/dist/services/document-service/index.d.ts.map +1 -0
  180. package/dist/services/document-service/internationalization.d.ts +8 -0
  181. package/dist/services/document-service/internationalization.d.ts.map +1 -0
  182. package/dist/services/document-service/middlewares/errors.d.ts +6 -0
  183. package/dist/services/document-service/middlewares/errors.d.ts.map +1 -0
  184. package/dist/services/document-service/middlewares/index.d.ts +2 -10
  185. package/dist/services/document-service/middlewares/index.d.ts.map +1 -1
  186. package/dist/services/document-service/middlewares/middleware-manager.d.ts +10 -0
  187. package/dist/services/document-service/middlewares/middleware-manager.d.ts.map +1 -0
  188. package/dist/services/document-service/params.d.ts +3 -1
  189. package/dist/services/document-service/params.d.ts.map +1 -1
  190. package/dist/services/document-service/repository.d.ts +3 -0
  191. package/dist/services/document-service/repository.d.ts.map +1 -0
  192. package/dist/services/document-service/transform/data.d.ts +5 -0
  193. package/dist/services/document-service/transform/data.d.ts.map +1 -0
  194. package/dist/services/document-service/transform/fields.d.ts +5 -0
  195. package/dist/services/document-service/transform/fields.d.ts.map +1 -0
  196. package/dist/services/document-service/transform/id-map.d.ts +23 -0
  197. package/dist/services/document-service/transform/id-map.d.ts.map +1 -0
  198. package/dist/services/document-service/transform/id-transform.d.ts +5 -0
  199. package/dist/services/document-service/transform/id-transform.d.ts.map +1 -0
  200. package/dist/services/document-service/transform/populate.d.ts +6 -0
  201. package/dist/services/document-service/transform/populate.d.ts.map +1 -0
  202. package/dist/services/document-service/transform/query.d.ts +5 -0
  203. package/dist/services/document-service/transform/query.d.ts.map +1 -0
  204. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +14 -0
  205. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -0
  206. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts +14 -0
  207. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts.map +1 -0
  208. package/dist/services/document-service/transform/relations/transform/default-locale.d.ts +9 -0
  209. package/dist/services/document-service/transform/relations/transform/default-locale.d.ts.map +1 -0
  210. package/dist/services/document-service/transform/relations/utils/data.d.ts +4 -0
  211. package/dist/services/document-service/transform/relations/utils/data.d.ts.map +1 -0
  212. package/dist/services/document-service/transform/relations/utils/dp.d.ts +10 -0
  213. package/dist/services/document-service/transform/relations/utils/dp.d.ts.map +1 -0
  214. package/dist/services/document-service/transform/relations/utils/i18n.d.ts +10 -0
  215. package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -0
  216. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts +6 -0
  217. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts.map +1 -0
  218. package/dist/services/document-service/transform/relations/utils/types.d.ts +21 -0
  219. package/dist/services/document-service/transform/relations/utils/types.d.ts.map +1 -0
  220. package/dist/services/document-service/transform/types.d.ts +13 -0
  221. package/dist/services/document-service/transform/types.d.ts.map +1 -0
  222. package/dist/services/document-service/utils/populate.d.ts +10 -0
  223. package/dist/services/document-service/utils/populate.d.ts.map +1 -0
  224. package/dist/services/document-service/utils/unidirectional-relations.d.ts +36 -0
  225. package/dist/services/document-service/utils/unidirectional-relations.d.ts.map +1 -0
  226. package/dist/services/entity-service/index.d.ts +4 -6
  227. package/dist/services/entity-service/index.d.ts.map +1 -1
  228. package/dist/services/entity-validator/blocks-validator.d.ts +1 -2
  229. package/dist/services/entity-validator/blocks-validator.d.ts.map +1 -1
  230. package/dist/services/entity-validator/index.d.ts +16 -2
  231. package/dist/services/entity-validator/index.d.ts.map +1 -1
  232. package/dist/services/entity-validator/validators.d.ts +36 -25
  233. package/dist/services/entity-validator/validators.d.ts.map +1 -1
  234. package/dist/services/event-hub.d.ts +1 -0
  235. package/dist/services/event-hub.d.ts.map +1 -1
  236. package/dist/services/features.d.ts +3 -3
  237. package/dist/services/features.d.ts.map +1 -1
  238. package/dist/services/fs.d.ts +2 -2
  239. package/dist/services/fs.d.ts.map +1 -1
  240. package/dist/services/metrics/admin-user-hash.d.ts +2 -2
  241. package/dist/services/metrics/admin-user-hash.d.ts.map +1 -1
  242. package/dist/services/metrics/index.d.ts +2 -2
  243. package/dist/services/metrics/index.d.ts.map +1 -1
  244. package/dist/services/metrics/middleware.d.ts +2 -2
  245. package/dist/services/metrics/middleware.d.ts.map +1 -1
  246. package/dist/services/metrics/rate-limiter.d.ts.map +1 -1
  247. package/dist/services/metrics/sender.d.ts +3 -3
  248. package/dist/services/metrics/sender.d.ts.map +1 -1
  249. package/dist/services/query-params.d.ts +7 -0
  250. package/dist/services/query-params.d.ts.map +1 -0
  251. package/dist/services/reloader.d.ts +7 -0
  252. package/dist/services/reloader.d.ts.map +1 -0
  253. package/dist/services/server/admin-api.d.ts +3 -3
  254. package/dist/services/server/admin-api.d.ts.map +1 -1
  255. package/dist/services/server/api.d.ts +3 -3
  256. package/dist/services/server/api.d.ts.map +1 -1
  257. package/dist/services/server/compose-endpoint.d.ts +2 -2
  258. package/dist/services/server/compose-endpoint.d.ts.map +1 -1
  259. package/dist/services/server/content-api.d.ts +3 -3
  260. package/dist/services/server/content-api.d.ts.map +1 -1
  261. package/dist/services/server/http-server.d.ts +2 -2
  262. package/dist/services/server/http-server.d.ts.map +1 -1
  263. package/dist/services/server/index.d.ts +2 -2
  264. package/dist/services/server/index.d.ts.map +1 -1
  265. package/dist/services/server/koa.d.ts.map +1 -1
  266. package/dist/services/server/middleware.d.ts +4 -4
  267. package/dist/services/server/middleware.d.ts.map +1 -1
  268. package/dist/services/server/policy.d.ts +3 -3
  269. package/dist/services/server/policy.d.ts.map +1 -1
  270. package/dist/services/server/register-middlewares.d.ts +2 -2
  271. package/dist/services/server/register-middlewares.d.ts.map +1 -1
  272. package/dist/services/server/register-routes.d.ts +2 -2
  273. package/dist/services/server/register-routes.d.ts.map +1 -1
  274. package/dist/services/server/routing.d.ts +5 -5
  275. package/dist/services/server/routing.d.ts.map +1 -1
  276. package/dist/services/utils/dynamic-zones.d.ts.map +1 -1
  277. package/dist/services/webhook-runner.d.ts +2 -1
  278. package/dist/services/webhook-runner.d.ts.map +1 -1
  279. package/dist/services/webhook-store.d.ts +2 -8
  280. package/dist/services/webhook-store.d.ts.map +1 -1
  281. package/dist/utils/convert-custom-field-type.d.ts +2 -2
  282. package/dist/utils/convert-custom-field-type.d.ts.map +1 -1
  283. package/dist/utils/fetch.d.ts +3 -3
  284. package/dist/utils/fetch.d.ts.map +1 -1
  285. package/dist/utils/filepath-to-prop-path.d.ts +1 -1
  286. package/dist/utils/filepath-to-prop-path.d.ts.map +1 -1
  287. package/dist/utils/index.d.ts +2 -1
  288. package/dist/utils/index.d.ts.map +1 -1
  289. package/dist/utils/is-initialized.d.ts +2 -2
  290. package/dist/utils/is-initialized.d.ts.map +1 -1
  291. package/dist/utils/load-files.d.ts.map +1 -1
  292. package/dist/utils/open-browser.d.ts +2 -2
  293. package/dist/utils/open-browser.d.ts.map +1 -1
  294. package/dist/utils/resolve-working-dirs.d.ts +19 -0
  295. package/dist/utils/resolve-working-dirs.d.ts.map +1 -0
  296. package/dist/utils/signals.d.ts +2 -2
  297. package/dist/utils/signals.d.ts.map +1 -1
  298. package/dist/utils/startup-logger.d.ts +2 -2
  299. package/dist/utils/startup-logger.d.ts.map +1 -1
  300. package/dist/utils/transform-content-types-to-models.d.ts +461 -3
  301. package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
  302. package/dist/utils/update-notifier/index.d.ts +2 -7
  303. package/dist/utils/update-notifier/index.d.ts.map +1 -1
  304. package/package.json +43 -40
  305. package/dist/Strapi.js +0 -443
  306. package/dist/Strapi.js.map +0 -1
  307. package/dist/Strapi.mjs +0 -442
  308. package/dist/Strapi.mjs.map +0 -1
  309. package/dist/compile.js +0 -18
  310. package/dist/compile.js.map +0 -1
  311. package/dist/compile.mjs +0 -17
  312. package/dist/compile.mjs.map +0 -1
  313. package/dist/configuration/config-loader.js +0 -102
  314. package/dist/configuration/config-loader.js.map +0 -1
  315. package/dist/configuration/config-loader.mjs +0 -100
  316. package/dist/configuration/config-loader.mjs.map +0 -1
  317. package/dist/configuration/index.js +0 -78
  318. package/dist/configuration/index.js.map +0 -1
  319. package/dist/configuration/index.mjs +0 -74
  320. package/dist/configuration/index.mjs.map +0 -1
  321. package/dist/container.js +0 -30
  322. package/dist/container.js.map +0 -1
  323. package/dist/container.mjs +0 -30
  324. package/dist/container.mjs.map +0 -1
  325. package/dist/core-api/controller/collection-type.js +0 -92
  326. package/dist/core-api/controller/collection-type.js.map +0 -1
  327. package/dist/core-api/controller/collection-type.mjs +0 -93
  328. package/dist/core-api/controller/collection-type.mjs.map +0 -1
  329. package/dist/core-api/controller/index.js +0 -47
  330. package/dist/core-api/controller/index.js.map +0 -1
  331. package/dist/core-api/controller/index.mjs +0 -47
  332. package/dist/core-api/controller/index.mjs.map +0 -1
  333. package/dist/core-api/controller/single-type.js +0 -50
  334. package/dist/core-api/controller/single-type.js.map +0 -1
  335. package/dist/core-api/controller/single-type.mjs +0 -51
  336. package/dist/core-api/controller/single-type.mjs.map +0 -1
  337. package/dist/core-api/controller/transform.js +0 -84
  338. package/dist/core-api/controller/transform.js.map +0 -1
  339. package/dist/core-api/controller/transform.mjs +0 -84
  340. package/dist/core-api/controller/transform.mjs.map +0 -1
  341. package/dist/core-api/routes/index.js +0 -67
  342. package/dist/core-api/routes/index.js.map +0 -1
  343. package/dist/core-api/routes/index.mjs +0 -67
  344. package/dist/core-api/routes/index.mjs.map +0 -1
  345. package/dist/core-api/service/collection-type.js +0 -58
  346. package/dist/core-api/service/collection-type.js.map +0 -1
  347. package/dist/core-api/service/collection-type.mjs +0 -59
  348. package/dist/core-api/service/collection-type.mjs.map +0 -1
  349. package/dist/core-api/service/get-fetch-params.d.ts +0 -7
  350. package/dist/core-api/service/get-fetch-params.d.ts.map +0 -1
  351. package/dist/core-api/service/get-fetch-params.js +0 -14
  352. package/dist/core-api/service/get-fetch-params.js.map +0 -1
  353. package/dist/core-api/service/get-fetch-params.mjs +0 -14
  354. package/dist/core-api/service/get-fetch-params.mjs.map +0 -1
  355. package/dist/core-api/service/index.js +0 -16
  356. package/dist/core-api/service/index.js.map +0 -1
  357. package/dist/core-api/service/index.mjs +0 -16
  358. package/dist/core-api/service/index.mjs.map +0 -1
  359. package/dist/core-api/service/pagination.js +0 -89
  360. package/dist/core-api/service/pagination.js.map +0 -1
  361. package/dist/core-api/service/pagination.mjs +0 -89
  362. package/dist/core-api/service/pagination.mjs.map +0 -1
  363. package/dist/core-api/service/single-type.js +0 -54
  364. package/dist/core-api/service/single-type.js.map +0 -1
  365. package/dist/core-api/service/single-type.mjs +0 -55
  366. package/dist/core-api/service/single-type.mjs.map +0 -1
  367. package/dist/domain/content-type/index.js +0 -108
  368. package/dist/domain/content-type/index.js.map +0 -1
  369. package/dist/domain/content-type/index.mjs +0 -106
  370. package/dist/domain/content-type/index.mjs.map +0 -1
  371. package/dist/domain/content-type/validator.js +0 -77
  372. package/dist/domain/content-type/validator.js.map +0 -1
  373. package/dist/domain/content-type/validator.mjs +0 -75
  374. package/dist/domain/content-type/validator.mjs.map +0 -1
  375. package/dist/domain/module/index.js +0 -107
  376. package/dist/domain/module/index.js.map +0 -1
  377. package/dist/domain/module/index.mjs +0 -105
  378. package/dist/domain/module/index.mjs.map +0 -1
  379. package/dist/domain/module/validation.js +0 -25
  380. package/dist/domain/module/validation.js.map +0 -1
  381. package/dist/domain/module/validation.mjs +0 -25
  382. package/dist/domain/module/validation.mjs.map +0 -1
  383. package/dist/ee/index.js +0 -153
  384. package/dist/ee/index.js.map +0 -1
  385. package/dist/ee/index.mjs +0 -154
  386. package/dist/ee/index.mjs.map +0 -1
  387. package/dist/ee/license.js +0 -90
  388. package/dist/ee/license.js.map +0 -1
  389. package/dist/ee/license.mjs +0 -87
  390. package/dist/ee/license.mjs.map +0 -1
  391. package/dist/factories.js +0 -86
  392. package/dist/factories.js.map +0 -1
  393. package/dist/factories.mjs +0 -86
  394. package/dist/factories.mjs.map +0 -1
  395. package/dist/loaders/admin.js +0 -27
  396. package/dist/loaders/admin.js.map +0 -1
  397. package/dist/loaders/admin.mjs +0 -26
  398. package/dist/loaders/admin.mjs.map +0 -1
  399. package/dist/loaders/apis.js +0 -137
  400. package/dist/loaders/apis.js.map +0 -1
  401. package/dist/loaders/apis.mjs +0 -135
  402. package/dist/loaders/apis.mjs.map +0 -1
  403. package/dist/loaders/components.js +0 -38
  404. package/dist/loaders/components.js.map +0 -1
  405. package/dist/loaders/components.mjs +0 -37
  406. package/dist/loaders/components.mjs.map +0 -1
  407. package/dist/loaders/index.js +0 -26
  408. package/dist/loaders/index.js.map +0 -1
  409. package/dist/loaders/index.mjs +0 -26
  410. package/dist/loaders/index.mjs.map +0 -1
  411. package/dist/loaders/middlewares.js +0 -31
  412. package/dist/loaders/middlewares.js.map +0 -1
  413. package/dist/loaders/middlewares.mjs +0 -30
  414. package/dist/loaders/middlewares.mjs.map +0 -1
  415. package/dist/loaders/plugins/get-enabled-plugins.js +0 -111
  416. package/dist/loaders/plugins/get-enabled-plugins.js.map +0 -1
  417. package/dist/loaders/plugins/get-enabled-plugins.mjs +0 -109
  418. package/dist/loaders/plugins/get-enabled-plugins.mjs.map +0 -1
  419. package/dist/loaders/plugins/get-user-plugins-config.js +0 -27
  420. package/dist/loaders/plugins/get-user-plugins-config.js.map +0 -1
  421. package/dist/loaders/plugins/get-user-plugins-config.mjs +0 -25
  422. package/dist/loaders/plugins/get-user-plugins-config.mjs.map +0 -1
  423. package/dist/loaders/plugins/index.js +0 -118
  424. package/dist/loaders/plugins/index.js.map +0 -1
  425. package/dist/loaders/plugins/index.mjs +0 -117
  426. package/dist/loaders/plugins/index.mjs.map +0 -1
  427. package/dist/loaders/policies.js +0 -25
  428. package/dist/loaders/policies.js.map +0 -1
  429. package/dist/loaders/policies.mjs +0 -24
  430. package/dist/loaders/policies.mjs.map +0 -1
  431. package/dist/loaders/sanitizers.js +0 -6
  432. package/dist/loaders/sanitizers.js.map +0 -1
  433. package/dist/loaders/sanitizers.mjs +0 -7
  434. package/dist/loaders/sanitizers.mjs.map +0 -1
  435. package/dist/loaders/src-index.js +0 -33
  436. package/dist/loaders/src-index.js.map +0 -1
  437. package/dist/loaders/src-index.mjs +0 -34
  438. package/dist/loaders/src-index.mjs.map +0 -1
  439. package/dist/loaders/validators.js +0 -6
  440. package/dist/loaders/validators.js.map +0 -1
  441. package/dist/loaders/validators.mjs +0 -7
  442. package/dist/loaders/validators.mjs.map +0 -1
  443. package/dist/middlewares/body.js +0 -65
  444. package/dist/middlewares/body.js.map +0 -1
  445. package/dist/middlewares/body.mjs +0 -61
  446. package/dist/middlewares/body.mjs.map +0 -1
  447. package/dist/middlewares/compression.js +0 -8
  448. package/dist/middlewares/compression.js.map +0 -1
  449. package/dist/middlewares/compression.mjs +0 -6
  450. package/dist/middlewares/compression.mjs.map +0 -1
  451. package/dist/middlewares/cors.js +0 -51
  452. package/dist/middlewares/cors.js.map +0 -1
  453. package/dist/middlewares/cors.mjs +0 -49
  454. package/dist/middlewares/cors.mjs.map +0 -1
  455. package/dist/middlewares/errors.js +0 -33
  456. package/dist/middlewares/errors.js.map +0 -1
  457. package/dist/middlewares/errors.mjs +0 -33
  458. package/dist/middlewares/errors.mjs.map +0 -1
  459. package/dist/middlewares/favicon.js +0 -22
  460. package/dist/middlewares/favicon.js.map +0 -1
  461. package/dist/middlewares/favicon.mjs +0 -20
  462. package/dist/middlewares/favicon.mjs.map +0 -1
  463. package/dist/middlewares/index.js +0 -34
  464. package/dist/middlewares/index.js.map +0 -1
  465. package/dist/middlewares/index.mjs +0 -34
  466. package/dist/middlewares/index.mjs.map +0 -1
  467. package/dist/middlewares/ip.js +0 -8
  468. package/dist/middlewares/ip.js.map +0 -1
  469. package/dist/middlewares/ip.mjs +0 -6
  470. package/dist/middlewares/ip.mjs.map +0 -1
  471. package/dist/middlewares/logger.js +0 -12
  472. package/dist/middlewares/logger.js.map +0 -1
  473. package/dist/middlewares/logger.mjs +0 -12
  474. package/dist/middlewares/logger.mjs.map +0 -1
  475. package/dist/middlewares/powered-by.js +0 -14
  476. package/dist/middlewares/powered-by.js.map +0 -1
  477. package/dist/middlewares/powered-by.mjs +0 -14
  478. package/dist/middlewares/powered-by.mjs.map +0 -1
  479. package/dist/middlewares/public.js +0 -34
  480. package/dist/middlewares/public.js.map +0 -1
  481. package/dist/middlewares/public.mjs +0 -32
  482. package/dist/middlewares/public.mjs.map +0 -1
  483. package/dist/middlewares/query.js +0 -40
  484. package/dist/middlewares/query.js.map +0 -1
  485. package/dist/middlewares/query.mjs +0 -38
  486. package/dist/middlewares/query.mjs.map +0 -1
  487. package/dist/middlewares/response-time.js +0 -12
  488. package/dist/middlewares/response-time.js.map +0 -1
  489. package/dist/middlewares/response-time.mjs +0 -12
  490. package/dist/middlewares/response-time.mjs.map +0 -1
  491. package/dist/middlewares/responses.js +0 -15
  492. package/dist/middlewares/responses.js.map +0 -1
  493. package/dist/middlewares/responses.mjs +0 -15
  494. package/dist/middlewares/responses.mjs.map +0 -1
  495. package/dist/middlewares/security.js +0 -71
  496. package/dist/middlewares/security.js.map +0 -1
  497. package/dist/middlewares/security.mjs +0 -69
  498. package/dist/middlewares/security.mjs.map +0 -1
  499. package/dist/middlewares/session.js +0 -30
  500. package/dist/middlewares/session.js.map +0 -1
  501. package/dist/middlewares/session.mjs +0 -28
  502. package/dist/middlewares/session.mjs.map +0 -1
  503. package/dist/registries/apis.js +0 -23
  504. package/dist/registries/apis.js.map +0 -1
  505. package/dist/registries/apis.mjs +0 -24
  506. package/dist/registries/apis.mjs.map +0 -1
  507. package/dist/registries/components.js +0 -45
  508. package/dist/registries/components.js.map +0 -1
  509. package/dist/registries/components.mjs +0 -46
  510. package/dist/registries/components.mjs.map +0 -1
  511. package/dist/registries/config.d.ts +0 -4
  512. package/dist/registries/config.d.ts.map +0 -1
  513. package/dist/registries/config.js +0 -23
  514. package/dist/registries/config.js.map +0 -1
  515. package/dist/registries/config.mjs +0 -22
  516. package/dist/registries/config.mjs.map +0 -1
  517. package/dist/registries/content-types.js +0 -71
  518. package/dist/registries/content-types.js.map +0 -1
  519. package/dist/registries/content-types.mjs +0 -72
  520. package/dist/registries/content-types.mjs.map +0 -1
  521. package/dist/registries/controllers.js +0 -80
  522. package/dist/registries/controllers.js.map +0 -1
  523. package/dist/registries/controllers.mjs +0 -81
  524. package/dist/registries/controllers.mjs.map +0 -1
  525. package/dist/registries/custom-fields.js +0 -71
  526. package/dist/registries/custom-fields.js.map +0 -1
  527. package/dist/registries/custom-fields.mjs +0 -72
  528. package/dist/registries/custom-fields.mjs.map +0 -1
  529. package/dist/registries/hooks.js +0 -58
  530. package/dist/registries/hooks.js.map +0 -1
  531. package/dist/registries/hooks.mjs +0 -59
  532. package/dist/registries/hooks.mjs.map +0 -1
  533. package/dist/registries/middlewares.js +0 -60
  534. package/dist/registries/middlewares.js.map +0 -1
  535. package/dist/registries/middlewares.mjs +0 -61
  536. package/dist/registries/middlewares.mjs.map +0 -1
  537. package/dist/registries/models.js +0 -16
  538. package/dist/registries/models.js.map +0 -1
  539. package/dist/registries/models.mjs +0 -16
  540. package/dist/registries/models.mjs.map +0 -1
  541. package/dist/registries/modules.js +0 -39
  542. package/dist/registries/modules.js.map +0 -1
  543. package/dist/registries/modules.mjs +0 -40
  544. package/dist/registries/modules.mjs.map +0 -1
  545. package/dist/registries/namespace.js +0 -27
  546. package/dist/registries/namespace.js.map +0 -1
  547. package/dist/registries/namespace.mjs +0 -27
  548. package/dist/registries/namespace.mjs.map +0 -1
  549. package/dist/registries/plugins.js +0 -23
  550. package/dist/registries/plugins.js.map +0 -1
  551. package/dist/registries/plugins.mjs +0 -24
  552. package/dist/registries/plugins.mjs.map +0 -1
  553. package/dist/registries/policies.js +0 -62
  554. package/dist/registries/policies.js.map +0 -1
  555. package/dist/registries/policies.mjs +0 -63
  556. package/dist/registries/policies.mjs.map +0 -1
  557. package/dist/registries/sanitizers.js +0 -25
  558. package/dist/registries/sanitizers.js.map +0 -1
  559. package/dist/registries/sanitizers.mjs +0 -24
  560. package/dist/registries/sanitizers.mjs.map +0 -1
  561. package/dist/registries/services.js +0 -80
  562. package/dist/registries/services.js.map +0 -1
  563. package/dist/registries/services.mjs +0 -81
  564. package/dist/registries/services.mjs.map +0 -1
  565. package/dist/registries/validators.js +0 -25
  566. package/dist/registries/validators.js.map +0 -1
  567. package/dist/registries/validators.mjs +0 -24
  568. package/dist/registries/validators.mjs.map +0 -1
  569. package/dist/services/auth/index.js +0 -81
  570. package/dist/services/auth/index.js.map +0 -1
  571. package/dist/services/auth/index.mjs +0 -80
  572. package/dist/services/auth/index.mjs.map +0 -1
  573. package/dist/services/content-api/index.js +0 -59
  574. package/dist/services/content-api/index.js.map +0 -1
  575. package/dist/services/content-api/index.mjs +0 -58
  576. package/dist/services/content-api/index.mjs.map +0 -1
  577. package/dist/services/content-api/permissions/engine.js +0 -7
  578. package/dist/services/content-api/permissions/engine.js.map +0 -1
  579. package/dist/services/content-api/permissions/engine.mjs +0 -6
  580. package/dist/services/content-api/permissions/engine.mjs.map +0 -1
  581. package/dist/services/content-api/permissions/index.js +0 -87
  582. package/dist/services/content-api/permissions/index.js.map +0 -1
  583. package/dist/services/content-api/permissions/index.mjs +0 -86
  584. package/dist/services/content-api/permissions/index.mjs.map +0 -1
  585. package/dist/services/content-api/permissions/providers/action.js +0 -16
  586. package/dist/services/content-api/permissions/providers/action.js.map +0 -1
  587. package/dist/services/content-api/permissions/providers/action.mjs +0 -17
  588. package/dist/services/content-api/permissions/providers/action.mjs.map +0 -1
  589. package/dist/services/content-api/permissions/providers/condition.js +0 -16
  590. package/dist/services/content-api/permissions/providers/condition.js.map +0 -1
  591. package/dist/services/content-api/permissions/providers/condition.mjs +0 -17
  592. package/dist/services/content-api/permissions/providers/condition.mjs.map +0 -1
  593. package/dist/services/core-store.js +0 -107
  594. package/dist/services/core-store.js.map +0 -1
  595. package/dist/services/core-store.mjs +0 -107
  596. package/dist/services/core-store.mjs.map +0 -1
  597. package/dist/services/cron.js +0 -63
  598. package/dist/services/cron.js.map +0 -1
  599. package/dist/services/cron.mjs +0 -64
  600. package/dist/services/cron.mjs.map +0 -1
  601. package/dist/services/custom-fields.js +0 -10
  602. package/dist/services/custom-fields.js.map +0 -1
  603. package/dist/services/custom-fields.mjs +0 -11
  604. package/dist/services/custom-fields.mjs.map +0 -1
  605. package/dist/services/document-service/document-engine.d.ts +0 -8
  606. package/dist/services/document-service/document-engine.d.ts.map +0 -1
  607. package/dist/services/document-service/document-engine.js +0 -200
  608. package/dist/services/document-service/document-engine.js.map +0 -1
  609. package/dist/services/document-service/document-engine.mjs +0 -201
  610. package/dist/services/document-service/document-engine.mjs.map +0 -1
  611. package/dist/services/document-service/document-service.d.ts.map +0 -1
  612. package/dist/services/document-service/document-service.js +0 -132
  613. package/dist/services/document-service/document-service.js.map +0 -1
  614. package/dist/services/document-service/document-service.mjs +0 -132
  615. package/dist/services/document-service/document-service.mjs.map +0 -1
  616. package/dist/services/document-service/middlewares/defaults/draft-and-publish.d.ts +0 -26
  617. package/dist/services/document-service/middlewares/defaults/draft-and-publish.d.ts.map +0 -1
  618. package/dist/services/document-service/middlewares/defaults/draft-and-publish.js +0 -58
  619. package/dist/services/document-service/middlewares/defaults/draft-and-publish.js.map +0 -1
  620. package/dist/services/document-service/middlewares/defaults/draft-and-publish.mjs +0 -58
  621. package/dist/services/document-service/middlewares/defaults/draft-and-publish.mjs.map +0 -1
  622. package/dist/services/document-service/middlewares/defaults/index.d.ts +0 -3
  623. package/dist/services/document-service/middlewares/defaults/index.d.ts.map +0 -1
  624. package/dist/services/document-service/middlewares/defaults/index.js +0 -82
  625. package/dist/services/document-service/middlewares/defaults/index.js.map +0 -1
  626. package/dist/services/document-service/middlewares/defaults/index.mjs +0 -82
  627. package/dist/services/document-service/middlewares/defaults/index.mjs.map +0 -1
  628. package/dist/services/document-service/middlewares/defaults/locales.d.ts +0 -18
  629. package/dist/services/document-service/middlewares/defaults/locales.d.ts.map +0 -1
  630. package/dist/services/document-service/middlewares/defaults/locales.js +0 -50
  631. package/dist/services/document-service/middlewares/defaults/locales.js.map +0 -1
  632. package/dist/services/document-service/middlewares/defaults/locales.mjs +0 -50
  633. package/dist/services/document-service/middlewares/defaults/locales.mjs.map +0 -1
  634. package/dist/services/document-service/middlewares/index.js +0 -59
  635. package/dist/services/document-service/middlewares/index.js.map +0 -1
  636. package/dist/services/document-service/middlewares/index.mjs +0 -59
  637. package/dist/services/document-service/middlewares/index.mjs.map +0 -1
  638. package/dist/services/entity-service/attributes/index.d.ts +0 -6
  639. package/dist/services/entity-service/attributes/index.d.ts.map +0 -1
  640. package/dist/services/entity-service/attributes/index.js +0 -22
  641. package/dist/services/entity-service/attributes/index.js.map +0 -1
  642. package/dist/services/entity-service/attributes/index.mjs +0 -22
  643. package/dist/services/entity-service/attributes/index.mjs.map +0 -1
  644. package/dist/services/entity-service/attributes/transforms.d.ts +0 -10
  645. package/dist/services/entity-service/attributes/transforms.d.ts.map +0 -1
  646. package/dist/services/entity-service/attributes/transforms.js +0 -20
  647. package/dist/services/entity-service/attributes/transforms.js.map +0 -1
  648. package/dist/services/entity-service/attributes/transforms.mjs +0 -19
  649. package/dist/services/entity-service/attributes/transforms.mjs.map +0 -1
  650. package/dist/services/entity-service/components.d.ts +0 -23
  651. package/dist/services/entity-service/components.d.ts.map +0 -1
  652. package/dist/services/entity-service/components.js +0 -384
  653. package/dist/services/entity-service/components.js.map +0 -1
  654. package/dist/services/entity-service/components.mjs +0 -382
  655. package/dist/services/entity-service/components.mjs.map +0 -1
  656. package/dist/services/entity-service/index.js +0 -328
  657. package/dist/services/entity-service/index.js.map +0 -1
  658. package/dist/services/entity-service/index.mjs +0 -326
  659. package/dist/services/entity-service/index.mjs.map +0 -1
  660. package/dist/services/entity-service/params.d.ts +0 -8
  661. package/dist/services/entity-service/params.d.ts.map +0 -1
  662. package/dist/services/entity-service/params.js +0 -8
  663. package/dist/services/entity-service/params.js.map +0 -1
  664. package/dist/services/entity-service/params.mjs +0 -8
  665. package/dist/services/entity-service/params.mjs.map +0 -1
  666. package/dist/services/entity-validator/blocks-validator.js +0 -107
  667. package/dist/services/entity-validator/blocks-validator.js.map +0 -1
  668. package/dist/services/entity-validator/blocks-validator.mjs +0 -108
  669. package/dist/services/entity-validator/blocks-validator.mjs.map +0 -1
  670. package/dist/services/entity-validator/index.js +0 -322
  671. package/dist/services/entity-validator/index.js.map +0 -1
  672. package/dist/services/entity-validator/index.mjs +0 -321
  673. package/dist/services/entity-validator/index.mjs.map +0 -1
  674. package/dist/services/entity-validator/validators.js +0 -122
  675. package/dist/services/entity-validator/validators.js.map +0 -1
  676. package/dist/services/entity-validator/validators.mjs +0 -120
  677. package/dist/services/entity-validator/validators.mjs.map +0 -1
  678. package/dist/services/errors.js +0 -76
  679. package/dist/services/errors.js.map +0 -1
  680. package/dist/services/errors.mjs +0 -74
  681. package/dist/services/errors.mjs.map +0 -1
  682. package/dist/services/event-hub.js +0 -67
  683. package/dist/services/event-hub.js.map +0 -1
  684. package/dist/services/event-hub.mjs +0 -68
  685. package/dist/services/event-hub.mjs.map +0 -1
  686. package/dist/services/features.js +0 -17
  687. package/dist/services/features.js.map +0 -1
  688. package/dist/services/features.mjs +0 -17
  689. package/dist/services/features.mjs.map +0 -1
  690. package/dist/services/fs.js +0 -51
  691. package/dist/services/fs.js.map +0 -1
  692. package/dist/services/fs.mjs +0 -49
  693. package/dist/services/fs.mjs.map +0 -1
  694. package/dist/services/metrics/admin-user-hash.js +0 -14
  695. package/dist/services/metrics/admin-user-hash.js.map +0 -1
  696. package/dist/services/metrics/admin-user-hash.mjs +0 -12
  697. package/dist/services/metrics/admin-user-hash.mjs.map +0 -1
  698. package/dist/services/metrics/index.js +0 -45
  699. package/dist/services/metrics/index.js.map +0 -1
  700. package/dist/services/metrics/index.mjs +0 -46
  701. package/dist/services/metrics/index.mjs.map +0 -1
  702. package/dist/services/metrics/is-truthy.js +0 -9
  703. package/dist/services/metrics/is-truthy.js.map +0 -1
  704. package/dist/services/metrics/is-truthy.mjs +0 -8
  705. package/dist/services/metrics/is-truthy.mjs.map +0 -1
  706. package/dist/services/metrics/middleware.js +0 -25
  707. package/dist/services/metrics/middleware.js.map +0 -1
  708. package/dist/services/metrics/middleware.mjs +0 -26
  709. package/dist/services/metrics/middleware.mjs.map +0 -1
  710. package/dist/services/metrics/rate-limiter.js +0 -21
  711. package/dist/services/metrics/rate-limiter.js.map +0 -1
  712. package/dist/services/metrics/rate-limiter.mjs +0 -22
  713. package/dist/services/metrics/rate-limiter.mjs.map +0 -1
  714. package/dist/services/metrics/sender.js +0 -76
  715. package/dist/services/metrics/sender.js.map +0 -1
  716. package/dist/services/metrics/sender.mjs +0 -70
  717. package/dist/services/metrics/sender.mjs.map +0 -1
  718. package/dist/services/request-context.js +0 -13
  719. package/dist/services/request-context.js.map +0 -1
  720. package/dist/services/request-context.mjs +0 -14
  721. package/dist/services/request-context.mjs.map +0 -1
  722. package/dist/services/server/admin-api.js +0 -13
  723. package/dist/services/server/admin-api.js.map +0 -1
  724. package/dist/services/server/admin-api.mjs +0 -13
  725. package/dist/services/server/admin-api.mjs.map +0 -1
  726. package/dist/services/server/api.js +0 -30
  727. package/dist/services/server/api.js.map +0 -1
  728. package/dist/services/server/api.mjs +0 -28
  729. package/dist/services/server/api.mjs.map +0 -1
  730. package/dist/services/server/compose-endpoint.js +0 -115
  731. package/dist/services/server/compose-endpoint.js.map +0 -1
  732. package/dist/services/server/compose-endpoint.mjs +0 -114
  733. package/dist/services/server/compose-endpoint.mjs.map +0 -1
  734. package/dist/services/server/content-api.js +0 -12
  735. package/dist/services/server/content-api.js.map +0 -1
  736. package/dist/services/server/content-api.mjs +0 -12
  737. package/dist/services/server/content-api.mjs.map +0 -1
  738. package/dist/services/server/http-server.js +0 -50
  739. package/dist/services/server/http-server.js.map +0 -1
  740. package/dist/services/server/http-server.mjs +0 -48
  741. package/dist/services/server/http-server.mjs.map +0 -1
  742. package/dist/services/server/index.js +0 -88
  743. package/dist/services/server/index.js.map +0 -1
  744. package/dist/services/server/index.mjs +0 -86
  745. package/dist/services/server/index.mjs.map +0 -1
  746. package/dist/services/server/koa.js +0 -52
  747. package/dist/services/server/koa.js.map +0 -1
  748. package/dist/services/server/koa.mjs +0 -48
  749. package/dist/services/server/koa.mjs.map +0 -1
  750. package/dist/services/server/middleware.js +0 -92
  751. package/dist/services/server/middleware.js.map +0 -1
  752. package/dist/services/server/middleware.mjs +0 -90
  753. package/dist/services/server/middleware.mjs.map +0 -1
  754. package/dist/services/server/policy.js +0 -20
  755. package/dist/services/server/policy.js.map +0 -1
  756. package/dist/services/server/policy.mjs +0 -20
  757. package/dist/services/server/policy.mjs.map +0 -1
  758. package/dist/services/server/register-middlewares.js +0 -72
  759. package/dist/services/server/register-middlewares.js.map +0 -1
  760. package/dist/services/server/register-middlewares.mjs +0 -73
  761. package/dist/services/server/register-middlewares.mjs.map +0 -1
  762. package/dist/services/server/register-routes.js +0 -76
  763. package/dist/services/server/register-routes.js.map +0 -1
  764. package/dist/services/server/register-routes.mjs +0 -75
  765. package/dist/services/server/register-routes.mjs.map +0 -1
  766. package/dist/services/server/routing.js +0 -91
  767. package/dist/services/server/routing.js.map +0 -1
  768. package/dist/services/server/routing.mjs +0 -89
  769. package/dist/services/server/routing.mjs.map +0 -1
  770. package/dist/services/utils/dynamic-zones.js +0 -16
  771. package/dist/services/utils/dynamic-zones.js.map +0 -1
  772. package/dist/services/utils/dynamic-zones.mjs +0 -17
  773. package/dist/services/utils/dynamic-zones.mjs.map +0 -1
  774. package/dist/services/utils/upload-files.d.ts +0 -8
  775. package/dist/services/utils/upload-files.d.ts.map +0 -1
  776. package/dist/services/utils/upload-files.js +0 -64
  777. package/dist/services/utils/upload-files.js.map +0 -1
  778. package/dist/services/utils/upload-files.mjs +0 -63
  779. package/dist/services/utils/upload-files.mjs.map +0 -1
  780. package/dist/services/webhook-runner.js +0 -133
  781. package/dist/services/webhook-runner.js.map +0 -1
  782. package/dist/services/webhook-runner.mjs +0 -131
  783. package/dist/services/webhook-runner.mjs.map +0 -1
  784. package/dist/services/webhook-store.js +0 -104
  785. package/dist/services/webhook-store.js.map +0 -1
  786. package/dist/services/webhook-store.mjs +0 -104
  787. package/dist/services/webhook-store.mjs.map +0 -1
  788. package/dist/services/worker-queue.js +0 -56
  789. package/dist/services/worker-queue.js.map +0 -1
  790. package/dist/services/worker-queue.mjs +0 -55
  791. package/dist/services/worker-queue.mjs.map +0 -1
  792. package/dist/utils/convert-custom-field-type.js +0 -24
  793. package/dist/utils/convert-custom-field-type.js.map +0 -1
  794. package/dist/utils/convert-custom-field-type.mjs +0 -24
  795. package/dist/utils/convert-custom-field-type.mjs.map +0 -1
  796. package/dist/utils/cron.js +0 -38
  797. package/dist/utils/cron.js.map +0 -1
  798. package/dist/utils/cron.mjs +0 -38
  799. package/dist/utils/cron.mjs.map +0 -1
  800. package/dist/utils/fetch.js +0 -20
  801. package/dist/utils/fetch.js.map +0 -1
  802. package/dist/utils/fetch.mjs +0 -20
  803. package/dist/utils/fetch.mjs.map +0 -1
  804. package/dist/utils/filepath-to-prop-path.js +0 -12
  805. package/dist/utils/filepath-to-prop-path.js.map +0 -1
  806. package/dist/utils/filepath-to-prop-path.mjs +0 -10
  807. package/dist/utils/filepath-to-prop-path.mjs.map +0 -1
  808. package/dist/utils/get-dirs.d.ts +0 -9
  809. package/dist/utils/get-dirs.d.ts.map +0 -1
  810. package/dist/utils/get-dirs.js +0 -30
  811. package/dist/utils/get-dirs.js.map +0 -1
  812. package/dist/utils/get-dirs.mjs +0 -30
  813. package/dist/utils/get-dirs.mjs.map +0 -1
  814. package/dist/utils/is-initialized.js +0 -16
  815. package/dist/utils/is-initialized.js.map +0 -1
  816. package/dist/utils/is-initialized.mjs +0 -16
  817. package/dist/utils/is-initialized.mjs.map +0 -1
  818. package/dist/utils/lifecycles.js +0 -9
  819. package/dist/utils/lifecycles.js.map +0 -1
  820. package/dist/utils/lifecycles.mjs +0 -9
  821. package/dist/utils/lifecycles.mjs.map +0 -1
  822. package/dist/utils/load-config-file.js +0 -45
  823. package/dist/utils/load-config-file.js.map +0 -1
  824. package/dist/utils/load-config-file.mjs +0 -42
  825. package/dist/utils/load-config-file.mjs.map +0 -1
  826. package/dist/utils/load-files.js +0 -39
  827. package/dist/utils/load-files.js.map +0 -1
  828. package/dist/utils/load-files.mjs +0 -35
  829. package/dist/utils/load-files.mjs.map +0 -1
  830. package/dist/utils/open-browser.js +0 -11
  831. package/dist/utils/open-browser.js.map +0 -1
  832. package/dist/utils/open-browser.mjs +0 -9
  833. package/dist/utils/open-browser.mjs.map +0 -1
  834. package/dist/utils/signals.js +0 -17
  835. package/dist/utils/signals.js.map +0 -1
  836. package/dist/utils/signals.mjs +0 -17
  837. package/dist/utils/signals.mjs.map +0 -1
  838. package/dist/utils/startup-logger.js +0 -81
  839. package/dist/utils/startup-logger.js.map +0 -1
  840. package/dist/utils/startup-logger.mjs +0 -77
  841. package/dist/utils/startup-logger.mjs.map +0 -1
  842. package/dist/utils/transform-content-types-to-models.js +0 -198
  843. package/dist/utils/transform-content-types-to-models.js.map +0 -1
  844. package/dist/utils/transform-content-types-to-models.mjs +0 -196
  845. package/dist/utils/transform-content-types-to-models.mjs.map +0 -1
  846. package/dist/utils/update-notifier/index.js +0 -88
  847. package/dist/utils/update-notifier/index.js.map +0 -1
  848. package/dist/utils/update-notifier/index.mjs +0 -81
  849. package/dist/utils/update-notifier/index.mjs.map +0 -1
@@ -1,22 +0,0 @@
1
- import transforms from "./transforms.mjs";
2
- const applyTransforms = (data, context) => {
3
- const { contentType } = context;
4
- const attributeNames = Object.keys(data);
5
- for (const attributeName of attributeNames) {
6
- const value = data[attributeName];
7
- const attribute = contentType.attributes[attributeName];
8
- if (!attribute) {
9
- continue;
10
- }
11
- const transform = transforms[attribute.type];
12
- if (transform) {
13
- const attributeContext = { ...context, attributeName, attribute };
14
- data[attributeName] = transform(value, attributeContext);
15
- }
16
- }
17
- return data;
18
- };
19
- export {
20
- applyTransforms
21
- };
22
- //# sourceMappingURL=index.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.mjs","sources":["../../../../src/services/entity-service/attributes/index.ts"],"sourcesContent":["import type { Common, Shared, EntityService } from '@strapi/types';\nimport transforms from './transforms';\n\nconst applyTransforms = <TUID extends Common.UID.ContentType>(\n data: EntityService.Params.Data.Input<TUID>,\n context: {\n contentType: Shared.ContentTypes[TUID];\n }\n) => {\n const { contentType } = context;\n\n const attributeNames = Object.keys(data) as Array<keyof typeof data & string>;\n\n for (const attributeName of attributeNames) {\n const value = data[attributeName];\n\n const attribute = contentType.attributes[attributeName];\n\n if (!attribute) {\n continue;\n }\n\n const transform = transforms[attribute.type];\n\n if (transform) {\n const attributeContext = { ...context, attributeName, attribute };\n\n data[attributeName] = transform(value, attributeContext);\n }\n }\n\n return data;\n};\n\nexport { applyTransforms };\n"],"names":[],"mappings":";AAGM,MAAA,kBAAkB,CACtB,MACA,YAGG;AACG,QAAA,EAAE,YAAgB,IAAA;AAElB,QAAA,iBAAiB,OAAO,KAAK,IAAI;AAEvC,aAAW,iBAAiB,gBAAgB;AACpC,UAAA,QAAQ,KAAK,aAAa;AAE1B,UAAA,YAAY,YAAY,WAAW,aAAa;AAEtD,QAAI,CAAC,WAAW;AACd;AAAA,IACF;AAEM,UAAA,YAAY,WAAW,UAAU,IAAI;AAE3C,QAAI,WAAW;AACb,YAAM,mBAAmB,EAAE,GAAG,SAAS,eAAe,UAAU;AAEhE,WAAK,aAAa,IAAI,UAAU,OAAO,gBAAgB;AAAA,IACzD;AAAA,EACF;AAEO,SAAA;AACT;"}
@@ -1,10 +0,0 @@
1
- import type { Attribute } from '@strapi/types';
2
- type Transforms = {
3
- [TKind in Attribute.Kind]?: (value: unknown, context: {
4
- attribute: Attribute.Any;
5
- attributeName: string;
6
- }) => any;
7
- };
8
- declare const transforms: Transforms;
9
- export default transforms;
10
- //# sourceMappingURL=transforms.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"transforms.d.ts","sourceRoot":"","sources":["../../../../src/services/entity-service/attributes/transforms.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAG/C,KAAK,UAAU,GAAG;KACf,KAAK,IAAI,SAAS,CAAC,IAAI,CAAC,CAAC,EAAE,CAC1B,KAAK,EAAE,OAAO,EACd,OAAO,EAAE;QAAE,SAAS,EAAE,SAAS,CAAC,GAAG,CAAC;QAAC,aAAa,EAAE,MAAM,CAAA;KAAE,KACzD,GAAG;CACT,CAAC;AAEF,QAAA,MAAM,UAAU,EAAE,UAgBjB,CAAC;AAEF,eAAe,UAAU,CAAC"}
@@ -1,20 +0,0 @@
1
- "use strict";
2
- const _ = require("lodash/fp");
3
- const bcrypt = require("bcryptjs");
4
- const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
5
- const bcrypt__default = /* @__PURE__ */ _interopDefault(bcrypt);
6
- const transforms = {
7
- password(value, context) {
8
- const { attribute } = context;
9
- if (attribute.type !== "password") {
10
- throw new Error("Invalid attribute type");
11
- }
12
- if (!_.isString(value) && !(value instanceof Buffer)) {
13
- return value;
14
- }
15
- const rounds = _.toNumber(_.getOr(10, "encryption.rounds", attribute));
16
- return bcrypt__default.default.hashSync(value.toString(), rounds);
17
- }
18
- };
19
- module.exports = transforms;
20
- //# sourceMappingURL=transforms.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"transforms.js","sources":["../../../../src/services/entity-service/attributes/transforms.ts"],"sourcesContent":["import { getOr, toNumber, isString } from 'lodash/fp';\nimport type { Attribute } from '@strapi/types';\nimport bcrypt from 'bcryptjs';\n\ntype Transforms = {\n [TKind in Attribute.Kind]?: (\n value: unknown,\n context: { attribute: Attribute.Any; attributeName: string }\n ) => any;\n};\n\nconst transforms: Transforms = {\n password(value, context) {\n const { attribute } = context;\n\n if (attribute.type !== 'password') {\n throw new Error('Invalid attribute type');\n }\n\n if (!isString(value) && !(value instanceof Buffer)) {\n return value;\n }\n\n const rounds = toNumber(getOr(10, 'encryption.rounds', attribute));\n\n return bcrypt.hashSync(value.toString(), rounds);\n },\n};\n\nexport default transforms;\n"],"names":["isString","toNumber","getOr","bcrypt"],"mappings":";;;;;AAWA,MAAM,aAAyB;AAAA,EAC7B,SAAS,OAAO,SAAS;AACjB,UAAA,EAAE,UAAc,IAAA;AAElB,QAAA,UAAU,SAAS,YAAY;AAC3B,YAAA,IAAI,MAAM,wBAAwB;AAAA,IAC1C;AAEA,QAAI,CAACA,EAAS,SAAA,KAAK,KAAK,EAAE,iBAAiB,SAAS;AAC3C,aAAA;AAAA,IACT;AAEA,UAAM,SAASC,EAAAA,SAASC,EAAA,MAAM,IAAI,qBAAqB,SAAS,CAAC;AAEjE,WAAOC,gBAAAA,QAAO,SAAS,MAAM,YAAY,MAAM;AAAA,EACjD;AACF;;"}
@@ -1,19 +0,0 @@
1
- import { isString, toNumber, getOr } from "lodash/fp";
2
- import bcrypt from "bcryptjs";
3
- const transforms = {
4
- password(value, context) {
5
- const { attribute } = context;
6
- if (attribute.type !== "password") {
7
- throw new Error("Invalid attribute type");
8
- }
9
- if (!isString(value) && !(value instanceof Buffer)) {
10
- return value;
11
- }
12
- const rounds = toNumber(getOr(10, "encryption.rounds", attribute));
13
- return bcrypt.hashSync(value.toString(), rounds);
14
- }
15
- };
16
- export {
17
- transforms as default
18
- };
19
- //# sourceMappingURL=transforms.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"transforms.mjs","sources":["../../../../src/services/entity-service/attributes/transforms.ts"],"sourcesContent":["import { getOr, toNumber, isString } from 'lodash/fp';\nimport type { Attribute } from '@strapi/types';\nimport bcrypt from 'bcryptjs';\n\ntype Transforms = {\n [TKind in Attribute.Kind]?: (\n value: unknown,\n context: { attribute: Attribute.Any; attributeName: string }\n ) => any;\n};\n\nconst transforms: Transforms = {\n password(value, context) {\n const { attribute } = context;\n\n if (attribute.type !== 'password') {\n throw new Error('Invalid attribute type');\n }\n\n if (!isString(value) && !(value instanceof Buffer)) {\n return value;\n }\n\n const rounds = toNumber(getOr(10, 'encryption.rounds', attribute));\n\n return bcrypt.hashSync(value.toString(), rounds);\n },\n};\n\nexport default transforms;\n"],"names":[],"mappings":";;AAWA,MAAM,aAAyB;AAAA,EAC7B,SAAS,OAAO,SAAS;AACjB,UAAA,EAAE,UAAc,IAAA;AAElB,QAAA,UAAU,SAAS,YAAY;AAC3B,YAAA,IAAI,MAAM,wBAAwB;AAAA,IAC1C;AAEA,QAAI,CAAC,SAAS,KAAK,KAAK,EAAE,iBAAiB,SAAS;AAC3C,aAAA;AAAA,IACT;AAEA,UAAM,SAAS,SAAS,MAAM,IAAI,qBAAqB,SAAS,CAAC;AAEjE,WAAO,OAAO,SAAS,MAAM,YAAY,MAAM;AAAA,EACjD;AACF;"}
@@ -1,23 +0,0 @@
1
- import type { Attribute, Common, Schema, EntityService } from '@strapi/types';
2
- type LoadedComponents<TUID extends Common.UID.Schema> = Attribute.GetValues<TUID, Attribute.GetKeysByType<TUID, 'component' | 'dynamiczone'>>;
3
- type ComponentBody = {
4
- [key: string]: Attribute.GetValue<Attribute.Component<Common.UID.Component, false> | Attribute.Component<Common.UID.Component, true> | Attribute.DynamicZone>;
5
- };
6
- declare function omitComponentData(contentType: Schema.ContentType, data: EntityService.Params.Data.Input<Schema.ContentType['uid']>): Partial<EntityService.Params.Data.Input<Schema.ContentType['uid']>>;
7
- declare function omitComponentData(contentType: Schema.Component, data: EntityService.Params.Data.Input<Schema.Component['uid']>): Partial<EntityService.Params.Data.Input<Schema.Component['uid']>>;
8
- declare const createComponents: <TUID extends Common.UID.Schema, TData extends EntityService.Params.Data.Input<TUID>>(uid: TUID, data: TData) => Promise<ComponentBody>;
9
- declare const getComponents: <TUID extends Common.UID.Schema>(uid: TUID, entity: {
10
- id: EntityService.Params.Attribute.ID;
11
- }) => Promise<LoadedComponents<TUID>>;
12
- declare const updateComponents: <TUID extends Common.UID.Schema, TData extends Partial<EntityService.Params.Data.Input<TUID>>>(uid: TUID, entityToUpdate: {
13
- id: EntityService.Params.Attribute.ID;
14
- }, data: TData) => Promise<ComponentBody>;
15
- declare const deleteComponents: <TUID extends Common.UID.Schema, TEntity extends Attribute.GetValues<TUID, Attribute.GetKeys<TUID>>>(uid: TUID, entityToDelete: TEntity, { loadComponents }?: {
16
- loadComponents?: boolean | undefined;
17
- }) => Promise<void>;
18
- declare const cloneComponents: <TUID extends Common.UID.Schema>(uid: TUID, entityToClone: {
19
- id: EntityService.Params.Attribute.ID;
20
- }, data: EntityService.Params.Data.Input<TUID>) => Promise<ComponentBody>;
21
- declare const deleteComponent: <TUID extends `${string}.${string}`>(uid: TUID, componentToDelete: Attribute.GetValues<TUID, Attribute.GetKeys<TUID>>) => Promise<void>;
22
- export { omitComponentData, getComponents, createComponents, updateComponents, deleteComponents, deleteComponent, cloneComponents, };
23
- //# sourceMappingURL=components.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"components.d.ts","sourceRoot":"","sources":["../../../src/services/entity-service/components.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,EAAS,aAAa,EAAE,MAAM,eAAe,CAAC;AAGrF,KAAK,gBAAgB,CAAC,IAAI,SAAS,MAAM,CAAC,GAAG,CAAC,MAAM,IAAI,SAAS,CAAC,SAAS,CACzE,IAAI,EACJ,SAAS,CAAC,aAAa,CAAC,IAAI,EAAE,WAAW,GAAG,aAAa,CAAC,CAC3D,CAAC;AAMF,KAAK,aAAa,GAAG;IACnB,CAAC,GAAG,EAAE,MAAM,GAAG,SAAS,CAAC,QAAQ,CAC7B,SAAS,CAAC,SAAS,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,EAAE,KAAK,CAAC,GAChD,SAAS,CAAC,SAAS,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,EAAE,IAAI,CAAC,GAC/C,SAAS,CAAC,WAAW,CACxB,CAAC;CACH,CAAC;AAIF,iBAAS,iBAAiB,CACxB,WAAW,EAAE,MAAM,CAAC,WAAW,EAC/B,IAAI,EAAE,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,GAC/D,OAAO,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;AACvE,iBAAS,iBAAiB,CACxB,WAAW,EAAE,MAAM,CAAC,SAAS,EAC7B,IAAI,EAAE,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,GAC7D,OAAO,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;AAcrE,QAAA,MAAM,gBAAgB,yIAqGrB,CAAC;AAEF,QAAA,MAAM,aAAa,sDAET;IAAE,EAAE,EAAE,cAAc,MAAM,UAAU,CAAC,EAAE,CAAA;CAAE,oCASlD,CAAC;AAMF,QAAA,MAAM,gBAAgB,4HAKJ;IAAE,EAAE,EAAE,cAAc,MAAM,UAAU,CAAC,EAAE,CAAA;CAAE,wCA2F1D,CAAC;AAkGF,QAAA,MAAM,gBAAgB;;mBAkDrB,CAAC;AAEF,QAAA,MAAM,eAAe,6DAEJ;IAAE,EAAE,EAAE,cAAc,MAAM,UAAU,CAAC,EAAE,CAAA;CAAE,wEA4FzD,CAAC;AA6DF,QAAA,MAAM,eAAe,yIAMpB,CAAC;AAyBF,OAAO,EACL,iBAAiB,EACjB,aAAa,EACb,gBAAgB,EAChB,gBAAgB,EAChB,gBAAgB,EAChB,eAAe,EACf,eAAe,GAChB,CAAC"}
@@ -1,384 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const _$1 = require("lodash");
4
- const _ = require("lodash/fp");
5
- const strapiUtils = require("@strapi/utils");
6
- const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
7
- const ___default = /* @__PURE__ */ _interopDefault(_$1);
8
- const isDialectMySQL = () => strapi.db?.dialect.client === "mysql";
9
- function omitComponentData(contentType, data) {
10
- const { attributes } = contentType;
11
- const componentAttributes = Object.keys(attributes).filter(
12
- (attributeName) => strapiUtils.contentTypes.isComponentAttribute(attributes[attributeName])
13
- );
14
- return _.omit(componentAttributes, data);
15
- }
16
- const createComponents = async (uid, data) => {
17
- const { attributes = {} } = strapi.getModel(uid);
18
- const componentBody = {};
19
- const attributeNames = Object.keys(attributes);
20
- for (const attributeName of attributeNames) {
21
- const attribute = attributes[attributeName];
22
- if (!_.has(attributeName, data) || !strapiUtils.contentTypes.isComponentAttribute(attribute)) {
23
- continue;
24
- }
25
- if (attribute.type === "component") {
26
- const { component: componentUID, repeatable = false } = attribute;
27
- const componentValue = data[attributeName];
28
- if (componentValue === null) {
29
- continue;
30
- }
31
- if (repeatable === true) {
32
- if (!Array.isArray(componentValue)) {
33
- throw new Error("Expected an array to create repeatable component");
34
- }
35
- const components = await strapiUtils.mapAsync(
36
- componentValue,
37
- (value) => createComponent(componentUID, value),
38
- { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
39
- );
40
- componentBody[attributeName] = components.map(({ id }) => {
41
- return {
42
- id,
43
- __pivot: {
44
- field: attributeName,
45
- component_type: componentUID
46
- }
47
- };
48
- });
49
- } else {
50
- const component = await createComponent(
51
- componentUID,
52
- componentValue
53
- );
54
- componentBody[attributeName] = {
55
- id: component.id,
56
- __pivot: {
57
- field: attributeName,
58
- component_type: componentUID
59
- }
60
- };
61
- }
62
- continue;
63
- }
64
- if (attribute.type === "dynamiczone") {
65
- const dynamiczoneValues = data[attributeName];
66
- if (!Array.isArray(dynamiczoneValues)) {
67
- throw new Error("Expected an array to create repeatable component");
68
- }
69
- const createDynamicZoneComponents = async (value) => {
70
- const { id } = await createComponent(value.__component, value);
71
- return {
72
- id,
73
- __component: value.__component,
74
- __pivot: {
75
- field: attributeName
76
- }
77
- };
78
- };
79
- componentBody[attributeName] = await strapiUtils.mapAsync(
80
- dynamiczoneValues,
81
- createDynamicZoneComponents,
82
- { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
83
- );
84
- continue;
85
- }
86
- }
87
- return componentBody;
88
- };
89
- const getComponents = async (uid, entity) => {
90
- const componentAttributes = strapiUtils.contentTypes.getComponentAttributes(strapi.getModel(uid));
91
- if (___default.default.isEmpty(componentAttributes)) {
92
- return {};
93
- }
94
- return strapi.query(uid).load(entity, componentAttributes);
95
- };
96
- const updateComponents = async (uid, entityToUpdate, data) => {
97
- const { attributes = {} } = strapi.getModel(uid);
98
- const componentBody = {};
99
- for (const attributeName of Object.keys(attributes)) {
100
- const attribute = attributes[attributeName];
101
- if (!_.has(attributeName, data)) {
102
- continue;
103
- }
104
- if (attribute.type === "component") {
105
- const { component: componentUID, repeatable = false } = attribute;
106
- const componentValue = data[attributeName];
107
- await deleteOldComponents(uid, componentUID, entityToUpdate, attributeName, componentValue);
108
- if (repeatable === true) {
109
- if (!Array.isArray(componentValue)) {
110
- throw new Error("Expected an array to create repeatable component");
111
- }
112
- const components = await strapiUtils.mapAsync(
113
- componentValue,
114
- (value) => updateOrCreateComponent(componentUID, value),
115
- { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
116
- );
117
- componentBody[attributeName] = components.filter(___default.default.negate(___default.default.isNil)).map(({ id }) => {
118
- return {
119
- id,
120
- __pivot: {
121
- field: attributeName,
122
- component_type: componentUID
123
- }
124
- };
125
- });
126
- } else {
127
- const component = await updateOrCreateComponent(componentUID, componentValue);
128
- componentBody[attributeName] = component && {
129
- id: component.id,
130
- __pivot: {
131
- field: attributeName,
132
- component_type: componentUID
133
- }
134
- };
135
- }
136
- continue;
137
- }
138
- if (attribute.type === "dynamiczone") {
139
- const dynamiczoneValues = data[attributeName];
140
- await deleteOldDZComponents(uid, entityToUpdate, attributeName, dynamiczoneValues);
141
- if (!Array.isArray(dynamiczoneValues)) {
142
- throw new Error("Expected an array to create repeatable component");
143
- }
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;
159
- }
160
- }
161
- return componentBody;
162
- };
163
- const pickStringifiedId = ({
164
- id
165
- }) => {
166
- if (typeof id === "string") {
167
- return id;
168
- }
169
- return `${id}`;
170
- };
171
- const deleteOldComponents = async (uid, componentUID, entityToUpdate, attributeName, componentValue) => {
172
- const previousValue = await strapi.query(uid).load(entityToUpdate, attributeName);
173
- const idsToKeep = ___default.default.castArray(componentValue).filter(_.has("id")).map(pickStringifiedId);
174
- const allIds = ___default.default.castArray(previousValue).filter(_.has("id")).map(pickStringifiedId);
175
- idsToKeep.forEach((id) => {
176
- if (!allIds.includes(id)) {
177
- throw new strapiUtils.errors.ApplicationError(
178
- `Some of the provided components in ${attributeName} are not related to the entity`
179
- );
180
- }
181
- });
182
- const idsToDelete = ___default.default.difference(allIds, idsToKeep);
183
- if (idsToDelete.length > 0) {
184
- for (const idToDelete of idsToDelete) {
185
- await deleteComponent(componentUID, { id: idToDelete });
186
- }
187
- }
188
- };
189
- const deleteOldDZComponents = async (uid, entityToUpdate, attributeName, dynamiczoneValues) => {
190
- const previousValue = await strapi.query(uid).load(entityToUpdate, attributeName);
191
- const idsToKeep = ___default.default.castArray(dynamiczoneValues).filter(_.has("id")).map((v) => ({
192
- id: pickStringifiedId(v),
193
- __component: v.__component
194
- }));
195
- const allIds = ___default.default.castArray(previousValue).filter(_.has("id")).map((v) => ({
196
- id: pickStringifiedId(v),
197
- __component: v.__component
198
- }));
199
- idsToKeep.forEach(({ id, __component }) => {
200
- if (!allIds.find((el) => el.id === id && el.__component === __component)) {
201
- const err = new Error(
202
- `Some of the provided components in ${attributeName} are not related to the entity`
203
- );
204
- Object.assign(err, { status: 400 });
205
- throw err;
206
- }
207
- });
208
- const idsToDelete = allIds.reduce((acc, { id, __component }) => {
209
- if (!idsToKeep.find((el) => el.id === id && el.__component === __component)) {
210
- acc.push({ id, __component });
211
- }
212
- return acc;
213
- }, []);
214
- if (idsToDelete.length > 0) {
215
- for (const idToDelete of idsToDelete) {
216
- const { id, __component } = idToDelete;
217
- await deleteComponent(__component, { id });
218
- }
219
- }
220
- };
221
- const deleteComponents = async (uid, entityToDelete, { loadComponents = true } = {}) => {
222
- const { attributes = {} } = strapi.getModel(uid);
223
- const attributeNames = Object.keys(attributes);
224
- for (const attributeName of attributeNames) {
225
- const attribute = attributes[attributeName];
226
- if (attribute.type === "component" || attribute.type === "dynamiczone") {
227
- let value;
228
- if (loadComponents) {
229
- value = await strapi.query(uid).load(entityToDelete, attributeName);
230
- } else {
231
- value = entityToDelete[attributeName];
232
- }
233
- if (!value) {
234
- continue;
235
- }
236
- if (attribute.type === "component") {
237
- const { component: componentUID } = attribute;
238
- await strapiUtils.mapAsync(
239
- ___default.default.castArray(value),
240
- (subValue) => deleteComponent(componentUID, subValue),
241
- {
242
- concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity
243
- }
244
- );
245
- } else {
246
- await strapiUtils.mapAsync(
247
- ___default.default.castArray(value),
248
- (subValue) => deleteComponent(subValue.__component, subValue),
249
- { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
250
- );
251
- }
252
- continue;
253
- }
254
- }
255
- };
256
- const cloneComponents = async (uid, entityToClone, data) => {
257
- const { attributes = {} } = strapi.getModel(uid);
258
- const componentBody = {};
259
- const componentData = await getComponents(uid, entityToClone);
260
- for (const attributeName of Object.keys(attributes)) {
261
- const attribute = attributes[attributeName];
262
- if (!_.has(attributeName, data) && !_.has(attributeName, componentData)) {
263
- continue;
264
- }
265
- if (attribute.type === "component") {
266
- const { component: componentUID, repeatable = false } = attribute;
267
- const componentValue = attributeName in data ? data[attributeName] : componentData[attributeName];
268
- if (componentValue === null) {
269
- continue;
270
- }
271
- if (repeatable === true) {
272
- if (!Array.isArray(componentValue)) {
273
- throw new Error("Expected an array to create repeatable component");
274
- }
275
- const components = await strapiUtils.mapAsync(
276
- componentValue,
277
- (value) => cloneComponent(componentUID, value),
278
- { concurrency: isDialectMySQL() ? 1 : Infinity }
279
- );
280
- componentBody[attributeName] = components.filter(___default.default.negate(___default.default.isNil)).map(({ id }) => {
281
- return {
282
- id,
283
- __pivot: {
284
- field: attributeName,
285
- component_type: componentUID
286
- }
287
- };
288
- });
289
- } else {
290
- const component = await cloneComponent(componentUID, componentValue);
291
- componentBody[attributeName] = component && {
292
- id: component.id,
293
- __pivot: {
294
- field: attributeName,
295
- component_type: componentUID
296
- }
297
- };
298
- }
299
- continue;
300
- }
301
- if (attribute.type === "dynamiczone") {
302
- const dynamiczoneValues = _.has(attributeName, data) ? data[attributeName] : componentData[attributeName];
303
- if (!Array.isArray(dynamiczoneValues)) {
304
- throw new Error("Expected an array to create repeatable component");
305
- }
306
- componentBody[attributeName] = await strapiUtils.mapAsync(
307
- dynamiczoneValues,
308
- async (value) => {
309
- const { id } = await cloneComponent(value.__component, value);
310
- return {
311
- id,
312
- __component: value.__component,
313
- __pivot: {
314
- field: attributeName
315
- }
316
- };
317
- },
318
- { concurrency: isDialectMySQL() ? 1 : Infinity }
319
- );
320
- continue;
321
- }
322
- }
323
- return componentBody;
324
- };
325
- const createComponent = async (uid, data) => {
326
- const model = strapi.getModel(uid);
327
- const componentData = await createComponents(uid, data);
328
- const transform = _.pipe(
329
- // Make sure we don't save the component with a pre-defined ID
330
- _.omit("id"),
331
- // Remove the component data from the original data object ...
332
- (payload) => omitComponentData(model, payload),
333
- // ... and assign the newly created component instead
334
- _.assign(componentData)
335
- );
336
- return strapi.query(uid).create({ data: transform(data) });
337
- };
338
- const updateComponent = async (uid, componentToUpdate, data) => {
339
- const model = strapi.getModel(uid);
340
- const componentData = await updateComponents(uid, componentToUpdate, data);
341
- return strapi.query(uid).update({
342
- where: {
343
- id: componentToUpdate.id
344
- },
345
- data: Object.assign(omitComponentData(model, data), componentData)
346
- });
347
- };
348
- const updateOrCreateComponent = (componentUID, value) => {
349
- if (value === null) {
350
- return null;
351
- }
352
- if ("id" in value && typeof value.id !== "undefined") {
353
- return updateComponent(componentUID, { id: value.id }, value);
354
- }
355
- return createComponent(componentUID, value);
356
- };
357
- const deleteComponent = async (uid, componentToDelete) => {
358
- await deleteComponents(uid, componentToDelete);
359
- await strapi.query(uid).delete({ where: { id: componentToDelete.id } });
360
- };
361
- const cloneComponent = async (uid, data) => {
362
- const model = strapi.getModel(uid);
363
- if (!("id" in data) || typeof data.id === "undefined") {
364
- return createComponent(uid, data);
365
- }
366
- const componentData = await cloneComponents(uid, { id: data.id }, data);
367
- const transform = _.pipe(
368
- // Make sure we don't save the component with a pre-defined ID
369
- _.omit("id"),
370
- // Remove the component data from the original data object ...
371
- (payload) => omitComponentData(model, payload),
372
- // ... and assign the newly created component instead
373
- _.assign(componentData)
374
- );
375
- return strapi.query(uid).clone(data.id, { data: transform(data) });
376
- };
377
- exports.cloneComponents = cloneComponents;
378
- exports.createComponents = createComponents;
379
- exports.deleteComponent = deleteComponent;
380
- exports.deleteComponents = deleteComponents;
381
- exports.getComponents = getComponents;
382
- exports.omitComponentData = omitComponentData;
383
- exports.updateComponents = updateComponents;
384
- //# sourceMappingURL=components.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"components.js","sources":["../../../src/services/entity-service/components.ts"],"sourcesContent":["import _ from 'lodash';\nimport { has, omit, pipe, assign } from 'lodash/fp';\nimport type { Attribute, Common, Schema, Utils, EntityService } from '@strapi/types';\nimport { contentTypes as contentTypesUtils, mapAsync, errors } from '@strapi/utils';\n\ntype LoadedComponents<TUID extends Common.UID.Schema> = Attribute.GetValues<\n TUID,\n Attribute.GetKeysByType<TUID, 'component' | 'dynamiczone'>\n>;\n\ntype ComponentValue = Attribute.GetValue<\n Attribute.Component<Common.UID.Component, false> | Attribute.Component<Common.UID.Component, true>\n>;\n\ntype ComponentBody = {\n [key: string]: Attribute.GetValue<\n | Attribute.Component<Common.UID.Component, false>\n | Attribute.Component<Common.UID.Component, true>\n | Attribute.DynamicZone\n >;\n};\n\nconst isDialectMySQL = () => strapi.db?.dialect.client === 'mysql';\n\nfunction omitComponentData(\n contentType: Schema.ContentType,\n data: EntityService.Params.Data.Input<Schema.ContentType['uid']>\n): Partial<EntityService.Params.Data.Input<Schema.ContentType['uid']>>;\nfunction omitComponentData(\n contentType: Schema.Component,\n data: EntityService.Params.Data.Input<Schema.Component['uid']>\n): Partial<EntityService.Params.Data.Input<Schema.Component['uid']>>;\nfunction omitComponentData(\n contentType: Schema.ContentType | Schema.Component,\n data: EntityService.Params.Data.Input<Schema.ContentType['uid'] | Schema.Component['uid']>\n): Partial<EntityService.Params.Data.Input<Schema.ContentType['uid'] | Schema.Component['uid']>> {\n const { attributes } = contentType;\n const componentAttributes = Object.keys(attributes).filter((attributeName) =>\n contentTypesUtils.isComponentAttribute(attributes[attributeName])\n );\n\n return omit(componentAttributes, data);\n}\n\n// NOTE: we could generalize the logic to allow CRUD of relation directly in the DB layer\nconst createComponents = async <\n TUID extends Common.UID.Schema,\n TData extends EntityService.Params.Data.Input<TUID>\n>(\n uid: TUID,\n data: TData\n) => {\n const { attributes = {} } = strapi.getModel(uid);\n\n const componentBody: ComponentBody = {};\n\n const attributeNames = Object.keys(attributes);\n\n for (const attributeName of attributeNames) {\n const attribute = attributes[attributeName];\n\n if (!has(attributeName, data) || !contentTypesUtils.isComponentAttribute(attribute)) {\n continue;\n }\n\n if (attribute.type === 'component') {\n const { component: componentUID, repeatable = false } = attribute;\n\n const componentValue = data[attributeName as keyof TData];\n\n if (componentValue === null) {\n continue;\n }\n\n if (repeatable === true) {\n if (!Array.isArray(componentValue)) {\n throw new Error('Expected an array to create repeatable component');\n }\n\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n const components = (await mapAsync(\n componentValue,\n (value: any) => createComponent(componentUID, value),\n { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }\n )) as Attribute.GetValue<Attribute.Component<Common.UID.Component, true>>;\n\n componentBody[attributeName] = components.map(({ id }) => {\n return {\n id,\n __pivot: {\n field: attributeName,\n component_type: componentUID,\n },\n };\n });\n } else {\n const component = await createComponent(\n componentUID,\n componentValue as EntityService.Params.Data.Input<Common.UID.Component>\n );\n componentBody[attributeName] = {\n id: component.id,\n __pivot: {\n field: attributeName,\n component_type: componentUID,\n },\n };\n }\n\n continue;\n }\n\n if (attribute.type === 'dynamiczone') {\n const dynamiczoneValues = data[\n attributeName as keyof TData\n ] as EntityService.Params.Attribute.GetValue<Attribute.DynamicZone>;\n\n if (!Array.isArray(dynamiczoneValues)) {\n throw new Error('Expected an array to create repeatable component');\n }\n\n const createDynamicZoneComponents = async (\n value: Utils.Array.Values<typeof dynamiczoneValues>\n ) => {\n const { id } = await createComponent(value.__component, value);\n return {\n id,\n __component: value.__component,\n __pivot: {\n field: attributeName,\n },\n };\n };\n\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n componentBody[attributeName] = await mapAsync(\n dynamiczoneValues,\n createDynamicZoneComponents,\n { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }\n );\n\n continue;\n }\n }\n\n return componentBody;\n};\n\nconst getComponents = async <TUID extends Common.UID.Schema>(\n uid: TUID,\n entity: { id: EntityService.Params.Attribute.ID }\n): Promise<LoadedComponents<TUID>> => {\n const componentAttributes = contentTypesUtils.getComponentAttributes(strapi.getModel(uid));\n\n if (_.isEmpty(componentAttributes)) {\n return {} as LoadedComponents<TUID>;\n }\n\n return strapi.query(uid).load(entity, componentAttributes) as Promise<LoadedComponents<TUID>>;\n};\n\n/*\n delete old components\n create or update\n*/\nconst updateComponents = async <\n TUID extends Common.UID.Schema,\n TData extends Partial<EntityService.Params.Data.Input<TUID>>\n>(\n uid: TUID,\n entityToUpdate: { id: EntityService.Params.Attribute.ID },\n data: TData\n) => {\n const { attributes = {} } = strapi.getModel(uid);\n\n const componentBody: ComponentBody = {};\n\n for (const attributeName of Object.keys(attributes)) {\n const attribute = attributes[attributeName];\n\n if (!has(attributeName, data)) {\n continue;\n }\n\n if (attribute.type === 'component') {\n const { component: componentUID, repeatable = false } = attribute;\n\n const componentValue = data[\n attributeName as keyof TData\n ] as Attribute.GetValue<Attribute.Component>;\n\n await deleteOldComponents(uid, componentUID, entityToUpdate, attributeName, componentValue);\n\n if (repeatable === true) {\n if (!Array.isArray(componentValue)) {\n throw new Error('Expected an array to create repeatable component');\n }\n\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n const components = (await mapAsync(\n componentValue,\n (value: any) => updateOrCreateComponent(componentUID, value),\n { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }\n )) as Attribute.GetValue<Attribute.Component<Common.UID.Component, true>>;\n\n componentBody[attributeName] = components.filter(_.negate(_.isNil)).map(({ id }) => {\n return {\n id,\n __pivot: {\n field: attributeName,\n component_type: componentUID,\n },\n };\n });\n } else {\n const component = await updateOrCreateComponent(componentUID, componentValue);\n componentBody[attributeName] = component && {\n id: component.id,\n __pivot: {\n field: attributeName,\n component_type: componentUID,\n },\n };\n }\n\n continue;\n }\n\n if (attribute.type === 'dynamiczone') {\n const dynamiczoneValues = data[\n attributeName as keyof TData\n ] as Attribute.GetValue<Attribute.DynamicZone>;\n\n await deleteOldDZComponents(uid, entityToUpdate, attributeName, dynamiczoneValues);\n\n if (!Array.isArray(dynamiczoneValues)) {\n throw new Error('Expected an array to create repeatable component');\n }\n\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n componentBody[attributeName] = await mapAsync(\n dynamiczoneValues,\n async (value: any) => {\n const { id } = await updateOrCreateComponent(value.__component, value);\n\n return {\n id,\n __component: value.__component,\n __pivot: {\n field: attributeName,\n },\n };\n },\n { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }\n );\n\n continue;\n }\n }\n\n return componentBody;\n};\n\nconst pickStringifiedId = ({\n id,\n}: {\n id: EntityService.Params.Attribute.ID;\n}): EntityService.Params.Attribute.ID & string => {\n if (typeof id === 'string') {\n return id;\n }\n\n return `${id}`;\n};\n\nconst deleteOldComponents = async <TUID extends Common.UID.Schema>(\n uid: TUID,\n componentUID: Common.UID.Component,\n entityToUpdate: { id: EntityService.Params.Attribute.ID },\n attributeName: string,\n componentValue: Attribute.GetValue<Attribute.Component>\n) => {\n const previousValue = (await strapi\n .query(uid)\n .load(entityToUpdate, attributeName)) as ComponentValue;\n\n const idsToKeep = _.castArray(componentValue).filter(has('id')).map(pickStringifiedId);\n const allIds = _.castArray(previousValue).filter(has('id')).map(pickStringifiedId);\n\n idsToKeep.forEach((id) => {\n if (!allIds.includes(id)) {\n throw new errors.ApplicationError(\n `Some of the provided components in ${attributeName} are not related to the entity`\n );\n }\n });\n\n const idsToDelete = _.difference(allIds, idsToKeep);\n\n if (idsToDelete.length > 0) {\n for (const idToDelete of idsToDelete) {\n await deleteComponent(componentUID, { id: idToDelete });\n }\n }\n};\n\nconst deleteOldDZComponents = async <TUID extends Common.UID.Schema>(\n uid: TUID,\n entityToUpdate: { id: EntityService.Params.Attribute.ID },\n attributeName: string,\n dynamiczoneValues: Attribute.GetValue<Attribute.DynamicZone>\n) => {\n const previousValue = (await strapi\n .query(uid)\n .load(entityToUpdate, attributeName)) as Attribute.GetValue<Attribute.DynamicZone>;\n\n const idsToKeep = _.castArray(dynamiczoneValues)\n .filter(has('id'))\n .map((v) => ({\n id: pickStringifiedId(v),\n __component: v.__component,\n }));\n\n const allIds = _.castArray(previousValue)\n .filter(has('id'))\n .map((v) => ({\n id: pickStringifiedId(v),\n __component: v.__component,\n }));\n\n idsToKeep.forEach(({ id, __component }) => {\n if (!allIds.find((el) => el.id === id && el.__component === __component)) {\n const err = new Error(\n `Some of the provided components in ${attributeName} are not related to the entity`\n );\n\n Object.assign(err, { status: 400 });\n throw err;\n }\n });\n\n type IdsToDelete = Attribute.GetValue<Attribute.DynamicZone>;\n\n const idsToDelete = allIds.reduce((acc, { id, __component }) => {\n if (!idsToKeep.find((el) => el.id === id && el.__component === __component)) {\n acc.push({ id, __component });\n }\n\n return acc;\n }, [] as IdsToDelete);\n\n if (idsToDelete.length > 0) {\n for (const idToDelete of idsToDelete) {\n const { id, __component } = idToDelete;\n await deleteComponent(__component, { id });\n }\n }\n};\n\nconst deleteComponents = async <\n TUID extends Common.UID.Schema,\n TEntity extends Attribute.GetValues<TUID>\n>(\n uid: TUID,\n entityToDelete: TEntity,\n { loadComponents = true } = {}\n) => {\n const { attributes = {} } = strapi.getModel(uid);\n\n const attributeNames = Object.keys(attributes);\n\n for (const attributeName of attributeNames) {\n const attribute = attributes[attributeName];\n\n if (attribute.type === 'component' || attribute.type === 'dynamiczone') {\n let value;\n if (loadComponents) {\n value = await strapi.query(uid).load(entityToDelete, attributeName);\n } else {\n value = entityToDelete[attributeName as keyof TEntity];\n }\n\n if (!value) {\n continue;\n }\n\n if (attribute.type === 'component') {\n const { component: componentUID } = attribute;\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n await mapAsync(\n _.castArray(value),\n (subValue: any) => deleteComponent(componentUID, subValue),\n {\n concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity,\n }\n );\n } else {\n // delete dynamic zone components\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n await mapAsync(\n _.castArray(value),\n (subValue: any) => deleteComponent(subValue.__component, subValue),\n { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }\n );\n }\n\n continue;\n }\n }\n};\n\nconst cloneComponents = async <TUID extends Common.UID.Schema>(\n uid: TUID,\n entityToClone: { id: EntityService.Params.Attribute.ID },\n data: EntityService.Params.Data.Input<TUID>\n) => {\n const { attributes = {} } = strapi.getModel(uid);\n\n const componentBody: ComponentBody = {};\n const componentData = await getComponents(uid, entityToClone);\n\n for (const attributeName of Object.keys(attributes)) {\n const attribute = attributes[attributeName];\n\n // If the attribute is not set or on the component to clone, skip it\n if (!has(attributeName, data) && !has(attributeName, componentData)) {\n continue;\n }\n\n if (attribute.type === 'component') {\n const { component: componentUID, repeatable = false } = attribute;\n\n const componentValue = (\n attributeName in data\n ? data[attributeName as keyof typeof data]\n : componentData[attributeName as keyof typeof componentData]\n ) as ComponentValue;\n\n if (componentValue === null) {\n continue;\n }\n\n if (repeatable === true) {\n if (!Array.isArray(componentValue)) {\n throw new Error('Expected an array to create repeatable component');\n }\n\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n const components = (await mapAsync(\n componentValue,\n (value: any) => cloneComponent(componentUID, value),\n { concurrency: isDialectMySQL() ? 1 : Infinity }\n )) as Attribute.GetValue<Attribute.Component<Common.UID.Component, true>>;\n\n componentBody[attributeName] = components.filter(_.negate(_.isNil)).map(({ id }) => {\n return {\n id,\n __pivot: {\n field: attributeName,\n component_type: componentUID,\n },\n };\n });\n } else {\n const component = await cloneComponent(componentUID, componentValue);\n componentBody[attributeName] = component && {\n id: component.id,\n __pivot: {\n field: attributeName,\n component_type: componentUID,\n },\n };\n }\n\n continue;\n }\n\n if (attribute.type === 'dynamiczone') {\n const dynamiczoneValues = has(attributeName, data)\n ? data[attributeName as keyof typeof data]\n : componentData[attributeName as keyof typeof componentData];\n\n if (!Array.isArray(dynamiczoneValues)) {\n throw new Error('Expected an array to create repeatable component');\n }\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n componentBody[attributeName] = await mapAsync(\n dynamiczoneValues,\n async (value: any) => {\n const { id } = await cloneComponent(value.__component, value);\n return {\n id,\n __component: value.__component,\n __pivot: {\n field: attributeName,\n },\n };\n },\n { concurrency: isDialectMySQL() ? 1 : Infinity }\n );\n continue;\n }\n }\n\n return componentBody;\n};\n/** *************************\n Component queries\n************************** */\n\n// components can have nested compos so this must be recursive\nconst createComponent = async <TUID extends Common.UID.Component>(\n uid: TUID,\n data: EntityService.Params.Data.Input<TUID>\n) => {\n const model = strapi.getModel(uid);\n\n const componentData = await createComponents(uid, data);\n const transform = pipe(\n // Make sure we don't save the component with a pre-defined ID\n omit('id'),\n // Remove the component data from the original data object ...\n (payload) => omitComponentData(model, payload),\n // ... and assign the newly created component instead\n assign(componentData)\n );\n\n return strapi.query(uid).create({ data: transform(data) });\n};\n\n// components can have nested compos so this must be recursive\nconst updateComponent = async <TUID extends Common.UID.Component>(\n uid: TUID,\n componentToUpdate: { id: EntityService.Params.Attribute.ID },\n data: EntityService.Params.Data.Input<TUID>\n) => {\n const model = strapi.getModel(uid);\n\n const componentData = await updateComponents(uid, componentToUpdate, data);\n\n return strapi.query(uid).update({\n where: {\n id: componentToUpdate.id,\n },\n data: Object.assign(omitComponentData(model, data), componentData),\n });\n};\n\nconst updateOrCreateComponent = <TUID extends Common.UID.Component>(\n componentUID: TUID,\n value: EntityService.Params.Data.Input<TUID>\n) => {\n if (value === null) {\n return null;\n }\n\n // update\n if ('id' in value && typeof value.id !== 'undefined') {\n // TODO: verify the compo is associated with the entity\n return updateComponent(componentUID, { id: value.id }, value);\n }\n\n // create\n return createComponent(componentUID, value);\n};\n\nconst deleteComponent = async <TUID extends Common.UID.Component>(\n uid: TUID,\n componentToDelete: Attribute.GetValues<TUID>\n) => {\n await deleteComponents(uid, componentToDelete);\n await strapi.query(uid).delete({ where: { id: componentToDelete.id } });\n};\n\nconst cloneComponent = async <TUID extends Common.UID.Component>(\n uid: TUID,\n data: EntityService.Params.Data.Input<TUID>\n) => {\n const model = strapi.getModel(uid);\n\n if (!('id' in data) || typeof data.id === 'undefined') {\n return createComponent(uid, data);\n }\n\n const componentData = await cloneComponents(uid, { id: data.id }, data);\n const transform = pipe(\n // Make sure we don't save the component with a pre-defined ID\n omit('id'),\n // Remove the component data from the original data object ...\n (payload) => omitComponentData(model, payload),\n // ... and assign the newly created component instead\n assign(componentData)\n );\n\n return strapi.query(uid).clone(data.id, { data: transform(data) });\n};\n\nexport {\n omitComponentData,\n getComponents,\n createComponents,\n updateComponents,\n deleteComponents,\n deleteComponent,\n cloneComponents,\n};\n"],"names":["contentTypesUtils","omit","has","mapAsync","_","errors","pipe","assign"],"mappings":"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"}