@strapi/core 0.0.0-experimental.fc1ac2acd58c8a5a858679956b6d102ac5ee4011 → 0.0.0-next.504076d2165a82f124620a3f1f3e3a6017e97f3f

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 (809) 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 +195 -214
  5. package/dist/Strapi.js.map +1 -1
  6. package/dist/Strapi.mjs +165 -204
  7. package/dist/Strapi.mjs.map +1 -1
  8. package/dist/configuration/config-loader.d.ts.map +1 -1
  9. package/dist/configuration/config-loader.js +9 -5
  10. package/dist/configuration/config-loader.js.map +1 -1
  11. package/dist/configuration/config-loader.mjs +9 -5
  12. package/dist/configuration/config-loader.mjs.map +1 -1
  13. package/dist/configuration/get-dirs.d.ts +10 -0
  14. package/dist/configuration/get-dirs.d.ts.map +1 -0
  15. package/dist/{utils → configuration}/get-dirs.js +3 -2
  16. package/dist/configuration/get-dirs.js.map +1 -0
  17. package/dist/{utils → configuration}/get-dirs.mjs +3 -2
  18. package/dist/configuration/get-dirs.mjs.map +1 -0
  19. package/dist/configuration/index.d.ts +4 -7
  20. package/dist/configuration/index.d.ts.map +1 -1
  21. package/dist/configuration/index.js +8 -6
  22. package/dist/configuration/index.js.map +1 -1
  23. package/dist/configuration/index.mjs +5 -4
  24. package/dist/configuration/index.mjs.map +1 -1
  25. package/dist/container.d.ts +2 -2
  26. package/dist/container.d.ts.map +1 -1
  27. package/dist/container.js.map +1 -1
  28. package/dist/container.mjs.map +1 -1
  29. package/dist/core-api/controller/collection-type.d.ts +3 -3
  30. package/dist/core-api/controller/collection-type.d.ts.map +1 -1
  31. package/dist/core-api/controller/collection-type.js +6 -3
  32. package/dist/core-api/controller/collection-type.js.map +1 -1
  33. package/dist/core-api/controller/collection-type.mjs +3 -0
  34. package/dist/core-api/controller/collection-type.mjs.map +1 -1
  35. package/dist/core-api/controller/index.d.ts +3 -3
  36. package/dist/core-api/controller/index.d.ts.map +1 -1
  37. package/dist/core-api/controller/index.js +7 -7
  38. package/dist/core-api/controller/index.js.map +1 -1
  39. package/dist/core-api/controller/index.mjs +6 -6
  40. package/dist/core-api/controller/index.mjs.map +1 -1
  41. package/dist/core-api/controller/single-type.d.ts +3 -3
  42. package/dist/core-api/controller/single-type.d.ts.map +1 -1
  43. package/dist/core-api/controller/single-type.js +3 -2
  44. package/dist/core-api/controller/single-type.js.map +1 -1
  45. package/dist/core-api/controller/single-type.mjs +1 -0
  46. package/dist/core-api/controller/single-type.mjs.map +1 -1
  47. package/dist/core-api/controller/transform.d.ts +2 -2
  48. package/dist/core-api/controller/transform.d.ts.map +1 -1
  49. package/dist/core-api/controller/transform.js +10 -13
  50. package/dist/core-api/controller/transform.js.map +1 -1
  51. package/dist/core-api/controller/transform.mjs +2 -5
  52. package/dist/core-api/controller/transform.mjs.map +1 -1
  53. package/dist/core-api/routes/index.d.ts.map +1 -1
  54. package/dist/core-api/service/collection-type.d.ts +11 -17
  55. package/dist/core-api/service/collection-type.d.ts.map +1 -1
  56. package/dist/core-api/service/collection-type.js +18 -7
  57. package/dist/core-api/service/collection-type.js.map +1 -1
  58. package/dist/core-api/service/collection-type.mjs +19 -8
  59. package/dist/core-api/service/collection-type.mjs.map +1 -1
  60. package/dist/core-api/service/index.d.ts +3 -3
  61. package/dist/core-api/service/index.d.ts.map +1 -1
  62. package/dist/core-api/service/index.js.map +1 -1
  63. package/dist/core-api/service/index.mjs.map +1 -1
  64. package/dist/core-api/service/pagination.d.ts +4 -11
  65. package/dist/core-api/service/pagination.d.ts.map +1 -1
  66. package/dist/core-api/service/pagination.js +18 -44
  67. package/dist/core-api/service/pagination.js.map +1 -1
  68. package/dist/core-api/service/pagination.mjs +16 -42
  69. package/dist/core-api/service/pagination.mjs.map +1 -1
  70. package/dist/core-api/service/single-type.d.ts +4 -4
  71. package/dist/core-api/service/single-type.d.ts.map +1 -1
  72. package/dist/core-api/service/single-type.js +9 -2
  73. package/dist/core-api/service/single-type.js.map +1 -1
  74. package/dist/core-api/service/single-type.mjs +9 -2
  75. package/dist/core-api/service/single-type.mjs.map +1 -1
  76. package/dist/domain/content-type/index.d.ts +1 -1
  77. package/dist/domain/content-type/index.d.ts.map +1 -1
  78. package/dist/domain/content-type/index.js +4 -4
  79. package/dist/domain/content-type/index.js.map +1 -1
  80. package/dist/domain/module/index.d.ts +24 -23
  81. package/dist/domain/module/index.d.ts.map +1 -1
  82. package/dist/domain/module/index.js +2 -1
  83. package/dist/domain/module/index.js.map +1 -1
  84. package/dist/domain/module/index.mjs +3 -2
  85. package/dist/domain/module/index.mjs.map +1 -1
  86. package/dist/ee/index.d.ts +4 -2
  87. package/dist/ee/index.d.ts.map +1 -1
  88. package/dist/ee/index.js +3 -3
  89. package/dist/ee/index.js.map +1 -1
  90. package/dist/ee/index.mjs.map +1 -1
  91. package/dist/ee/license.d.ts +2 -2
  92. package/dist/ee/license.d.ts.map +1 -1
  93. package/dist/ee/license.js +2 -1
  94. package/dist/ee/license.js.map +1 -1
  95. package/dist/ee/license.mjs +2 -1
  96. package/dist/ee/license.mjs.map +1 -1
  97. package/dist/factories.d.ts +10 -10
  98. package/dist/factories.d.ts.map +1 -1
  99. package/dist/factories.js +10 -6
  100. package/dist/factories.js.map +1 -1
  101. package/dist/factories.mjs +6 -2
  102. package/dist/factories.mjs.map +1 -1
  103. package/dist/index.d.ts +18 -2
  104. package/dist/index.d.ts.map +1 -1
  105. package/dist/index.js +25 -1
  106. package/dist/index.js.map +1 -1
  107. package/dist/index.mjs +27 -3
  108. package/dist/index.mjs.map +1 -1
  109. package/dist/loaders/admin.d.ts +2 -2
  110. package/dist/loaders/admin.d.ts.map +1 -1
  111. package/dist/loaders/admin.js +0 -1
  112. package/dist/loaders/admin.js.map +1 -1
  113. package/dist/loaders/admin.mjs +0 -1
  114. package/dist/loaders/admin.mjs.map +1 -1
  115. package/dist/loaders/apis.d.ts +2 -2
  116. package/dist/loaders/apis.d.ts.map +1 -1
  117. package/dist/loaders/apis.js +12 -12
  118. package/dist/loaders/apis.js.map +1 -1
  119. package/dist/loaders/apis.mjs +10 -10
  120. package/dist/loaders/apis.mjs.map +1 -1
  121. package/dist/loaders/components.d.ts +2 -2
  122. package/dist/loaders/components.d.ts.map +1 -1
  123. package/dist/loaders/components.js.map +1 -1
  124. package/dist/loaders/components.mjs.map +1 -1
  125. package/dist/loaders/index.d.ts +2 -2
  126. package/dist/loaders/index.d.ts.map +1 -1
  127. package/dist/loaders/index.js +0 -2
  128. package/dist/loaders/index.js.map +1 -1
  129. package/dist/loaders/index.mjs +0 -2
  130. package/dist/loaders/index.mjs.map +1 -1
  131. package/dist/loaders/middlewares.d.ts +2 -2
  132. package/dist/loaders/middlewares.d.ts.map +1 -1
  133. package/dist/loaders/middlewares.js.map +1 -1
  134. package/dist/loaders/middlewares.mjs.map +1 -1
  135. package/dist/loaders/plugins/get-enabled-plugins.d.ts +2 -2
  136. package/dist/loaders/plugins/get-enabled-plugins.d.ts.map +1 -1
  137. package/dist/loaders/plugins/get-enabled-plugins.js +46 -16
  138. package/dist/loaders/plugins/get-enabled-plugins.js.map +1 -1
  139. package/dist/loaders/plugins/get-enabled-plugins.mjs +16 -8
  140. package/dist/loaders/plugins/get-enabled-plugins.mjs.map +1 -1
  141. package/dist/loaders/plugins/get-user-plugins-config.js +2 -2
  142. package/dist/loaders/plugins/get-user-plugins-config.js.map +1 -1
  143. package/dist/loaders/plugins/index.d.ts +2 -2
  144. package/dist/loaders/plugins/index.d.ts.map +1 -1
  145. package/dist/loaders/plugins/index.js +34 -7
  146. package/dist/loaders/plugins/index.js.map +1 -1
  147. package/dist/loaders/plugins/index.mjs +9 -1
  148. package/dist/loaders/plugins/index.mjs.map +1 -1
  149. package/dist/loaders/policies.d.ts +2 -2
  150. package/dist/loaders/policies.d.ts.map +1 -1
  151. package/dist/loaders/policies.js.map +1 -1
  152. package/dist/loaders/policies.mjs.map +1 -1
  153. package/dist/loaders/sanitizers.d.ts +2 -2
  154. package/dist/loaders/sanitizers.d.ts.map +1 -1
  155. package/dist/loaders/sanitizers.js.map +1 -1
  156. package/dist/loaders/sanitizers.mjs.map +1 -1
  157. package/dist/loaders/src-index.d.ts +2 -2
  158. package/dist/loaders/src-index.d.ts.map +1 -1
  159. package/dist/loaders/src-index.js.map +1 -1
  160. package/dist/loaders/src-index.mjs.map +1 -1
  161. package/dist/loaders/validators.d.ts +2 -2
  162. package/dist/loaders/validators.d.ts.map +1 -1
  163. package/dist/loaders/validators.js.map +1 -1
  164. package/dist/loaders/validators.mjs.map +1 -1
  165. package/dist/middlewares/body.d.ts +4 -4
  166. package/dist/middlewares/body.d.ts.map +1 -1
  167. package/dist/middlewares/body.js +6 -6
  168. package/dist/middlewares/body.js.map +1 -1
  169. package/dist/middlewares/body.mjs +4 -4
  170. package/dist/middlewares/body.mjs.map +1 -1
  171. package/dist/middlewares/compression.d.ts +2 -2
  172. package/dist/middlewares/compression.d.ts.map +1 -1
  173. package/dist/middlewares/compression.js.map +1 -1
  174. package/dist/middlewares/compression.mjs.map +1 -1
  175. package/dist/middlewares/cors.d.ts +2 -2
  176. package/dist/middlewares/cors.d.ts.map +1 -1
  177. package/dist/middlewares/cors.js +9 -7
  178. package/dist/middlewares/cors.js.map +1 -1
  179. package/dist/middlewares/cors.mjs +9 -7
  180. package/dist/middlewares/cors.mjs.map +1 -1
  181. package/dist/middlewares/errors.d.ts +2 -2
  182. package/dist/middlewares/errors.d.ts.map +1 -1
  183. package/dist/middlewares/errors.js.map +1 -1
  184. package/dist/middlewares/errors.mjs.map +1 -1
  185. package/dist/middlewares/favicon.d.ts +2 -2
  186. package/dist/middlewares/favicon.d.ts.map +1 -1
  187. package/dist/middlewares/favicon.js.map +1 -1
  188. package/dist/middlewares/favicon.mjs.map +1 -1
  189. package/dist/middlewares/index.d.ts +2 -2
  190. package/dist/middlewares/index.d.ts.map +1 -1
  191. package/dist/middlewares/index.js.map +1 -1
  192. package/dist/middlewares/index.mjs.map +1 -1
  193. package/dist/middlewares/ip.d.ts +2 -2
  194. package/dist/middlewares/ip.d.ts.map +1 -1
  195. package/dist/middlewares/ip.js.map +1 -1
  196. package/dist/middlewares/ip.mjs.map +1 -1
  197. package/dist/middlewares/logger.d.ts +2 -2
  198. package/dist/middlewares/logger.d.ts.map +1 -1
  199. package/dist/middlewares/logger.js.map +1 -1
  200. package/dist/middlewares/logger.mjs.map +1 -1
  201. package/dist/middlewares/powered-by.d.ts +2 -2
  202. package/dist/middlewares/powered-by.d.ts.map +1 -1
  203. package/dist/middlewares/powered-by.js.map +1 -1
  204. package/dist/middlewares/powered-by.mjs.map +1 -1
  205. package/dist/middlewares/public.d.ts +2 -2
  206. package/dist/middlewares/public.d.ts.map +1 -1
  207. package/dist/middlewares/public.js +3 -3
  208. package/dist/middlewares/public.js.map +1 -1
  209. package/dist/middlewares/public.mjs +1 -1
  210. package/dist/middlewares/public.mjs.map +1 -1
  211. package/dist/middlewares/query.d.ts +2 -2
  212. package/dist/middlewares/query.d.ts.map +1 -1
  213. package/dist/middlewares/query.js.map +1 -1
  214. package/dist/middlewares/query.mjs.map +1 -1
  215. package/dist/middlewares/response-time.d.ts +2 -2
  216. package/dist/middlewares/response-time.d.ts.map +1 -1
  217. package/dist/middlewares/response-time.js.map +1 -1
  218. package/dist/middlewares/response-time.mjs.map +1 -1
  219. package/dist/middlewares/responses.d.ts +3 -3
  220. package/dist/middlewares/responses.d.ts.map +1 -1
  221. package/dist/middlewares/responses.js +2 -2
  222. package/dist/middlewares/responses.js.map +1 -1
  223. package/dist/middlewares/responses.mjs.map +1 -1
  224. package/dist/middlewares/security.d.ts +2 -2
  225. package/dist/middlewares/security.d.ts.map +1 -1
  226. package/dist/middlewares/security.js +13 -6
  227. package/dist/middlewares/security.js.map +1 -1
  228. package/dist/middlewares/security.mjs +12 -5
  229. package/dist/middlewares/security.mjs.map +1 -1
  230. package/dist/middlewares/session.d.ts +2 -2
  231. package/dist/middlewares/session.d.ts.map +1 -1
  232. package/dist/middlewares/session.js +2 -2
  233. package/dist/middlewares/session.js.map +1 -1
  234. package/dist/middlewares/session.mjs.map +1 -1
  235. package/dist/migrations/database/5.0.0-discard-drafts.d.ts +33 -0
  236. package/dist/migrations/database/5.0.0-discard-drafts.d.ts.map +1 -0
  237. package/dist/migrations/database/5.0.0-discard-drafts.js +94 -0
  238. package/dist/migrations/database/5.0.0-discard-drafts.js.map +1 -0
  239. package/dist/migrations/database/5.0.0-discard-drafts.mjs +94 -0
  240. package/dist/migrations/database/5.0.0-discard-drafts.mjs.map +1 -0
  241. package/dist/migrations/draft-publish.d.ts +1 -1
  242. package/dist/migrations/draft-publish.d.ts.map +1 -1
  243. package/dist/migrations/draft-publish.js +14 -31
  244. package/dist/migrations/draft-publish.js.map +1 -1
  245. package/dist/migrations/draft-publish.mjs +15 -32
  246. package/dist/migrations/draft-publish.mjs.map +1 -1
  247. package/dist/migrations/i18n.d.ts +5 -0
  248. package/dist/migrations/i18n.d.ts.map +1 -0
  249. package/dist/migrations/i18n.js +54 -0
  250. package/dist/migrations/i18n.js.map +1 -0
  251. package/dist/migrations/i18n.mjs +54 -0
  252. package/dist/migrations/i18n.mjs.map +1 -0
  253. package/dist/migrations/index.d.ts +5 -0
  254. package/dist/migrations/index.d.ts.map +1 -0
  255. package/dist/migrations/index.js +15 -0
  256. package/dist/migrations/index.js.map +1 -0
  257. package/dist/migrations/index.mjs +15 -0
  258. package/dist/migrations/index.mjs.map +1 -0
  259. package/dist/providers/admin.d.ts +3 -0
  260. package/dist/providers/admin.d.ts.map +1 -0
  261. package/dist/providers/admin.js +20 -0
  262. package/dist/providers/admin.js.map +1 -0
  263. package/dist/providers/admin.mjs +21 -0
  264. package/dist/providers/admin.mjs.map +1 -0
  265. package/dist/providers/coreStore.d.ts +3 -0
  266. package/dist/providers/coreStore.d.ts.map +1 -0
  267. package/dist/providers/coreStore.js +11 -0
  268. package/dist/providers/coreStore.js.map +1 -0
  269. package/dist/providers/coreStore.mjs +12 -0
  270. package/dist/providers/coreStore.mjs.map +1 -0
  271. package/dist/providers/cron.d.ts +3 -0
  272. package/dist/providers/cron.d.ts.map +1 -0
  273. package/dist/providers/cron.js +20 -0
  274. package/dist/providers/cron.js.map +1 -0
  275. package/dist/providers/cron.mjs +21 -0
  276. package/dist/providers/cron.mjs.map +1 -0
  277. package/dist/providers/index.d.ts +3 -0
  278. package/dist/providers/index.d.ts.map +1 -0
  279. package/dist/providers/index.js +11 -0
  280. package/dist/providers/index.js.map +1 -0
  281. package/dist/providers/index.mjs +11 -0
  282. package/dist/providers/index.mjs.map +1 -0
  283. package/dist/providers/provider.d.ts +9 -0
  284. package/dist/providers/provider.d.ts.map +1 -0
  285. package/dist/providers/provider.js +5 -0
  286. package/dist/providers/provider.js.map +1 -0
  287. package/dist/providers/provider.mjs +5 -0
  288. package/dist/providers/provider.mjs.map +1 -0
  289. package/dist/providers/registries.d.ts +3 -0
  290. package/dist/providers/registries.d.ts.map +1 -0
  291. package/dist/providers/registries.js +35 -0
  292. package/dist/providers/registries.js.map +1 -0
  293. package/dist/providers/registries.mjs +36 -0
  294. package/dist/providers/registries.mjs.map +1 -0
  295. package/dist/providers/telemetry.d.ts +3 -0
  296. package/dist/providers/telemetry.d.ts.map +1 -0
  297. package/dist/providers/telemetry.js +19 -0
  298. package/dist/providers/telemetry.js.map +1 -0
  299. package/dist/providers/telemetry.mjs +20 -0
  300. package/dist/providers/telemetry.mjs.map +1 -0
  301. package/dist/providers/webhooks.d.ts +3 -0
  302. package/dist/providers/webhooks.d.ts.map +1 -0
  303. package/dist/providers/webhooks.js +30 -0
  304. package/dist/providers/webhooks.js.map +1 -0
  305. package/dist/providers/webhooks.mjs +31 -0
  306. package/dist/providers/webhooks.mjs.map +1 -0
  307. package/dist/registries/apis.d.ts +2 -2
  308. package/dist/registries/apis.d.ts.map +1 -1
  309. package/dist/registries/apis.js +2 -2
  310. package/dist/registries/apis.js.map +1 -1
  311. package/dist/registries/apis.mjs.map +1 -1
  312. package/dist/registries/components.d.ts +6 -6
  313. package/dist/registries/components.d.ts.map +1 -1
  314. package/dist/registries/components.js +2 -2
  315. package/dist/registries/components.js.map +1 -1
  316. package/dist/registries/components.mjs.map +1 -1
  317. package/dist/registries/content-types.d.ts +5 -5
  318. package/dist/registries/content-types.d.ts.map +1 -1
  319. package/dist/registries/content-types.js +3 -3
  320. package/dist/registries/content-types.js.map +1 -1
  321. package/dist/registries/content-types.mjs.map +1 -1
  322. package/dist/registries/controllers.d.ts +10 -10
  323. package/dist/registries/controllers.d.ts.map +1 -1
  324. package/dist/registries/controllers.js +3 -3
  325. package/dist/registries/controllers.js.map +1 -1
  326. package/dist/registries/controllers.mjs.map +1 -1
  327. package/dist/registries/custom-fields.d.ts +3 -3
  328. package/dist/registries/custom-fields.d.ts.map +1 -1
  329. package/dist/registries/custom-fields.js +4 -4
  330. package/dist/registries/custom-fields.js.map +1 -1
  331. package/dist/registries/custom-fields.mjs.map +1 -1
  332. package/dist/registries/hooks.js +2 -2
  333. package/dist/registries/hooks.js.map +1 -1
  334. package/dist/registries/index.d.ts +0 -1
  335. package/dist/registries/index.d.ts.map +1 -1
  336. package/dist/registries/middlewares.d.ts +6 -6
  337. package/dist/registries/middlewares.d.ts.map +1 -1
  338. package/dist/registries/middlewares.js +3 -3
  339. package/dist/registries/middlewares.js.map +1 -1
  340. package/dist/registries/middlewares.mjs.map +1 -1
  341. package/dist/registries/modules.d.ts +2 -2
  342. package/dist/registries/modules.d.ts.map +1 -1
  343. package/dist/registries/modules.js +3 -3
  344. package/dist/registries/modules.js.map +1 -1
  345. package/dist/registries/modules.mjs.map +1 -1
  346. package/dist/registries/plugins.d.ts +5 -5
  347. package/dist/registries/plugins.d.ts.map +1 -1
  348. package/dist/registries/plugins.js +2 -2
  349. package/dist/registries/plugins.js.map +1 -1
  350. package/dist/registries/plugins.mjs.map +1 -1
  351. package/dist/registries/policies.d.ts +22 -10
  352. package/dist/registries/policies.d.ts.map +1 -1
  353. package/dist/registries/policies.js +66 -20
  354. package/dist/registries/policies.js.map +1 -1
  355. package/dist/registries/policies.mjs +65 -19
  356. package/dist/registries/policies.mjs.map +1 -1
  357. package/dist/registries/services.d.ts +8 -8
  358. package/dist/registries/services.d.ts.map +1 -1
  359. package/dist/registries/services.js +3 -3
  360. package/dist/registries/services.js.map +1 -1
  361. package/dist/registries/services.mjs.map +1 -1
  362. package/dist/services/auth/index.d.ts +4 -4
  363. package/dist/services/auth/index.d.ts.map +1 -1
  364. package/dist/services/auth/index.js +3 -3
  365. package/dist/services/auth/index.js.map +1 -1
  366. package/dist/services/auth/index.mjs.map +1 -1
  367. package/dist/services/config.d.ts +3 -0
  368. package/dist/services/config.d.ts.map +1 -0
  369. package/dist/services/config.js +47 -0
  370. package/dist/services/config.js.map +1 -0
  371. package/dist/services/config.mjs +47 -0
  372. package/dist/services/config.mjs.map +1 -0
  373. package/dist/services/content-api/index.d.ts +31 -15
  374. package/dist/services/content-api/index.d.ts.map +1 -1
  375. package/dist/services/content-api/index.js +28 -2
  376. package/dist/services/content-api/index.js.map +1 -1
  377. package/dist/services/content-api/index.mjs +28 -2
  378. package/dist/services/content-api/index.mjs.map +1 -1
  379. package/dist/services/content-api/permissions/index.d.ts +13 -15
  380. package/dist/services/content-api/permissions/index.d.ts.map +1 -1
  381. package/dist/services/content-api/permissions/index.js +1 -1
  382. package/dist/services/content-api/permissions/index.js.map +1 -1
  383. package/dist/services/content-api/permissions/index.mjs +1 -1
  384. package/dist/services/content-api/permissions/index.mjs.map +1 -1
  385. package/dist/services/content-api/permissions/providers/action.d.ts +5 -6
  386. package/dist/services/content-api/permissions/providers/action.d.ts.map +1 -1
  387. package/dist/services/content-api/permissions/providers/condition.d.ts +5 -6
  388. package/dist/services/content-api/permissions/providers/condition.d.ts.map +1 -1
  389. package/dist/services/core-store.d.ts.map +1 -1
  390. package/dist/services/core-store.js +3 -3
  391. package/dist/services/core-store.js.map +1 -1
  392. package/dist/services/cron.d.ts +5 -5
  393. package/dist/services/cron.d.ts.map +1 -1
  394. package/dist/services/cron.js +3 -3
  395. package/dist/services/cron.js.map +1 -1
  396. package/dist/services/cron.mjs.map +1 -1
  397. package/dist/services/custom-fields.d.ts +2 -2
  398. package/dist/services/custom-fields.d.ts.map +1 -1
  399. package/dist/services/custom-fields.js.map +1 -1
  400. package/dist/services/custom-fields.mjs.map +1 -1
  401. package/dist/services/document-service/attributes/index.d.ts +6 -0
  402. package/dist/services/document-service/attributes/index.d.ts.map +1 -0
  403. package/dist/services/{entity-service → document-service}/attributes/index.js +5 -5
  404. package/dist/services/document-service/attributes/index.js.map +1 -0
  405. package/dist/services/{entity-service → document-service}/attributes/index.mjs +5 -5
  406. package/dist/services/document-service/attributes/index.mjs.map +1 -0
  407. package/dist/services/document-service/attributes/transforms.d.ts +10 -0
  408. package/dist/services/document-service/attributes/transforms.d.ts.map +1 -0
  409. package/dist/services/{entity-service → document-service}/attributes/transforms.js +3 -3
  410. package/dist/services/document-service/attributes/transforms.js.map +1 -0
  411. package/dist/services/document-service/attributes/transforms.mjs.map +1 -0
  412. package/dist/services/document-service/common.d.ts +2 -2
  413. package/dist/services/document-service/common.d.ts.map +1 -1
  414. package/dist/services/document-service/common.js.map +1 -1
  415. package/dist/services/document-service/common.mjs.map +1 -1
  416. package/dist/services/document-service/components.d.ts +25 -1
  417. package/dist/services/document-service/components.d.ts.map +1 -1
  418. package/dist/services/{entity-service → document-service}/components.js +52 -148
  419. package/dist/services/document-service/components.js.map +1 -0
  420. package/dist/services/{entity-service → document-service}/components.mjs +42 -138
  421. package/dist/services/document-service/components.mjs.map +1 -0
  422. package/dist/services/document-service/draft-and-publish.d.ts +7 -7
  423. package/dist/services/document-service/draft-and-publish.d.ts.map +1 -1
  424. package/dist/services/document-service/draft-and-publish.js +16 -16
  425. package/dist/services/document-service/draft-and-publish.js.map +1 -1
  426. package/dist/services/document-service/draft-and-publish.mjs.map +1 -1
  427. package/dist/services/document-service/entries.d.ts +10 -0
  428. package/dist/services/document-service/entries.d.ts.map +1 -0
  429. package/dist/services/document-service/entries.js +96 -0
  430. package/dist/services/document-service/entries.js.map +1 -0
  431. package/dist/services/document-service/entries.mjs +96 -0
  432. package/dist/services/document-service/entries.mjs.map +1 -0
  433. package/dist/services/document-service/events.d.ts +25 -0
  434. package/dist/services/document-service/events.d.ts.map +1 -0
  435. package/dist/services/document-service/events.js +47 -0
  436. package/dist/services/document-service/events.js.map +1 -0
  437. package/dist/services/document-service/events.mjs +47 -0
  438. package/dist/services/document-service/events.mjs.map +1 -0
  439. package/dist/services/document-service/index.d.ts +2 -4
  440. package/dist/services/document-service/index.d.ts.map +1 -1
  441. package/dist/services/document-service/index.js +18 -5
  442. package/dist/services/document-service/index.js.map +1 -1
  443. package/dist/services/document-service/index.mjs +16 -3
  444. package/dist/services/document-service/index.mjs.map +1 -1
  445. package/dist/services/document-service/internationalization.d.ts +5 -5
  446. package/dist/services/document-service/internationalization.d.ts.map +1 -1
  447. package/dist/services/document-service/internationalization.js +21 -12
  448. package/dist/services/document-service/internationalization.js.map +1 -1
  449. package/dist/services/document-service/internationalization.mjs +14 -5
  450. package/dist/services/document-service/internationalization.mjs.map +1 -1
  451. package/dist/services/document-service/middlewares/errors.d.ts +6 -0
  452. package/dist/services/document-service/middlewares/errors.d.ts.map +1 -0
  453. package/dist/services/document-service/middlewares/errors.js +25 -0
  454. package/dist/services/document-service/middlewares/errors.js.map +1 -0
  455. package/dist/services/document-service/middlewares/errors.mjs +25 -0
  456. package/dist/services/document-service/middlewares/errors.mjs.map +1 -0
  457. package/dist/services/document-service/middlewares/index.d.ts +3 -0
  458. package/dist/services/document-service/middlewares/index.d.ts.map +1 -0
  459. package/dist/services/document-service/middlewares/middleware-manager.d.ts +10 -0
  460. package/dist/services/document-service/middlewares/middleware-manager.d.ts.map +1 -0
  461. package/dist/services/document-service/{middlewares.js → middlewares/middleware-manager.js} +9 -6
  462. package/dist/services/document-service/middlewares/middleware-manager.js.map +1 -0
  463. package/dist/services/document-service/{middlewares.mjs → middlewares/middleware-manager.mjs} +9 -6
  464. package/dist/services/document-service/middlewares/middleware-manager.mjs.map +1 -0
  465. package/dist/services/document-service/params.d.ts +3 -1
  466. package/dist/services/document-service/params.d.ts.map +1 -1
  467. package/dist/services/{entity-service → document-service}/params.js +2 -2
  468. package/dist/services/document-service/params.js.map +1 -0
  469. package/dist/services/document-service/params.mjs.map +1 -0
  470. package/dist/services/document-service/repository.d.ts.map +1 -1
  471. package/dist/services/document-service/repository.js +195 -185
  472. package/dist/services/document-service/repository.js.map +1 -1
  473. package/dist/services/document-service/repository.mjs +175 -165
  474. package/dist/services/document-service/repository.mjs.map +1 -1
  475. package/dist/services/document-service/transform/data.d.ts.map +1 -1
  476. package/dist/services/document-service/transform/data.js +4 -2
  477. package/dist/services/document-service/transform/data.js.map +1 -1
  478. package/dist/services/document-service/transform/data.mjs +4 -2
  479. package/dist/services/document-service/transform/data.mjs.map +1 -1
  480. package/dist/services/document-service/transform/fields.d.ts +2 -2
  481. package/dist/services/document-service/transform/fields.d.ts.map +1 -1
  482. package/dist/services/document-service/transform/fields.js.map +1 -1
  483. package/dist/services/document-service/transform/fields.mjs.map +1 -1
  484. package/dist/services/document-service/transform/id-map.d.ts +3 -3
  485. package/dist/services/document-service/transform/id-map.d.ts.map +1 -1
  486. package/dist/services/document-service/transform/id-map.js.map +1 -1
  487. package/dist/services/document-service/transform/id-map.mjs.map +1 -1
  488. package/dist/services/document-service/transform/id-transform.d.ts +2 -2
  489. package/dist/services/document-service/transform/id-transform.d.ts.map +1 -1
  490. package/dist/services/document-service/transform/id-transform.js +2 -2
  491. package/dist/services/document-service/transform/id-transform.js.map +1 -1
  492. package/dist/services/document-service/transform/id-transform.mjs.map +1 -1
  493. package/dist/services/document-service/transform/populate.d.ts +2 -2
  494. package/dist/services/document-service/transform/populate.d.ts.map +1 -1
  495. package/dist/services/document-service/transform/populate.js +1 -1
  496. package/dist/services/document-service/transform/populate.js.map +1 -1
  497. package/dist/services/document-service/transform/populate.mjs +1 -1
  498. package/dist/services/document-service/transform/populate.mjs.map +1 -1
  499. package/dist/services/document-service/transform/query.d.ts +5 -0
  500. package/dist/services/document-service/transform/query.d.ts.map +1 -0
  501. package/dist/services/document-service/transform/query.js +9 -0
  502. package/dist/services/document-service/transform/query.js.map +1 -0
  503. package/dist/services/document-service/transform/query.mjs +9 -0
  504. package/dist/services/document-service/transform/query.mjs.map +1 -0
  505. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +8 -7
  506. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -1
  507. package/dist/services/document-service/transform/relations/extract/data-ids.js +45 -78
  508. package/dist/services/document-service/transform/relations/extract/data-ids.js.map +1 -1
  509. package/dist/services/document-service/transform/relations/extract/data-ids.mjs +44 -77
  510. package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +1 -1
  511. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts +8 -4
  512. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts.map +1 -1
  513. package/dist/services/document-service/transform/relations/transform/data-ids.js +61 -126
  514. package/dist/services/document-service/transform/relations/transform/data-ids.js.map +1 -1
  515. package/dist/services/document-service/transform/relations/transform/data-ids.mjs +61 -126
  516. package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +1 -1
  517. package/dist/services/document-service/transform/relations/transform/default-locale.d.ts +9 -0
  518. package/dist/services/document-service/transform/relations/transform/default-locale.d.ts.map +1 -0
  519. package/dist/services/document-service/transform/relations/transform/default-locale.js +32 -0
  520. package/dist/services/document-service/transform/relations/transform/default-locale.js.map +1 -0
  521. package/dist/services/document-service/transform/relations/transform/default-locale.mjs +32 -0
  522. package/dist/services/document-service/transform/relations/transform/default-locale.mjs.map +1 -0
  523. package/dist/services/document-service/transform/relations/utils/dp.d.ts +3 -3
  524. package/dist/services/document-service/transform/relations/utils/dp.d.ts.map +1 -1
  525. package/dist/services/document-service/transform/relations/utils/dp.js +10 -5
  526. package/dist/services/document-service/transform/relations/utils/dp.js.map +1 -1
  527. package/dist/services/document-service/transform/relations/utils/dp.mjs +9 -4
  528. package/dist/services/document-service/transform/relations/utils/dp.mjs.map +1 -1
  529. package/dist/services/document-service/transform/relations/utils/i18n.d.ts +6 -6
  530. package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -1
  531. package/dist/services/document-service/transform/relations/utils/i18n.js +3 -9
  532. package/dist/services/document-service/transform/relations/utils/i18n.js.map +1 -1
  533. package/dist/services/document-service/transform/relations/utils/i18n.mjs +3 -9
  534. package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +1 -1
  535. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts +6 -0
  536. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts.map +1 -0
  537. package/dist/services/document-service/transform/relations/utils/map-relation.js +91 -0
  538. package/dist/services/document-service/transform/relations/utils/map-relation.js.map +1 -0
  539. package/dist/services/document-service/transform/relations/utils/map-relation.mjs +91 -0
  540. package/dist/services/document-service/transform/relations/utils/map-relation.mjs.map +1 -0
  541. package/dist/services/document-service/transform/relations/utils/types.d.ts +6 -0
  542. package/dist/services/document-service/transform/relations/utils/types.d.ts.map +1 -1
  543. package/dist/services/document-service/transform/types.d.ts +3 -3
  544. package/dist/services/document-service/transform/types.d.ts.map +1 -1
  545. package/dist/services/document-service/utils/populate.d.ts +9 -2
  546. package/dist/services/document-service/utils/populate.d.ts.map +1 -1
  547. package/dist/services/document-service/utils/populate.js +11 -5
  548. package/dist/services/document-service/utils/populate.js.map +1 -1
  549. package/dist/services/document-service/utils/populate.mjs +11 -5
  550. package/dist/services/document-service/utils/populate.mjs.map +1 -1
  551. package/dist/services/document-service/utils/unidirectional-relations.d.ts +33 -0
  552. package/dist/services/document-service/utils/unidirectional-relations.d.ts.map +1 -0
  553. package/dist/services/document-service/utils/unidirectional-relations.js +58 -0
  554. package/dist/services/document-service/utils/unidirectional-relations.js.map +1 -0
  555. package/dist/services/document-service/utils/unidirectional-relations.mjs +58 -0
  556. package/dist/services/document-service/utils/unidirectional-relations.mjs.map +1 -0
  557. package/dist/services/entity-service/index.d.ts +4 -6
  558. package/dist/services/entity-service/index.d.ts.map +1 -1
  559. package/dist/services/entity-service/index.js +44 -203
  560. package/dist/services/entity-service/index.js.map +1 -1
  561. package/dist/services/entity-service/index.mjs +38 -197
  562. package/dist/services/entity-service/index.mjs.map +1 -1
  563. package/dist/services/entity-validator/blocks-validator.d.ts +1 -2
  564. package/dist/services/entity-validator/blocks-validator.d.ts.map +1 -1
  565. package/dist/services/entity-validator/blocks-validator.js +4 -3
  566. package/dist/services/entity-validator/blocks-validator.js.map +1 -1
  567. package/dist/services/entity-validator/blocks-validator.mjs +3 -3
  568. package/dist/services/entity-validator/blocks-validator.mjs.map +1 -1
  569. package/dist/services/entity-validator/index.d.ts +16 -2
  570. package/dist/services/entity-validator/index.d.ts.map +1 -1
  571. package/dist/services/entity-validator/index.js +197 -130
  572. package/dist/services/entity-validator/index.js.map +1 -1
  573. package/dist/services/entity-validator/index.mjs +192 -125
  574. package/dist/services/entity-validator/index.mjs.map +1 -1
  575. package/dist/services/entity-validator/validators.d.ts +36 -25
  576. package/dist/services/entity-validator/validators.d.ts.map +1 -1
  577. package/dist/services/entity-validator/validators.js +153 -33
  578. package/dist/services/entity-validator/validators.js.map +1 -1
  579. package/dist/services/entity-validator/validators.mjs +145 -25
  580. package/dist/services/entity-validator/validators.mjs.map +1 -1
  581. package/dist/services/event-hub.d.ts +1 -0
  582. package/dist/services/event-hub.d.ts.map +1 -1
  583. package/dist/services/event-hub.js +9 -4
  584. package/dist/services/event-hub.js.map +1 -1
  585. package/dist/services/event-hub.mjs +9 -4
  586. package/dist/services/event-hub.mjs.map +1 -1
  587. package/dist/services/features.d.ts +3 -3
  588. package/dist/services/features.d.ts.map +1 -1
  589. package/dist/services/features.js.map +1 -1
  590. package/dist/services/features.mjs.map +1 -1
  591. package/dist/services/fs.d.ts +2 -2
  592. package/dist/services/fs.d.ts.map +1 -1
  593. package/dist/services/fs.js.map +1 -1
  594. package/dist/services/fs.mjs.map +1 -1
  595. package/dist/services/metrics/admin-user-hash.d.ts +2 -2
  596. package/dist/services/metrics/admin-user-hash.d.ts.map +1 -1
  597. package/dist/services/metrics/admin-user-hash.js.map +1 -1
  598. package/dist/services/metrics/admin-user-hash.mjs.map +1 -1
  599. package/dist/services/metrics/index.d.ts +2 -2
  600. package/dist/services/metrics/index.d.ts.map +1 -1
  601. package/dist/services/metrics/index.js.map +1 -1
  602. package/dist/services/metrics/index.mjs.map +1 -1
  603. package/dist/services/metrics/middleware.d.ts +2 -2
  604. package/dist/services/metrics/middleware.d.ts.map +1 -1
  605. package/dist/services/metrics/middleware.js.map +1 -1
  606. package/dist/services/metrics/middleware.mjs.map +1 -1
  607. package/dist/services/metrics/rate-limiter.d.ts.map +1 -1
  608. package/dist/services/metrics/rate-limiter.js.map +1 -1
  609. package/dist/services/metrics/rate-limiter.mjs.map +1 -1
  610. package/dist/services/metrics/sender.d.ts +3 -3
  611. package/dist/services/metrics/sender.d.ts.map +1 -1
  612. package/dist/services/metrics/sender.js.map +1 -1
  613. package/dist/services/metrics/sender.mjs.map +1 -1
  614. package/dist/services/query-params.d.ts +7 -0
  615. package/dist/services/query-params.d.ts.map +1 -0
  616. package/dist/services/query-params.js +12 -0
  617. package/dist/services/query-params.js.map +1 -0
  618. package/dist/services/query-params.mjs +13 -0
  619. package/dist/services/query-params.mjs.map +1 -0
  620. package/dist/services/reloader.d.ts +7 -0
  621. package/dist/services/reloader.d.ts.map +1 -0
  622. package/dist/services/reloader.js +36 -0
  623. package/dist/services/reloader.js.map +1 -0
  624. package/dist/services/reloader.mjs +36 -0
  625. package/dist/services/reloader.mjs.map +1 -0
  626. package/dist/services/server/admin-api.d.ts +3 -3
  627. package/dist/services/server/admin-api.d.ts.map +1 -1
  628. package/dist/services/server/admin-api.js.map +1 -1
  629. package/dist/services/server/admin-api.mjs.map +1 -1
  630. package/dist/services/server/api.d.ts +3 -3
  631. package/dist/services/server/api.d.ts.map +1 -1
  632. package/dist/services/server/api.js.map +1 -1
  633. package/dist/services/server/api.mjs.map +1 -1
  634. package/dist/services/server/compose-endpoint.d.ts +2 -2
  635. package/dist/services/server/compose-endpoint.d.ts.map +1 -1
  636. package/dist/services/server/compose-endpoint.js +8 -9
  637. package/dist/services/server/compose-endpoint.js.map +1 -1
  638. package/dist/services/server/compose-endpoint.mjs +2 -3
  639. package/dist/services/server/compose-endpoint.mjs.map +1 -1
  640. package/dist/services/server/content-api.d.ts +3 -3
  641. package/dist/services/server/content-api.d.ts.map +1 -1
  642. package/dist/services/server/content-api.js.map +1 -1
  643. package/dist/services/server/content-api.mjs.map +1 -1
  644. package/dist/services/server/http-server.d.ts +2 -2
  645. package/dist/services/server/http-server.d.ts.map +1 -1
  646. package/dist/services/server/http-server.js.map +1 -1
  647. package/dist/services/server/http-server.mjs.map +1 -1
  648. package/dist/services/server/index.d.ts +2 -2
  649. package/dist/services/server/index.d.ts.map +1 -1
  650. package/dist/services/server/index.js +2 -3
  651. package/dist/services/server/index.js.map +1 -1
  652. package/dist/services/server/index.mjs +2 -3
  653. package/dist/services/server/index.mjs.map +1 -1
  654. package/dist/services/server/koa.d.ts.map +1 -1
  655. package/dist/services/server/koa.js +4 -4
  656. package/dist/services/server/koa.js.map +1 -1
  657. package/dist/services/server/koa.mjs +1 -1
  658. package/dist/services/server/koa.mjs.map +1 -1
  659. package/dist/services/server/middleware.d.ts +4 -4
  660. package/dist/services/server/middleware.d.ts.map +1 -1
  661. package/dist/services/server/middleware.js +3 -3
  662. package/dist/services/server/middleware.js.map +1 -1
  663. package/dist/services/server/middleware.mjs.map +1 -1
  664. package/dist/services/server/policy.d.ts +3 -3
  665. package/dist/services/server/policy.d.ts.map +1 -1
  666. package/dist/services/server/policy.js +4 -4
  667. package/dist/services/server/policy.js.map +1 -1
  668. package/dist/services/server/policy.mjs +4 -4
  669. package/dist/services/server/policy.mjs.map +1 -1
  670. package/dist/services/server/register-middlewares.d.ts +2 -2
  671. package/dist/services/server/register-middlewares.d.ts.map +1 -1
  672. package/dist/services/server/register-middlewares.js.map +1 -1
  673. package/dist/services/server/register-middlewares.mjs.map +1 -1
  674. package/dist/services/server/register-routes.d.ts +2 -2
  675. package/dist/services/server/register-routes.d.ts.map +1 -1
  676. package/dist/services/server/register-routes.js +3 -3
  677. package/dist/services/server/register-routes.js.map +1 -1
  678. package/dist/services/server/register-routes.mjs +3 -3
  679. package/dist/services/server/register-routes.mjs.map +1 -1
  680. package/dist/services/server/routing.d.ts +5 -5
  681. package/dist/services/server/routing.d.ts.map +1 -1
  682. package/dist/services/server/routing.js +2 -2
  683. package/dist/services/server/routing.js.map +1 -1
  684. package/dist/services/server/routing.mjs.map +1 -1
  685. package/dist/services/utils/dynamic-zones.d.ts.map +1 -1
  686. package/dist/services/utils/dynamic-zones.js +7 -6
  687. package/dist/services/utils/dynamic-zones.js.map +1 -1
  688. package/dist/services/utils/dynamic-zones.mjs +2 -1
  689. package/dist/services/utils/dynamic-zones.mjs.map +1 -1
  690. package/dist/services/webhook-runner.d.ts +2 -1
  691. package/dist/services/webhook-runner.d.ts.map +1 -1
  692. package/dist/services/webhook-runner.js.map +1 -1
  693. package/dist/services/webhook-runner.mjs.map +1 -1
  694. package/dist/services/webhook-store.d.ts +2 -8
  695. package/dist/services/webhook-store.d.ts.map +1 -1
  696. package/dist/services/webhook-store.js +14 -8
  697. package/dist/services/webhook-store.js.map +1 -1
  698. package/dist/services/webhook-store.mjs +14 -8
  699. package/dist/services/webhook-store.mjs.map +1 -1
  700. package/dist/utils/convert-custom-field-type.d.ts +2 -2
  701. package/dist/utils/convert-custom-field-type.d.ts.map +1 -1
  702. package/dist/utils/convert-custom-field-type.js.map +1 -1
  703. package/dist/utils/convert-custom-field-type.mjs.map +1 -1
  704. package/dist/utils/cron.js +3 -3
  705. package/dist/utils/cron.js.map +1 -1
  706. package/dist/utils/fetch.d.ts +3 -3
  707. package/dist/utils/fetch.d.ts.map +1 -1
  708. package/dist/utils/fetch.js +4 -3
  709. package/dist/utils/fetch.js.map +1 -1
  710. package/dist/utils/fetch.mjs +4 -3
  711. package/dist/utils/fetch.mjs.map +1 -1
  712. package/dist/utils/filepath-to-prop-path.d.ts +1 -1
  713. package/dist/utils/filepath-to-prop-path.d.ts.map +1 -1
  714. package/dist/utils/filepath-to-prop-path.js +27 -6
  715. package/dist/utils/filepath-to-prop-path.js.map +1 -1
  716. package/dist/utils/filepath-to-prop-path.mjs +25 -5
  717. package/dist/utils/filepath-to-prop-path.mjs.map +1 -1
  718. package/dist/utils/index.d.ts +2 -1
  719. package/dist/utils/index.d.ts.map +1 -1
  720. package/dist/utils/is-initialized.d.ts +2 -2
  721. package/dist/utils/is-initialized.d.ts.map +1 -1
  722. package/dist/utils/is-initialized.js +4 -4
  723. package/dist/utils/is-initialized.js.map +1 -1
  724. package/dist/utils/is-initialized.mjs +1 -1
  725. package/dist/utils/is-initialized.mjs.map +1 -1
  726. package/dist/utils/load-files.d.ts.map +1 -1
  727. package/dist/utils/open-browser.d.ts +2 -2
  728. package/dist/utils/open-browser.d.ts.map +1 -1
  729. package/dist/utils/open-browser.js.map +1 -1
  730. package/dist/utils/open-browser.mjs.map +1 -1
  731. package/dist/utils/resolve-working-dirs.d.ts +19 -0
  732. package/dist/utils/resolve-working-dirs.d.ts.map +1 -0
  733. package/dist/utils/resolve-working-dirs.js +13 -0
  734. package/dist/utils/resolve-working-dirs.js.map +1 -0
  735. package/dist/utils/resolve-working-dirs.mjs +11 -0
  736. package/dist/utils/resolve-working-dirs.mjs.map +1 -0
  737. package/dist/utils/signals.d.ts +2 -2
  738. package/dist/utils/signals.d.ts.map +1 -1
  739. package/dist/utils/signals.js.map +1 -1
  740. package/dist/utils/signals.mjs.map +1 -1
  741. package/dist/utils/startup-logger.d.ts +2 -2
  742. package/dist/utils/startup-logger.d.ts.map +1 -1
  743. package/dist/utils/startup-logger.js +4 -4
  744. package/dist/utils/startup-logger.js.map +1 -1
  745. package/dist/utils/startup-logger.mjs +3 -3
  746. package/dist/utils/startup-logger.mjs.map +1 -1
  747. package/dist/utils/transform-content-types-to-models.d.ts +54 -99
  748. package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
  749. package/dist/utils/transform-content-types-to-models.js +112 -61
  750. package/dist/utils/transform-content-types-to-models.js.map +1 -1
  751. package/dist/utils/transform-content-types-to-models.mjs +111 -60
  752. package/dist/utils/transform-content-types-to-models.mjs.map +1 -1
  753. package/dist/utils/update-notifier/index.d.ts +2 -7
  754. package/dist/utils/update-notifier/index.d.ts.map +1 -1
  755. package/dist/utils/update-notifier/index.js +11 -14
  756. package/dist/utils/update-notifier/index.js.map +1 -1
  757. package/dist/utils/update-notifier/index.mjs +11 -14
  758. package/dist/utils/update-notifier/index.mjs.map +1 -1
  759. package/package.json +34 -30
  760. package/dist/registries/config.d.ts +0 -4
  761. package/dist/registries/config.d.ts.map +0 -1
  762. package/dist/registries/config.js +0 -31
  763. package/dist/registries/config.js.map +0 -1
  764. package/dist/registries/config.mjs +0 -32
  765. package/dist/registries/config.mjs.map +0 -1
  766. package/dist/services/document-service/middlewares.d.ts +0 -8
  767. package/dist/services/document-service/middlewares.d.ts.map +0 -1
  768. package/dist/services/document-service/middlewares.js.map +0 -1
  769. package/dist/services/document-service/middlewares.mjs.map +0 -1
  770. package/dist/services/document-service/transform/filters.d.ts +0 -3
  771. package/dist/services/document-service/transform/filters.d.ts.map +0 -1
  772. package/dist/services/document-service/transform/relations/transform/output-ids.d.ts +0 -4
  773. package/dist/services/document-service/transform/relations/transform/output-ids.d.ts.map +0 -1
  774. package/dist/services/document-service/transform/relations/utils/data.js +0 -12
  775. package/dist/services/document-service/transform/relations/utils/data.js.map +0 -1
  776. package/dist/services/document-service/transform/relations/utils/data.mjs +0 -12
  777. package/dist/services/document-service/transform/relations/utils/data.mjs.map +0 -1
  778. package/dist/services/document-service/transform/sort.d.ts +0 -5
  779. package/dist/services/document-service/transform/sort.d.ts.map +0 -1
  780. package/dist/services/document-service/transform/utils.d.ts +0 -9
  781. package/dist/services/document-service/transform/utils.d.ts.map +0 -1
  782. package/dist/services/entity-service/attributes/index.d.ts +0 -6
  783. package/dist/services/entity-service/attributes/index.d.ts.map +0 -1
  784. package/dist/services/entity-service/attributes/index.js.map +0 -1
  785. package/dist/services/entity-service/attributes/index.mjs.map +0 -1
  786. package/dist/services/entity-service/attributes/transforms.d.ts +0 -10
  787. package/dist/services/entity-service/attributes/transforms.d.ts.map +0 -1
  788. package/dist/services/entity-service/attributes/transforms.js.map +0 -1
  789. package/dist/services/entity-service/attributes/transforms.mjs.map +0 -1
  790. package/dist/services/entity-service/components.d.ts +0 -23
  791. package/dist/services/entity-service/components.d.ts.map +0 -1
  792. package/dist/services/entity-service/components.js.map +0 -1
  793. package/dist/services/entity-service/components.mjs.map +0 -1
  794. package/dist/services/entity-service/params.d.ts +0 -8
  795. package/dist/services/entity-service/params.d.ts.map +0 -1
  796. package/dist/services/entity-service/params.js.map +0 -1
  797. package/dist/services/entity-service/params.mjs.map +0 -1
  798. package/dist/services/utils/upload-files.d.ts +0 -8
  799. package/dist/services/utils/upload-files.d.ts.map +0 -1
  800. package/dist/services/utils/upload-files.js +0 -64
  801. package/dist/services/utils/upload-files.js.map +0 -1
  802. package/dist/services/utils/upload-files.mjs +0 -63
  803. package/dist/services/utils/upload-files.mjs.map +0 -1
  804. package/dist/utils/get-dirs.d.ts +0 -9
  805. package/dist/utils/get-dirs.d.ts.map +0 -1
  806. package/dist/utils/get-dirs.js.map +0 -1
  807. package/dist/utils/get-dirs.mjs.map +0 -1
  808. /package/dist/services/{entity-service → document-service}/attributes/transforms.mjs +0 -0
  809. /package/dist/services/{entity-service → document-service}/params.mjs +0 -0
