@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,14 +1,15 @@
1
1
  import _ from "lodash";
2
- import { omit, has, pipe, assign } from "lodash/fp";
3
- import { contentTypes, mapAsync, errors } from "@strapi/utils";
4
- const isDialectMySQL = () => strapi.db?.dialect.client === "mysql";
5
- function omitComponentData(contentType, data) {
6
- const { attributes } = contentType;
7
- const componentAttributes = Object.keys(attributes).filter(
8
- (attributeName) => contentTypes.isComponentAttribute(attributes[attributeName])
9
- );
10
- return omit(componentAttributes, data);
11
- }
2
+ import { curry, omit, pipe, assign, has } from "lodash/fp";
3
+ import { contentTypes, async, errors } from "@strapi/utils";
4
+ const omitComponentData = curry(
5
+ (schema, data) => {
6
+ const { attributes } = schema;
7
+ const componentAttributes = Object.keys(attributes).filter(
8
+ (attributeName) => contentTypes.isComponentAttribute(attributes[attributeName])
9
+ );
10
+ return omit(componentAttributes, data);
11
+ }
12
+ );
12
13
  const createComponents = async (uid, data) => {
13
14
  const { attributes = {} } = strapi.getModel(uid);
14
15
  const componentBody = {};
@@ -28,10 +29,9 @@ const createComponents = async (uid, data) => {
28
29
  if (!Array.isArray(componentValue)) {
29
30
  throw new Error("Expected an array to create repeatable component");
30
31
  }
31
- const components = await mapAsync(
32
+ const components = await async.map(
32
33
  componentValue,
33
- (value) => createComponent(componentUID, value),
34
- { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
34
+ (value) => createComponent(componentUID, value)
35
35
  );
36
36
  componentBody[attributeName] = components.map(({ id }) => {
37
37
  return {
@@ -72,10 +72,9 @@ const createComponents = async (uid, data) => {
72
72
  }
73
73
  };
74
74
  };
75
- componentBody[attributeName] = await mapAsync(
75
+ componentBody[attributeName] = await async.map(
76
76
  dynamiczoneValues,
77
- createDynamicZoneComponents,
78
- { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
77
+ createDynamicZoneComponents
79
78
  );
80
79
  continue;
81
80
  }
@@ -87,7 +86,7 @@ const getComponents = async (uid, entity) => {
87
86
  if (_.isEmpty(componentAttributes)) {
88
87
  return {};
89
88
  }
90
- return strapi.query(uid).load(entity, componentAttributes);
89
+ return strapi.db.query(uid).load(entity, componentAttributes);
91
90
  };
92
91
  const updateComponents = async (uid, entityToUpdate, data) => {
93
92
  const { attributes = {} } = strapi.getModel(uid);
@@ -105,10 +104,9 @@ const updateComponents = async (uid, entityToUpdate, data) => {
105
104
  if (!Array.isArray(componentValue)) {
106
105
  throw new Error("Expected an array to create repeatable component");
107
106
  }
108
- const components = await mapAsync(
107
+ const components = await async.map(
109
108
  componentValue,
110
- (value) => updateOrCreateComponent(componentUID, value),
111
- { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
109
+ (value) => updateOrCreateComponent(componentUID, value)
112
110
  );
113
111
  componentBody[attributeName] = components.filter(_.negate(_.isNil)).map(({ id }) => {
114
112
  return {
@@ -129,29 +127,22 @@ const updateComponents = async (uid, entityToUpdate, data) => {
129
127
  }
130
128
  };
131
129
  }
132
- continue;
133
- }
134
- if (attribute.type === "dynamiczone") {
130
+ } else if (attribute.type === "dynamiczone") {
135
131
  const dynamiczoneValues = data[attributeName];
136
132
  await deleteOldDZComponents(uid, entityToUpdate, attributeName, dynamiczoneValues);
137
133
  if (!Array.isArray(dynamiczoneValues)) {
138
134
  throw new Error("Expected an array to create repeatable component");
139
135
  }
140
- componentBody[attributeName] = await mapAsync(
141
- dynamiczoneValues,
142
- async (value) => {
143
- const { id } = await updateOrCreateComponent(value.__component, value);
144
- return {
145
- id,
146
- __component: value.__component,
147
- __pivot: {
148
- field: attributeName
149
- }
150
- };
151
- },
152
- { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
153
- );
154
- continue;
136
+ componentBody[attributeName] = await async.map(dynamiczoneValues, async (value) => {
137
+ const { id } = await updateOrCreateComponent(value.__component, value);
138
+ return {
139
+ id,
140
+ __component: value.__component,
141
+ __pivot: {
142
+ field: attributeName
143
+ }
144
+ };
145
+ });
155
146
  }
156
147
  }
157
148
  return componentBody;
@@ -165,7 +156,7 @@ const pickStringifiedId = ({
165
156
  return `${id}`;
166
157
  };
167
158
  const deleteOldComponents = async (uid, componentUID, entityToUpdate, attributeName, componentValue) => {
168
- const previousValue = await strapi.query(uid).load(entityToUpdate, attributeName);
159
+ const previousValue = await strapi.db.query(uid).load(entityToUpdate, attributeName);
169
160
  const idsToKeep = _.castArray(componentValue).filter(has("id")).map(pickStringifiedId);
170
161
  const allIds = _.castArray(previousValue).filter(has("id")).map(pickStringifiedId);
171
162
  idsToKeep.forEach((id) => {
@@ -183,7 +174,7 @@ const deleteOldComponents = async (uid, componentUID, entityToUpdate, attributeN
183
174
  }
184
175
  };
185
176
  const deleteOldDZComponents = async (uid, entityToUpdate, attributeName, dynamiczoneValues) => {
186
- const previousValue = await strapi.query(uid).load(entityToUpdate, attributeName);
177
+ const previousValue = await strapi.db.query(uid).load(entityToUpdate, attributeName);
187
178
  const idsToKeep = _.castArray(dynamiczoneValues).filter(has("id")).map((v) => ({
188
179
  id: pickStringifiedId(v),
189
180
  __component: v.__component
@@ -222,7 +213,7 @@ const deleteComponents = async (uid, entityToDelete, { loadComponents = true } =
222
213
  if (attribute.type === "component" || attribute.type === "dynamiczone") {
223
214
  let value;
224
215
  if (loadComponents) {
225
- value = await strapi.query(uid).load(entityToDelete, attributeName);
216
+ value = await strapi.db.query(uid).load(entityToDelete, attributeName);
226
217
  } else {
227
218
  value = entityToDelete[attributeName];
228
219
  }
@@ -231,114 +222,38 @@ const deleteComponents = async (uid, entityToDelete, { loadComponents = true } =
231
222
  }
232
223
  if (attribute.type === "component") {
233
224
  const { component: componentUID } = attribute;
234
- await mapAsync(
225
+ await async.map(
235
226
  _.castArray(value),
236
- (subValue) => deleteComponent(componentUID, subValue),
237
- {
238
- concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity
239
- }
227
+ (subValue) => deleteComponent(componentUID, subValue)
240
228
  );
241
229
  } else {
242
- await mapAsync(
230
+ await async.map(
243
231
  _.castArray(value),
244
- (subValue) => deleteComponent(subValue.__component, subValue),
245
- { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
232
+ (subValue) => deleteComponent(subValue.__component, subValue)
246
233
  );
247
234
  }
248
235
  continue;
249
236
  }
250
237
  }
251
238
  };
252
- const cloneComponents = async (uid, entityToClone, data) => {
253
- const { attributes = {} } = strapi.getModel(uid);
254
- const componentBody = {};
255
- const componentData = await getComponents(uid, entityToClone);
256
- for (const attributeName of Object.keys(attributes)) {
257
- const attribute = attributes[attributeName];
258
- if (!has(attributeName, data) && !has(attributeName, componentData)) {
259
- continue;
260
- }
261
- if (attribute.type === "component") {
262
- const { component: componentUID, repeatable = false } = attribute;
263
- const componentValue = attributeName in data ? data[attributeName] : componentData[attributeName];
264
- if (componentValue === null) {
265
- continue;
266
- }
267
- if (repeatable === true) {
268
- if (!Array.isArray(componentValue)) {
269
- throw new Error("Expected an array to create repeatable component");
270
- }
271
- const components = await mapAsync(
272
- componentValue,
273
- (value) => cloneComponent(componentUID, value),
274
- { concurrency: isDialectMySQL() ? 1 : Infinity }
275
- );
276
- componentBody[attributeName] = components.filter(_.negate(_.isNil)).map(({ id }) => {
277
- return {
278
- id,
279
- __pivot: {
280
- field: attributeName,
281
- component_type: componentUID
282
- }
283
- };
284
- });
285
- } else {
286
- const component = await cloneComponent(componentUID, componentValue);
287
- componentBody[attributeName] = component && {
288
- id: component.id,
289
- __pivot: {
290
- field: attributeName,
291
- component_type: componentUID
292
- }
293
- };
294
- }
295
- continue;
296
- }
297
- if (attribute.type === "dynamiczone") {
298
- const dynamiczoneValues = has(attributeName, data) ? data[attributeName] : componentData[attributeName];
299
- if (!Array.isArray(dynamiczoneValues)) {
300
- throw new Error("Expected an array to create repeatable component");
301
- }
302
- componentBody[attributeName] = await mapAsync(
303
- dynamiczoneValues,
304
- async (value) => {
305
- const { id } = await cloneComponent(value.__component, value);
306
- return {
307
- id,
308
- __component: value.__component,
309
- __pivot: {
310
- field: attributeName
311
- }
312
- };
313
- },
314
- { concurrency: isDialectMySQL() ? 1 : Infinity }
315
- );
316
- continue;
317
- }
318
- }
319
- return componentBody;
320
- };
321
239
  const createComponent = async (uid, data) => {
322
- const model = strapi.getModel(uid);
240
+ const schema = strapi.getModel(uid);
323
241
  const componentData = await createComponents(uid, data);
324
242
  const transform = pipe(
325
243
  // Make sure we don't save the component with a pre-defined ID
326
244
  omit("id"),
327
- // Remove the component data from the original data object ...
328
- (payload) => omitComponentData(model, payload),
329
- // ... and assign the newly created component instead
330
- assign(componentData)
245
+ assignComponentData(schema, componentData)
331
246
  );
332
- return strapi.query(uid).create({ data: transform(data) });
247
+ return strapi.db.query(uid).create({ data: transform(data) });
333
248
  };
334
249
  const updateComponent = async (uid, componentToUpdate, data) => {
335
- const model = strapi.getModel(uid);
250
+ const schema = strapi.getModel(uid);
336
251
  const componentData = await updateComponents(uid, componentToUpdate, data);
337
- return strapi.query(uid).update({
252
+ return strapi.db.query(uid).update({
338
253
  where: {
339
254
  id: componentToUpdate.id
340
255
  },
341
- data: Object.assign(omitComponentData(model, data), componentData)
256
+ data: assignComponentData(schema, componentData, data)
342
257
  });
343
258
  };
344
259
  const updateOrCreateComponent = (componentUID, value) => {
@@ -352,26 +267,15 @@ const updateOrCreateComponent = (componentUID, value) => {
352
267
  };
353
268
  const deleteComponent = async (uid, componentToDelete) => {
354
269
  await deleteComponents(uid, componentToDelete);
355
- await strapi.query(uid).delete({ where: { id: componentToDelete.id } });
270
+ await strapi.db.query(uid).delete({ where: { id: componentToDelete.id } });
356
271
  };
357
- const cloneComponent = async (uid, data) => {
358
- const model = strapi.getModel(uid);
359
- if (!("id" in data) || typeof data.id === "undefined") {
360
- return createComponent(uid, data);
272
+ const assignComponentData = curry(
273
+ (schema, componentData, data) => {
274
+ return pipe(omitComponentData(schema), assign(componentData))(data);
361
275
  }
362
- const componentData = await cloneComponents(uid, { id: data.id }, data);
363
- const transform = pipe(
364
- // Make sure we don't save the component with a pre-defined ID
365
- omit("id"),
366
- // Remove the component data from the original data object ...
367
- (payload) => omitComponentData(model, payload),
368
- // ... and assign the newly created component instead
369
- assign(componentData)
370
- );
371
- return strapi.query(uid).clone(data.id, { data: transform(data) });
372
- };
276
+ );
373
277
  export {
374
- cloneComponents,
278
+ assignComponentData,
375
279
  createComponents,
376
280
  deleteComponent,
377
281
  deleteComponents,
@@ -0,0 +1 @@
1
+ {"version":3,"file":"components.mjs","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":["contentTypesUtils"],"mappings":"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"}
@@ -1,24 +1,10 @@
1
- import { Documents } from '@strapi/types';
2
- type ParamsTransform = (params: Documents.Params.All) => Documents.Params.All;
3
- /**
4
- * Sets status to draft only
5
- */
6
- export declare const setStatusToDraft: ParamsTransform;
7
- /**
8
- * Adds a default status of `draft` to the params
9
- */
10
- export declare const defaultToDraft: ParamsTransform;
11
- /**
12
- * In mutating actions we don't want user to set the publishedAt attribute.
13
- */
14
- export declare const filterDataPublishedAt: ParamsTransform;
15
- /**
16
- * Add status lookup query to the params
17
- */
18
- export declare const statusToLookup: ParamsTransform;
19
- /**
20
- * Translate publication status parameter into the data that will be saved
21
- */
22
- export declare const statusToData: ParamsTransform;
23
- export {};
1
+ /// <reference types="lodash" />
2
+ import { Modules, Struct } from '@strapi/types';
3
+ declare const setStatusToDraftCurry: import("lodash").CurriedFunction2<Struct.SingleTypeSchema | Struct.CollectionTypeSchema, Modules.Documents.Params.All, Modules.Documents.Params.All>;
4
+ declare const defaultToDraftCurry: import("lodash").CurriedFunction1<Modules.Documents.Params.All, Modules.Documents.Params.All>;
5
+ declare const defaultStatusCurry: import("lodash").CurriedFunction2<Struct.SingleTypeSchema | Struct.CollectionTypeSchema, Modules.Documents.Params.All, Modules.Documents.Params.All>;
6
+ declare const filterDataPublishedAtCurry: import("lodash").CurriedFunction1<Modules.Documents.Params.All, Modules.Documents.Params.All>;
7
+ declare const statusToLookupCurry: import("lodash").CurriedFunction2<Struct.SingleTypeSchema | Struct.CollectionTypeSchema, Modules.Documents.Params.All, Modules.Documents.Params.All>;
8
+ declare const statusToDataCurry: import("lodash").CurriedFunction2<Struct.SingleTypeSchema | Struct.CollectionTypeSchema, Modules.Documents.Params.All, Modules.Documents.Params.All>;
9
+ export { setStatusToDraftCurry as setStatusToDraft, defaultToDraftCurry as defaultToDraft, defaultStatusCurry as defaultStatus, filterDataPublishedAtCurry as filterDataPublishedAt, statusToLookupCurry as statusToLookup, statusToDataCurry as statusToData, };
24
10
  //# sourceMappingURL=draft-and-publish.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"draft-and-publish.d.ts","sourceRoot":"","sources":["../../../src/services/document-service/draft-and-publish.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAG1C,KAAK,eAAe,GAAG,CAAC,MAAM,EAAE,SAAS,CAAC,MAAM,CAAC,GAAG,KAAK,SAAS,CAAC,MAAM,CAAC,GAAG,CAAC;AAE9E;;GAEG;AACH,eAAO,MAAM,gBAAgB,EAAE,eAA0C,CAAC;AAE1E;;GAEG;AACH,eAAO,MAAM,cAAc,EAAE,eAO5B,CAAC;AAEF;;GAEG;AACH,eAAO,MAAM,qBAAqB,EAAE,eAMnC,CAAC;AAEF;;GAEG;AACH,eAAO,MAAM,cAAc,EAAE,eAa5B,CAAC;AAEF;;GAEG;AACH,eAAO,MAAM,YAAY,EAAE,eAW1B,CAAC"}
1
+ {"version":3,"file":"draft-and-publish.d.ts","sourceRoot":"","sources":["../../../src/services/document-service/draft-and-publish.ts"],"names":[],"mappings":";AAEA,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAwGhD,QAAA,MAAM,qBAAqB,sJAA0B,CAAC;AACtD,QAAA,MAAM,mBAAmB,+FAAwB,CAAC;AAClD,QAAA,MAAM,kBAAkB,sJAAuB,CAAC;AAChD,QAAA,MAAM,0BAA0B,+FAA+B,CAAC;AAChE,QAAA,MAAM,mBAAmB,sJAAwB,CAAC;AAClD,QAAA,MAAM,iBAAiB,sJAAsB,CAAC;AAE9C,OAAO,EACL,qBAAqB,IAAI,gBAAgB,EACzC,mBAAmB,IAAI,cAAc,EACrC,kBAAkB,IAAI,aAAa,EACnC,0BAA0B,IAAI,qBAAqB,EACnD,mBAAmB,IAAI,cAAc,EACrC,iBAAiB,IAAI,YAAY,GAClC,CAAC"}
@@ -1,41 +1,69 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const _ = require("lodash/fp");
4
- const setStatusToDraft = _.assoc("status", "draft");
3
+ const fp = require("lodash/fp");
4
+ const strapiUtils = require("@strapi/utils");
5
+ const setStatusToDraft = (contentType, params) => {
6
+ if (!strapiUtils.contentTypes.hasDraftAndPublish(contentType) && params.status) {
7
+ return params;
8
+ }
9
+ return fp.assoc("status", "draft", params);
10
+ };
5
11
  const defaultToDraft = (params) => {
6
12
  if (!params.status || params.status !== "published") {
7
- return setStatusToDraft(params);
13
+ return fp.assoc("status", "draft", params);
14
+ }
15
+ return params;
16
+ };
17
+ const defaultStatus = (contentType, params) => {
18
+ if (!strapiUtils.contentTypes.hasDraftAndPublish(contentType)) {
19
+ return params;
20
+ }
21
+ if (!params.status || params.status !== "published") {
22
+ return defaultToDraft(params);
8
23
  }
9
24
  return params;
10
25
  };
11
26
  const filterDataPublishedAt = (params) => {
12
27
  if (params?.data?.publishedAt) {
13
- return _.assoc(["data", "publishedAt"], null, params);
28
+ return fp.assoc(["data", "publishedAt"], null, params);
14
29
  }
15
30
  return params;
16
31
  };
17
- const statusToLookup = (params) => {
32
+ const statusToLookup = (contentType, params) => {
33
+ if (!strapiUtils.contentTypes.hasDraftAndPublish(contentType)) {
34
+ return params;
35
+ }
18
36
  const lookup = params.lookup || {};
19
37
  switch (params?.status) {
20
38
  case "published":
21
- return _.assoc(["lookup", "publishedAt"], { $notNull: true }, params);
39
+ return fp.assoc(["lookup", "publishedAt"], { $notNull: true }, params);
22
40
  case "draft":
23
- return _.assoc(["lookup", "publishedAt"], { $null: true }, params);
41
+ return fp.assoc(["lookup", "publishedAt"], { $null: true }, params);
24
42
  }
25
- return _.assoc("lookup", lookup, params);
43
+ return fp.assoc("lookup", lookup, params);
26
44
  };
27
- const statusToData = (params) => {
45
+ const statusToData = (contentType, params) => {
46
+ if (!strapiUtils.contentTypes.hasDraftAndPublish(contentType)) {
47
+ return fp.assoc(["data", "publishedAt"], /* @__PURE__ */ new Date(), params);
48
+ }
28
49
  switch (params?.status) {
29
50
  case "published":
30
- return _.assoc(["data", "publishedAt"], /* @__PURE__ */ new Date(), params);
51
+ return fp.assoc(["data", "publishedAt"], /* @__PURE__ */ new Date(), params);
31
52
  case "draft":
32
- return _.assoc(["data", "publishedAt"], null, params);
53
+ return fp.assoc(["data", "publishedAt"], null, params);
33
54
  }
34
55
  return params;
35
56
  };
36
- exports.defaultToDraft = defaultToDraft;
37
- exports.filterDataPublishedAt = filterDataPublishedAt;
38
- exports.setStatusToDraft = setStatusToDraft;
39
- exports.statusToData = statusToData;
40
- exports.statusToLookup = statusToLookup;
57
+ const setStatusToDraftCurry = fp.curry(setStatusToDraft);
58
+ const defaultToDraftCurry = fp.curry(defaultToDraft);
59
+ const defaultStatusCurry = fp.curry(defaultStatus);
60
+ const filterDataPublishedAtCurry = fp.curry(filterDataPublishedAt);
61
+ const statusToLookupCurry = fp.curry(statusToLookup);
62
+ const statusToDataCurry = fp.curry(statusToData);
63
+ exports.defaultStatus = defaultStatusCurry;
64
+ exports.defaultToDraft = defaultToDraftCurry;
65
+ exports.filterDataPublishedAt = filterDataPublishedAtCurry;
66
+ exports.setStatusToDraft = setStatusToDraftCurry;
67
+ exports.statusToData = statusToDataCurry;
68
+ exports.statusToLookup = statusToLookupCurry;
41
69
  //# sourceMappingURL=draft-and-publish.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"draft-and-publish.js","sources":["../../../src/services/document-service/draft-and-publish.ts"],"sourcesContent":["import { Documents } from '@strapi/types';\nimport { assoc } from 'lodash/fp';\n\ntype ParamsTransform = (params: Documents.Params.All) => Documents.Params.All;\n\n/**\n * Sets status to draft only\n */\nexport const setStatusToDraft: ParamsTransform = assoc('status', 'draft');\n\n/**\n * Adds a default status of `draft` to the params\n */\nexport const defaultToDraft: ParamsTransform = (params) => {\n // Default to draft if no status is provided or it's invalid\n if (!params.status || params.status !== 'published') {\n return setStatusToDraft(params);\n }\n\n return params;\n};\n\n/**\n * In mutating actions we don't want user to set the publishedAt attribute.\n */\nexport const filterDataPublishedAt: ParamsTransform = (params) => {\n if (params?.data?.publishedAt) {\n return assoc(['data', 'publishedAt'], null, params);\n }\n\n return params;\n};\n\n/**\n * Add status lookup query to the params\n */\nexport const statusToLookup: ParamsTransform = (params) => {\n const lookup = params.lookup || {};\n\n switch (params?.status) {\n case 'published':\n return assoc(['lookup', 'publishedAt'], { $notNull: true }, params);\n case 'draft':\n return assoc(['lookup', 'publishedAt'], { $null: true }, params);\n default:\n break;\n }\n\n return assoc('lookup', lookup, params);\n};\n\n/**\n * Translate publication status parameter into the data that will be saved\n */\nexport const statusToData: ParamsTransform = (params) => {\n switch (params?.status) {\n case 'published':\n return assoc(['data', 'publishedAt'], new Date(), params);\n case 'draft':\n return assoc(['data', 'publishedAt'], null, params);\n default:\n break;\n }\n\n return params;\n};\n"],"names":["assoc"],"mappings":";;;AAQa,MAAA,mBAAoCA,EAAAA,MAAM,UAAU,OAAO;AAK3D,MAAA,iBAAkC,CAAC,WAAW;AAEzD,MAAI,CAAC,OAAO,UAAU,OAAO,WAAW,aAAa;AACnD,WAAO,iBAAiB,MAAM;AAAA,EAChC;AAEO,SAAA;AACT;AAKa,MAAA,wBAAyC,CAAC,WAAW;AAC5D,MAAA,QAAQ,MAAM,aAAa;AAC7B,WAAOA,EAAAA,MAAM,CAAC,QAAQ,aAAa,GAAG,MAAM,MAAM;AAAA,EACpD;AAEO,SAAA;AACT;AAKa,MAAA,iBAAkC,CAAC,WAAW;AACnD,QAAA,SAAS,OAAO,UAAU;AAEhC,UAAQ,QAAQ,QAAQ;AAAA,IACtB,KAAK;AACI,aAAAA,EAAA,MAAM,CAAC,UAAU,aAAa,GAAG,EAAE,UAAU,QAAQ,MAAM;AAAA,IACpE,KAAK;AACI,aAAAA,EAAA,MAAM,CAAC,UAAU,aAAa,GAAG,EAAE,OAAO,QAAQ,MAAM;AAAA,EAGnE;AAEO,SAAAA,QAAM,UAAU,QAAQ,MAAM;AACvC;AAKa,MAAA,eAAgC,CAAC,WAAW;AACvD,UAAQ,QAAQ,QAAQ;AAAA,IACtB,KAAK;AACI,aAAAA,EAAAA,MAAM,CAAC,QAAQ,aAAa,GAAO,oBAAA,KAAA,GAAQ,MAAM;AAAA,IAC1D,KAAK;AACH,aAAOA,EAAAA,MAAM,CAAC,QAAQ,aAAa,GAAG,MAAM,MAAM;AAAA,EAGtD;AAEO,SAAA;AACT;;;;;;"}
1
+ {"version":3,"file":"draft-and-publish.js","sources":["../../../src/services/document-service/draft-and-publish.ts"],"sourcesContent":["import { assoc, curry } from 'lodash/fp';\n\nimport { Modules, Struct } from '@strapi/types';\nimport { contentTypes } from '@strapi/utils';\n\ntype ParamsTransform = (params: Modules.Documents.Params.All) => Modules.Documents.Params.All;\n\ntype TransformWithContentType = (\n contentType: Struct.SingleTypeSchema | Struct.CollectionTypeSchema,\n params: Modules.Documents.Params.All\n) => Modules.Documents.Params.All;\n\n/**\n * DP enabled -> set status to draft\n * DP disabled -> Used mostly for parsing relations, so there is not a need for a default.\n */\nconst setStatusToDraft: TransformWithContentType = (contentType, params) => {\n if (!contentTypes.hasDraftAndPublish(contentType) && params.status) {\n return params;\n }\n\n return assoc('status', 'draft', params);\n};\n\n/**\n * Adds a default status of `draft` to the params\n */\nconst defaultToDraft: ParamsTransform = (params) => {\n // Default to draft if no status is provided or it's invalid\n if (!params.status || params.status !== 'published') {\n return assoc('status', 'draft', params);\n }\n\n return params;\n};\n\n/**\n * DP disabled -> ignore status\n * DP enabled -> set status to draft if no status is provided or it's invalid\n */\nconst defaultStatus: TransformWithContentType = (contentType, params) => {\n if (!contentTypes.hasDraftAndPublish(contentType)) {\n return params;\n }\n\n // Default to draft if no status is provided or it's invalid\n if (!params.status || params.status !== 'published') {\n return defaultToDraft(params);\n }\n\n return params;\n};\n\n/**\n * In mutating actions we don't want user to set the publishedAt attribute.\n */\nconst filterDataPublishedAt: ParamsTransform = (params) => {\n if (params?.data?.publishedAt) {\n return assoc(['data', 'publishedAt'], null, params);\n }\n\n return params;\n};\n\n/**\n * Add status lookup query to the params\n */\nconst statusToLookup: TransformWithContentType = (contentType, params) => {\n if (!contentTypes.hasDraftAndPublish(contentType)) {\n return params;\n }\n\n const lookup = params.lookup || {};\n\n switch (params?.status) {\n case 'published':\n return assoc(['lookup', 'publishedAt'], { $notNull: true }, params);\n case 'draft':\n return assoc(['lookup', 'publishedAt'], { $null: true }, params);\n default:\n break;\n }\n\n return assoc('lookup', lookup, params);\n};\n\n/**\n * Translate publication status parameter into the data that will be saved\n */\nconst statusToData: TransformWithContentType = (contentType, params) => {\n if (!contentTypes.hasDraftAndPublish(contentType)) {\n return assoc(['data', 'publishedAt'], new Date(), params);\n }\n\n switch (params?.status) {\n case 'published':\n return assoc(['data', 'publishedAt'], new Date(), params);\n case 'draft':\n return assoc(['data', 'publishedAt'], null, params);\n default:\n break;\n }\n\n return params;\n};\n\nconst setStatusToDraftCurry = curry(setStatusToDraft);\nconst defaultToDraftCurry = curry(defaultToDraft);\nconst defaultStatusCurry = curry(defaultStatus);\nconst filterDataPublishedAtCurry = curry(filterDataPublishedAt);\nconst statusToLookupCurry = curry(statusToLookup);\nconst statusToDataCurry = curry(statusToData);\n\nexport {\n setStatusToDraftCurry as setStatusToDraft,\n defaultToDraftCurry as defaultToDraft,\n defaultStatusCurry as defaultStatus,\n filterDataPublishedAtCurry as filterDataPublishedAt,\n statusToLookupCurry as statusToLookup,\n statusToDataCurry as statusToData,\n};\n"],"names":["contentTypes","assoc","curry"],"mappings":";;;;AAgBA,MAAM,mBAA6C,CAAC,aAAa,WAAW;AAC1E,MAAI,CAACA,YAAa,aAAA,mBAAmB,WAAW,KAAK,OAAO,QAAQ;AAC3D,WAAA;AAAA,EAAA;AAGF,SAAAC,SAAM,UAAU,SAAS,MAAM;AACxC;AAKA,MAAM,iBAAkC,CAAC,WAAW;AAElD,MAAI,CAAC,OAAO,UAAU,OAAO,WAAW,aAAa;AAC5C,WAAAA,SAAM,UAAU,SAAS,MAAM;AAAA,EAAA;AAGjC,SAAA;AACT;AAMA,MAAM,gBAA0C,CAAC,aAAa,WAAW;AACvE,MAAI,CAACD,YAAA,aAAa,mBAAmB,WAAW,GAAG;AAC1C,WAAA;AAAA,EAAA;AAIT,MAAI,CAAC,OAAO,UAAU,OAAO,WAAW,aAAa;AACnD,WAAO,eAAe,MAAM;AAAA,EAAA;AAGvB,SAAA;AACT;AAKA,MAAM,wBAAyC,CAAC,WAAW;AACrD,MAAA,QAAQ,MAAM,aAAa;AAC7B,WAAOC,GAAAA,MAAM,CAAC,QAAQ,aAAa,GAAG,MAAM,MAAM;AAAA,EAAA;AAG7C,SAAA;AACT;AAKA,MAAM,iBAA2C,CAAC,aAAa,WAAW;AACxE,MAAI,CAACD,YAAA,aAAa,mBAAmB,WAAW,GAAG;AAC1C,WAAA;AAAA,EAAA;AAGH,QAAA,SAAS,OAAO,UAAU,CAAC;AAEjC,UAAQ,QAAQ,QAAQ;AAAA,IACtB,KAAK;AACI,aAAAC,GAAA,MAAM,CAAC,UAAU,aAAa,GAAG,EAAE,UAAU,KAAK,GAAG,MAAM;AAAA,IACpE,KAAK;AACI,aAAAA,GAAA,MAAM,CAAC,UAAU,aAAa,GAAG,EAAE,OAAO,KAAK,GAAG,MAAM;AAAA,EAE/D;AAGG,SAAAA,SAAM,UAAU,QAAQ,MAAM;AACvC;AAKA,MAAM,eAAyC,CAAC,aAAa,WAAW;AACtE,MAAI,CAACD,YAAA,aAAa,mBAAmB,WAAW,GAAG;AAC1C,WAAAC,GAAAA,MAAM,CAAC,QAAQ,aAAa,GAAO,oBAAA,QAAQ,MAAM;AAAA,EAAA;AAG1D,UAAQ,QAAQ,QAAQ;AAAA,IACtB,KAAK;AACI,aAAAA,GAAAA,MAAM,CAAC,QAAQ,aAAa,GAAO,oBAAA,QAAQ,MAAM;AAAA,IAC1D,KAAK;AACH,aAAOA,GAAAA,MAAM,CAAC,QAAQ,aAAa,GAAG,MAAM,MAAM;AAAA,EAElD;AAGG,SAAA;AACT;AAEM,MAAA,wBAAwBC,SAAM,gBAAgB;AAC9C,MAAA,sBAAsBA,SAAM,cAAc;AAC1C,MAAA,qBAAqBA,SAAM,aAAa;AACxC,MAAA,6BAA6BA,SAAM,qBAAqB;AACxD,MAAA,sBAAsBA,SAAM,cAAc;AAC1C,MAAA,oBAAoBA,SAAM,YAAY;;;;;;;"}
@@ -1,8 +1,23 @@
1
- import { assoc } from "lodash/fp";
2
- const setStatusToDraft = assoc("status", "draft");
1
+ import { curry, assoc } from "lodash/fp";
2
+ import { contentTypes } from "@strapi/utils";
3
+ const setStatusToDraft = (contentType, params) => {
4
+ if (!contentTypes.hasDraftAndPublish(contentType) && params.status) {
5
+ return params;
6
+ }
7
+ return assoc("status", "draft", params);
8
+ };
3
9
  const defaultToDraft = (params) => {
4
10
  if (!params.status || params.status !== "published") {
5
- return setStatusToDraft(params);
11
+ return assoc("status", "draft", params);
12
+ }
13
+ return params;
14
+ };
15
+ const defaultStatus = (contentType, params) => {
16
+ if (!contentTypes.hasDraftAndPublish(contentType)) {
17
+ return params;
18
+ }
19
+ if (!params.status || params.status !== "published") {
20
+ return defaultToDraft(params);
6
21
  }
7
22
  return params;
8
23
  };
@@ -12,7 +27,10 @@ const filterDataPublishedAt = (params) => {
12
27
  }
13
28
  return params;
14
29
  };
15
- const statusToLookup = (params) => {
30
+ const statusToLookup = (contentType, params) => {
31
+ if (!contentTypes.hasDraftAndPublish(contentType)) {
32
+ return params;
33
+ }
16
34
  const lookup = params.lookup || {};
17
35
  switch (params?.status) {
18
36
  case "published":
@@ -22,7 +40,10 @@ const statusToLookup = (params) => {
22
40
  }
23
41
  return assoc("lookup", lookup, params);
24
42
  };
25
- const statusToData = (params) => {
43
+ const statusToData = (contentType, params) => {
44
+ if (!contentTypes.hasDraftAndPublish(contentType)) {
45
+ return assoc(["data", "publishedAt"], /* @__PURE__ */ new Date(), params);
46
+ }
26
47
  switch (params?.status) {
27
48
  case "published":
28
49
  return assoc(["data", "publishedAt"], /* @__PURE__ */ new Date(), params);
@@ -31,11 +52,18 @@ const statusToData = (params) => {
31
52
  }
32
53
  return params;
33
54
  };
55
+ const setStatusToDraftCurry = curry(setStatusToDraft);
56
+ const defaultToDraftCurry = curry(defaultToDraft);
57
+ const defaultStatusCurry = curry(defaultStatus);
58
+ const filterDataPublishedAtCurry = curry(filterDataPublishedAt);
59
+ const statusToLookupCurry = curry(statusToLookup);
60
+ const statusToDataCurry = curry(statusToData);
34
61
  export {
35
- defaultToDraft,
36
- filterDataPublishedAt,
37
- setStatusToDraft,
38
- statusToData,
39
- statusToLookup
62
+ defaultStatusCurry as defaultStatus,
63
+ defaultToDraftCurry as defaultToDraft,
64
+ filterDataPublishedAtCurry as filterDataPublishedAt,
65
+ setStatusToDraftCurry as setStatusToDraft,
66
+ statusToDataCurry as statusToData,
67
+ statusToLookupCurry as statusToLookup
40
68
  };
41
69
  //# sourceMappingURL=draft-and-publish.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"draft-and-publish.mjs","sources":["../../../src/services/document-service/draft-and-publish.ts"],"sourcesContent":["import { Documents } from '@strapi/types';\nimport { assoc } from 'lodash/fp';\n\ntype ParamsTransform = (params: Documents.Params.All) => Documents.Params.All;\n\n/**\n * Sets status to draft only\n */\nexport const setStatusToDraft: ParamsTransform = assoc('status', 'draft');\n\n/**\n * Adds a default status of `draft` to the params\n */\nexport const defaultToDraft: ParamsTransform = (params) => {\n // Default to draft if no status is provided or it's invalid\n if (!params.status || params.status !== 'published') {\n return setStatusToDraft(params);\n }\n\n return params;\n};\n\n/**\n * In mutating actions we don't want user to set the publishedAt attribute.\n */\nexport const filterDataPublishedAt: ParamsTransform = (params) => {\n if (params?.data?.publishedAt) {\n return assoc(['data', 'publishedAt'], null, params);\n }\n\n return params;\n};\n\n/**\n * Add status lookup query to the params\n */\nexport const statusToLookup: ParamsTransform = (params) => {\n const lookup = params.lookup || {};\n\n switch (params?.status) {\n case 'published':\n return assoc(['lookup', 'publishedAt'], { $notNull: true }, params);\n case 'draft':\n return assoc(['lookup', 'publishedAt'], { $null: true }, params);\n default:\n break;\n }\n\n return assoc('lookup', lookup, params);\n};\n\n/**\n * Translate publication status parameter into the data that will be saved\n */\nexport const statusToData: ParamsTransform = (params) => {\n switch (params?.status) {\n case 'published':\n return assoc(['data', 'publishedAt'], new Date(), params);\n case 'draft':\n return assoc(['data', 'publishedAt'], null, params);\n default:\n break;\n }\n\n return params;\n};\n"],"names":[],"mappings":";AAQa,MAAA,mBAAoC,MAAM,UAAU,OAAO;AAK3D,MAAA,iBAAkC,CAAC,WAAW;AAEzD,MAAI,CAAC,OAAO,UAAU,OAAO,WAAW,aAAa;AACnD,WAAO,iBAAiB,MAAM;AAAA,EAChC;AAEO,SAAA;AACT;AAKa,MAAA,wBAAyC,CAAC,WAAW;AAC5D,MAAA,QAAQ,MAAM,aAAa;AAC7B,WAAO,MAAM,CAAC,QAAQ,aAAa,GAAG,MAAM,MAAM;AAAA,EACpD;AAEO,SAAA;AACT;AAKa,MAAA,iBAAkC,CAAC,WAAW;AACnD,QAAA,SAAS,OAAO,UAAU;AAEhC,UAAQ,QAAQ,QAAQ;AAAA,IACtB,KAAK;AACI,aAAA,MAAM,CAAC,UAAU,aAAa,GAAG,EAAE,UAAU,QAAQ,MAAM;AAAA,IACpE,KAAK;AACI,aAAA,MAAM,CAAC,UAAU,aAAa,GAAG,EAAE,OAAO,QAAQ,MAAM;AAAA,EAGnE;AAEO,SAAA,MAAM,UAAU,QAAQ,MAAM;AACvC;AAKa,MAAA,eAAgC,CAAC,WAAW;AACvD,UAAQ,QAAQ,QAAQ;AAAA,IACtB,KAAK;AACI,aAAA,MAAM,CAAC,QAAQ,aAAa,GAAO,oBAAA,KAAA,GAAQ,MAAM;AAAA,IAC1D,KAAK;AACH,aAAO,MAAM,CAAC,QAAQ,aAAa,GAAG,MAAM,MAAM;AAAA,EAGtD;AAEO,SAAA;AACT;"}
1
+ {"version":3,"file":"draft-and-publish.mjs","sources":["../../../src/services/document-service/draft-and-publish.ts"],"sourcesContent":["import { assoc, curry } from 'lodash/fp';\n\nimport { Modules, Struct } from '@strapi/types';\nimport { contentTypes } from '@strapi/utils';\n\ntype ParamsTransform = (params: Modules.Documents.Params.All) => Modules.Documents.Params.All;\n\ntype TransformWithContentType = (\n contentType: Struct.SingleTypeSchema | Struct.CollectionTypeSchema,\n params: Modules.Documents.Params.All\n) => Modules.Documents.Params.All;\n\n/**\n * DP enabled -> set status to draft\n * DP disabled -> Used mostly for parsing relations, so there is not a need for a default.\n */\nconst setStatusToDraft: TransformWithContentType = (contentType, params) => {\n if (!contentTypes.hasDraftAndPublish(contentType) && params.status) {\n return params;\n }\n\n return assoc('status', 'draft', params);\n};\n\n/**\n * Adds a default status of `draft` to the params\n */\nconst defaultToDraft: ParamsTransform = (params) => {\n // Default to draft if no status is provided or it's invalid\n if (!params.status || params.status !== 'published') {\n return assoc('status', 'draft', params);\n }\n\n return params;\n};\n\n/**\n * DP disabled -> ignore status\n * DP enabled -> set status to draft if no status is provided or it's invalid\n */\nconst defaultStatus: TransformWithContentType = (contentType, params) => {\n if (!contentTypes.hasDraftAndPublish(contentType)) {\n return params;\n }\n\n // Default to draft if no status is provided or it's invalid\n if (!params.status || params.status !== 'published') {\n return defaultToDraft(params);\n }\n\n return params;\n};\n\n/**\n * In mutating actions we don't want user to set the publishedAt attribute.\n */\nconst filterDataPublishedAt: ParamsTransform = (params) => {\n if (params?.data?.publishedAt) {\n return assoc(['data', 'publishedAt'], null, params);\n }\n\n return params;\n};\n\n/**\n * Add status lookup query to the params\n */\nconst statusToLookup: TransformWithContentType = (contentType, params) => {\n if (!contentTypes.hasDraftAndPublish(contentType)) {\n return params;\n }\n\n const lookup = params.lookup || {};\n\n switch (params?.status) {\n case 'published':\n return assoc(['lookup', 'publishedAt'], { $notNull: true }, params);\n case 'draft':\n return assoc(['lookup', 'publishedAt'], { $null: true }, params);\n default:\n break;\n }\n\n return assoc('lookup', lookup, params);\n};\n\n/**\n * Translate publication status parameter into the data that will be saved\n */\nconst statusToData: TransformWithContentType = (contentType, params) => {\n if (!contentTypes.hasDraftAndPublish(contentType)) {\n return assoc(['data', 'publishedAt'], new Date(), params);\n }\n\n switch (params?.status) {\n case 'published':\n return assoc(['data', 'publishedAt'], new Date(), params);\n case 'draft':\n return assoc(['data', 'publishedAt'], null, params);\n default:\n break;\n }\n\n return params;\n};\n\nconst setStatusToDraftCurry = curry(setStatusToDraft);\nconst defaultToDraftCurry = curry(defaultToDraft);\nconst defaultStatusCurry = curry(defaultStatus);\nconst filterDataPublishedAtCurry = curry(filterDataPublishedAt);\nconst statusToLookupCurry = curry(statusToLookup);\nconst statusToDataCurry = curry(statusToData);\n\nexport {\n setStatusToDraftCurry as setStatusToDraft,\n defaultToDraftCurry as defaultToDraft,\n defaultStatusCurry as defaultStatus,\n filterDataPublishedAtCurry as filterDataPublishedAt,\n statusToLookupCurry as statusToLookup,\n statusToDataCurry as statusToData,\n};\n"],"names":[],"mappings":";;AAgBA,MAAM,mBAA6C,CAAC,aAAa,WAAW;AAC1E,MAAI,CAAC,aAAa,mBAAmB,WAAW,KAAK,OAAO,QAAQ;AAC3D,WAAA;AAAA,EAAA;AAGF,SAAA,MAAM,UAAU,SAAS,MAAM;AACxC;AAKA,MAAM,iBAAkC,CAAC,WAAW;AAElD,MAAI,CAAC,OAAO,UAAU,OAAO,WAAW,aAAa;AAC5C,WAAA,MAAM,UAAU,SAAS,MAAM;AAAA,EAAA;AAGjC,SAAA;AACT;AAMA,MAAM,gBAA0C,CAAC,aAAa,WAAW;AACvE,MAAI,CAAC,aAAa,mBAAmB,WAAW,GAAG;AAC1C,WAAA;AAAA,EAAA;AAIT,MAAI,CAAC,OAAO,UAAU,OAAO,WAAW,aAAa;AACnD,WAAO,eAAe,MAAM;AAAA,EAAA;AAGvB,SAAA;AACT;AAKA,MAAM,wBAAyC,CAAC,WAAW;AACrD,MAAA,QAAQ,MAAM,aAAa;AAC7B,WAAO,MAAM,CAAC,QAAQ,aAAa,GAAG,MAAM,MAAM;AAAA,EAAA;AAG7C,SAAA;AACT;AAKA,MAAM,iBAA2C,CAAC,aAAa,WAAW;AACxE,MAAI,CAAC,aAAa,mBAAmB,WAAW,GAAG;AAC1C,WAAA;AAAA,EAAA;AAGH,QAAA,SAAS,OAAO,UAAU,CAAC;AAEjC,UAAQ,QAAQ,QAAQ;AAAA,IACtB,KAAK;AACI,aAAA,MAAM,CAAC,UAAU,aAAa,GAAG,EAAE,UAAU,KAAK,GAAG,MAAM;AAAA,IACpE,KAAK;AACI,aAAA,MAAM,CAAC,UAAU,aAAa,GAAG,EAAE,OAAO,KAAK,GAAG,MAAM;AAAA,EAE/D;AAGG,SAAA,MAAM,UAAU,QAAQ,MAAM;AACvC;AAKA,MAAM,eAAyC,CAAC,aAAa,WAAW;AACtE,MAAI,CAAC,aAAa,mBAAmB,WAAW,GAAG;AAC1C,WAAA,MAAM,CAAC,QAAQ,aAAa,GAAO,oBAAA,QAAQ,MAAM;AAAA,EAAA;AAG1D,UAAQ,QAAQ,QAAQ;AAAA,IACtB,KAAK;AACI,aAAA,MAAM,CAAC,QAAQ,aAAa,GAAO,oBAAA,QAAQ,MAAM;AAAA,IAC1D,KAAK;AACH,aAAO,MAAM,CAAC,QAAQ,aAAa,GAAG,MAAM,MAAM;AAAA,EAElD;AAGG,SAAA;AACT;AAEM,MAAA,wBAAwB,MAAM,gBAAgB;AAC9C,MAAA,sBAAsB,MAAM,cAAc;AAC1C,MAAA,qBAAqB,MAAM,aAAa;AACxC,MAAA,6BAA6B,MAAM,qBAAqB;AACxD,MAAA,sBAAsB,MAAM,cAAc;AAC1C,MAAA,oBAAoB,MAAM,YAAY;"}
@@ -0,0 +1,10 @@
1
+ import type { UID, Modules } from '@strapi/types';
2
+ declare const createEntriesService: (uid: UID.ContentType, entityValidator: Modules.EntityValidator.EntityValidator) => {
3
+ create: (params?: any) => Promise<any>;
4
+ delete: (id: number) => Promise<any>;
5
+ update: (entryToUpdate: any, params?: any) => Promise<any>;
6
+ publish: (entry: any, params?: any) => Promise<object>;
7
+ discardDraft: (entry: any, params?: any) => Promise<object>;
8
+ };
9
+ export { createEntriesService };
10
+ //# sourceMappingURL=entries.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"entries.d.ts","sourceRoot":"","sources":["../../../src/services/document-service/entries.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,GAAG,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AAYlD,QAAA,MAAM,oBAAoB,QACnB,IAAI,WAAW,mBACH,QAAQ,eAAe,CAAC,eAAe;;iBAmCzB,MAAM;4BAUK,GAAG;qBA4BV,GAAG;0BAaE,GAAG;CAoB5C,CAAC;AAEF,OAAO,EAAE,oBAAoB,EAAE,CAAC"}