@strapi/core 0.0.0-experimental.fc1ac2acd58c8a5a858679956b6d102ac5ee4011 → 0.0.0-experimental.fca58d9b01ba89012d84a58a20556a6fd716cb92

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 (1014) 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 +436 -431
  5. package/dist/Strapi.js.map +1 -1
  6. package/dist/Strapi.mjs +427 -442
  7. package/dist/Strapi.mjs.map +1 -1
  8. package/dist/compile.js +23 -14
  9. package/dist/compile.js.map +1 -1
  10. package/dist/compile.mjs +22 -14
  11. package/dist/compile.mjs.map +1 -1
  12. package/dist/configuration/config-loader.d.ts.map +1 -1
  13. package/dist/configuration/config-loader.js +110 -93
  14. package/dist/configuration/config-loader.js.map +1 -1
  15. package/dist/configuration/config-loader.mjs +109 -92
  16. package/dist/configuration/config-loader.mjs.map +1 -1
  17. package/dist/configuration/get-dirs.d.ts +10 -0
  18. package/dist/configuration/get-dirs.d.ts.map +1 -0
  19. package/dist/configuration/get-dirs.js +33 -0
  20. package/dist/configuration/get-dirs.js.map +1 -0
  21. package/dist/configuration/get-dirs.mjs +31 -0
  22. package/dist/configuration/get-dirs.mjs.map +1 -0
  23. package/dist/configuration/index.d.ts +5 -7
  24. package/dist/configuration/index.d.ts.map +1 -1
  25. package/dist/configuration/index.js +86 -72
  26. package/dist/configuration/index.js.map +1 -1
  27. package/dist/configuration/index.mjs +84 -68
  28. package/dist/configuration/index.mjs.map +1 -1
  29. package/dist/configuration/urls.d.ts.map +1 -1
  30. package/dist/configuration/urls.js +74 -61
  31. package/dist/configuration/urls.js.map +1 -1
  32. package/dist/configuration/urls.mjs +73 -62
  33. package/dist/configuration/urls.mjs.map +1 -1
  34. package/dist/container.d.ts +2 -2
  35. package/dist/container.d.ts.map +1 -1
  36. package/dist/container.js +27 -23
  37. package/dist/container.js.map +1 -1
  38. package/dist/container.mjs +26 -24
  39. package/dist/container.mjs.map +1 -1
  40. package/dist/core-api/controller/collection-type.d.ts +3 -3
  41. package/dist/core-api/controller/collection-type.d.ts.map +1 -1
  42. package/dist/core-api/controller/collection-type.js +77 -73
  43. package/dist/core-api/controller/collection-type.js.map +1 -1
  44. package/dist/core-api/controller/collection-type.mjs +76 -74
  45. package/dist/core-api/controller/collection-type.mjs.map +1 -1
  46. package/dist/core-api/controller/index.d.ts +3 -3
  47. package/dist/core-api/controller/index.d.ts.map +1 -1
  48. package/dist/core-api/controller/index.js +63 -48
  49. package/dist/core-api/controller/index.js.map +1 -1
  50. package/dist/core-api/controller/index.mjs +62 -49
  51. package/dist/core-api/controller/index.mjs.map +1 -1
  52. package/dist/core-api/controller/single-type.d.ts +3 -3
  53. package/dist/core-api/controller/single-type.d.ts.map +1 -1
  54. package/dist/core-api/controller/single-type.js +41 -39
  55. package/dist/core-api/controller/single-type.js.map +1 -1
  56. package/dist/core-api/controller/single-type.mjs +40 -40
  57. package/dist/core-api/controller/single-type.mjs.map +1 -1
  58. package/dist/core-api/controller/transform.d.ts +2 -2
  59. package/dist/core-api/controller/transform.d.ts.map +1 -1
  60. package/dist/core-api/controller/transform.js +72 -66
  61. package/dist/core-api/controller/transform.js.map +1 -1
  62. package/dist/core-api/controller/transform.mjs +71 -67
  63. package/dist/core-api/controller/transform.mjs.map +1 -1
  64. package/dist/core-api/routes/index.d.ts.map +1 -1
  65. package/dist/core-api/routes/index.js +64 -62
  66. package/dist/core-api/routes/index.js.map +1 -1
  67. package/dist/core-api/routes/index.mjs +62 -62
  68. package/dist/core-api/routes/index.mjs.map +1 -1
  69. package/dist/core-api/service/collection-type.d.ts +11 -17
  70. package/dist/core-api/service/collection-type.d.ts.map +1 -1
  71. package/dist/core-api/service/collection-type.js +73 -49
  72. package/dist/core-api/service/collection-type.js.map +1 -1
  73. package/dist/core-api/service/collection-type.mjs +72 -51
  74. package/dist/core-api/service/collection-type.mjs.map +1 -1
  75. package/dist/core-api/service/core-service.js +9 -8
  76. package/dist/core-api/service/core-service.js.map +1 -1
  77. package/dist/core-api/service/core-service.mjs +8 -9
  78. package/dist/core-api/service/core-service.mjs.map +1 -1
  79. package/dist/core-api/service/index.d.ts +3 -3
  80. package/dist/core-api/service/index.d.ts.map +1 -1
  81. package/dist/core-api/service/index.js +13 -13
  82. package/dist/core-api/service/index.js.map +1 -1
  83. package/dist/core-api/service/index.mjs +12 -14
  84. package/dist/core-api/service/index.mjs.map +1 -1
  85. package/dist/core-api/service/pagination.d.ts +4 -11
  86. package/dist/core-api/service/pagination.d.ts.map +1 -1
  87. package/dist/core-api/service/pagination.js +68 -68
  88. package/dist/core-api/service/pagination.js.map +1 -1
  89. package/dist/core-api/service/pagination.mjs +66 -71
  90. package/dist/core-api/service/pagination.mjs.map +1 -1
  91. package/dist/core-api/service/single-type.d.ts +4 -4
  92. package/dist/core-api/service/single-type.d.ts.map +1 -1
  93. package/dist/core-api/service/single-type.js +43 -32
  94. package/dist/core-api/service/single-type.js.map +1 -1
  95. package/dist/core-api/service/single-type.mjs +42 -34
  96. package/dist/core-api/service/single-type.mjs.map +1 -1
  97. package/dist/domain/content-type/index.d.ts +1 -1
  98. package/dist/domain/content-type/index.d.ts.map +1 -1
  99. package/dist/domain/content-type/index.js +95 -100
  100. package/dist/domain/content-type/index.js.map +1 -1
  101. package/dist/domain/content-type/index.mjs +94 -100
  102. package/dist/domain/content-type/index.mjs.map +1 -1
  103. package/dist/domain/content-type/validator.js +84 -69
  104. package/dist/domain/content-type/validator.js.map +1 -1
  105. package/dist/domain/content-type/validator.mjs +83 -68
  106. package/dist/domain/content-type/validator.mjs.map +1 -1
  107. package/dist/domain/module/index.d.ts +24 -23
  108. package/dist/domain/module/index.d.ts.map +1 -1
  109. package/dist/domain/module/index.js +109 -99
  110. package/dist/domain/module/index.js.map +1 -1
  111. package/dist/domain/module/index.mjs +108 -98
  112. package/dist/domain/module/index.mjs.map +1 -1
  113. package/dist/domain/module/validation.js +25 -20
  114. package/dist/domain/module/validation.js.map +1 -1
  115. package/dist/domain/module/validation.mjs +24 -21
  116. package/dist/domain/module/validation.mjs.map +1 -1
  117. package/dist/ee/index.d.ts +5 -2
  118. package/dist/ee/index.d.ts.map +1 -1
  119. package/dist/ee/index.js +171 -132
  120. package/dist/ee/index.js.map +1 -1
  121. package/dist/ee/index.mjs +170 -134
  122. package/dist/ee/index.mjs.map +1 -1
  123. package/dist/ee/license.d.ts +2 -2
  124. package/dist/ee/license.d.ts.map +1 -1
  125. package/dist/ee/license.js +100 -74
  126. package/dist/ee/license.js.map +1 -1
  127. package/dist/ee/license.mjs +99 -75
  128. package/dist/ee/license.mjs.map +1 -1
  129. package/dist/factories.d.ts +10 -10
  130. package/dist/factories.d.ts.map +1 -1
  131. package/dist/factories.js +72 -63
  132. package/dist/factories.js.map +1 -1
  133. package/dist/factories.mjs +71 -67
  134. package/dist/factories.mjs.map +1 -1
  135. package/dist/index.d.ts +18 -2
  136. package/dist/index.d.ts.map +1 -1
  137. package/dist/index.js +32 -5
  138. package/dist/index.js.map +1 -1
  139. package/dist/index.mjs +29 -5
  140. package/dist/index.mjs.map +1 -1
  141. package/dist/loaders/admin.d.ts +2 -2
  142. package/dist/loaders/admin.d.ts.map +1 -1
  143. package/dist/loaders/admin.js +21 -21
  144. package/dist/loaders/admin.js.map +1 -1
  145. package/dist/loaders/admin.mjs +20 -21
  146. package/dist/loaders/admin.mjs.map +1 -1
  147. package/dist/loaders/apis.d.ts +2 -2
  148. package/dist/loaders/apis.d.ts.map +1 -1
  149. package/dist/loaders/apis.js +143 -120
  150. package/dist/loaders/apis.js.map +1 -1
  151. package/dist/loaders/apis.mjs +142 -119
  152. package/dist/loaders/apis.mjs.map +1 -1
  153. package/dist/loaders/components.d.ts +2 -2
  154. package/dist/loaders/components.d.ts.map +1 -1
  155. package/dist/loaders/components.js +33 -34
  156. package/dist/loaders/components.js.map +1 -1
  157. package/dist/loaders/components.mjs +32 -34
  158. package/dist/loaders/components.mjs.map +1 -1
  159. package/dist/loaders/index.d.ts +2 -2
  160. package/dist/loaders/index.d.ts.map +1 -1
  161. package/dist/loaders/index.js +22 -22
  162. package/dist/loaders/index.js.map +1 -1
  163. package/dist/loaders/index.mjs +21 -23
  164. package/dist/loaders/index.mjs.map +1 -1
  165. package/dist/loaders/middlewares.d.ts +2 -2
  166. package/dist/loaders/middlewares.d.ts.map +1 -1
  167. package/dist/loaders/middlewares.js +29 -25
  168. package/dist/loaders/middlewares.js.map +1 -1
  169. package/dist/loaders/middlewares.mjs +28 -25
  170. package/dist/loaders/middlewares.mjs.map +1 -1
  171. package/dist/loaders/plugins/get-enabled-plugins.d.ts +2 -2
  172. package/dist/loaders/plugins/get-enabled-plugins.d.ts.map +1 -1
  173. package/dist/loaders/plugins/get-enabled-plugins.js +125 -100
  174. package/dist/loaders/plugins/get-enabled-plugins.js.map +1 -1
  175. package/dist/loaders/plugins/get-enabled-plugins.mjs +124 -99
  176. package/dist/loaders/plugins/get-enabled-plugins.mjs.map +1 -1
  177. package/dist/loaders/plugins/get-user-plugins-config.js +25 -24
  178. package/dist/loaders/plugins/get-user-plugins-config.js.map +1 -1
  179. package/dist/loaders/plugins/get-user-plugins-config.mjs +24 -23
  180. package/dist/loaders/plugins/get-user-plugins-config.mjs.map +1 -1
  181. package/dist/loaders/plugins/index.d.ts +2 -2
  182. package/dist/loaders/plugins/index.d.ts.map +1 -1
  183. package/dist/loaders/plugins/index.js +141 -104
  184. package/dist/loaders/plugins/index.js.map +1 -1
  185. package/dist/loaders/plugins/index.mjs +121 -104
  186. package/dist/loaders/plugins/index.mjs.map +1 -1
  187. package/dist/loaders/policies.d.ts +2 -2
  188. package/dist/loaders/policies.d.ts.map +1 -1
  189. package/dist/loaders/policies.js +24 -20
  190. package/dist/loaders/policies.js.map +1 -1
  191. package/dist/loaders/policies.mjs +23 -20
  192. package/dist/loaders/policies.mjs.map +1 -1
  193. package/dist/loaders/sanitizers.d.ts +2 -2
  194. package/dist/loaders/sanitizers.d.ts.map +1 -1
  195. package/dist/loaders/sanitizers.js +10 -4
  196. package/dist/loaders/sanitizers.js.map +1 -1
  197. package/dist/loaders/sanitizers.mjs +9 -6
  198. package/dist/loaders/sanitizers.mjs.map +1 -1
  199. package/dist/loaders/src-index.d.ts +2 -2
  200. package/dist/loaders/src-index.d.ts.map +1 -1
  201. package/dist/loaders/src-index.js +35 -27
  202. package/dist/loaders/src-index.js.map +1 -1
  203. package/dist/loaders/src-index.mjs +34 -29
  204. package/dist/loaders/src-index.mjs.map +1 -1
  205. package/dist/loaders/validators.d.ts +2 -2
  206. package/dist/loaders/validators.d.ts.map +1 -1
  207. package/dist/loaders/validators.js +9 -4
  208. package/dist/loaders/validators.js.map +1 -1
  209. package/dist/loaders/validators.mjs +8 -6
  210. package/dist/loaders/validators.mjs.map +1 -1
  211. package/dist/middlewares/body.d.ts +4 -4
  212. package/dist/middlewares/body.d.ts.map +1 -1
  213. package/dist/middlewares/body.js +58 -54
  214. package/dist/middlewares/body.js.map +1 -1
  215. package/dist/middlewares/body.mjs +57 -51
  216. package/dist/middlewares/body.mjs.map +1 -1
  217. package/dist/middlewares/compression.d.ts +2 -2
  218. package/dist/middlewares/compression.d.ts.map +1 -1
  219. package/dist/middlewares/compression.js +6 -6
  220. package/dist/middlewares/compression.js.map +1 -1
  221. package/dist/middlewares/compression.mjs +5 -5
  222. package/dist/middlewares/compression.mjs.map +1 -1
  223. package/dist/middlewares/cors.d.ts +2 -2
  224. package/dist/middlewares/cors.d.ts.map +1 -1
  225. package/dist/middlewares/cors.js +59 -46
  226. package/dist/middlewares/cors.js.map +1 -1
  227. package/dist/middlewares/cors.mjs +58 -45
  228. package/dist/middlewares/cors.mjs.map +1 -1
  229. package/dist/middlewares/errors.d.ts +2 -2
  230. package/dist/middlewares/errors.d.ts.map +1 -1
  231. package/dist/middlewares/errors.js +32 -30
  232. package/dist/middlewares/errors.js.map +1 -1
  233. package/dist/middlewares/errors.mjs +31 -31
  234. package/dist/middlewares/errors.mjs.map +1 -1
  235. package/dist/middlewares/favicon.d.ts +2 -2
  236. package/dist/middlewares/favicon.d.ts.map +1 -1
  237. package/dist/middlewares/favicon.js +27 -17
  238. package/dist/middlewares/favicon.js.map +1 -1
  239. package/dist/middlewares/favicon.mjs +26 -16
  240. package/dist/middlewares/favicon.mjs.map +1 -1
  241. package/dist/middlewares/index.d.ts +2 -2
  242. package/dist/middlewares/index.d.ts.map +1 -1
  243. package/dist/middlewares/index.js +32 -30
  244. package/dist/middlewares/index.js.map +1 -1
  245. package/dist/middlewares/index.mjs +31 -31
  246. package/dist/middlewares/index.mjs.map +1 -1
  247. package/dist/middlewares/ip.d.ts +2 -2
  248. package/dist/middlewares/ip.d.ts.map +1 -1
  249. package/dist/middlewares/ip.js +6 -6
  250. package/dist/middlewares/ip.js.map +1 -1
  251. package/dist/middlewares/ip.mjs +5 -5
  252. package/dist/middlewares/ip.mjs.map +1 -1
  253. package/dist/middlewares/logger.d.ts +2 -2
  254. package/dist/middlewares/logger.d.ts.map +1 -1
  255. package/dist/middlewares/logger.js +10 -9
  256. package/dist/middlewares/logger.js.map +1 -1
  257. package/dist/middlewares/logger.mjs +9 -10
  258. package/dist/middlewares/logger.mjs.map +1 -1
  259. package/dist/middlewares/powered-by.d.ts +2 -2
  260. package/dist/middlewares/powered-by.d.ts.map +1 -1
  261. package/dist/middlewares/powered-by.js +13 -9
  262. package/dist/middlewares/powered-by.js.map +1 -1
  263. package/dist/middlewares/powered-by.mjs +12 -10
  264. package/dist/middlewares/powered-by.mjs.map +1 -1
  265. package/dist/middlewares/public.d.ts +2 -2
  266. package/dist/middlewares/public.d.ts.map +1 -1
  267. package/dist/middlewares/public.js +33 -29
  268. package/dist/middlewares/public.js.map +1 -1
  269. package/dist/middlewares/public.mjs +32 -28
  270. package/dist/middlewares/public.mjs.map +1 -1
  271. package/dist/middlewares/query.d.ts +2 -2
  272. package/dist/middlewares/query.d.ts.map +1 -1
  273. package/dist/middlewares/query.js +35 -32
  274. package/dist/middlewares/query.js.map +1 -1
  275. package/dist/middlewares/query.mjs +34 -31
  276. package/dist/middlewares/query.mjs.map +1 -1
  277. package/dist/middlewares/response-time.d.ts +2 -2
  278. package/dist/middlewares/response-time.d.ts.map +1 -1
  279. package/dist/middlewares/response-time.js +10 -9
  280. package/dist/middlewares/response-time.js.map +1 -1
  281. package/dist/middlewares/response-time.mjs +9 -10
  282. package/dist/middlewares/response-time.mjs.map +1 -1
  283. package/dist/middlewares/responses.d.ts +3 -3
  284. package/dist/middlewares/responses.d.ts.map +1 -1
  285. package/dist/middlewares/responses.js +14 -12
  286. package/dist/middlewares/responses.js.map +1 -1
  287. package/dist/middlewares/responses.mjs +13 -13
  288. package/dist/middlewares/responses.mjs.map +1 -1
  289. package/dist/middlewares/security.d.ts +2 -2
  290. package/dist/middlewares/security.d.ts.map +1 -1
  291. package/dist/middlewares/security.js +110 -65
  292. package/dist/middlewares/security.js.map +1 -1
  293. package/dist/middlewares/security.mjs +108 -63
  294. package/dist/middlewares/security.mjs.map +1 -1
  295. package/dist/middlewares/session.d.ts +2 -2
  296. package/dist/middlewares/session.d.ts.map +1 -1
  297. package/dist/middlewares/session.js +26 -25
  298. package/dist/middlewares/session.js.map +1 -1
  299. package/dist/middlewares/session.mjs +25 -24
  300. package/dist/middlewares/session.mjs.map +1 -1
  301. package/dist/migrations/database/5.0.0-discard-drafts.d.ts +33 -0
  302. package/dist/migrations/database/5.0.0-discard-drafts.d.ts.map +1 -0
  303. package/dist/migrations/database/5.0.0-discard-drafts.js +168 -0
  304. package/dist/migrations/database/5.0.0-discard-drafts.js.map +1 -0
  305. package/dist/migrations/database/5.0.0-discard-drafts.mjs +165 -0
  306. package/dist/migrations/database/5.0.0-discard-drafts.mjs.map +1 -0
  307. package/dist/migrations/draft-publish.d.ts +2 -2
  308. package/dist/migrations/draft-publish.d.ts.map +1 -1
  309. package/dist/migrations/draft-publish.js +59 -49
  310. package/dist/migrations/draft-publish.js.map +1 -1
  311. package/dist/migrations/draft-publish.mjs +58 -51
  312. package/dist/migrations/draft-publish.mjs.map +1 -1
  313. package/dist/migrations/i18n.d.ts +5 -0
  314. package/dist/migrations/i18n.d.ts.map +1 -0
  315. package/dist/migrations/i18n.js +71 -0
  316. package/dist/migrations/i18n.js.map +1 -0
  317. package/dist/migrations/i18n.mjs +68 -0
  318. package/dist/migrations/i18n.mjs.map +1 -0
  319. package/dist/migrations/index.d.ts +5 -0
  320. package/dist/migrations/index.d.ts.map +1 -0
  321. package/dist/migrations/index.js +29 -0
  322. package/dist/migrations/index.js.map +1 -0
  323. package/dist/migrations/index.mjs +26 -0
  324. package/dist/migrations/index.mjs.map +1 -0
  325. package/dist/package.json.js +182 -0
  326. package/dist/package.json.js.map +1 -0
  327. package/dist/package.json.mjs +159 -0
  328. package/dist/package.json.mjs.map +1 -0
  329. package/dist/providers/admin.d.ts +3 -0
  330. package/dist/providers/admin.d.ts.map +1 -0
  331. package/dist/providers/admin.js +30 -0
  332. package/dist/providers/admin.js.map +1 -0
  333. package/dist/providers/admin.mjs +28 -0
  334. package/dist/providers/admin.mjs.map +1 -0
  335. package/dist/providers/coreStore.d.ts +3 -0
  336. package/dist/providers/coreStore.d.ts.map +1 -0
  337. package/dist/providers/coreStore.js +16 -0
  338. package/dist/providers/coreStore.js.map +1 -0
  339. package/dist/providers/coreStore.mjs +14 -0
  340. package/dist/providers/coreStore.mjs.map +1 -0
  341. package/dist/providers/cron.d.ts +3 -0
  342. package/dist/providers/cron.d.ts.map +1 -0
  343. package/dist/providers/cron.js +23 -0
  344. package/dist/providers/cron.js.map +1 -0
  345. package/dist/providers/cron.mjs +21 -0
  346. package/dist/providers/cron.mjs.map +1 -0
  347. package/dist/providers/index.d.ts +3 -0
  348. package/dist/providers/index.d.ts.map +1 -0
  349. package/dist/providers/index.js +20 -0
  350. package/dist/providers/index.js.map +1 -0
  351. package/dist/providers/index.mjs +18 -0
  352. package/dist/providers/index.mjs.map +1 -0
  353. package/dist/providers/provider.d.ts +9 -0
  354. package/dist/providers/provider.d.ts.map +1 -0
  355. package/dist/providers/provider.js +6 -0
  356. package/dist/providers/provider.js.map +1 -0
  357. package/dist/providers/provider.mjs +4 -0
  358. package/dist/providers/provider.mjs.map +1 -0
  359. package/dist/providers/registries.d.ts +3 -0
  360. package/dist/providers/registries.d.ts.map +1 -0
  361. package/dist/providers/registries.js +40 -0
  362. package/dist/providers/registries.js.map +1 -0
  363. package/dist/providers/registries.mjs +38 -0
  364. package/dist/providers/registries.mjs.map +1 -0
  365. package/dist/providers/telemetry.d.ts +3 -0
  366. package/dist/providers/telemetry.d.ts.map +1 -0
  367. package/dist/providers/telemetry.js +22 -0
  368. package/dist/providers/telemetry.js.map +1 -0
  369. package/dist/providers/telemetry.mjs +20 -0
  370. package/dist/providers/telemetry.mjs.map +1 -0
  371. package/dist/providers/webhooks.d.ts +3 -0
  372. package/dist/providers/webhooks.d.ts.map +1 -0
  373. package/dist/providers/webhooks.js +32 -0
  374. package/dist/providers/webhooks.js.map +1 -0
  375. package/dist/providers/webhooks.mjs +30 -0
  376. package/dist/providers/webhooks.mjs.map +1 -0
  377. package/dist/registries/apis.d.ts +2 -2
  378. package/dist/registries/apis.d.ts.map +1 -1
  379. package/dist/registries/apis.js +23 -20
  380. package/dist/registries/apis.js.map +1 -1
  381. package/dist/registries/apis.mjs +22 -22
  382. package/dist/registries/apis.mjs.map +1 -1
  383. package/dist/registries/components.d.ts +6 -6
  384. package/dist/registries/components.d.ts.map +1 -1
  385. package/dist/registries/components.js +35 -37
  386. package/dist/registries/components.js.map +1 -1
  387. package/dist/registries/components.mjs +34 -39
  388. package/dist/registries/components.mjs.map +1 -1
  389. package/dist/registries/content-types.d.ts +5 -5
  390. package/dist/registries/content-types.d.ts.map +1 -1
  391. package/dist/registries/content-types.js +54 -59
  392. package/dist/registries/content-types.js.map +1 -1
  393. package/dist/registries/content-types.mjs +53 -61
  394. package/dist/registries/content-types.mjs.map +1 -1
  395. package/dist/registries/controllers.d.ts +10 -10
  396. package/dist/registries/controllers.d.ts.map +1 -1
  397. package/dist/registries/controllers.js +70 -71
  398. package/dist/registries/controllers.js.map +1 -1
  399. package/dist/registries/controllers.mjs +69 -73
  400. package/dist/registries/controllers.mjs.map +1 -1
  401. package/dist/registries/custom-fields.d.ts +3 -3
  402. package/dist/registries/custom-fields.d.ts.map +1 -1
  403. package/dist/registries/custom-fields.js +75 -65
  404. package/dist/registries/custom-fields.js.map +1 -1
  405. package/dist/registries/custom-fields.mjs +74 -67
  406. package/dist/registries/custom-fields.mjs.map +1 -1
  407. package/dist/registries/hooks.js +46 -49
  408. package/dist/registries/hooks.js.map +1 -1
  409. package/dist/registries/hooks.mjs +45 -51
  410. package/dist/registries/hooks.mjs.map +1 -1
  411. package/dist/registries/index.d.ts +0 -1
  412. package/dist/registries/index.d.ts.map +1 -1
  413. package/dist/registries/middlewares.d.ts +6 -6
  414. package/dist/registries/middlewares.d.ts.map +1 -1
  415. package/dist/registries/middlewares.js +49 -51
  416. package/dist/registries/middlewares.js.map +1 -1
  417. package/dist/registries/middlewares.mjs +48 -53
  418. package/dist/registries/middlewares.mjs.map +1 -1
  419. package/dist/registries/models.js +14 -13
  420. package/dist/registries/models.js.map +1 -1
  421. package/dist/registries/models.mjs +13 -14
  422. package/dist/registries/models.mjs.map +1 -1
  423. package/dist/registries/modules.d.ts +2 -2
  424. package/dist/registries/modules.d.ts.map +1 -1
  425. package/dist/registries/modules.js +39 -36
  426. package/dist/registries/modules.js.map +1 -1
  427. package/dist/registries/modules.mjs +38 -38
  428. package/dist/registries/modules.mjs.map +1 -1
  429. package/dist/registries/namespace.js +21 -20
  430. package/dist/registries/namespace.js.map +1 -1
  431. package/dist/registries/namespace.mjs +20 -23
  432. package/dist/registries/namespace.mjs.map +1 -1
  433. package/dist/registries/plugins.d.ts +5 -5
  434. package/dist/registries/plugins.d.ts.map +1 -1
  435. package/dist/registries/plugins.js +23 -20
  436. package/dist/registries/plugins.js.map +1 -1
  437. package/dist/registries/plugins.mjs +22 -22
  438. package/dist/registries/plugins.mjs.map +1 -1
  439. package/dist/registries/policies.d.ts +22 -10
  440. package/dist/registries/policies.d.ts.map +1 -1
  441. package/dist/registries/policies.js +107 -54
  442. package/dist/registries/policies.js.map +1 -1
  443. package/dist/registries/policies.mjs +106 -56
  444. package/dist/registries/policies.mjs.map +1 -1
  445. package/dist/registries/sanitizers.js +23 -22
  446. package/dist/registries/sanitizers.js.map +1 -1
  447. package/dist/registries/sanitizers.mjs +22 -22
  448. package/dist/registries/sanitizers.mjs.map +1 -1
  449. package/dist/registries/services.d.ts +8 -8
  450. package/dist/registries/services.d.ts.map +1 -1
  451. package/dist/registries/services.js +71 -71
  452. package/dist/registries/services.js.map +1 -1
  453. package/dist/registries/services.mjs +70 -73
  454. package/dist/registries/services.mjs.map +1 -1
  455. package/dist/registries/validators.js +23 -22
  456. package/dist/registries/validators.js.map +1 -1
  457. package/dist/registries/validators.mjs +22 -22
  458. package/dist/registries/validators.mjs.map +1 -1
  459. package/dist/services/auth/index.d.ts +4 -4
  460. package/dist/services/auth/index.d.ts.map +1 -1
  461. package/dist/services/auth/index.js +74 -74
  462. package/dist/services/auth/index.js.map +1 -1
  463. package/dist/services/auth/index.mjs +73 -74
  464. package/dist/services/auth/index.mjs.map +1 -1
  465. package/dist/services/config.d.ts +3 -0
  466. package/dist/services/config.d.ts.map +1 -0
  467. package/dist/services/config.js +51 -0
  468. package/dist/services/config.js.map +1 -0
  469. package/dist/services/config.mjs +49 -0
  470. package/dist/services/config.mjs.map +1 -0
  471. package/dist/services/content-api/index.d.ts +31 -15
  472. package/dist/services/content-api/index.d.ts.map +1 -1
  473. package/dist/services/content-api/index.js +80 -53
  474. package/dist/services/content-api/index.js.map +1 -1
  475. package/dist/services/content-api/index.mjs +79 -53
  476. package/dist/services/content-api/index.mjs.map +1 -1
  477. package/dist/services/content-api/permissions/engine.js +8 -5
  478. package/dist/services/content-api/permissions/engine.js.map +1 -1
  479. package/dist/services/content-api/permissions/engine.mjs +7 -5
  480. package/dist/services/content-api/permissions/engine.mjs.map +1 -1
  481. package/dist/services/content-api/permissions/index.d.ts +13 -15
  482. package/dist/services/content-api/permissions/index.d.ts.map +1 -1
  483. package/dist/services/content-api/permissions/index.js +101 -81
  484. package/dist/services/content-api/permissions/index.js.map +1 -1
  485. package/dist/services/content-api/permissions/index.mjs +100 -81
  486. package/dist/services/content-api/permissions/index.mjs.map +1 -1
  487. package/dist/services/content-api/permissions/providers/action.d.ts +5 -6
  488. package/dist/services/content-api/permissions/providers/action.d.ts.map +1 -1
  489. package/dist/services/content-api/permissions/providers/action.js +17 -14
  490. package/dist/services/content-api/permissions/providers/action.js.map +1 -1
  491. package/dist/services/content-api/permissions/providers/action.mjs +16 -16
  492. package/dist/services/content-api/permissions/providers/action.mjs.map +1 -1
  493. package/dist/services/content-api/permissions/providers/condition.d.ts +5 -6
  494. package/dist/services/content-api/permissions/providers/condition.d.ts.map +1 -1
  495. package/dist/services/content-api/permissions/providers/condition.js +17 -14
  496. package/dist/services/content-api/permissions/providers/condition.js.map +1 -1
  497. package/dist/services/content-api/permissions/providers/condition.mjs +16 -16
  498. package/dist/services/content-api/permissions/providers/condition.mjs.map +1 -1
  499. package/dist/services/core-store.d.ts.map +1 -1
  500. package/dist/services/core-store.js +115 -95
  501. package/dist/services/core-store.js.map +1 -1
  502. package/dist/services/core-store.mjs +114 -97
  503. package/dist/services/core-store.mjs.map +1 -1
  504. package/dist/services/cron.d.ts +5 -5
  505. package/dist/services/cron.d.ts.map +1 -1
  506. package/dist/services/cron.js +74 -60
  507. package/dist/services/cron.js.map +1 -1
  508. package/dist/services/cron.mjs +73 -62
  509. package/dist/services/cron.mjs.map +1 -1
  510. package/dist/services/custom-fields.d.ts +2 -2
  511. package/dist/services/custom-fields.d.ts.map +1 -1
  512. package/dist/services/custom-fields.js +9 -7
  513. package/dist/services/custom-fields.js.map +1 -1
  514. package/dist/services/custom-fields.mjs +8 -9
  515. package/dist/services/custom-fields.mjs.map +1 -1
  516. package/dist/services/document-service/attributes/index.d.ts +6 -0
  517. package/dist/services/document-service/attributes/index.d.ts.map +1 -0
  518. package/dist/services/document-service/attributes/index.js +27 -0
  519. package/dist/services/document-service/attributes/index.js.map +1 -0
  520. package/dist/services/document-service/attributes/index.mjs +25 -0
  521. package/dist/services/document-service/attributes/index.mjs.map +1 -0
  522. package/dist/services/document-service/attributes/transforms.d.ts +10 -0
  523. package/dist/services/document-service/attributes/transforms.d.ts.map +1 -0
  524. package/dist/services/document-service/attributes/transforms.js +21 -0
  525. package/dist/services/document-service/attributes/transforms.js.map +1 -0
  526. package/dist/services/document-service/attributes/transforms.mjs +19 -0
  527. package/dist/services/document-service/attributes/transforms.mjs.map +1 -0
  528. package/dist/services/document-service/common.d.ts +2 -2
  529. package/dist/services/document-service/common.d.ts.map +1 -1
  530. package/dist/services/document-service/common.js +5 -4
  531. package/dist/services/document-service/common.js.map +1 -1
  532. package/dist/services/document-service/common.mjs +4 -5
  533. package/dist/services/document-service/common.mjs.map +1 -1
  534. package/dist/services/document-service/components.d.ts +25 -1
  535. package/dist/services/document-service/components.d.ts.map +1 -1
  536. package/dist/services/document-service/components.js +286 -0
  537. package/dist/services/document-service/components.js.map +1 -0
  538. package/dist/services/document-service/components.mjs +278 -0
  539. package/dist/services/document-service/components.mjs.map +1 -0
  540. package/dist/services/document-service/draft-and-publish.d.ts +7 -7
  541. package/dist/services/document-service/draft-and-publish.d.ts.map +1 -1
  542. package/dist/services/document-service/draft-and-publish.js +94 -54
  543. package/dist/services/document-service/draft-and-publish.js.map +1 -1
  544. package/dist/services/document-service/draft-and-publish.mjs +87 -54
  545. package/dist/services/document-service/draft-and-publish.mjs.map +1 -1
  546. package/dist/services/document-service/entries.d.ts +10 -0
  547. package/dist/services/document-service/entries.d.ts.map +1 -0
  548. package/dist/services/document-service/entries.js +113 -0
  549. package/dist/services/document-service/entries.js.map +1 -0
  550. package/dist/services/document-service/entries.mjs +111 -0
  551. package/dist/services/document-service/entries.mjs.map +1 -0
  552. package/dist/services/document-service/events.d.ts +25 -0
  553. package/dist/services/document-service/events.d.ts.map +1 -0
  554. package/dist/services/document-service/events.js +59 -0
  555. package/dist/services/document-service/events.js.map +1 -0
  556. package/dist/services/document-service/events.mjs +57 -0
  557. package/dist/services/document-service/events.mjs.map +1 -0
  558. package/dist/services/document-service/index.d.ts +3 -4
  559. package/dist/services/document-service/index.d.ts.map +1 -1
  560. package/dist/services/document-service/index.js +53 -19
  561. package/dist/services/document-service/index.js.map +1 -1
  562. package/dist/services/document-service/index.mjs +52 -20
  563. package/dist/services/document-service/index.mjs.map +1 -1
  564. package/dist/services/document-service/internationalization.d.ts +5 -5
  565. package/dist/services/document-service/internationalization.d.ts.map +1 -1
  566. package/dist/services/document-service/internationalization.js +66 -41
  567. package/dist/services/document-service/internationalization.js.map +1 -1
  568. package/dist/services/document-service/internationalization.mjs +61 -41
  569. package/dist/services/document-service/internationalization.mjs.map +1 -1
  570. package/dist/services/document-service/middlewares/errors.d.ts +6 -0
  571. package/dist/services/document-service/middlewares/errors.d.ts.map +1 -0
  572. package/dist/services/document-service/middlewares/errors.js +29 -0
  573. package/dist/services/document-service/middlewares/errors.js.map +1 -0
  574. package/dist/services/document-service/middlewares/errors.mjs +27 -0
  575. package/dist/services/document-service/middlewares/errors.mjs.map +1 -0
  576. package/dist/services/document-service/middlewares/index.d.ts +3 -0
  577. package/dist/services/document-service/middlewares/index.d.ts.map +1 -0
  578. package/dist/services/document-service/middlewares/middleware-manager.d.ts +10 -0
  579. package/dist/services/document-service/middlewares/middleware-manager.d.ts.map +1 -0
  580. package/dist/services/document-service/middlewares/middleware-manager.js +51 -0
  581. package/dist/services/document-service/middlewares/middleware-manager.js.map +1 -0
  582. package/dist/services/document-service/middlewares/middleware-manager.mjs +49 -0
  583. package/dist/services/document-service/middlewares/middleware-manager.mjs.map +1 -0
  584. package/dist/services/document-service/params.d.ts +3 -1
  585. package/dist/services/document-service/params.d.ts.map +1 -1
  586. package/dist/services/document-service/params.js +14 -0
  587. package/dist/services/document-service/params.js.map +1 -0
  588. package/dist/services/document-service/params.mjs +12 -0
  589. package/dist/services/document-service/params.mjs.map +1 -0
  590. package/dist/services/document-service/repository.d.ts.map +1 -1
  591. package/dist/services/document-service/repository.js +353 -293
  592. package/dist/services/document-service/repository.js.map +1 -1
  593. package/dist/services/document-service/repository.mjs +352 -294
  594. package/dist/services/document-service/repository.mjs.map +1 -1
  595. package/dist/services/document-service/transform/data.d.ts.map +1 -1
  596. package/dist/services/document-service/transform/data.js +22 -10
  597. package/dist/services/document-service/transform/data.js.map +1 -1
  598. package/dist/services/document-service/transform/data.mjs +21 -11
  599. package/dist/services/document-service/transform/data.mjs.map +1 -1
  600. package/dist/services/document-service/transform/fields.d.ts +2 -2
  601. package/dist/services/document-service/transform/fields.d.ts.map +1 -1
  602. package/dist/services/document-service/transform/fields.js +26 -17
  603. package/dist/services/document-service/transform/fields.js.map +1 -1
  604. package/dist/services/document-service/transform/fields.mjs +25 -18
  605. package/dist/services/document-service/transform/fields.mjs.map +1 -1
  606. package/dist/services/document-service/transform/id-map.d.ts +3 -3
  607. package/dist/services/document-service/transform/id-map.d.ts.map +1 -1
  608. package/dist/services/document-service/transform/id-map.js +116 -69
  609. package/dist/services/document-service/transform/id-map.js.map +1 -1
  610. package/dist/services/document-service/transform/id-map.mjs +115 -70
  611. package/dist/services/document-service/transform/id-map.mjs.map +1 -1
  612. package/dist/services/document-service/transform/id-transform.d.ts +2 -2
  613. package/dist/services/document-service/transform/id-transform.d.ts.map +1 -1
  614. package/dist/services/document-service/transform/id-transform.js +38 -30
  615. package/dist/services/document-service/transform/id-transform.js.map +1 -1
  616. package/dist/services/document-service/transform/id-transform.mjs +36 -30
  617. package/dist/services/document-service/transform/id-transform.mjs.map +1 -1
  618. package/dist/services/document-service/transform/populate.d.ts +2 -2
  619. package/dist/services/document-service/transform/populate.d.ts.map +1 -1
  620. package/dist/services/document-service/transform/populate.js +23 -18
  621. package/dist/services/document-service/transform/populate.js.map +1 -1
  622. package/dist/services/document-service/transform/populate.mjs +22 -19
  623. package/dist/services/document-service/transform/populate.mjs.map +1 -1
  624. package/dist/services/document-service/transform/query.d.ts +5 -0
  625. package/dist/services/document-service/transform/query.d.ts.map +1 -0
  626. package/dist/services/document-service/transform/query.js +14 -0
  627. package/dist/services/document-service/transform/query.js.map +1 -0
  628. package/dist/services/document-service/transform/query.mjs +12 -0
  629. package/dist/services/document-service/transform/query.mjs.map +1 -0
  630. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +8 -7
  631. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -1
  632. package/dist/services/document-service/transform/relations/extract/data-ids.js +75 -85
  633. package/dist/services/document-service/transform/relations/extract/data-ids.js.map +1 -1
  634. package/dist/services/document-service/transform/relations/extract/data-ids.mjs +74 -86
  635. package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +1 -1
  636. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts +8 -4
  637. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts.map +1 -1
  638. package/dist/services/document-service/transform/relations/transform/data-ids.js +103 -134
  639. package/dist/services/document-service/transform/relations/transform/data-ids.js.map +1 -1
  640. package/dist/services/document-service/transform/relations/transform/data-ids.mjs +102 -135
  641. package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +1 -1
  642. package/dist/services/document-service/transform/relations/transform/default-locale.d.ts +9 -0
  643. package/dist/services/document-service/transform/relations/transform/default-locale.d.ts.map +1 -0
  644. package/dist/services/document-service/transform/relations/transform/default-locale.js +50 -0
  645. package/dist/services/document-service/transform/relations/transform/default-locale.js.map +1 -0
  646. package/dist/services/document-service/transform/relations/transform/default-locale.mjs +48 -0
  647. package/dist/services/document-service/transform/relations/transform/default-locale.mjs.map +1 -0
  648. package/dist/services/document-service/transform/relations/utils/dp.d.ts +3 -3
  649. package/dist/services/document-service/transform/relations/utils/dp.d.ts.map +1 -1
  650. package/dist/services/document-service/transform/relations/utils/dp.js +53 -22
  651. package/dist/services/document-service/transform/relations/utils/dp.js.map +1 -1
  652. package/dist/services/document-service/transform/relations/utils/dp.mjs +52 -23
  653. package/dist/services/document-service/transform/relations/utils/dp.mjs.map +1 -1
  654. package/dist/services/document-service/transform/relations/utils/i18n.d.ts +6 -6
  655. package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -1
  656. package/dist/services/document-service/transform/relations/utils/i18n.js +19 -23
  657. package/dist/services/document-service/transform/relations/utils/i18n.js.map +1 -1
  658. package/dist/services/document-service/transform/relations/utils/i18n.mjs +18 -26
  659. package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +1 -1
  660. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts +6 -0
  661. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts.map +1 -0
  662. package/dist/services/document-service/transform/relations/utils/map-relation.js +130 -0
  663. package/dist/services/document-service/transform/relations/utils/map-relation.js.map +1 -0
  664. package/dist/services/document-service/transform/relations/utils/map-relation.mjs +127 -0
  665. package/dist/services/document-service/transform/relations/utils/map-relation.mjs.map +1 -0
  666. package/dist/services/document-service/transform/relations/utils/types.d.ts +6 -0
  667. package/dist/services/document-service/transform/relations/utils/types.d.ts.map +1 -1
  668. package/dist/services/document-service/transform/types.d.ts +3 -3
  669. package/dist/services/document-service/transform/types.d.ts.map +1 -1
  670. package/dist/services/document-service/utils/bidirectional-relations.d.ts +95 -0
  671. package/dist/services/document-service/utils/bidirectional-relations.d.ts.map +1 -0
  672. package/dist/services/document-service/utils/bidirectional-relations.js +148 -0
  673. package/dist/services/document-service/utils/bidirectional-relations.js.map +1 -0
  674. package/dist/services/document-service/utils/bidirectional-relations.mjs +145 -0
  675. package/dist/services/document-service/utils/bidirectional-relations.mjs.map +1 -0
  676. package/dist/services/document-service/utils/populate.d.ts +9 -2
  677. package/dist/services/document-service/utils/populate.d.ts.map +1 -1
  678. package/dist/services/document-service/utils/populate.js +67 -37
  679. package/dist/services/document-service/utils/populate.js.map +1 -1
  680. package/dist/services/document-service/utils/populate.mjs +66 -38
  681. package/dist/services/document-service/utils/populate.mjs.map +1 -1
  682. package/dist/services/document-service/utils/unidirectional-relations.d.ts +36 -0
  683. package/dist/services/document-service/utils/unidirectional-relations.d.ts.map +1 -0
  684. package/dist/services/document-service/utils/unidirectional-relations.js +116 -0
  685. package/dist/services/document-service/utils/unidirectional-relations.js.map +1 -0
  686. package/dist/services/document-service/utils/unidirectional-relations.mjs +113 -0
  687. package/dist/services/document-service/utils/unidirectional-relations.mjs.map +1 -0
  688. package/dist/services/entity-service/index.d.ts +4 -6
  689. package/dist/services/entity-service/index.d.ts.map +1 -1
  690. package/dist/services/entity-service/index.js +229 -319
  691. package/dist/services/entity-service/index.js.map +1 -1
  692. package/dist/services/entity-service/index.mjs +228 -318
  693. package/dist/services/entity-service/index.mjs.map +1 -1
  694. package/dist/services/entity-validator/blocks-validator.d.ts +1 -2
  695. package/dist/services/entity-validator/blocks-validator.d.ts.map +1 -1
  696. package/dist/services/entity-validator/blocks-validator.js +137 -104
  697. package/dist/services/entity-validator/blocks-validator.js.map +1 -1
  698. package/dist/services/entity-validator/blocks-validator.mjs +135 -105
  699. package/dist/services/entity-validator/blocks-validator.mjs.map +1 -1
  700. package/dist/services/entity-validator/index.d.ts +16 -2
  701. package/dist/services/entity-validator/index.d.ts.map +1 -1
  702. package/dist/services/entity-validator/index.js +362 -300
  703. package/dist/services/entity-validator/index.js.map +1 -1
  704. package/dist/services/entity-validator/index.mjs +358 -297
  705. package/dist/services/entity-validator/index.mjs.map +1 -1
  706. package/dist/services/entity-validator/validators.d.ts +36 -25
  707. package/dist/services/entity-validator/validators.d.ts.map +1 -1
  708. package/dist/services/entity-validator/validators.js +283 -105
  709. package/dist/services/entity-validator/validators.js.map +1 -1
  710. package/dist/services/entity-validator/validators.mjs +274 -103
  711. package/dist/services/entity-validator/validators.mjs.map +1 -1
  712. package/dist/services/errors.js +65 -65
  713. package/dist/services/errors.js.map +1 -1
  714. package/dist/services/errors.mjs +64 -66
  715. package/dist/services/errors.mjs.map +1 -1
  716. package/dist/services/event-hub.d.ts +1 -0
  717. package/dist/services/event-hub.d.ts.map +1 -1
  718. package/dist/services/event-hub.js +82 -64
  719. package/dist/services/event-hub.js.map +1 -1
  720. package/dist/services/event-hub.mjs +81 -66
  721. package/dist/services/event-hub.mjs.map +1 -1
  722. package/dist/services/features.d.ts +3 -3
  723. package/dist/services/features.d.ts.map +1 -1
  724. package/dist/services/features.js +19 -14
  725. package/dist/services/features.js.map +1 -1
  726. package/dist/services/features.mjs +18 -15
  727. package/dist/services/features.mjs.map +1 -1
  728. package/dist/services/fs.d.ts +2 -2
  729. package/dist/services/fs.d.ts.map +1 -1
  730. package/dist/services/fs.js +41 -40
  731. package/dist/services/fs.js.map +1 -1
  732. package/dist/services/fs.mjs +40 -39
  733. package/dist/services/fs.mjs.map +1 -1
  734. package/dist/services/metrics/admin-user-hash.d.ts +2 -2
  735. package/dist/services/metrics/admin-user-hash.d.ts.map +1 -1
  736. package/dist/services/metrics/admin-user-hash.js +13 -11
  737. package/dist/services/metrics/admin-user-hash.js.map +1 -1
  738. package/dist/services/metrics/admin-user-hash.mjs +12 -10
  739. package/dist/services/metrics/admin-user-hash.mjs.map +1 -1
  740. package/dist/services/metrics/index.d.ts +2 -2
  741. package/dist/services/metrics/index.d.ts.map +1 -1
  742. package/dist/services/metrics/index.js +46 -40
  743. package/dist/services/metrics/index.js.map +1 -1
  744. package/dist/services/metrics/index.mjs +45 -42
  745. package/dist/services/metrics/index.mjs.map +1 -1
  746. package/dist/services/metrics/is-truthy.js +13 -6
  747. package/dist/services/metrics/is-truthy.js.map +1 -1
  748. package/dist/services/metrics/is-truthy.mjs +12 -6
  749. package/dist/services/metrics/is-truthy.mjs.map +1 -1
  750. package/dist/services/metrics/middleware.d.ts +2 -2
  751. package/dist/services/metrics/middleware.d.ts.map +1 -1
  752. package/dist/services/metrics/middleware.js +37 -22
  753. package/dist/services/metrics/middleware.js.map +1 -1
  754. package/dist/services/metrics/middleware.mjs +36 -24
  755. package/dist/services/metrics/middleware.mjs.map +1 -1
  756. package/dist/services/metrics/rate-limiter.d.ts.map +1 -1
  757. package/dist/services/metrics/rate-limiter.js +24 -19
  758. package/dist/services/metrics/rate-limiter.js.map +1 -1
  759. package/dist/services/metrics/rate-limiter.mjs +23 -21
  760. package/dist/services/metrics/rate-limiter.mjs.map +1 -1
  761. package/dist/services/metrics/sender.d.ts +3 -3
  762. package/dist/services/metrics/sender.d.ts.map +1 -1
  763. package/dist/services/metrics/sender.js +78 -69
  764. package/dist/services/metrics/sender.js.map +1 -1
  765. package/dist/services/metrics/sender.mjs +77 -64
  766. package/dist/services/metrics/sender.mjs.map +1 -1
  767. package/dist/services/query-params.d.ts +7 -0
  768. package/dist/services/query-params.d.ts.map +1 -0
  769. package/dist/services/query-params.js +15 -0
  770. package/dist/services/query-params.js.map +1 -0
  771. package/dist/services/query-params.mjs +13 -0
  772. package/dist/services/query-params.mjs.map +1 -0
  773. package/dist/services/reloader.d.ts +7 -0
  774. package/dist/services/reloader.d.ts.map +1 -0
  775. package/dist/services/reloader.js +39 -0
  776. package/dist/services/reloader.js.map +1 -0
  777. package/dist/services/reloader.mjs +37 -0
  778. package/dist/services/reloader.mjs.map +1 -0
  779. package/dist/services/request-context.js +11 -8
  780. package/dist/services/request-context.js.map +1 -1
  781. package/dist/services/request-context.mjs +10 -10
  782. package/dist/services/request-context.mjs.map +1 -1
  783. package/dist/services/server/admin-api.d.ts +3 -3
  784. package/dist/services/server/admin-api.d.ts.map +1 -1
  785. package/dist/services/server/admin-api.js +11 -10
  786. package/dist/services/server/admin-api.js.map +1 -1
  787. package/dist/services/server/admin-api.mjs +10 -11
  788. package/dist/services/server/admin-api.mjs.map +1 -1
  789. package/dist/services/server/api.d.ts +3 -3
  790. package/dist/services/server/api.d.ts.map +1 -1
  791. package/dist/services/server/api.js +33 -27
  792. package/dist/services/server/api.js.map +1 -1
  793. package/dist/services/server/api.mjs +32 -26
  794. package/dist/services/server/api.mjs.map +1 -1
  795. package/dist/services/server/compose-endpoint.d.ts +2 -2
  796. package/dist/services/server/compose-endpoint.d.ts.map +1 -1
  797. package/dist/services/server/compose-endpoint.js +116 -106
  798. package/dist/services/server/compose-endpoint.js.map +1 -1
  799. package/dist/services/server/compose-endpoint.mjs +115 -106
  800. package/dist/services/server/compose-endpoint.mjs.map +1 -1
  801. package/dist/services/server/content-api.d.ts +3 -3
  802. package/dist/services/server/content-api.d.ts.map +1 -1
  803. package/dist/services/server/content-api.js +11 -9
  804. package/dist/services/server/content-api.js.map +1 -1
  805. package/dist/services/server/content-api.mjs +10 -10
  806. package/dist/services/server/content-api.mjs.map +1 -1
  807. package/dist/services/server/http-server.d.ts +2 -2
  808. package/dist/services/server/http-server.d.ts.map +1 -1
  809. package/dist/services/server/http-server.js +48 -44
  810. package/dist/services/server/http-server.js.map +1 -1
  811. package/dist/services/server/http-server.mjs +47 -43
  812. package/dist/services/server/http-server.mjs.map +1 -1
  813. package/dist/services/server/index.d.ts +2 -2
  814. package/dist/services/server/index.d.ts.map +1 -1
  815. package/dist/services/server/index.js +85 -83
  816. package/dist/services/server/index.js.map +1 -1
  817. package/dist/services/server/index.mjs +84 -82
  818. package/dist/services/server/index.mjs.map +1 -1
  819. package/dist/services/server/koa.d.ts.map +1 -1
  820. package/dist/services/server/koa.js +49 -47
  821. package/dist/services/server/koa.js.map +1 -1
  822. package/dist/services/server/koa.mjs +48 -44
  823. package/dist/services/server/koa.mjs.map +1 -1
  824. package/dist/services/server/middleware.d.ts +4 -4
  825. package/dist/services/server/middleware.d.ts.map +1 -1
  826. package/dist/services/server/middleware.js +86 -82
  827. package/dist/services/server/middleware.js.map +1 -1
  828. package/dist/services/server/middleware.mjs +85 -82
  829. package/dist/services/server/middleware.mjs.map +1 -1
  830. package/dist/services/server/policy.d.ts +3 -3
  831. package/dist/services/server/policy.d.ts.map +1 -1
  832. package/dist/services/server/policy.js +25 -18
  833. package/dist/services/server/policy.js.map +1 -1
  834. package/dist/services/server/policy.mjs +23 -18
  835. package/dist/services/server/policy.mjs.map +1 -1
  836. package/dist/services/server/register-middlewares.d.ts +2 -2
  837. package/dist/services/server/register-middlewares.d.ts.map +1 -1
  838. package/dist/services/server/register-middlewares.js +68 -61
  839. package/dist/services/server/register-middlewares.js.map +1 -1
  840. package/dist/services/server/register-middlewares.mjs +67 -63
  841. package/dist/services/server/register-middlewares.mjs.map +1 -1
  842. package/dist/services/server/register-routes.d.ts +2 -2
  843. package/dist/services/server/register-routes.d.ts.map +1 -1
  844. package/dist/services/server/register-routes.js +90 -67
  845. package/dist/services/server/register-routes.js.map +1 -1
  846. package/dist/services/server/register-routes.mjs +89 -67
  847. package/dist/services/server/register-routes.mjs.map +1 -1
  848. package/dist/services/server/routing.d.ts +5 -5
  849. package/dist/services/server/routing.d.ts.map +1 -1
  850. package/dist/services/server/routing.js +94 -81
  851. package/dist/services/server/routing.js.map +1 -1
  852. package/dist/services/server/routing.mjs +93 -81
  853. package/dist/services/server/routing.mjs.map +1 -1
  854. package/dist/services/utils/dynamic-zones.d.ts.map +1 -1
  855. package/dist/services/utils/dynamic-zones.js +13 -13
  856. package/dist/services/utils/dynamic-zones.js.map +1 -1
  857. package/dist/services/utils/dynamic-zones.mjs +12 -15
  858. package/dist/services/utils/dynamic-zones.mjs.map +1 -1
  859. package/dist/services/webhook-runner.d.ts +2 -1
  860. package/dist/services/webhook-runner.d.ts.map +1 -1
  861. package/dist/services/webhook-runner.js +124 -122
  862. package/dist/services/webhook-runner.js.map +1 -1
  863. package/dist/services/webhook-runner.mjs +123 -121
  864. package/dist/services/webhook-runner.mjs.map +1 -1
  865. package/dist/services/webhook-store.d.ts +2 -8
  866. package/dist/services/webhook-store.d.ts.map +1 -1
  867. package/dist/services/webhook-store.js +132 -93
  868. package/dist/services/webhook-store.js.map +1 -1
  869. package/dist/services/webhook-store.mjs +131 -95
  870. package/dist/services/webhook-store.mjs.map +1 -1
  871. package/dist/services/worker-queue.js +44 -49
  872. package/dist/services/worker-queue.js.map +1 -1
  873. package/dist/services/worker-queue.mjs +43 -49
  874. package/dist/services/worker-queue.mjs.map +1 -1
  875. package/dist/utils/convert-custom-field-type.d.ts +2 -2
  876. package/dist/utils/convert-custom-field-type.d.ts.map +1 -1
  877. package/dist/utils/convert-custom-field-type.js +17 -20
  878. package/dist/utils/convert-custom-field-type.js.map +1 -1
  879. package/dist/utils/convert-custom-field-type.mjs +16 -21
  880. package/dist/utils/convert-custom-field-type.mjs.map +1 -1
  881. package/dist/utils/cron.js +64 -30
  882. package/dist/utils/cron.js.map +1 -1
  883. package/dist/utils/cron.mjs +63 -31
  884. package/dist/utils/cron.mjs.map +1 -1
  885. package/dist/utils/fetch.d.ts +3 -3
  886. package/dist/utils/fetch.d.ts.map +1 -1
  887. package/dist/utils/fetch.js +24 -17
  888. package/dist/utils/fetch.js.map +1 -1
  889. package/dist/utils/fetch.mjs +23 -18
  890. package/dist/utils/fetch.mjs.map +1 -1
  891. package/dist/utils/filepath-to-prop-path.d.ts +1 -1
  892. package/dist/utils/filepath-to-prop-path.d.ts.map +1 -1
  893. package/dist/utils/filepath-to-prop-path.js +22 -9
  894. package/dist/utils/filepath-to-prop-path.js.map +1 -1
  895. package/dist/utils/filepath-to-prop-path.mjs +20 -7
  896. package/dist/utils/filepath-to-prop-path.mjs.map +1 -1
  897. package/dist/utils/index.d.ts +2 -1
  898. package/dist/utils/index.d.ts.map +1 -1
  899. package/dist/utils/is-initialized.d.ts +2 -2
  900. package/dist/utils/is-initialized.d.ts.map +1 -1
  901. package/dist/utils/is-initialized.js +21 -12
  902. package/dist/utils/is-initialized.js.map +1 -1
  903. package/dist/utils/is-initialized.mjs +20 -13
  904. package/dist/utils/is-initialized.mjs.map +1 -1
  905. package/dist/utils/lifecycles.js +6 -5
  906. package/dist/utils/lifecycles.js.map +1 -1
  907. package/dist/utils/lifecycles.mjs +5 -6
  908. package/dist/utils/lifecycles.mjs.map +1 -1
  909. package/dist/utils/load-config-file.js +40 -38
  910. package/dist/utils/load-config-file.js.map +1 -1
  911. package/dist/utils/load-config-file.mjs +39 -36
  912. package/dist/utils/load-config-file.mjs.map +1 -1
  913. package/dist/utils/load-files.d.ts.map +1 -1
  914. package/dist/utils/load-files.js +40 -35
  915. package/dist/utils/load-files.js.map +1 -1
  916. package/dist/utils/load-files.mjs +39 -32
  917. package/dist/utils/load-files.mjs.map +1 -1
  918. package/dist/utils/open-browser.d.ts +2 -2
  919. package/dist/utils/open-browser.d.ts.map +1 -1
  920. package/dist/utils/open-browser.js +8 -8
  921. package/dist/utils/open-browser.js.map +1 -1
  922. package/dist/utils/open-browser.mjs +7 -7
  923. package/dist/utils/open-browser.mjs.map +1 -1
  924. package/dist/utils/resolve-working-dirs.d.ts +19 -0
  925. package/dist/utils/resolve-working-dirs.d.ts.map +1 -0
  926. package/dist/utils/resolve-working-dirs.js +26 -0
  927. package/dist/utils/resolve-working-dirs.js.map +1 -0
  928. package/dist/utils/resolve-working-dirs.mjs +24 -0
  929. package/dist/utils/resolve-working-dirs.mjs.map +1 -0
  930. package/dist/utils/signals.d.ts +2 -2
  931. package/dist/utils/signals.d.ts.map +1 -1
  932. package/dist/utils/signals.js +20 -14
  933. package/dist/utils/signals.js.map +1 -1
  934. package/dist/utils/signals.mjs +19 -15
  935. package/dist/utils/signals.mjs.map +1 -1
  936. package/dist/utils/startup-logger.d.ts +2 -2
  937. package/dist/utils/startup-logger.d.ts.map +1 -1
  938. package/dist/utils/startup-logger.js +107 -78
  939. package/dist/utils/startup-logger.js.map +1 -1
  940. package/dist/utils/startup-logger.mjs +106 -75
  941. package/dist/utils/startup-logger.mjs.map +1 -1
  942. package/dist/utils/transform-content-types-to-models.d.ts +377 -90
  943. package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
  944. package/dist/utils/transform-content-types-to-models.js +357 -217
  945. package/dist/utils/transform-content-types-to-models.js.map +1 -1
  946. package/dist/utils/transform-content-types-to-models.mjs +351 -220
  947. package/dist/utils/transform-content-types-to-models.mjs.map +1 -1
  948. package/dist/utils/update-notifier/index.d.ts +2 -7
  949. package/dist/utils/update-notifier/index.d.ts.map +1 -1
  950. package/dist/utils/update-notifier/index.js +66 -74
  951. package/dist/utils/update-notifier/index.js.map +1 -1
  952. package/dist/utils/update-notifier/index.mjs +65 -68
  953. package/dist/utils/update-notifier/index.mjs.map +1 -1
  954. package/package.json +43 -40
  955. package/dist/registries/config.d.ts +0 -4
  956. package/dist/registries/config.d.ts.map +0 -1
  957. package/dist/registries/config.js +0 -31
  958. package/dist/registries/config.js.map +0 -1
  959. package/dist/registries/config.mjs +0 -32
  960. package/dist/registries/config.mjs.map +0 -1
  961. package/dist/services/document-service/middlewares.d.ts +0 -8
  962. package/dist/services/document-service/middlewares.d.ts.map +0 -1
  963. package/dist/services/document-service/middlewares.js +0 -46
  964. package/dist/services/document-service/middlewares.js.map +0 -1
  965. package/dist/services/document-service/middlewares.mjs +0 -46
  966. package/dist/services/document-service/middlewares.mjs.map +0 -1
  967. package/dist/services/document-service/transform/filters.d.ts +0 -3
  968. package/dist/services/document-service/transform/filters.d.ts.map +0 -1
  969. package/dist/services/document-service/transform/relations/transform/output-ids.d.ts +0 -4
  970. package/dist/services/document-service/transform/relations/transform/output-ids.d.ts.map +0 -1
  971. package/dist/services/document-service/transform/relations/utils/data.js +0 -12
  972. package/dist/services/document-service/transform/relations/utils/data.js.map +0 -1
  973. package/dist/services/document-service/transform/relations/utils/data.mjs +0 -12
  974. package/dist/services/document-service/transform/relations/utils/data.mjs.map +0 -1
  975. package/dist/services/document-service/transform/sort.d.ts +0 -5
  976. package/dist/services/document-service/transform/sort.d.ts.map +0 -1
  977. package/dist/services/document-service/transform/utils.d.ts +0 -9
  978. package/dist/services/document-service/transform/utils.d.ts.map +0 -1
  979. package/dist/services/entity-service/attributes/index.d.ts +0 -6
  980. package/dist/services/entity-service/attributes/index.d.ts.map +0 -1
  981. package/dist/services/entity-service/attributes/index.js +0 -22
  982. package/dist/services/entity-service/attributes/index.js.map +0 -1
  983. package/dist/services/entity-service/attributes/index.mjs +0 -22
  984. package/dist/services/entity-service/attributes/index.mjs.map +0 -1
  985. package/dist/services/entity-service/attributes/transforms.d.ts +0 -10
  986. package/dist/services/entity-service/attributes/transforms.d.ts.map +0 -1
  987. package/dist/services/entity-service/attributes/transforms.js +0 -20
  988. package/dist/services/entity-service/attributes/transforms.js.map +0 -1
  989. package/dist/services/entity-service/attributes/transforms.mjs +0 -19
  990. package/dist/services/entity-service/attributes/transforms.mjs.map +0 -1
  991. package/dist/services/entity-service/components.d.ts +0 -23
  992. package/dist/services/entity-service/components.d.ts.map +0 -1
  993. package/dist/services/entity-service/components.js +0 -384
  994. package/dist/services/entity-service/components.js.map +0 -1
  995. package/dist/services/entity-service/components.mjs +0 -382
  996. package/dist/services/entity-service/components.mjs.map +0 -1
  997. package/dist/services/entity-service/params.d.ts +0 -8
  998. package/dist/services/entity-service/params.d.ts.map +0 -1
  999. package/dist/services/entity-service/params.js +0 -8
  1000. package/dist/services/entity-service/params.js.map +0 -1
  1001. package/dist/services/entity-service/params.mjs +0 -8
  1002. package/dist/services/entity-service/params.mjs.map +0 -1
  1003. package/dist/services/utils/upload-files.d.ts +0 -8
  1004. package/dist/services/utils/upload-files.d.ts.map +0 -1
  1005. package/dist/services/utils/upload-files.js +0 -64
  1006. package/dist/services/utils/upload-files.js.map +0 -1
  1007. package/dist/services/utils/upload-files.mjs +0 -63
  1008. package/dist/services/utils/upload-files.mjs.map +0 -1
  1009. package/dist/utils/get-dirs.d.ts +0 -9
  1010. package/dist/utils/get-dirs.d.ts.map +0 -1
  1011. package/dist/utils/get-dirs.js +0 -30
  1012. package/dist/utils/get-dirs.js.map +0 -1
  1013. package/dist/utils/get-dirs.mjs +0 -30
  1014. package/dist/utils/get-dirs.mjs.map +0 -1
