@strapi/core 0.0.0-experimental.d362bf200f5f9359a4bbd4a549603de5ee1f04ca → 0.0.0-experimental.d4b8dd9e74eefeba4fc0574502c919ba4d091e1e

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