@strapi/core 0.0.0-experimental.a407f3bc8fb79a53cf7975140864526b6ddbac4b → 0.0.0-experimental.a4bb06d54b493ab973659d0200e0e42937988850

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