@@ -0,0 +1,278 @@
1
+ import _ from 'lodash';
2
+ import { curry, omit, pipe, assign, has } from 'lodash/fp';
3
+ import { contentTypes, async, errors } from '@strapi/utils';
4
+
5
+ const omitComponentData = curry((schema, data)=>{
6
+ const { attributes } = schema;
7
+ const componentAttributes = Object.keys(attributes).filter((attributeName)=>contentTypes.isComponentAttribute(attributes[attributeName]));
8
+ return omit(componentAttributes, data);
9
+ });
10
+ // NOTE: we could generalize the logic to allow CRUD of relation directly in the DB layer
11
+ const createComponents = async (uid, data)=>{
12
+ const { attributes = {} } = strapi.getModel(uid);
13
+ const componentBody = {};
14
+ const attributeNames = Object.keys(attributes);
15
+ for (const attributeName of attributeNames){
16
+ const attribute = attributes[attributeName];
17
+ if (!has(attributeName, data) || !contentTypes.isComponentAttribute(attribute)) {
18
+ continue;
19
+ }
20
+ if (attribute.type === 'component') {
21
+ const { component: componentUID, repeatable = false } = attribute;
22
+ const componentValue = data[attributeName];
23
+ if (componentValue === null) {
24
+ continue;
25
+ }
26
+ if (repeatable === true) {
27
+ if (!Array.isArray(componentValue)) {
28
+ throw new Error('Expected an array to create repeatable component');
29
+ }
30
+ const components = await async.map(componentValue, (value)=>createComponent(componentUID, value));
31
+ componentBody[attributeName] = components.map(({ id })=>{
32
+ return {
33
+ id,
34
+ __pivot: {
35
+ field: attributeName,
36
+ component_type: componentUID
37
+ }
38
+ };
39
+ });
40
+ } else {
41
+ const component = await createComponent(componentUID, componentValue);
42
+ componentBody[attributeName] = {
43
+ id: component.id,
44
+ __pivot: {
45
+ field: attributeName,
46
+ component_type: componentUID
47
+ }
48
+ };
49
+ }
50
+ continue;
51
+ }
52
+ if (attribute.type === 'dynamiczone') {
53
+ const dynamiczoneValues = data[attributeName];
54
+ if (!Array.isArray(dynamiczoneValues)) {
55
+ throw new Error('Expected an array to create repeatable component');
56
+ }
57
+ const createDynamicZoneComponents = async (value)=>{
58
+ const { id } = await createComponent(value.__component, value);
59
+ return {
60
+ id,
61
+ __component: value.__component,
62
+ __pivot: {
63
+ field: attributeName
64
+ }
65
+ };
66
+ };
67
+ // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1
68
+ componentBody[attributeName] = await async.map(dynamiczoneValues, createDynamicZoneComponents);
69
+ continue;
70
+ }
71
+ }
72
+ return componentBody;
73
+ };
74
+ const getComponents = async (uid, entity)=>{
75
+ const componentAttributes = contentTypes.getComponentAttributes(strapi.getModel(uid));
76
+ if (_.isEmpty(componentAttributes)) {
77
+ return {};
78
+ }
79
+ return strapi.db.query(uid).load(entity, componentAttributes);
80
+ };
81
+ /*
82
+ delete old components
83
+ create or update
84
+ */ const updateComponents = async (uid, entityToUpdate, data)=>{
85
+ const { attributes = {} } = strapi.getModel(uid);
86
+ const componentBody = {};
87
+ for (const attributeName of Object.keys(attributes)){
88
+ const attribute = attributes[attributeName];
89
+ if (!has(attributeName, data)) {
90
+ continue;
91
+ }
92
+ if (attribute.type === 'component') {
93
+ const { component: componentUID, repeatable = false } = attribute;
94
+ const componentValue = data[attributeName];
95
+ await deleteOldComponents(uid, componentUID, entityToUpdate, attributeName, componentValue);
96
+ if (repeatable === true) {
97
+ if (!Array.isArray(componentValue)) {
98
+ throw new Error('Expected an array to create repeatable component');
99
+ }
100
+ // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1
101
+ const components = await async.map(componentValue, (value)=>updateOrCreateComponent(componentUID, value));
102
+ componentBody[attributeName] = components.filter(_.negate(_.isNil)).map(({ id })=>{
103
+ return {
104
+ id,
105
+ __pivot: {
106
+ field: attributeName,
107
+ component_type: componentUID
108
+ }
109
+ };
110
+ });
111
+ } else {
112
+ const component = await updateOrCreateComponent(componentUID, componentValue);
113
+ componentBody[attributeName] = component && {
114
+ id: component.id,
115
+ __pivot: {
116
+ field: attributeName,
117
+ component_type: componentUID
118
+ }
119
+ };
120
+ }
121
+ } else if (attribute.type === 'dynamiczone') {
122
+ const dynamiczoneValues = data[attributeName];
123
+ await deleteOldDZComponents(uid, entityToUpdate, attributeName, dynamiczoneValues);
124
+ if (!Array.isArray(dynamiczoneValues)) {
125
+ throw new Error('Expected an array to create repeatable component');
126
+ }
127
+ // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1
128
+ componentBody[attributeName] = await async.map(dynamiczoneValues, async (value)=>{
129
+ const { id } = await updateOrCreateComponent(value.__component, value);
130
+ return {
131
+ id,
132
+ __component: value.__component,
133
+ __pivot: {
134
+ field: attributeName
135
+ }
136
+ };
137
+ });
138
+ }
139
+ }
140
+ return componentBody;
141
+ };
142
+ const pickStringifiedId = ({ id })=>{
143
+ if (typeof id === 'string') {
144
+ return id;
145
+ }
146
+ return `${id}`;
147
+ };
148
+ const deleteOldComponents = async (uid, componentUID, entityToUpdate, attributeName, componentValue)=>{
149
+ const previousValue = await strapi.db.query(uid).load(entityToUpdate, attributeName);
150
+ const idsToKeep = _.castArray(componentValue).filter(has('id')).map(pickStringifiedId);
151
+ const allIds = _.castArray(previousValue).filter(has('id')).map(pickStringifiedId);
152
+ idsToKeep.forEach((id)=>{
153
+ if (!allIds.includes(id)) {
154
+ throw new errors.ApplicationError(`Some of the provided components in ${attributeName} are not related to the entity`);
155
+ }
156
+ });
157
+ const idsToDelete = _.difference(allIds, idsToKeep);
158
+ if (idsToDelete.length > 0) {
159
+ for (const idToDelete of idsToDelete){
160
+ await deleteComponent(componentUID, {
161
+ id: idToDelete
162
+ });
163
+ }
164
+ }
165
+ };
166
+ const deleteOldDZComponents = async (uid, entityToUpdate, attributeName, dynamiczoneValues)=>{
167
+ const previousValue = await strapi.db.query(uid).load(entityToUpdate, attributeName);
168
+ const idsToKeep = _.castArray(dynamiczoneValues).filter(has('id')).map((v)=>({
169
+ id: pickStringifiedId(v),
170
+ __component: v.__component
171
+ }));
172
+ const allIds = _.castArray(previousValue).filter(has('id')).map((v)=>({
173
+ id: pickStringifiedId(v),
174
+ __component: v.__component
175
+ }));
176
+ idsToKeep.forEach(({ id, __component })=>{
177
+ if (!allIds.find((el)=>el.id === id && el.__component === __component)) {
178
+ const err = new Error(`Some of the provided components in ${attributeName} are not related to the entity`);
179
+ Object.assign(err, {
180
+ status: 400
181
+ });
182
+ throw err;
183
+ }
184
+ });
185
+ const idsToDelete = allIds.reduce((acc, { id, __component })=>{
186
+ if (!idsToKeep.find((el)=>el.id === id && el.__component === __component)) {
187
+ acc.push({
188
+ id,
189
+ __component
190
+ });
191
+ }
192
+ return acc;
193
+ }, []);
194
+ if (idsToDelete.length > 0) {
195
+ for (const idToDelete of idsToDelete){
196
+ const { id, __component } = idToDelete;
197
+ await deleteComponent(__component, {
198
+ id
199
+ });
200
+ }
201
+ }
202
+ };
203
+ const deleteComponents = async (uid, entityToDelete, { loadComponents = true } = {})=>{
204
+ const { attributes = {} } = strapi.getModel(uid);
205
+ const attributeNames = Object.keys(attributes);
206
+ for (const attributeName of attributeNames){
207
+ const attribute = attributes[attributeName];
208
+ if (attribute.type === 'component' || attribute.type === 'dynamiczone') {
209
+ let value;
210
+ if (loadComponents) {
211
+ value = await strapi.db.query(uid).load(entityToDelete, attributeName);
212
+ } else {
213
+ value = entityToDelete[attributeName];
214
+ }
215
+ if (!value) {
216
+ continue;
217
+ }
218
+ if (attribute.type === 'component') {
219
+ const { component: componentUID } = attribute;
220
+ await async.map(_.castArray(value), (subValue)=>deleteComponent(componentUID, subValue));
221
+ } else {
222
+ await async.map(_.castArray(value), (subValue)=>deleteComponent(subValue.__component, subValue));
223
+ }
224
+ continue;
225
+ }
226
+ }
227
+ };
228
+ /** *************************
229
+ Component queries
230
+ ************************** */ // components can have nested compos so this must be recursive
231
+ const createComponent = async (uid, data)=>{
232
+ const schema = strapi.getModel(uid);
233
+ const componentData = await createComponents(uid, data);
234
+ const transform = pipe(// Make sure we don't save the component with a pre-defined ID
235
+ omit('id'), assignComponentData(schema, componentData));
236
+ return strapi.db.query(uid).create({
237
+ data: transform(data)
238
+ });
239
+ };
240
+ // components can have nested compos so this must be recursive
241
+ const updateComponent = async (uid, componentToUpdate, data)=>{
242
+ const schema = strapi.getModel(uid);
243
+ const componentData = await updateComponents(uid, componentToUpdate, data);
244
+ return strapi.db.query(uid).update({
245
+ where: {
246
+ id: componentToUpdate.id
247
+ },
248
+ data: assignComponentData(schema, componentData, data)
249
+ });
250
+ };
251
+ const updateOrCreateComponent = (componentUID, value)=>{
252
+ if (value === null) {
253
+ return null;
254
+ }
255
+ // update
256
+ if ('id' in value && typeof value.id !== 'undefined') {
257
+ // TODO: verify the compo is associated with the entity
258
+ return updateComponent(componentUID, {
259
+ id: value.id
260
+ }, value);
261
+ }
262
+ // create
263
+ return createComponent(componentUID, value);
264
+ };
265
+ const deleteComponent = async (uid, componentToDelete)=>{
266
+ await deleteComponents(uid, componentToDelete);
267
+ await strapi.db.query(uid).delete({
268
+ where: {
269
+ id: componentToDelete.id
270
+ }
271
+ });
272
+ };
273
+ const assignComponentData = curry((schema, componentData, data)=>{
274
+ return pipe(omitComponentData(schema), assign(componentData))(data);
275
+ });
276
+
277
+ export { assignComponentData, createComponents, deleteComponent, deleteComponents, getComponents, omitComponentData, updateComponents };
278
+ //# sourceMappingURL=components.mjs.map
@@ -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":["omitComponentData","curry","schema","data","attributes","componentAttributes","Object","keys","filter","attributeName","contentTypesUtils","isComponentAttribute","omit","createComponents","uid","strapi","getModel","componentBody","attributeNames","attribute","has","type","component","componentUID","repeatable","componentValue","Array","isArray","Error","components","async","map","value","createComponent","id","__pivot","field","component_type","dynamiczoneValues","createDynamicZoneComponents","__component","getComponents","entity","getComponentAttributes","_","isEmpty","db","query","load","updateComponents","entityToUpdate","deleteOldComponents","updateOrCreateComponent","negate","isNil","deleteOldDZComponents","pickStringifiedId","previousValue","idsToKeep","castArray","allIds","forEach","includes","errors","ApplicationError","idsToDelete","difference","length","idToDelete","deleteComponent","v","find","el","err","assign","status","reduce","acc","push","deleteComponents","entityToDelete","loadComponents","subValue","componentData","transform","pipe","assignComponentData","create","updateComponent","componentToUpdate","update","where","componentToDelete","delete"],"mappings":"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"}
@@ -1,10 +1,10 @@
1
1
  /// <reference types="lodash" />