@@ -1,13 +1,19 @@
1
1
  import { contentTypes } from "@strapi/utils";
2
- const getDeepPopulate = (uid) => {
2
+ const { CREATED_BY_ATTRIBUTE, UPDATED_BY_ATTRIBUTE } = contentTypes.constants;
3
+ const getDeepPopulate = (uid, opts = {}) => {
3
4
  const model = strapi.getModel(uid);
4
5
  const attributes = Object.entries(model.attributes);
5
6
  return attributes.reduce((acc, [attributeName, attribute]) => {
6
7
  switch (attribute.type) {
7
8
  case "relation": {
9
+ const isMorphRelation = attribute.relation.toLowerCase().startsWith("morph");
10
+ if (isMorphRelation) {
11
+ break;
12
+ }
8
13
  const isVisible = contentTypes.isVisibleAttribute(model, attributeName);
9
- if (isVisible) {
10
- acc[attributeName] = { select: ["document_id", "locale"] };
14
+ const isCreatorField = [CREATED_BY_ATTRIBUTE, UPDATED_BY_ATTRIBUTE].includes(attributeName);
15
+ if (isVisible || isCreatorField) {
16
+ acc[attributeName] = { select: opts.relationalFields };
11
17
  }
12
18
  break;
13
19
  }
@@ -16,14 +22,14 @@ const getDeepPopulate = (uid) => {
16
22
  break;
17
23
  }
18
24
  case "component": {
19
- const populate = getDeepPopulate(attribute.component);
25
+ const populate = getDeepPopulate(attribute.component, opts);
20
26
  acc[attributeName] = { populate };
21
27
  break;
22
28
  }
23
29
  case "dynamiczone": {
24
30
  const populatedComponents = (attribute.components || []).reduce(
25
31
  (acc2, componentUID) => {
26
- acc2[componentUID] = { populate: getDeepPopulate(componentUID) };
32
+ acc2[componentUID] = { populate: getDeepPopulate(componentUID, opts) };
27
33
  return acc2;
28
34
  },
29
35
  {}
@@ -1 +1 @@
1
- {"version":3,"file":"populate.mjs","sources":["../../../../src/services/document-service/utils/populate.ts"],"sourcesContent":["import { Common } from '@strapi/types';\nimport { contentTypes } from '@strapi/utils';\n\n// We want to build a populate object based on the schema\nexport const getDeepPopulate = (uid: Common.UID.Schema) => {\n const model = strapi.getModel(uid);\n const attributes = Object.entries(model.attributes);\n\n return attributes.reduce((acc: any, [attributeName, attribute]) => {\n switch (attribute.type) {\n case 'relation': {\n // TODO: Should this just be a plain list?\n // Ignore createdBy, updatedBy, ...\n const isVisible = contentTypes.isVisibleAttribute(model, attributeName);\n if (isVisible) {\n acc[attributeName] = { select: ['document_id', 'locale'] };\n }\n break;\n }\n\n case 'media': {\n acc[attributeName] = { select: ['id'] };\n break;\n }\n\n case 'component': {\n const populate = getDeepPopulate(attribute.component);\n acc[attributeName] = { populate };\n break;\n }\n\n case 'dynamiczone': {\n // Use fragments to populate the dynamic zone components\n const populatedComponents = (attribute.components || []).reduce(\n (acc: any, componentUID: Common.UID.Component) => {\n acc[componentUID] = { populate: getDeepPopulate(componentUID) };\n return acc;\n },\n {}\n );\n\n acc[attributeName] = { on: populatedComponents };\n break;\n }\n default:\n break;\n }\n\n return acc;\n }, {});\n};\n"],"names":["acc"],"mappings":";AAIa,MAAA,kBAAkB,CAAC,QAA2B;AACnD,QAAA,QAAQ,OAAO,SAAS,GAAG;AACjC,QAAM,aAAa,OAAO,QAAQ,MAAM,UAAU;AAElD,SAAO,WAAW,OAAO,CAAC,KAAU,CAAC,eAAe,SAAS,MAAM;AACjE,YAAQ,UAAU,MAAM;AAAA,MACtB,KAAK,YAAY;AAGf,cAAM,YAAY,aAAa,mBAAmB,OAAO,aAAa;AACtE,YAAI,WAAW;AACb,cAAI,aAAa,IAAI,EAAE,QAAQ,CAAC,eAAe,QAAQ;QACzD;AACA;AAAA,MACF;AAAA,MAEA,KAAK,SAAS;AACZ,YAAI,aAAa,IAAI,EAAE,QAAQ,CAAC,IAAI,EAAE;AACtC;AAAA,MACF;AAAA,MAEA,KAAK,aAAa;AACV,cAAA,WAAW,gBAAgB,UAAU,SAAS;AAChD,YAAA,aAAa,IAAI,EAAE;AACvB;AAAA,MACF;AAAA,MAEA,KAAK,eAAe;AAElB,cAAM,uBAAuB,UAAU,cAAc,CAAI,GAAA;AAAA,UACvD,CAACA,MAAU,iBAAuC;AAChDA,iBAAI,YAAY,IAAI,EAAE,UAAU,gBAAgB,YAAY;AACrDA,mBAAAA;AAAAA,UACT;AAAA,UACA,CAAC;AAAA,QAAA;AAGH,YAAI,aAAa,IAAI,EAAE,IAAI,oBAAoB;AAC/C;AAAA,MACF;AAAA,IAGF;AAEO,WAAA;AAAA,EACT,GAAG,CAAE,CAAA;AACP;"}
1
+ {"version":3,"file":"populate.mjs","sources":["../../../../src/services/document-service/utils/populate.ts"],"sourcesContent":["import { UID } from '@strapi/types';\nimport { contentTypes } from '@strapi/utils';\n\ninterface Options {\n /**\n * Fields to select when populating relations\n */\n relationalFields?: string[];\n}\n\nconst { CREATED_BY_ATTRIBUTE, UPDATED_BY_ATTRIBUTE } = contentTypes.constants;\n\n// We want to build a populate object based on the schema\nexport const getDeepPopulate = (uid: UID.Schema, opts: Options = {}) => {\n const model = strapi.getModel(uid);\n const attributes = Object.entries(model.attributes);\n\n return attributes.reduce((acc: any, [attributeName, attribute]) => {\n switch (attribute.type) {\n case 'relation': {\n // TODO: Support polymorphic relations\n const isMorphRelation = attribute.relation.toLowerCase().startsWith('morph');\n if (isMorphRelation) {\n break;\n }\n\n // Ignore not visible fields other than createdBy and updatedBy\n const isVisible = contentTypes.isVisibleAttribute(model, attributeName);\n const isCreatorField = [CREATED_BY_ATTRIBUTE, UPDATED_BY_ATTRIBUTE].includes(attributeName);\n\n if (isVisible || isCreatorField) {\n acc[attributeName] = { select: opts.relationalFields };\n }\n\n break;\n }\n\n case 'media': {\n acc[attributeName] = { select: ['id'] };\n break;\n }\n\n case 'component': {\n const populate = getDeepPopulate(attribute.component, opts);\n acc[attributeName] = { populate };\n break;\n }\n\n case 'dynamiczone': {\n // Use fragments to populate the dynamic zone components\n const populatedComponents = (attribute.components || []).reduce(\n (acc: any, componentUID: UID.Component) => {\n acc[componentUID] = { populate: getDeepPopulate(componentUID, opts) };\n return acc;\n },\n {}\n );\n\n acc[attributeName] = { on: populatedComponents };\n break;\n }\n default:\n break;\n }\n\n return acc;\n }, {});\n};\n"],"names":["acc"],"mappings":";AAUA,MAAM,EAAE,sBAAsB,yBAAyB,aAAa;AAG7D,MAAM,kBAAkB,CAAC,KAAiB,OAAgB,OAAO;AAChE,QAAA,QAAQ,OAAO,SAAS,GAAG;AACjC,QAAM,aAAa,OAAO,QAAQ,MAAM,UAAU;AAElD,SAAO,WAAW,OAAO,CAAC,KAAU,CAAC,eAAe,SAAS,MAAM;AACjE,YAAQ,UAAU,MAAM;AAAA,MACtB,KAAK,YAAY;AAEf,cAAM,kBAAkB,UAAU,SAAS,YAAY,EAAE,WAAW,OAAO;AAC3E,YAAI,iBAAiB;AACnB;AAAA,QACF;AAGA,cAAM,YAAY,aAAa,mBAAmB,OAAO,aAAa;AACtE,cAAM,iBAAiB,CAAC,sBAAsB,oBAAoB,EAAE,SAAS,aAAa;AAE1F,YAAI,aAAa,gBAAgB;AAC/B,cAAI,aAAa,IAAI,EAAE,QAAQ,KAAK,iBAAiB;AAAA,QACvD;AAEA;AAAA,MACF;AAAA,MAEA,KAAK,SAAS;AACZ,YAAI,aAAa,IAAI,EAAE,QAAQ,CAAC,IAAI,EAAE;AACtC;AAAA,MACF;AAAA,MAEA,KAAK,aAAa;AAChB,cAAM,WAAW,gBAAgB,UAAU,WAAW,IAAI;AACtD,YAAA,aAAa,IAAI,EAAE;AACvB;AAAA,MACF;AAAA,MAEA,KAAK,eAAe;AAElB,cAAM,uBAAuB,UAAU,cAAc,CAAI,GAAA;AAAA,UACvD,CAACA,MAAU,iBAAgC;AACzCA,iBAAI,YAAY,IAAI,EAAE,UAAU,gBAAgB,cAAc,IAAI;AAC3DA,mBAAAA;AAAAA,UACT;AAAA,UACA,CAAC;AAAA,QAAA;AAGH,YAAI,aAAa,IAAI,EAAE,IAAI,oBAAoB;AAC/C;AAAA,MACF;AAAA,IAGF;AAEO,WAAA;AAAA,EACT,GAAG,CAAE,CAAA;AACP;"}
@@ -0,0 +1,33 @@
1
+ import { UID } from '@strapi/types';
2
+ /**
3
+ * Loads lingering relations that need to be updated when overriding a published or draft entry.
4
+ * This is necessary because the relations are uni-directional and the target entry is not aware of the source entry.
5
+ * This is not the case for bi-directional relations, where the target entry is also linked to the source entry.
6
+ *
7
+ * @param uid The content type uid
8
+ * @param oldEntries The old entries that are being overridden
9
+ * @returns An array of relations that need to be updated with the join table reference.
10
+ */
11
+ declare const load: (uid: UID.ContentType, oldEntries: {
12
+ id: string;
13
+ locale: string;
14
+ }[]) => Promise<any>;
15
+ /**
16
+ * Updates uni directional relations to target the right entries when overriding published or draft entries.
17
+ *
18
+ * @param oldEntries The old entries that are being overridden
19
+ * @param newEntries The new entries that are overriding the old ones
20
+ * @param oldRelations The relations that were previously loaded with `load` @see load
21
+ */
22
+ declare const sync: (oldEntries: {
23
+ id: string;
24
+ locale: string;
25
+ }[], newEntries: {
26
+ id: string;
27
+ locale: string;
28
+ }[], oldRelations: {
29
+ joinTable: any;
30
+ relations: any[];
31
+ }[]) => Promise<void>;
32
+ export { load, sync };
33
+ //# sourceMappingURL=unidirectional-relations.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"unidirectional-relations.d.ts","sourceRoot":"","sources":["../../../../src/services/document-service/utils/unidirectional-relations.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,GAAG,EAAU,MAAM,eAAe,CAAC;AAE5C;;;;;;;;GAQG;AACH,QAAA,MAAM,IAAI,QAAe,IAAI,WAAW,cAAc;IAAE,EAAE,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,EAAE,iBA2CrF,CAAC;AAEF;;;;;;GAMG;AACH,QAAA,MAAM,IAAI,eACI;IAAE,EAAE,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,EAAE,cAChC;IAAE,EAAE,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,EAAE,gBAC9B;IAAE,SAAS,EAAE,GAAG,CAAC;IAAC,SAAS,EAAE,GAAG,EAAE,CAAA;CAAE,EAAE,kBAkCrD,CAAC;AAEF,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC"}
@@ -0,0 +1,58 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const fp = require("lodash/fp");
4
+ const load = async (uid, oldEntries) => {
5
+ const updates = [];
6
+ await strapi.db.transaction(async ({ trx }) => {
7
+ const contentTypes = Object.values(strapi.contentTypes);
8
+ const components = Object.values(strapi.components);
9
+ for (const model of [...contentTypes, ...components]) {
10
+ const dbModel = strapi.db.metadata.get(model.uid);
11
+ for (const attribute of Object.values(dbModel.attributes)) {
12
+ if (attribute.type !== "relation")
13
+ continue;
14
+ if (attribute.target !== uid)
15
+ continue;
16
+ if (attribute.inversedBy || attribute.mappedBy)
17
+ continue;
18
+ const joinTable = attribute.joinTable;
19
+ if (!joinTable)
20
+ continue;
21
+ const { name } = joinTable.inverseJoinColumn;
22
+ const oldEntriesIds = oldEntries.map((entry) => entry.id);
23
+ const relations = await strapi.db.getConnection().select("*").from(joinTable.name).whereIn(name, oldEntriesIds).transacting(trx);
24
+ if (relations.length === 0)
25
+ continue;
26
+ updates.push({ joinTable, relations });
27
+ }
28
+ }
29
+ });
30
+ return updates;
31
+ };
32
+ const sync = async (oldEntries, newEntries, oldRelations) => {
33
+ const newEntryByLocale = fp.keyBy("locale", newEntries);
34
+ const oldEntriesMap = oldEntries.reduce(
35
+ (acc, entry) => {
36
+ const newEntry = newEntryByLocale[entry.locale];
37
+ if (!newEntry)
38
+ return acc;
39
+ acc[entry.id] = newEntry.id;
40
+ return acc;
41
+ },
42
+ {}
43
+ );
44
+ await strapi.db.transaction(async ({ trx }) => {
45
+ const con = strapi.db.getConnection();
46
+ for (const { joinTable, relations } of oldRelations) {
47
+ const newRelations = relations.map((relation) => {
48
+ const column = joinTable.inverseJoinColumn.name;
49
+ const newId = oldEntriesMap[relation[column]];
50
+ return { ...relation, [column]: newId };
51
+ });
52
+ await con.batchInsert(joinTable.name, newRelations).transacting(trx);
53
+ }
54
+ });
55
+ };
56
+ exports.load = load;
57
+ exports.sync = sync;
58
+ //# sourceMappingURL=unidirectional-relations.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"unidirectional-relations.js","sources":["../../../../src/services/document-service/utils/unidirectional-relations.ts"],"sourcesContent":["/* eslint-disable no-continue */\nimport { keyBy } from 'lodash/fp';\n\nimport { UID, Schema } from '@strapi/types';\n\n/**\n * Loads lingering relations that need to be updated when overriding a published or draft entry.\n * This is necessary because the relations are uni-directional and the target entry is not aware of the source entry.\n * This is not the case for bi-directional relations, where the target entry is also linked to the source entry.\n *\n * @param uid The content type uid\n * @param oldEntries The old entries that are being overridden\n * @returns An array of relations that need to be updated with the join table reference.\n */\nconst load = async (uid: UID.ContentType, oldEntries: { id: string; locale: string }[]) => {\n const updates = [] as any;\n\n // Iterate all components and content types to find relations that need to be updated\n await strapi.db.transaction(async ({ trx }) => {\n const contentTypes = Object.values(strapi.contentTypes) as Schema.ContentType[];\n const components = Object.values(strapi.components) as Schema.Component[];\n\n for (const model of [...contentTypes, ...components]) {\n const dbModel = strapi.db.metadata.get(model.uid);\n\n for (const attribute of Object.values(dbModel.attributes) as any) {\n /**\n * Only consider unidirectional relations\n */\n if (attribute.type !== 'relation') continue;\n if (attribute.target !== uid) continue;\n if (attribute.inversedBy || attribute.mappedBy) continue;\n const joinTable = attribute.joinTable;\n // TODO: joinColumn relations\n if (!joinTable) continue;\n\n const { name } = joinTable.inverseJoinColumn;\n\n /**\n * Load all relations that need to be updated\n */\n const oldEntriesIds = oldEntries.map((entry) => entry.id);\n const relations = await strapi.db\n .getConnection()\n .select('*')\n .from(joinTable.name)\n .whereIn(name, oldEntriesIds)\n .transacting(trx);\n\n if (relations.length === 0) continue;\n\n updates.push({ joinTable, relations });\n }\n }\n });\n\n return updates;\n};\n\n/**\n * Updates uni directional relations to target the right entries when overriding published or draft entries.\n *\n * @param oldEntries The old entries that are being overridden\n * @param newEntries The new entries that are overriding the old ones\n * @param oldRelations The relations that were previously loaded with `load` @see load\n */\nconst sync = async (\n oldEntries: { id: string; locale: string }[],\n newEntries: { id: string; locale: string }[],\n oldRelations: { joinTable: any; relations: any[] }[]\n) => {\n /**\n * Create a map of old entry ids to new entry ids\n *\n * Will be used to update the relation target ids\n */\n const newEntryByLocale = keyBy('locale', newEntries);\n const oldEntriesMap = oldEntries.reduce(\n (acc, entry) => {\n const newEntry = newEntryByLocale[entry.locale];\n if (!newEntry) return acc;\n acc[entry.id] = newEntry.id;\n return acc;\n },\n {} as Record<string, string>\n );\n\n await strapi.db.transaction(async ({ trx }) => {\n const con = strapi.db.getConnection();\n\n // Iterate old relations that are deleted and insert the new ones\n for (const { joinTable, relations } of oldRelations) {\n // Update old ids with the new ones\n const newRelations = relations.map((relation) => {\n const column = joinTable.inverseJoinColumn.name;\n const newId = oldEntriesMap[relation[column]];\n return { ...relation, [column]: newId };\n });\n\n // Insert those relations into the join table\n await con.batchInsert(joinTable.name, newRelations).transacting(trx);\n }\n });\n};\n\nexport { load, sync };\n"],"names":["keyBy"],"mappings":";;;AAcM,MAAA,OAAO,OAAO,KAAsB,eAAiD;AACzF,QAAM,UAAU,CAAA;AAGhB,QAAM,OAAO,GAAG,YAAY,OAAO,EAAE,UAAU;AAC7C,UAAM,eAAe,OAAO,OAAO,OAAO,YAAY;AACtD,UAAM,aAAa,OAAO,OAAO,OAAO,UAAU;AAElD,eAAW,SAAS,CAAC,GAAG,cAAc,GAAG,UAAU,GAAG;AACpD,YAAM,UAAU,OAAO,GAAG,SAAS,IAAI,MAAM,GAAG;AAEhD,iBAAW,aAAa,OAAO,OAAO,QAAQ,UAAU,GAAU;AAIhE,YAAI,UAAU,SAAS;AAAY;AACnC,YAAI,UAAU,WAAW;AAAK;AAC1B,YAAA,UAAU,cAAc,UAAU;AAAU;AAChD,cAAM,YAAY,UAAU;AAE5B,YAAI,CAAC;AAAW;AAEV,cAAA,EAAE,KAAK,IAAI,UAAU;AAK3B,cAAM,gBAAgB,WAAW,IAAI,CAAC,UAAU,MAAM,EAAE;AACxD,cAAM,YAAY,MAAM,OAAO,GAC5B,gBACA,OAAO,GAAG,EACV,KAAK,UAAU,IAAI,EACnB,QAAQ,MAAM,aAAa,EAC3B,YAAY,GAAG;AAElB,YAAI,UAAU,WAAW;AAAG;AAE5B,gBAAQ,KAAK,EAAE,WAAW,UAAW,CAAA;AAAA,MACvC;AAAA,IACF;AAAA,EAAA,CACD;AAEM,SAAA;AACT;AASA,MAAM,OAAO,OACX,YACA,YACA,iBACG;AAMG,QAAA,mBAAmBA,GAAAA,MAAM,UAAU,UAAU;AACnD,QAAM,gBAAgB,WAAW;AAAA,IAC/B,CAAC,KAAK,UAAU;AACR,YAAA,WAAW,iBAAiB,MAAM,MAAM;AAC9C,UAAI,CAAC;AAAiB,eAAA;AAClB,UAAA,MAAM,EAAE,IAAI,SAAS;AAClB,aAAA;AAAA,IACT;AAAA,IACA,CAAC;AAAA,EAAA;AAGH,QAAM,OAAO,GAAG,YAAY,OAAO,EAAE,UAAU;AACvC,UAAA,MAAM,OAAO,GAAG,cAAc;AAGpC,eAAW,EAAE,WAAW,UAAU,KAAK,cAAc;AAEnD,YAAM,eAAe,UAAU,IAAI,CAAC,aAAa;AACzC,cAAA,SAAS,UAAU,kBAAkB;AAC3C,cAAM,QAAQ,cAAc,SAAS,MAAM,CAAC;AAC5C,eAAO,EAAE,GAAG,UAAU,CAAC,MAAM,GAAG,MAAM;AAAA,MAAA,CACvC;AAGD,YAAM,IAAI,YAAY,UAAU,MAAM,YAAY,EAAE,YAAY,GAAG;AAAA,IACrE;AAAA,EAAA,CACD;AACH;;;"}
@@ -0,0 +1,58 @@
1
+ import { keyBy } from "lodash/fp";
2
+ const load = async (uid, oldEntries) => {
3
+ const updates = [];
4
+ await strapi.db.transaction(async ({ trx }) => {
5
+ const contentTypes = Object.values(strapi.contentTypes);
6
+ const components = Object.values(strapi.components);
7
+ for (const model of [...contentTypes, ...components]) {
8
+ const dbModel = strapi.db.metadata.get(model.uid);
9
+ for (const attribute of Object.values(dbModel.attributes)) {
10
+ if (attribute.type !== "relation")
11
+ continue;
12
+ if (attribute.target !== uid)
13
+ continue;
14
+ if (attribute.inversedBy || attribute.mappedBy)
15
+ continue;
16
+ const joinTable = attribute.joinTable;
17
+ if (!joinTable)
18
+ continue;
19
+ const { name } = joinTable.inverseJoinColumn;
20
+ const oldEntriesIds = oldEntries.map((entry) => entry.id);
21
+ const relations = await strapi.db.getConnection().select("*").from(joinTable.name).whereIn(name, oldEntriesIds).transacting(trx);
22
+ if (relations.length === 0)
23
+ continue;
24
+ updates.push({ joinTable, relations });
25
+ }
26
+ }
27
+ });
28
+ return updates;
29
+ };
30
+ const sync = async (oldEntries, newEntries, oldRelations) => {
31
+ const newEntryByLocale = keyBy("locale", newEntries);
32
+ const oldEntriesMap = oldEntries.reduce(
33
+ (acc, entry) => {
34
+ const newEntry = newEntryByLocale[entry.locale];
35
+ if (!newEntry)
36
+ return acc;
37
+ acc[entry.id] = newEntry.id;
38
+ return acc;
39
+ },
40
+ {}
41
+ );
42
+ await strapi.db.transaction(async ({ trx }) => {
43
+ const con = strapi.db.getConnection();
44
+ for (const { joinTable, relations } of oldRelations) {
45
+ const newRelations = relations.map((relation) => {
46
+ const column = joinTable.inverseJoinColumn.name;
47
+ const newId = oldEntriesMap[relation[column]];
48
+ return { ...relation, [column]: newId };
49
+ });
50
+ await con.batchInsert(joinTable.name, newRelations).transacting(trx);
51
+ }
52
+ });
53
+ };
54
+ export {
55
+ load,
56
+ sync
57
+ };
58
+ //# sourceMappingURL=unidirectional-relations.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"unidirectional-relations.mjs","sources":["../../../../src/services/document-service/utils/unidirectional-relations.ts"],"sourcesContent":["/* eslint-disable no-continue */\nimport { keyBy } from 'lodash/fp';\n\nimport { UID, Schema } from '@strapi/types';\n\n/**\n * Loads lingering relations that need to be updated when overriding a published or draft entry.\n * This is necessary because the relations are uni-directional and the target entry is not aware of the source entry.\n * This is not the case for bi-directional relations, where the target entry is also linked to the source entry.\n *\n * @param uid The content type uid\n * @param oldEntries The old entries that are being overridden\n * @returns An array of relations that need to be updated with the join table reference.\n */\nconst load = async (uid: UID.ContentType, oldEntries: { id: string; locale: string }[]) => {\n const updates = [] as any;\n\n // Iterate all components and content types to find relations that need to be updated\n await strapi.db.transaction(async ({ trx }) => {\n const contentTypes = Object.values(strapi.contentTypes) as Schema.ContentType[];\n const components = Object.values(strapi.components) as Schema.Component[];\n\n for (const model of [...contentTypes, ...components]) {\n const dbModel = strapi.db.metadata.get(model.uid);\n\n for (const attribute of Object.values(dbModel.attributes) as any) {\n /**\n * Only consider unidirectional relations\n */\n if (attribute.type !== 'relation') continue;\n if (attribute.target !== uid) continue;\n if (attribute.inversedBy || attribute.mappedBy) continue;\n const joinTable = attribute.joinTable;\n // TODO: joinColumn relations\n if (!joinTable) continue;\n\n const { name } = joinTable.inverseJoinColumn;\n\n /**\n * Load all relations that need to be updated\n */\n const oldEntriesIds = oldEntries.map((entry) => entry.id);\n const relations = await strapi.db\n .getConnection()\n .select('*')\n .from(joinTable.name)\n .whereIn(name, oldEntriesIds)\n .transacting(trx);\n\n if (relations.length === 0) continue;\n\n updates.push({ joinTable, relations });\n }\n }\n });\n\n return updates;\n};\n\n/**\n * Updates uni directional relations to target the right entries when overriding published or draft entries.\n *\n * @param oldEntries The old entries that are being overridden\n * @param newEntries The new entries that are overriding the old ones\n * @param oldRelations The relations that were previously loaded with `load` @see load\n */\nconst sync = async (\n oldEntries: { id: string; locale: string }[],\n newEntries: { id: string; locale: string }[],\n oldRelations: { joinTable: any; relations: any[] }[]\n) => {\n /**\n * Create a map of old entry ids to new entry ids\n *\n * Will be used to update the relation target ids\n */\n const newEntryByLocale = keyBy('locale', newEntries);\n const oldEntriesMap = oldEntries.reduce(\n (acc, entry) => {\n const newEntry = newEntryByLocale[entry.locale];\n if (!newEntry) return acc;\n acc[entry.id] = newEntry.id;\n return acc;\n },\n {} as Record<string, string>\n );\n\n await strapi.db.transaction(async ({ trx }) => {\n const con = strapi.db.getConnection();\n\n // Iterate old relations that are deleted and insert the new ones\n for (const { joinTable, relations } of oldRelations) {\n // Update old ids with the new ones\n const newRelations = relations.map((relation) => {\n const column = joinTable.inverseJoinColumn.name;\n const newId = oldEntriesMap[relation[column]];\n return { ...relation, [column]: newId };\n });\n\n // Insert those relations into the join table\n await con.batchInsert(joinTable.name, newRelations).transacting(trx);\n }\n });\n};\n\nexport { load, sync };\n"],"names":[],"mappings":";AAcM,MAAA,OAAO,OAAO,KAAsB,eAAiD;AACzF,QAAM,UAAU,CAAA;AAGhB,QAAM,OAAO,GAAG,YAAY,OAAO,EAAE,UAAU;AAC7C,UAAM,eAAe,OAAO,OAAO,OAAO,YAAY;AACtD,UAAM,aAAa,OAAO,OAAO,OAAO,UAAU;AAElD,eAAW,SAAS,CAAC,GAAG,cAAc,GAAG,UAAU,GAAG;AACpD,YAAM,UAAU,OAAO,GAAG,SAAS,IAAI,MAAM,GAAG;AAEhD,iBAAW,aAAa,OAAO,OAAO,QAAQ,UAAU,GAAU;AAIhE,YAAI,UAAU,SAAS;AAAY;AACnC,YAAI,UAAU,WAAW;AAAK;AAC1B,YAAA,UAAU,cAAc,UAAU;AAAU;AAChD,cAAM,YAAY,UAAU;AAE5B,YAAI,CAAC;AAAW;AAEV,cAAA,EAAE,KAAK,IAAI,UAAU;AAK3B,cAAM,gBAAgB,WAAW,IAAI,CAAC,UAAU,MAAM,EAAE;AACxD,cAAM,YAAY,MAAM,OAAO,GAC5B,gBACA,OAAO,GAAG,EACV,KAAK,UAAU,IAAI,EACnB,QAAQ,MAAM,aAAa,EAC3B,YAAY,GAAG;AAElB,YAAI,UAAU,WAAW;AAAG;AAE5B,gBAAQ,KAAK,EAAE,WAAW,UAAW,CAAA;AAAA,MACvC;AAAA,IACF;AAAA,EAAA,CACD;AAEM,SAAA;AACT;AASA,MAAM,OAAO,OACX,YACA,YACA,iBACG;AAMG,QAAA,mBAAmB,MAAM,UAAU,UAAU;AACnD,QAAM,gBAAgB,WAAW;AAAA,IAC/B,CAAC,KAAK,UAAU;AACR,YAAA,WAAW,iBAAiB,MAAM,MAAM;AAC9C,UAAI,CAAC;AAAiB,eAAA;AAClB,UAAA,MAAM,EAAE,IAAI,SAAS;AAClB,aAAA;AAAA,IACT;AAAA,IACA,CAAC;AAAA,EAAA;AAGH,QAAM,OAAO,GAAG,YAAY,OAAO,EAAE,UAAU;AACvC,UAAA,MAAM,OAAO,GAAG,cAAc;AAGpC,eAAW,EAAE,WAAW,UAAU,KAAK,cAAc;AAEnD,YAAM,eAAe,UAAU,IAAI,CAAC,aAAa;AACzC,cAAA,SAAS,UAAU,kBAAkB;AAC3C,cAAM,QAAQ,cAAc,SAAS,MAAM,CAAC;AAC5C,eAAO,EAAE,GAAG,UAAU,CAAC,MAAM,GAAG,MAAM;AAAA,MAAA,CACvC;AAGD,YAAM,IAAI,YAAY,UAAU,MAAM,YAAY,EAAE,YAAY,GAAG;AAAA,IACrE;AAAA,EAAA,CACD;AACH;"}
@@ -1,15 +1,13 @@
1
1
  import type { Database } from '@strapi/database';
2
- import type { Strapi, EntityService, EntityValidator, EventHub } from '@strapi/types';
2
+ import type { Core, Modules } from '@strapi/types';
3
3
  type Decoratable<T> = T & {
4
- decorate(decorator: (old: EntityService.EntityService) => EntityService.EntityService & {
4
+ decorate(decorator: (old: Modules.EntityService.EntityService) => Modules.EntityService.EntityService & {
5
5
  [key: string]: unknown;
6
6
  }): void;
7
7
  };
8
8
  declare const _default: (ctx: {
9
- strapi: Strapi;
9
+ strapi: Core.Strapi;
10
10
  db: Database;
11
- eventHub: EventHub;
12
- entityValidator: EntityValidator;
13
- }) => Decoratable<EntityService.EntityService>;
11
+ }) => Decoratable<Modules.EntityService.EntityService>;
14
12
  export default _default;
15
13
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/services/entity-service/index.ts"],"names":[],"mappings":"AAUA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AACjD,OAAO,KAAK,EACV,MAAM,EACN,aAAa,EACb,eAAe,EACf,QAAQ,EAKT,MAAM,eAAe,CAAC;AAkBvB,KAAK,WAAW,CAAC,CAAC,IAAI,CAAC,GAAG;IACxB,QAAQ,CACN,SAAS,EAAE,CAAC,GAAG,EAAE,aAAa,CAAC,aAAa,KAAK,aAAa,CAAC,aAAa,GAAG;QAC7E,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;KACxB,GACA,IAAI,CAAC;CACT,CAAC;8BA0ZmB;IACnB,QAAQ,MAAM,CAAC;IACf,EAAE,EAAE,QAAQ,CAAC;IACb,QAAQ,EAAE,QAAQ,CAAC;IACnB,eAAe,EAAE,eAAe,CAAC;CAClC,KAAG,YAAY,2BAA2B,CAAC;AAL5C,wBA0DE"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/services/entity-service/index.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AACjD,OAAO,KAAK,EAAE,IAAI,EAAE,OAAO,EAAS,MAAM,eAAe,CAAC;AAE1D,KAAK,WAAW,CAAC,CAAC,IAAI,CAAC,GAAG;IACxB,QAAQ,CACN,SAAS,EAAE,CAAC,GAAG,EAAE,OAAO,CAAC,aAAa,CAAC,aAAa,KAAK,OAAO,CAAC,aAAa,CAAC,aAAa,GAAG;QAC7F,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;KACxB,GACA,IAAI,CAAC;CACT,CAAC;8BAuLmB;IACnB,MAAM,EAAE,KAAK,MAAM,CAAC;IACpB,EAAE,EAAE,QAAQ,CAAC;CACd,KAAG,YAAY,QAAQ,aAAa,CAAC,aAAa,CAAC;AAHpD,wBAoDE"}
@@ -3,16 +3,11 @@ const _ = require("lodash");
3
3
  const delegate = require("delegates");
4
4
  const database = require("@strapi/database");
5
5
  const strapiUtils = require("@strapi/utils");
6
- const uploadFiles = require("../utils/upload-files.js");
7
- const components = require("./components.js");
8
- const params = require("./params.js");
9
- const index = require("./attributes/index.js");
10
6
  const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
11
7
  const ___default = /* @__PURE__ */ _interopDefault(_);
12
8
  const delegate__default = /* @__PURE__ */ _interopDefault(delegate);
13
- const { transformParamsToQuery } = strapiUtils.convertQueryParams;
14
- const transformLoadParamsToQuery = (uid, field, params2, pagination = {}) => {
15
- const query = transformParamsToQuery(uid, { populate: { [field]: params2 } });
9
+ const transformLoadParamsToQuery = (uid, field, params, pagination = {}) => {
10
+ const query = strapi.get("query-params").transform(uid, { populate: { [field]: params } });
16
11
  const res = {
17
12
  ...query.populate[field],
18
13
  ...pagination
@@ -25,258 +20,107 @@ const databaseErrorsToTransform = [
25
20
  database.errors.InvalidDateError,
26
21
  database.errors.InvalidRelationError
27
22
  ];
28
- const creationPipeline = (data, context) => {
29
- return index.applyTransforms(data, context);
30
- };
31
- const updatePipeline = (data, context) => {
32
- return index.applyTransforms(data, context);
33
- };
34
- const ALLOWED_WEBHOOK_EVENTS = {
35
- ENTRY_CREATE: "entry.create",
36
- ENTRY_UPDATE: "entry.update",
37
- ENTRY_DELETE: "entry.delete"
38
- };
39
23
  const createDefaultImplementation = ({
40
- strapi,
41
- db,
42
- eventHub,
43
- entityValidator
24
+ strapi: strapi2,
25
+ db
44
26
  }) => ({
45
- /**
46
- * Upload files utility
47
- */
48
- uploadFiles,
49
27
  async wrapParams(options = {}) {
50
28
  return options;
51
29
  },
52
30
  async wrapResult(result = {}) {
53
31
  return result;
54
32
  },
55
- async emitEvent(uid, event, entity) {
56
- if (uid === "admin::audit-log") {
57
- return;
58
- }
59
- const model = strapi.getModel(uid);
60
- const sanitizedEntity = await strapiUtils.sanitize.sanitizers.defaultSanitizeOutput(model, entity);
61
- eventHub.emit(event, {
62
- model: model.modelName,
63
- uid: model.uid,
64
- entry: sanitizedEntity
65
- });
66
- },
67
33
  async findMany(uid, opts) {
68
- const { kind } = strapi.getModel(uid);
34
+ const { kind } = strapi2.getModel(uid);
69
35
  const wrappedParams = await this.wrapParams(opts, { uid, action: "findMany" });
70
- const query = transformParamsToQuery(uid, wrappedParams);
71
36
  if (kind === "singleType") {
72
- const entity = db.query(uid).findOne(query);
37
+ const entity = strapi2.documents(uid).findFirst(wrappedParams);
73
38
  return this.wrapResult(entity, { uid, action: "findOne" });
74
39
  }
75
- const entities = await db.query(uid).findMany(query);
40
+ const entities = await strapi2.documents(uid).findMany(wrappedParams);
76
41
  return this.wrapResult(entities, { uid, action: "findMany" });
77
42
  },
78
43
  async findPage(uid, opts) {
79
44
  const wrappedParams = await this.wrapParams(opts, { uid, action: "findPage" });
80
- const query = transformParamsToQuery(uid, wrappedParams);
81
- const page = await db.query(uid).findPage(query);
82
- return {
83
- ...page,
84
- results: await this.wrapResult(page.results, { uid, action: "findPage" })
85
- };
86
- },
87
- // TODO: streamline the logic based on the populate option
88
- async findWithRelationCountsPage(uid, opts) {
89
- const wrappedParams = await this.wrapParams(opts, { uid, action: "findWithRelationCounts" });
90
- const query = transformParamsToQuery(uid, wrappedParams);
45
+ const query = strapi2.get("query-params").transform(uid, wrappedParams);
91
46
  const entities = await db.query(uid).findPage(query);
92
- return {
93
- ...entities,
94
- results: await this.wrapResult(entities.results, { uid, action: "findWithRelationCounts" })
95
- };
96
- },
97
- async findWithRelationCounts(uid, opts) {
98
- const wrappedParams = await this.wrapParams(opts, { uid, action: "findWithRelationCounts" });
99
- const query = transformParamsToQuery(uid, wrappedParams);
100
- const entities = await db.query(uid).findMany(query);
101
- return this.wrapResult(entities, { uid, action: "findWithRelationCounts" });
47
+ return this.wrapResult(entities, { uid, action: "findMany" });
102
48
  },
103
49
  async findOne(uid, entityId, opts) {
104
50
  const wrappedParams = await this.wrapParams(opts, { uid, action: "findOne" });
105
- const query = transformParamsToQuery(uid, params.pickSelectionParams(wrappedParams));
106
- const entity = await db.query(uid).findOne({ ...query, where: { id: entityId } });
51
+ const res = await db.query(uid).findOne({ where: { id: entityId } });
52
+ if (!res) {
53
+ return this.wrapResult(null, { uid, action: "findOne" });
54
+ }
55
+ const entity = await strapi2.documents(uid).findOne({
56
+ ...wrappedParams,
57
+ documentId: res.documentId
58
+ });
107
59
  return this.wrapResult(entity, { uid, action: "findOne" });
108
60
  },
109
61
  async count(uid, opts) {
110
62
  const wrappedParams = await this.wrapParams(opts, { uid, action: "count" });
111
- const query = transformParamsToQuery(uid, wrappedParams);
112
- return db.query(uid).count(query);
63
+ return strapi2.documents(uid).count(wrappedParams);
113
64
  },
114
- async create(uid, params$1) {
115
- const wrappedParams = await this.wrapParams(params$1, { uid, action: "create" });
116
- const { data, files } = wrappedParams;
65
+ async create(uid, params) {
66
+ const wrappedParams = await this.wrapParams(params, { uid, action: "create" });
67
+ const { data } = wrappedParams;
117
68
  if (!data) {
118
69
  throw new Error("cannot create");
119
70
  }
120
- const model = strapi.getModel(uid);
121
- const isDraft = strapiUtils.contentTypes.isDraft(data, model);
122
- const validData = await entityValidator.validateEntityCreation(model, data, { isDraft });
123
- const query = transformParamsToQuery(uid, params.pickSelectionParams(wrappedParams));
124
- const componentData = await components.createComponents(uid, validData);
125
- const entityData = creationPipeline(
126
- Object.assign(components.omitComponentData(model, validData), componentData),
127
- {
128
- contentType: model
129
- }
130
- );
131
- let entity = await db.query(uid).create({
132
- ...query,
133
- data: entityData
71
+ const shouldPublish = !strapiUtils.contentTypes.isDraft(data, strapi2.getModel(uid));
72
+ const entity = await strapi2.documents(uid).create({
73
+ ...wrappedParams,
74
+ status: shouldPublish ? "published" : "draft"
134
75
  });
135
- if (files && Object.keys(files).length > 0) {
136
- await this.uploadFiles(uid, Object.assign(entityData, entity), files);
137
- entity = await this.findOne(uid, entity.id, wrappedParams);
138
- }
139
- entity = await this.wrapResult(entity, { uid, action: "create" });
140
- const { ENTRY_CREATE } = ALLOWED_WEBHOOK_EVENTS;
141
- await this.emitEvent(uid, ENTRY_CREATE, entity);
142
- return entity;
76
+ return this.wrapResult(entity, { uid, action: "create" });
143
77
  },
144
78
  async update(uid, entityId, opts) {
145
79
  const wrappedParams = await this.wrapParams(opts, {
146
80
  uid,
147
81
  action: "update"
148
82
  });
149
- const { data, files } = wrappedParams;
150
- const model = strapi.getModel(uid);
151
83
  const entityToUpdate = await db.query(uid).findOne({ where: { id: entityId } });
152
84
  if (!entityToUpdate) {
153
- return null;
85
+ return this.wrapResult(null, { uid, action: "update" });
154
86
  }
155
- const isDraft = strapiUtils.contentTypes.isDraft(entityToUpdate, model);
156
- const validData = await entityValidator.validateEntityUpdate(
157
- model,
158
- data,
159
- {
160
- isDraft
161
- },
162
- entityToUpdate
163
- );
164
- const query = transformParamsToQuery(uid, params.pickSelectionParams(wrappedParams));
165
- const componentData = await components.updateComponents(uid, entityToUpdate, validData);
166
- const entityData = updatePipeline(
167
- Object.assign(components.omitComponentData(model, validData), componentData),
168
- { contentType: model }
169
- );
170
- let entity = await db.query(uid).update({
171
- ...query,
172
- where: { id: entityId },
173
- data: entityData
87
+ const shouldPublish = !strapiUtils.contentTypes.isDraft(entityToUpdate, strapi2.getModel(uid));
88
+ const entity = strapi2.documents(uid).update({
89
+ ...wrappedParams,
90
+ status: shouldPublish ? "published" : "draft",
91
+ documentId: entityToUpdate.documentId
174
92
  });
175
- if (files && Object.keys(files).length > 0) {
176
- await this.uploadFiles(uid, Object.assign(entityData, entity), files);
177
- entity = await this.findOne(uid, entity.id, wrappedParams);
178
- }
179
- entity = await this.wrapResult(entity, { uid, action: "update" });
180
- const { ENTRY_UPDATE } = ALLOWED_WEBHOOK_EVENTS;
181
- await this.emitEvent(uid, ENTRY_UPDATE, entity);
182
- return entity;
93
+ return this.wrapResult(entity, { uid, action: "update" });
183
94
  },
184
95
  async delete(uid, entityId, opts) {
185
96
  const wrappedParams = await this.wrapParams(opts, { uid, action: "delete" });
186
- const query = transformParamsToQuery(uid, params.pickSelectionParams(wrappedParams));
187
- let entityToDelete = await db.query(uid).findOne({
188
- ...query,
189
- where: { id: entityId }
190
- });
97
+ const entityToDelete = await db.query(uid).findOne({ where: { id: entityId } });
191
98
  if (!entityToDelete) {
192
- return null;
99
+ return this.wrapResult(null, { uid, action: "delete" });
193
100
  }
194
- const componentsToDelete = await components.getComponents(uid, entityToDelete);
195
- await db.query(uid).delete({ where: { id: entityToDelete.id } });
196
- await components.deleteComponents(uid, componentsToDelete, { loadComponents: false });
197
- entityToDelete = await this.wrapResult(entityToDelete, { uid, action: "delete" });
198
- const { ENTRY_DELETE } = ALLOWED_WEBHOOK_EVENTS;
199
- await this.emitEvent(uid, ENTRY_DELETE, entityToDelete);
200
- return entityToDelete;
201
- },
202
- async clone(uid, cloneId, opts) {
203
- const wrappedParams = await this.wrapParams(opts, { uid, action: "clone" });
204
- const { data, files } = wrappedParams;
205
- if (!data) {
206
- throw new Error("cannot clone");
207
- }
208
- const model = strapi.getModel(uid);
209
- const entityToClone = await db.query(uid).findOne({ where: { id: cloneId } });
210
- if (!entityToClone) {
211
- return null;
212
- }
213
- const isDraft = strapiUtils.contentTypes.isDraft(entityToClone, model);
214
- const validData = await entityValidator.validateEntityUpdate(
215
- model,
216
- // Omit the id, the cloned entity id will be generated by the database
217
- ___default.default.omit(data, ["id"]),
218
- { isDraft },
219
- entityToClone
220
- );
221
- const query = transformParamsToQuery(uid, params.pickSelectionParams(wrappedParams));
222
- const componentData = await components.cloneComponents(uid, entityToClone, validData);
223
- const entityData = creationPipeline(
224
- Object.assign(components.omitComponentData(model, validData), componentData),
225
- {
226
- contentType: model
227
- }
228
- );
229
- let entity = await db.query(uid).clone(cloneId, {
230
- ...query,
231
- data: entityData
101
+ await strapi2.documents(uid).delete({
102
+ ...wrappedParams,
103
+ documentId: entityToDelete.documentId
232
104
  });
233
- if (files && Object.keys(files).length > 0) {
234
- await this.uploadFiles(uid, Object.assign(entityData, entity), files);
235
- entity = await this.findOne(uid, entity.id, wrappedParams);
236
- }
237
- const { ENTRY_CREATE } = ALLOWED_WEBHOOK_EVENTS;
238
- await this.emitEvent(uid, ENTRY_CREATE, entity);
239
- return entity;
105
+ return this.wrapResult(entityToDelete, { uid, action: "delete" });
240
106
  },
241
- // FIXME: used only for the CM to be removed
242
- async deleteMany(uid, opts) {
243
- const wrappedParams = await this.wrapParams(opts, { uid, action: "delete" });
244
- const query = transformParamsToQuery(uid, wrappedParams);
245
- let entitiesToDelete = await db.query(uid).findMany(query);
246
- if (!entitiesToDelete.length) {
247
- return { count: 0 };
248
- }
249
- const componentsToDelete = await Promise.all(
250
- entitiesToDelete.map((entityToDelete) => components.getComponents(uid, entityToDelete))
251
- );
252
- const deletedEntities = await db.query(uid).deleteMany(query);
253
- await Promise.all(
254
- componentsToDelete.map(
255
- (compos) => components.deleteComponents(uid, compos, { loadComponents: false })
256
- )
257
- );
258
- entitiesToDelete = await this.wrapResult(entitiesToDelete, { uid, action: "delete" });
259
- const { ENTRY_DELETE } = ALLOWED_WEBHOOK_EVENTS;
260
- await Promise.all(entitiesToDelete.map((entity) => this.emitEvent(uid, ENTRY_DELETE, entity)));
261
- return deletedEntities;
262
- },
263
- async load(uid, entity, field, params2) {
107
+ async load(uid, entity, field, params) {
264
108
  if (!___default.default.isString(field)) {
265
109
  throw new Error(`Invalid load. Expected "${field}" to be a string`);
266
110
  }
267
- const loadedEntity = await db.query(uid).load(entity, field, transformLoadParamsToQuery(uid, field, params2 ?? {}));
111
+ const loadedEntity = await db.query(uid).load(entity, field, transformLoadParamsToQuery(uid, field, params ?? {}));
268
112
  return this.wrapResult(loadedEntity, { uid, field, action: "load" });
269
113
  },
270
- async loadPages(uid, entity, field, params2, pagination = {}) {
114
+ async loadPages(uid, entity, field, params, pagination = {}) {
271
115
  if (!___default.default.isString(field)) {
272
116
  throw new Error(`Invalid load. Expected "${field}" to be a string`);
273
117
  }
274
- const { attributes } = strapi.getModel(uid);
118
+ const { attributes } = strapi2.getModel(uid);
275
119
  const attribute = attributes[field];
276
120
  if (!strapiUtils.relations.isAnyToMany(attribute)) {
277
121
  throw new Error(`Invalid load. Expected "${field}" to be an anyToMany relational attribute`);
278
122
  }
279
- const query = transformLoadParamsToQuery(uid, field, params2 ?? {}, pagination);
123
+ const query = transformLoadParamsToQuery(uid, field, params ?? {}, pagination);
280
124
  const loadedPage = await db.query(uid).loadPages(entity, field, query);
281
125
  return {
282
126
  ...loadedPage,
@@ -285,9 +129,6 @@ const createDefaultImplementation = ({
285
129
  }
286
130
  });
287
131
  const createEntityService = (ctx) => {
288
- Object.entries(ALLOWED_WEBHOOK_EVENTS).forEach(([key, value]) => {
289
- ctx.strapi.webhookStore?.addAllowedEvent(key, value);
290
- });
291
132
  const implementation = createDefaultImplementation(ctx);
292
133
  const service = {
293
134
  implementation,