@strapi/core 0.0.0-experimental.e3e48deb89bd0a1b6cc69b698696566fa7854a95 → 0.0.0-experimental.e576af447d9f97e89e24c6daa32d8f714376cd5f

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