2
- import { Schema, Documents } from '@strapi/types';
3
- declare const setStatusToDraftCurry: import("lodash").CurriedFunction2<Schema.SingleType | Schema.CollectionType, Documents.Params.All, Documents.Params.All>;
4
- declare const defaultToDraftCurry: import("lodash").CurriedFunction1<Documents.Params.All, Documents.Params.All>;
5
- declare const defaultStatusCurry: import("lodash").CurriedFunction2<Schema.SingleType | Schema.CollectionType, Documents.Params.All, Documents.Params.All>;
6
- declare const filterDataPublishedAtCurry: import("lodash").CurriedFunction1<Documents.Params.All, Documents.Params.All>;
7
- declare const statusToLookupCurry: import("lodash").CurriedFunction2<Schema.SingleType | Schema.CollectionType, Documents.Params.All, Documents.Params.All>;
8
- declare const statusToDataCurry: import("lodash").CurriedFunction2<Schema.SingleType | Schema.CollectionType, Documents.Params.All, Documents.Params.All>;
2
+ import type { 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
9
  export { setStatusToDraftCurry as setStatusToDraft, defaultToDraftCurry as defaultToDraft, defaultStatusCurry as defaultStatus, filterDataPublishedAtCurry as filterDataPublishedAt, statusToLookupCurry as statusToLookup, statusToDataCurry as statusToData, };
10
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":";AAEA,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAwGlD,QAAA,MAAM,qBAAqB,0HAA0B,CAAC;AACtD,QAAA,MAAM,mBAAmB,+EAAwB,CAAC;AAClD,QAAA,MAAM,kBAAkB,0HAAuB,CAAC;AAChD,QAAA,MAAM,0BAA0B,+EAA+B,CAAC;AAChE,QAAA,MAAM,mBAAmB,0HAAwB,CAAC;AAClD,QAAA,MAAM,iBAAiB,0HAAsB,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
+ {"version":3,"file":"draft-and-publish.d.ts","sourceRoot":"","sources":["../../../src/services/document-service/draft-and-publish.ts"],"names":[],"mappings":";AAEA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAwGrD,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,65 +1,105 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const _ = require("lodash/fp");
4
- const strapiUtils = require("@strapi/utils");
5
- const setStatusToDraft = (contentType, params) => {
6
- if (!strapiUtils.contentTypes.hasDraftAndPublish(contentType) && params.status) {
1
+ 'use strict';
2
+
3
+ var fp = require('lodash/fp');
4
+ var strapiUtils = require('@strapi/utils');
5
+
6
+ /**
7
+ * DP enabled -> set status to draft
8
+ * DP disabled -> Used mostly for parsing relations, so there is not a need for a default.
9
+ */ const setStatusToDraft = (contentType, params)=>{
10
+ if (!strapiUtils.contentTypes.hasDraftAndPublish(contentType) && params.status) {
11
+ return params;
12
+ }
13
+ return fp.assoc('status', 'draft', params);
14
+ };
15
+ /**
16
+ * Adds a default status of `draft` to the params
17
+ */ const defaultToDraft = (params)=>{
18
+ // Default to draft if no status is provided or it's invalid
19
+ if (!params.status || params.status !== 'published') {
20
+ return fp.assoc('status', 'draft', params);
21
+ }
7
22
  return params;
8
- }
9
- return _.assoc("status", "draft", params);
10
23
  };
11
- const defaultToDraft = (params) => {
12
- if (!params.status || params.status !== "published") {
13
- return _.assoc("status", "draft", params);
14
- }
15
- return params;
24
+ /**
25
+ * DP disabled -> ignore status
26
+ * DP enabled -> set status to draft if no status is provided or it's invalid
27
+ */ const defaultStatus = (contentType, params)=>{
28
+ if (!strapiUtils.contentTypes.hasDraftAndPublish(contentType)) {
29
+ return params;
30
+ }
31
+ // Default to draft if no status is provided or it's invalid
32
+ if (!params.status || params.status !== 'published') {
33
+ return defaultToDraft(params);
34
+ }
35
+ return params;
16
36
  };
17
- const defaultStatus = (contentType, params) => {
18
- if (!strapiUtils.contentTypes.hasDraftAndPublish(contentType)) {
37
+ /**
38
+ * In mutating actions we don't want user to set the publishedAt attribute.
39
+ */ const filterDataPublishedAt = (params)=>{
40
+ if (params?.data?.publishedAt) {
41
+ return fp.assoc([
42
+ 'data',
43
+ 'publishedAt'
44
+ ], null, params);
45
+ }
19
46
  return params;
20
- }
21
- if (!params.status || params.status !== "published") {
22
- return defaultToDraft(params);
23
- }
24
- return params;
25
47
  };
26
- const filterDataPublishedAt = (params) => {
27
- if (params?.data?.publishedAt) {
28
- return _.assoc(["data", "publishedAt"], null, params);
29
- }
30
- return params;
48
+ /**
49
+ * Add status lookup query to the params
50
+ */ const statusToLookup = (contentType, params)=>{
51
+ if (!strapiUtils.contentTypes.hasDraftAndPublish(contentType)) {
52
+ return params;
53
+ }
54
+ const lookup = params.lookup || {};
55
+ switch(params?.status){
56
+ case 'published':
57
+ return fp.assoc([
58
+ 'lookup',
59
+ 'publishedAt'
60
+ ], {
61
+ $notNull: true
62
+ }, params);
63
+ case 'draft':
64
+ return fp.assoc([
65
+ 'lookup',
66
+ 'publishedAt'
67
+ ], {
68
+ $null: true
69
+ }, params);
70
+ }
71
+ return fp.assoc('lookup', lookup, params);
31
72
  };
32
- const statusToLookup = (contentType, params) => {
33
- if (!strapiUtils.contentTypes.hasDraftAndPublish(contentType)) {
73
+ /**
74
+ * Translate publication status parameter into the data that will be saved
75
+ */ const statusToData = (contentType, params)=>{
76
+ if (!strapiUtils.contentTypes.hasDraftAndPublish(contentType)) {
77
+ return fp.assoc([
78
+ 'data',
79
+ 'publishedAt'
80
+ ], new Date(), params);
81
+ }
82
+ switch(params?.status){
83
+ case 'published':
84
+ return fp.assoc([
85
+ 'data',
86
+ 'publishedAt'
87
+ ], new Date(), params);
88
+ case 'draft':
89
+ return fp.assoc([
90
+ 'data',
91
+ 'publishedAt'
92
+ ], null, params);
93
+ }
34
94
  return params;
35
- }
36
- const lookup = params.lookup || {};
37
- switch (params?.status) {
38
- case "published":
39
- return _.assoc(["lookup", "publishedAt"], { $notNull: true }, params);
40
- case "draft":
41
- return _.assoc(["lookup", "publishedAt"], { $null: true }, params);
42
- }
43
- return _.assoc("lookup", lookup, params);
44
- };
45
- const statusToData = (contentType, params) => {
46
- if (!strapiUtils.contentTypes.hasDraftAndPublish(contentType)) {
47
- return _.assoc(["data", "publishedAt"], /* @__PURE__ */ new Date(), params);
48
- }
49
- switch (params?.status) {
50
- case "published":
51
- return _.assoc(["data", "publishedAt"], /* @__PURE__ */ new Date(), params);
52
- case "draft":
53
- return _.assoc(["data", "publishedAt"], null, params);
54
- }
55
- return params;
56
95
  };
57
- const setStatusToDraftCurry = _.curry(setStatusToDraft);
58
- const defaultToDraftCurry = _.curry(defaultToDraft);
59
- const defaultStatusCurry = _.curry(defaultStatus);
60
- const filterDataPublishedAtCurry = _.curry(filterDataPublishedAt);
61
- const statusToLookupCurry = _.curry(statusToLookup);
62
- const statusToDataCurry = _.curry(statusToData);
96
+ const setStatusToDraftCurry = fp.curry(setStatusToDraft);
97
+ const defaultToDraftCurry = fp.curry(defaultToDraft);
98
+ const defaultStatusCurry = fp.curry(defaultStatus);
99
+ const filterDataPublishedAtCurry = fp.curry(filterDataPublishedAt);
100
+ const statusToLookupCurry = fp.curry(statusToLookup);
101
+ const statusToDataCurry = fp.curry(statusToData);
102
+
63
103
  exports.defaultStatus = defaultStatusCurry;
64
104
  exports.defaultToDraft = defaultToDraftCurry;
65
105
  exports.filterDataPublishedAt = filterDataPublishedAtCurry;
@@ -1 +1 @@
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 { Schema, Documents } from '@strapi/types';\nimport { contentTypes } from '@strapi/utils';\n\ntype ParamsTransform = (params: Documents.Params.All) => Documents.Params.All;\n\ntype TransformWithContentType = (\n contentType: Schema.SingleType | Schema.CollectionType,\n params: Documents.Params.All\n) => 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,EACT;AAEO,SAAAC,QAAM,UAAU,SAAS,MAAM;AACxC;AAKA,MAAM,iBAAkC,CAAC,WAAW;AAElD,MAAI,CAAC,OAAO,UAAU,OAAO,WAAW,aAAa;AAC5C,WAAAA,QAAM,UAAU,SAAS,MAAM;AAAA,EACxC;AAEO,SAAA;AACT;AAMA,MAAM,gBAA0C,CAAC,aAAa,WAAW;AACvE,MAAI,CAACD,YAAA,aAAa,mBAAmB,WAAW,GAAG;AAC1C,WAAA;AAAA,EACT;AAGA,MAAI,CAAC,OAAO,UAAU,OAAO,WAAW,aAAa;AACnD,WAAO,eAAe,MAAM;AAAA,EAC9B;AAEO,SAAA;AACT;AAKA,MAAM,wBAAyC,CAAC,WAAW;AACrD,MAAA,QAAQ,MAAM,aAAa;AAC7B,WAAOC,EAAAA,MAAM,CAAC,QAAQ,aAAa,GAAG,MAAM,MAAM;AAAA,EACpD;AAEO,SAAA;AACT;AAKA,MAAM,iBAA2C,CAAC,aAAa,WAAW;AACxE,MAAI,CAACD,YAAA,aAAa,mBAAmB,WAAW,GAAG;AAC1C,WAAA;AAAA,EACT;AAEM,QAAA,SAAS,OAAO,UAAU;AAEhC,UAAQ,QAAQ,QAAQ;AAAA,IACtB,KAAK;AACI,aAAAC,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,MAAM,eAAyC,CAAC,aAAa,WAAW;AACtE,MAAI,CAACD,YAAA,aAAa,mBAAmB,WAAW,GAAG;AAC1C,WAAAC,EAAAA,MAAM,CAAC,QAAQ,aAAa,GAAO,oBAAA,KAAA,GAAQ,MAAM;AAAA,EAC1D;AAEA,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;AAEM,MAAA,wBAAwBC,QAAM,gBAAgB;AAC9C,MAAA,sBAAsBA,QAAM,cAAc;AAC1C,MAAA,qBAAqBA,QAAM,aAAa;AACxC,MAAA,6BAA6BA,QAAM,qBAAqB;AACxD,MAAA,sBAAsBA,QAAM,cAAc;AAC1C,MAAA,oBAAoBA,QAAM,YAAY;;;;;;;"}
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 type { 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":["setStatusToDraft","contentType","params","contentTypes","hasDraftAndPublish","status","assoc","defaultToDraft","defaultStatus","filterDataPublishedAt","data","publishedAt","statusToLookup","lookup","$notNull","$null","statusToData","Date","setStatusToDraftCurry","curry","defaultToDraftCurry","defaultStatusCurry","filterDataPublishedAtCurry","statusToLookupCurry","statusToDataCurry"],"mappings":"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"}