@strapi/core 0.0.0-experimental.9034cc03ac5cf73cd9dcb2ff7c6cadece3f6910d → 0.0.0-experimental.93181c8b900e97a04bf10785b368657101ec98d8

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.

Potentially problematic release.


This version of @strapi/core might be problematic. Click here for more details.

Files changed (507) hide show
  1. package/LICENSE +18 -3
  2. package/dist/Strapi.d.ts +37 -46
  3. package/dist/Strapi.d.ts.map +1 -1
  4. package/dist/Strapi.js +186 -221
  5. package/dist/Strapi.js.map +1 -1
  6. package/dist/Strapi.mjs +155 -210
  7. package/dist/Strapi.mjs.map +1 -1
  8. package/dist/configuration/config-loader.d.ts.map +1 -1
  9. package/dist/configuration/config-loader.js +9 -5
  10. package/dist/configuration/config-loader.js.map +1 -1
  11. package/dist/configuration/config-loader.mjs +9 -5
  12. package/dist/configuration/config-loader.mjs.map +1 -1
  13. package/dist/configuration/get-dirs.d.ts +10 -0
  14. package/dist/configuration/get-dirs.d.ts.map +1 -0
  15. package/dist/{utils → configuration}/get-dirs.js +3 -2
  16. package/dist/configuration/get-dirs.js.map +1 -0
  17. package/dist/{utils → configuration}/get-dirs.mjs +3 -2
  18. package/dist/configuration/get-dirs.mjs.map +1 -0
  19. package/dist/configuration/index.d.ts +4 -7
  20. package/dist/configuration/index.d.ts.map +1 -1
  21. package/dist/configuration/index.js +8 -6
  22. package/dist/configuration/index.js.map +1 -1
  23. package/dist/configuration/index.mjs +5 -4
  24. package/dist/configuration/index.mjs.map +1 -1
  25. package/dist/core-api/controller/collection-type.d.ts.map +1 -1
  26. package/dist/core-api/controller/collection-type.js +6 -3
  27. package/dist/core-api/controller/collection-type.js.map +1 -1
  28. package/dist/core-api/controller/collection-type.mjs +3 -0
  29. package/dist/core-api/controller/collection-type.mjs.map +1 -1
  30. package/dist/core-api/controller/index.js +2 -2
  31. package/dist/core-api/controller/index.js.map +1 -1
  32. package/dist/core-api/controller/single-type.d.ts.map +1 -1
  33. package/dist/core-api/controller/single-type.js +3 -2
  34. package/dist/core-api/controller/single-type.js.map +1 -1
  35. package/dist/core-api/controller/single-type.mjs +1 -0
  36. package/dist/core-api/controller/single-type.mjs.map +1 -1
  37. package/dist/core-api/controller/transform.js +8 -8
  38. package/dist/core-api/controller/transform.js.map +1 -1
  39. package/dist/core-api/routes/index.d.ts.map +1 -1
  40. package/dist/core-api/service/collection-type.d.ts +5 -11
  41. package/dist/core-api/service/collection-type.d.ts.map +1 -1
  42. package/dist/core-api/service/collection-type.js +18 -7
  43. package/dist/core-api/service/collection-type.js.map +1 -1
  44. package/dist/core-api/service/collection-type.mjs +19 -8
  45. package/dist/core-api/service/collection-type.mjs.map +1 -1
  46. package/dist/core-api/service/pagination.d.ts +4 -11
  47. package/dist/core-api/service/pagination.d.ts.map +1 -1
  48. package/dist/core-api/service/pagination.js +18 -44
  49. package/dist/core-api/service/pagination.js.map +1 -1
  50. package/dist/core-api/service/pagination.mjs +16 -42
  51. package/dist/core-api/service/pagination.mjs.map +1 -1
  52. package/dist/core-api/service/single-type.d.ts.map +1 -1
  53. package/dist/core-api/service/single-type.js +9 -2
  54. package/dist/core-api/service/single-type.js.map +1 -1
  55. package/dist/core-api/service/single-type.mjs +9 -2
  56. package/dist/core-api/service/single-type.mjs.map +1 -1
  57. package/dist/domain/content-type/index.js +4 -4
  58. package/dist/domain/content-type/index.js.map +1 -1
  59. package/dist/ee/index.d.ts +2 -0
  60. package/dist/ee/index.d.ts.map +1 -1
  61. package/dist/ee/index.js +3 -3
  62. package/dist/ee/index.js.map +1 -1
  63. package/dist/ee/index.mjs.map +1 -1
  64. package/dist/ee/license.d.ts.map +1 -1
  65. package/dist/ee/license.js +2 -1
  66. package/dist/ee/license.js.map +1 -1
  67. package/dist/ee/license.mjs +2 -1
  68. package/dist/ee/license.mjs.map +1 -1
  69. package/dist/factories.d.ts +2 -2
  70. package/dist/factories.d.ts.map +1 -1
  71. package/dist/factories.js +4 -4
  72. package/dist/factories.js.map +1 -1
  73. package/dist/factories.mjs.map +1 -1
  74. package/dist/index.d.ts +18 -2
  75. package/dist/index.d.ts.map +1 -1
  76. package/dist/index.js +25 -1
  77. package/dist/index.js.map +1 -1
  78. package/dist/index.mjs +27 -3
  79. package/dist/index.mjs.map +1 -1
  80. package/dist/loaders/admin.js +0 -1
  81. package/dist/loaders/admin.js.map +1 -1
  82. package/dist/loaders/admin.mjs +0 -1
  83. package/dist/loaders/admin.mjs.map +1 -1
  84. package/dist/loaders/apis.d.ts.map +1 -1
  85. package/dist/loaders/apis.js +12 -12
  86. package/dist/loaders/apis.js.map +1 -1
  87. package/dist/loaders/apis.mjs +10 -10
  88. package/dist/loaders/apis.mjs.map +1 -1
  89. package/dist/loaders/index.d.ts.map +1 -1
  90. package/dist/loaders/index.js +0 -2
  91. package/dist/loaders/index.js.map +1 -1
  92. package/dist/loaders/index.mjs +0 -2
  93. package/dist/loaders/index.mjs.map +1 -1
  94. package/dist/loaders/plugins/get-enabled-plugins.d.ts.map +1 -1
  95. package/dist/loaders/plugins/get-enabled-plugins.js +41 -15
  96. package/dist/loaders/plugins/get-enabled-plugins.js.map +1 -1
  97. package/dist/loaders/plugins/get-enabled-plugins.mjs +11 -7
  98. package/dist/loaders/plugins/get-enabled-plugins.mjs.map +1 -1
  99. package/dist/loaders/plugins/get-user-plugins-config.js +2 -2
  100. package/dist/loaders/plugins/get-user-plugins-config.js.map +1 -1
  101. package/dist/loaders/plugins/index.js +6 -6
  102. package/dist/loaders/plugins/index.js.map +1 -1
  103. package/dist/middlewares/body.d.ts +2 -2
  104. package/dist/middlewares/body.d.ts.map +1 -1
  105. package/dist/middlewares/body.js +6 -6
  106. package/dist/middlewares/body.js.map +1 -1
  107. package/dist/middlewares/body.mjs +4 -4
  108. package/dist/middlewares/body.mjs.map +1 -1
  109. package/dist/middlewares/cors.d.ts.map +1 -1
  110. package/dist/middlewares/cors.js +9 -7
  111. package/dist/middlewares/cors.js.map +1 -1
  112. package/dist/middlewares/cors.mjs +9 -7
  113. package/dist/middlewares/cors.mjs.map +1 -1
  114. package/dist/middlewares/public.js +3 -3
  115. package/dist/middlewares/public.js.map +1 -1
  116. package/dist/middlewares/public.mjs +1 -1
  117. package/dist/middlewares/public.mjs.map +1 -1
  118. package/dist/middlewares/query.d.ts.map +1 -1
  119. package/dist/middlewares/query.js.map +1 -1
  120. package/dist/middlewares/query.mjs.map +1 -1
  121. package/dist/middlewares/responses.js +2 -2
  122. package/dist/middlewares/responses.js.map +1 -1
  123. package/dist/middlewares/security.d.ts.map +1 -1
  124. package/dist/middlewares/security.js +12 -5
  125. package/dist/middlewares/security.js.map +1 -1
  126. package/dist/middlewares/security.mjs +11 -4
  127. package/dist/middlewares/security.mjs.map +1 -1
  128. package/dist/middlewares/session.js +2 -2
  129. package/dist/middlewares/session.js.map +1 -1
  130. package/dist/migrations/database/5.0.0-discard-drafts.d.ts +30 -0
  131. package/dist/migrations/database/5.0.0-discard-drafts.d.ts.map +1 -0
  132. package/dist/migrations/database/5.0.0-discard-drafts.js +50 -0
  133. package/dist/migrations/database/5.0.0-discard-drafts.js.map +1 -0
  134. package/dist/migrations/database/5.0.0-discard-drafts.mjs +50 -0
  135. package/dist/migrations/database/5.0.0-discard-drafts.mjs.map +1 -0
  136. package/dist/migrations/draft-publish.d.ts.map +1 -1
  137. package/dist/migrations/draft-publish.js +14 -31
  138. package/dist/migrations/draft-publish.js.map +1 -1
  139. package/dist/migrations/draft-publish.mjs +15 -32
  140. package/dist/migrations/draft-publish.mjs.map +1 -1
  141. package/dist/providers/admin.d.ts +3 -0
  142. package/dist/providers/admin.d.ts.map +1 -0
  143. package/dist/providers/admin.js +20 -0
  144. package/dist/providers/admin.js.map +1 -0
  145. package/dist/providers/admin.mjs +21 -0
  146. package/dist/providers/admin.mjs.map +1 -0
  147. package/dist/providers/coreStore.d.ts +3 -0
  148. package/dist/providers/coreStore.d.ts.map +1 -0
  149. package/dist/providers/coreStore.js +11 -0
  150. package/dist/providers/coreStore.js.map +1 -0
  151. package/dist/providers/coreStore.mjs +12 -0
  152. package/dist/providers/coreStore.mjs.map +1 -0
  153. package/dist/providers/cron.d.ts +3 -0
  154. package/dist/providers/cron.d.ts.map +1 -0
  155. package/dist/providers/cron.js +20 -0
  156. package/dist/providers/cron.js.map +1 -0
  157. package/dist/providers/cron.mjs +21 -0
  158. package/dist/providers/cron.mjs.map +1 -0
  159. package/dist/providers/index.d.ts +3 -0
  160. package/dist/providers/index.d.ts.map +1 -0
  161. package/dist/providers/index.js +11 -0
  162. package/dist/providers/index.js.map +1 -0
  163. package/dist/providers/index.mjs +11 -0
  164. package/dist/providers/index.mjs.map +1 -0
  165. package/dist/providers/provider.d.ts +9 -0
  166. package/dist/providers/provider.d.ts.map +1 -0
  167. package/dist/providers/provider.js +5 -0
  168. package/dist/providers/provider.js.map +1 -0
  169. package/dist/providers/provider.mjs +5 -0
  170. package/dist/providers/provider.mjs.map +1 -0
  171. package/dist/providers/registries.d.ts +3 -0
  172. package/dist/providers/registries.d.ts.map +1 -0
  173. package/dist/providers/registries.js +35 -0
  174. package/dist/providers/registries.js.map +1 -0
  175. package/dist/providers/registries.mjs +36 -0
  176. package/dist/providers/registries.mjs.map +1 -0
  177. package/dist/providers/telemetry.d.ts +3 -0
  178. package/dist/providers/telemetry.d.ts.map +1 -0
  179. package/dist/providers/telemetry.js +19 -0
  180. package/dist/providers/telemetry.js.map +1 -0
  181. package/dist/providers/telemetry.mjs +20 -0
  182. package/dist/providers/telemetry.mjs.map +1 -0
  183. package/dist/providers/webhooks.d.ts +3 -0
  184. package/dist/providers/webhooks.d.ts.map +1 -0
  185. package/dist/providers/webhooks.js +30 -0
  186. package/dist/providers/webhooks.js.map +1 -0
  187. package/dist/providers/webhooks.mjs +31 -0
  188. package/dist/providers/webhooks.mjs.map +1 -0
  189. package/dist/registries/apis.js +2 -2
  190. package/dist/registries/apis.js.map +1 -1
  191. package/dist/registries/components.js +2 -2
  192. package/dist/registries/components.js.map +1 -1
  193. package/dist/registries/content-types.js +3 -3
  194. package/dist/registries/content-types.js.map +1 -1
  195. package/dist/registries/controllers.js +3 -3
  196. package/dist/registries/controllers.js.map +1 -1
  197. package/dist/registries/custom-fields.js +4 -4
  198. package/dist/registries/custom-fields.js.map +1 -1
  199. package/dist/registries/hooks.js +2 -2
  200. package/dist/registries/hooks.js.map +1 -1
  201. package/dist/registries/index.d.ts +0 -1
  202. package/dist/registries/index.d.ts.map +1 -1
  203. package/dist/registries/middlewares.js +3 -3
  204. package/dist/registries/middlewares.js.map +1 -1
  205. package/dist/registries/modules.js +3 -3
  206. package/dist/registries/modules.js.map +1 -1
  207. package/dist/registries/plugins.js +2 -2
  208. package/dist/registries/plugins.js.map +1 -1
  209. package/dist/registries/policies.d.ts +1 -1
  210. package/dist/registries/policies.d.ts.map +1 -1
  211. package/dist/registries/policies.js +5 -5
  212. package/dist/registries/policies.js.map +1 -1
  213. package/dist/registries/policies.mjs +1 -1
  214. package/dist/registries/policies.mjs.map +1 -1
  215. package/dist/registries/services.js +3 -3
  216. package/dist/registries/services.js.map +1 -1
  217. package/dist/services/auth/index.js +3 -3
  218. package/dist/services/auth/index.js.map +1 -1
  219. package/dist/services/config.d.ts +3 -0
  220. package/dist/services/config.d.ts.map +1 -0
  221. package/dist/{registries → services}/config.js +11 -7
  222. package/dist/services/config.js.map +1 -0
  223. package/dist/{registries → services}/config.mjs +10 -7
  224. package/dist/services/config.mjs.map +1 -0
  225. package/dist/services/content-api/index.d.ts +6 -12
  226. package/dist/services/content-api/index.d.ts.map +1 -1
  227. package/dist/services/content-api/index.js +1 -1
  228. package/dist/services/content-api/index.js.map +1 -1
  229. package/dist/services/content-api/index.mjs +1 -1
  230. package/dist/services/content-api/index.mjs.map +1 -1
  231. package/dist/services/content-api/permissions/index.d.ts +6 -12
  232. package/dist/services/content-api/permissions/index.d.ts.map +1 -1
  233. package/dist/services/content-api/permissions/index.js +1 -1
  234. package/dist/services/content-api/permissions/index.js.map +1 -1
  235. package/dist/services/content-api/permissions/index.mjs +1 -1
  236. package/dist/services/content-api/permissions/index.mjs.map +1 -1
  237. package/dist/services/content-api/permissions/providers/action.d.ts +3 -6
  238. package/dist/services/content-api/permissions/providers/action.d.ts.map +1 -1
  239. package/dist/services/content-api/permissions/providers/condition.d.ts +3 -6
  240. package/dist/services/content-api/permissions/providers/condition.d.ts.map +1 -1
  241. package/dist/services/core-store.d.ts.map +1 -1
  242. package/dist/services/core-store.js +3 -3
  243. package/dist/services/core-store.js.map +1 -1
  244. package/dist/services/cron.js +3 -3
  245. package/dist/services/cron.js.map +1 -1
  246. package/dist/services/document-service/attributes/index.d.ts +6 -0
  247. package/dist/services/document-service/attributes/index.d.ts.map +1 -0
  248. package/dist/services/{entity-service → document-service}/attributes/index.js +5 -5
  249. package/dist/services/document-service/attributes/index.js.map +1 -0
  250. package/dist/services/{entity-service → document-service}/attributes/index.mjs +5 -5
  251. package/dist/services/document-service/attributes/index.mjs.map +1 -0
  252. package/dist/services/document-service/attributes/transforms.d.ts.map +1 -0
  253. package/dist/services/{entity-service → document-service}/attributes/transforms.js +3 -3
  254. package/dist/services/document-service/attributes/transforms.js.map +1 -0
  255. package/dist/services/document-service/attributes/transforms.mjs.map +1 -0
  256. package/dist/services/document-service/common.d.ts +1 -1
  257. package/dist/services/document-service/common.d.ts.map +1 -1
  258. package/dist/services/document-service/common.js.map +1 -1
  259. package/dist/services/document-service/common.mjs.map +1 -1
  260. package/dist/services/document-service/components.d.ts +25 -1
  261. package/dist/services/document-service/components.d.ts.map +1 -1
  262. package/dist/services/{entity-service → document-service}/components.js +45 -52
  263. package/dist/services/document-service/components.js.map +1 -0
  264. package/dist/services/{entity-service → document-service}/components.mjs +35 -42
  265. package/dist/services/document-service/components.mjs.map +1 -0
  266. package/dist/services/document-service/draft-and-publish.js +16 -16
  267. package/dist/services/document-service/draft-and-publish.js.map +1 -1
  268. package/dist/services/document-service/entries.d.ts +10 -0
  269. package/dist/services/document-service/entries.d.ts.map +1 -0
  270. package/dist/services/document-service/entries.js +96 -0
  271. package/dist/services/document-service/entries.js.map +1 -0
  272. package/dist/services/document-service/entries.mjs +96 -0
  273. package/dist/services/document-service/entries.mjs.map +1 -0
  274. package/dist/services/document-service/events.d.ts +25 -0
  275. package/dist/services/document-service/events.d.ts.map +1 -0
  276. package/dist/services/document-service/events.js +47 -0
  277. package/dist/services/document-service/events.js.map +1 -0
  278. package/dist/services/document-service/events.mjs +47 -0
  279. package/dist/services/document-service/events.mjs.map +1 -0
  280. package/dist/services/document-service/index.d.ts +0 -2
  281. package/dist/services/document-service/index.d.ts.map +1 -1
  282. package/dist/services/document-service/index.js +9 -2
  283. package/dist/services/document-service/index.js.map +1 -1
  284. package/dist/services/document-service/index.mjs +9 -2
  285. package/dist/services/document-service/index.mjs.map +1 -1
  286. package/dist/services/document-service/internationalization.d.ts.map +1 -1
  287. package/dist/services/document-service/internationalization.js +21 -12
  288. package/dist/services/document-service/internationalization.js.map +1 -1
  289. package/dist/services/document-service/internationalization.mjs +14 -5
  290. package/dist/services/document-service/internationalization.mjs.map +1 -1
  291. package/dist/services/document-service/middlewares/middleware-manager.d.ts +5 -2
  292. package/dist/services/document-service/middlewares/middleware-manager.d.ts.map +1 -1
  293. package/dist/services/document-service/middlewares/middleware-manager.js +8 -5
  294. package/dist/services/document-service/middlewares/middleware-manager.js.map +1 -1
  295. package/dist/services/document-service/middlewares/middleware-manager.mjs +8 -5
  296. package/dist/services/document-service/middlewares/middleware-manager.mjs.map +1 -1
  297. package/dist/services/document-service/params.d.ts +3 -1
  298. package/dist/services/document-service/params.d.ts.map +1 -1
  299. package/dist/services/{entity-service → document-service}/params.js +2 -2
  300. package/dist/services/document-service/params.js.map +1 -0
  301. package/dist/services/document-service/params.mjs.map +1 -0
  302. package/dist/services/document-service/repository.d.ts.map +1 -1
  303. package/dist/services/document-service/repository.js +140 -169
  304. package/dist/services/document-service/repository.js.map +1 -1
  305. package/dist/services/document-service/repository.mjs +116 -145
  306. package/dist/services/document-service/repository.mjs.map +1 -1
  307. package/dist/services/document-service/transform/data.d.ts.map +1 -1
  308. package/dist/services/document-service/transform/data.js +4 -2
  309. package/dist/services/document-service/transform/data.js.map +1 -1
  310. package/dist/services/document-service/transform/data.mjs +4 -2
  311. package/dist/services/document-service/transform/data.mjs.map +1 -1
  312. package/dist/services/document-service/transform/id-map.d.ts.map +1 -1
  313. package/dist/services/document-service/transform/id-transform.js +2 -2
  314. package/dist/services/document-service/transform/id-transform.js.map +1 -1
  315. package/dist/services/document-service/transform/query.d.ts +5 -0
  316. package/dist/services/document-service/transform/query.d.ts.map +1 -0
  317. package/dist/services/document-service/transform/query.js +9 -0
  318. package/dist/services/document-service/transform/query.js.map +1 -0
  319. package/dist/services/document-service/transform/query.mjs +9 -0
  320. package/dist/services/document-service/transform/query.mjs.map +1 -0
  321. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +8 -7
  322. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -1
  323. package/dist/services/document-service/transform/relations/extract/data-ids.js +45 -78
  324. package/dist/services/document-service/transform/relations/extract/data-ids.js.map +1 -1
  325. package/dist/services/document-service/transform/relations/extract/data-ids.mjs +44 -77
  326. package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +1 -1
  327. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts +7 -3
  328. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts.map +1 -1
  329. package/dist/services/document-service/transform/relations/transform/data-ids.js +61 -126
  330. package/dist/services/document-service/transform/relations/transform/data-ids.js.map +1 -1
  331. package/dist/services/document-service/transform/relations/transform/data-ids.mjs +61 -126
  332. package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +1 -1
  333. package/dist/services/document-service/transform/relations/transform/default-locale.d.ts +9 -0
  334. package/dist/services/document-service/transform/relations/transform/default-locale.d.ts.map +1 -0
  335. package/dist/services/document-service/transform/relations/transform/default-locale.js +32 -0
  336. package/dist/services/document-service/transform/relations/transform/default-locale.js.map +1 -0
  337. package/dist/services/document-service/transform/relations/transform/default-locale.mjs +32 -0
  338. package/dist/services/document-service/transform/relations/transform/default-locale.mjs.map +1 -0
  339. package/dist/services/document-service/transform/relations/utils/dp.js +2 -2
  340. package/dist/services/document-service/transform/relations/utils/dp.js.map +1 -1
  341. package/dist/services/document-service/transform/relations/utils/i18n.d.ts +2 -2
  342. package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -1
  343. package/dist/services/document-service/transform/relations/utils/i18n.js +3 -9
  344. package/dist/services/document-service/transform/relations/utils/i18n.js.map +1 -1
  345. package/dist/services/document-service/transform/relations/utils/i18n.mjs +3 -9
  346. package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +1 -1
  347. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts +6 -0
  348. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts.map +1 -0
  349. package/dist/services/document-service/transform/relations/utils/map-relation.js +91 -0
  350. package/dist/services/document-service/transform/relations/utils/map-relation.js.map +1 -0
  351. package/dist/services/document-service/transform/relations/utils/map-relation.mjs +91 -0
  352. package/dist/services/document-service/transform/relations/utils/map-relation.mjs.map +1 -0
  353. package/dist/services/document-service/transform/relations/utils/types.d.ts +6 -0
  354. package/dist/services/document-service/transform/relations/utils/types.d.ts.map +1 -1
  355. package/dist/services/document-service/utils/populate.d.ts.map +1 -1
  356. package/dist/services/document-service/utils/populate.js +4 -0
  357. package/dist/services/document-service/utils/populate.js.map +1 -1
  358. package/dist/services/document-service/utils/populate.mjs +4 -0
  359. package/dist/services/document-service/utils/populate.mjs.map +1 -1
  360. package/dist/services/entity-service/index.d.ts.map +1 -1
  361. package/dist/services/entity-service/index.js +11 -4
  362. package/dist/services/entity-service/index.js.map +1 -1
  363. package/dist/services/entity-service/index.mjs +11 -4
  364. package/dist/services/entity-service/index.mjs.map +1 -1
  365. package/dist/services/entity-validator/blocks-validator.d.ts +1 -2
  366. package/dist/services/entity-validator/blocks-validator.d.ts.map +1 -1
  367. package/dist/services/entity-validator/blocks-validator.js +4 -3
  368. package/dist/services/entity-validator/blocks-validator.js.map +1 -1
  369. package/dist/services/entity-validator/blocks-validator.mjs +3 -3
  370. package/dist/services/entity-validator/blocks-validator.mjs.map +1 -1
  371. package/dist/services/entity-validator/index.d.ts +15 -1
  372. package/dist/services/entity-validator/index.d.ts.map +1 -1
  373. package/dist/services/entity-validator/index.js +183 -125
  374. package/dist/services/entity-validator/index.js.map +1 -1
  375. package/dist/services/entity-validator/index.mjs +178 -120
  376. package/dist/services/entity-validator/index.mjs.map +1 -1
  377. package/dist/services/entity-validator/validators.d.ts +36 -25
  378. package/dist/services/entity-validator/validators.d.ts.map +1 -1
  379. package/dist/services/entity-validator/validators.js +148 -33
  380. package/dist/services/entity-validator/validators.js.map +1 -1
  381. package/dist/services/entity-validator/validators.mjs +140 -25
  382. package/dist/services/entity-validator/validators.mjs.map +1 -1
  383. package/dist/services/event-hub.d.ts +1 -0
  384. package/dist/services/event-hub.d.ts.map +1 -1
  385. package/dist/services/event-hub.js +9 -4
  386. package/dist/services/event-hub.js.map +1 -1
  387. package/dist/services/event-hub.mjs +9 -4
  388. package/dist/services/event-hub.mjs.map +1 -1
  389. package/dist/services/metrics/middleware.d.ts.map +1 -1
  390. package/dist/services/metrics/rate-limiter.d.ts.map +1 -1
  391. package/dist/services/metrics/rate-limiter.js.map +1 -1
  392. package/dist/services/metrics/rate-limiter.mjs.map +1 -1
  393. package/dist/services/reloader.d.ts +7 -0
  394. package/dist/services/reloader.d.ts.map +1 -0
  395. package/dist/services/reloader.js +36 -0
  396. package/dist/services/reloader.js.map +1 -0
  397. package/dist/services/reloader.mjs +36 -0
  398. package/dist/services/reloader.mjs.map +1 -0
  399. package/dist/services/server/compose-endpoint.d.ts.map +1 -1
  400. package/dist/services/server/compose-endpoint.js +7 -7
  401. package/dist/services/server/compose-endpoint.js.map +1 -1
  402. package/dist/services/server/index.js +1 -1
  403. package/dist/services/server/index.js.map +1 -1
  404. package/dist/services/server/index.mjs +1 -1
  405. package/dist/services/server/index.mjs.map +1 -1
  406. package/dist/services/server/koa.d.ts.map +1 -1
  407. package/dist/services/server/koa.js +4 -4
  408. package/dist/services/server/koa.js.map +1 -1
  409. package/dist/services/server/koa.mjs +1 -1
  410. package/dist/services/server/koa.mjs.map +1 -1
  411. package/dist/services/server/middleware.js +3 -3
  412. package/dist/services/server/middleware.js.map +1 -1
  413. package/dist/services/server/register-routes.js +3 -3
  414. package/dist/services/server/register-routes.js.map +1 -1
  415. package/dist/services/server/register-routes.mjs +3 -3
  416. package/dist/services/server/register-routes.mjs.map +1 -1
  417. package/dist/services/server/routing.d.ts +1 -1
  418. package/dist/services/server/routing.js +2 -2
  419. package/dist/services/server/routing.js.map +1 -1
  420. package/dist/services/utils/dynamic-zones.js +5 -5
  421. package/dist/services/utils/dynamic-zones.js.map +1 -1
  422. package/dist/services/webhook-runner.d.ts +2 -1
  423. package/dist/services/webhook-runner.d.ts.map +1 -1
  424. package/dist/services/webhook-runner.js.map +1 -1
  425. package/dist/services/webhook-runner.mjs.map +1 -1
  426. package/dist/services/webhook-store.d.ts +2 -8
  427. package/dist/services/webhook-store.d.ts.map +1 -1
  428. package/dist/services/webhook-store.js +14 -8
  429. package/dist/services/webhook-store.js.map +1 -1
  430. package/dist/services/webhook-store.mjs +14 -8
  431. package/dist/services/webhook-store.mjs.map +1 -1
  432. package/dist/utils/cron.js +3 -3
  433. package/dist/utils/cron.js.map +1 -1
  434. package/dist/utils/fetch.d.ts.map +1 -1
  435. package/dist/utils/fetch.js +4 -3
  436. package/dist/utils/fetch.js.map +1 -1
  437. package/dist/utils/fetch.mjs +4 -3
  438. package/dist/utils/fetch.mjs.map +1 -1
  439. package/dist/utils/filepath-to-prop-path.d.ts +1 -1
  440. package/dist/utils/filepath-to-prop-path.d.ts.map +1 -1
  441. package/dist/utils/filepath-to-prop-path.js +27 -6
  442. package/dist/utils/filepath-to-prop-path.js.map +1 -1
  443. package/dist/utils/filepath-to-prop-path.mjs +25 -5
  444. package/dist/utils/filepath-to-prop-path.mjs.map +1 -1
  445. package/dist/utils/index.d.ts +2 -1
  446. package/dist/utils/index.d.ts.map +1 -1
  447. package/dist/utils/is-initialized.js +3 -3
  448. package/dist/utils/is-initialized.js.map +1 -1
  449. package/dist/utils/load-files.d.ts.map +1 -1
  450. package/dist/utils/resolve-working-dirs.d.ts +19 -0
  451. package/dist/utils/resolve-working-dirs.d.ts.map +1 -0
  452. package/dist/utils/resolve-working-dirs.js +13 -0
  453. package/dist/utils/resolve-working-dirs.js.map +1 -0
  454. package/dist/utils/resolve-working-dirs.mjs +11 -0
  455. package/dist/utils/resolve-working-dirs.mjs.map +1 -0
  456. package/dist/utils/startup-logger.d.ts.map +1 -1
  457. package/dist/utils/startup-logger.js +4 -4
  458. package/dist/utils/startup-logger.js.map +1 -1
  459. package/dist/utils/startup-logger.mjs +3 -3
  460. package/dist/utils/startup-logger.mjs.map +1 -1
  461. package/dist/utils/transform-content-types-to-models.d.ts +2 -2
  462. package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
  463. package/dist/utils/transform-content-types-to-models.js +17 -4
  464. package/dist/utils/transform-content-types-to-models.js.map +1 -1
  465. package/dist/utils/transform-content-types-to-models.mjs +16 -3
  466. package/dist/utils/transform-content-types-to-models.mjs.map +1 -1
  467. package/dist/utils/update-notifier/index.d.ts +1 -6
  468. package/dist/utils/update-notifier/index.d.ts.map +1 -1
  469. package/dist/utils/update-notifier/index.js +12 -17
  470. package/dist/utils/update-notifier/index.js.map +1 -1
  471. package/dist/utils/update-notifier/index.mjs +12 -16
  472. package/dist/utils/update-notifier/index.mjs.map +1 -1
  473. package/package.json +31 -27
  474. package/dist/registries/config.d.ts +0 -4
  475. package/dist/registries/config.d.ts.map +0 -1
  476. package/dist/registries/config.js.map +0 -1
  477. package/dist/registries/config.mjs.map +0 -1
  478. package/dist/services/document-service/document-engine.d.ts +0 -2
  479. package/dist/services/document-service/document-engine.d.ts.map +0 -1
  480. package/dist/services/document-service/transform/relations/transform/output-ids.d.ts +0 -2
  481. package/dist/services/document-service/transform/relations/transform/output-ids.d.ts.map +0 -1
  482. package/dist/services/document-service/transform/relations/utils/data.js +0 -12
  483. package/dist/services/document-service/transform/relations/utils/data.js.map +0 -1
  484. package/dist/services/document-service/transform/relations/utils/data.mjs +0 -12
  485. package/dist/services/document-service/transform/relations/utils/data.mjs.map +0 -1
  486. package/dist/services/entity-service/attributes/index.d.ts +0 -6
  487. package/dist/services/entity-service/attributes/index.d.ts.map +0 -1
  488. package/dist/services/entity-service/attributes/index.js.map +0 -1
  489. package/dist/services/entity-service/attributes/index.mjs.map +0 -1
  490. package/dist/services/entity-service/attributes/transforms.d.ts.map +0 -1
  491. package/dist/services/entity-service/attributes/transforms.js.map +0 -1
  492. package/dist/services/entity-service/attributes/transforms.mjs.map +0 -1
  493. package/dist/services/entity-service/components.d.ts +0 -95
  494. package/dist/services/entity-service/components.d.ts.map +0 -1
  495. package/dist/services/entity-service/components.js.map +0 -1
  496. package/dist/services/entity-service/components.mjs.map +0 -1
  497. package/dist/services/entity-service/params.d.ts +0 -8
  498. package/dist/services/entity-service/params.d.ts.map +0 -1
  499. package/dist/services/entity-service/params.js.map +0 -1
  500. package/dist/services/entity-service/params.mjs.map +0 -1
  501. package/dist/utils/get-dirs.d.ts +0 -9
  502. package/dist/utils/get-dirs.d.ts.map +0 -1
  503. package/dist/utils/get-dirs.js.map +0 -1
  504. package/dist/utils/get-dirs.mjs.map +0 -1
  505. /package/dist/services/{entity-service → document-service}/attributes/transforms.d.ts +0 -0
  506. /package/dist/services/{entity-service → document-service}/attributes/transforms.mjs +0 -0
  507. /package/dist/services/{entity-service → document-service}/params.mjs +0 -0
@@ -1,14 +1,15 @@
1
1
  import _ from "lodash";
2
- import { omit, has, pipe, assign } from "lodash/fp";
2
+ import { curry, omit, pipe, assign, has } from "lodash/fp";
3
3
  import { contentTypes, async, errors } from "@strapi/utils";
4
- const isDialectMySQL = () => strapi.db?.dialect.client === "mysql";
5
- function omitComponentData(contentType, data) {
6
- const { attributes } = contentType;
7
- const componentAttributes = Object.keys(attributes).filter(
8
- (attributeName) => contentTypes.isComponentAttribute(attributes[attributeName])
9
- );
10
- return omit(componentAttributes, data);
11
- }
4
+ const omitComponentData = curry(
5
+ (schema, data) => {
6
+ const { attributes } = schema;
7
+ const componentAttributes = Object.keys(attributes).filter(
8
+ (attributeName) => contentTypes.isComponentAttribute(attributes[attributeName])
9
+ );
10
+ return omit(componentAttributes, data);
11
+ }
12
+ );
12
13
  const createComponents = async (uid, data) => {
13
14
  const { attributes = {} } = strapi.getModel(uid);
14
15
  const componentBody = {};
@@ -30,8 +31,7 @@ const createComponents = async (uid, data) => {
30
31
  }
31
32
  const components = await async.map(
32
33
  componentValue,
33
- (value) => createComponent(componentUID, value),
34
- { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
34
+ (value) => createComponent(componentUID, value)
35
35
  );
36
36
  componentBody[attributeName] = components.map(({ id }) => {
37
37
  return {
@@ -74,8 +74,7 @@ const createComponents = async (uid, data) => {
74
74
  };
75
75
  componentBody[attributeName] = await async.map(
76
76
  dynamiczoneValues,
77
- createDynamicZoneComponents,
78
- { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
77
+ createDynamicZoneComponents
79
78
  );
80
79
  continue;
81
80
  }
@@ -107,8 +106,7 @@ const updateComponents = async (uid, entityToUpdate, data) => {
107
106
  }
108
107
  const components = await async.map(
109
108
  componentValue,
110
- (value) => updateOrCreateComponent(componentUID, value),
111
- { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
109
+ (value) => updateOrCreateComponent(componentUID, value)
112
110
  );
113
111
  componentBody[attributeName] = components.filter(_.negate(_.isNil)).map(({ id }) => {
114
112
  return {
@@ -135,20 +133,16 @@ const updateComponents = async (uid, entityToUpdate, data) => {
135
133
  if (!Array.isArray(dynamiczoneValues)) {
136
134
  throw new Error("Expected an array to create repeatable component");
137
135
  }
138
- componentBody[attributeName] = await async.map(
139
- dynamiczoneValues,
140
- async (value) => {
141
- const { id } = await updateOrCreateComponent(value.__component, value);
142
- return {
143
- id,
144
- __component: value.__component,
145
- __pivot: {
146
- field: attributeName
147
- }
148
- };
149
- },
150
- { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
151
- );
136
+ componentBody[attributeName] = await async.map(dynamiczoneValues, async (value) => {
137
+ const { id } = await updateOrCreateComponent(value.__component, value);
138
+ return {
139
+ id,
140
+ __component: value.__component,
141
+ __pivot: {
142
+ field: attributeName
143
+ }
144
+ };
145
+ });
152
146
  }
153
147
  }
154
148
  return componentBody;
@@ -230,16 +224,12 @@ const deleteComponents = async (uid, entityToDelete, { loadComponents = true } =
230
224
  const { component: componentUID } = attribute;
231
225
  await async.map(
232
226
  _.castArray(value),
233
- (subValue) => deleteComponent(componentUID, subValue),
234
- {
235
- concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity
236
- }
227
+ (subValue) => deleteComponent(componentUID, subValue)
237
228
  );
238
229
  } else {
239
230
  await async.map(
240
231
  _.castArray(value),
241
- (subValue) => deleteComponent(subValue.__component, subValue),
242
- { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
232
+ (subValue) => deleteComponent(subValue.__component, subValue)
243
233
  );
244
234
  }
245
235
  continue;
@@ -247,26 +237,23 @@ const deleteComponents = async (uid, entityToDelete, { loadComponents = true } =
247
237
  }
248
238
  };
249
239
  const createComponent = async (uid, data) => {
250
- const model = strapi.getModel(uid);
240
+ const schema = strapi.getModel(uid);
251
241
  const componentData = await createComponents(uid, data);
252
242
  const transform = pipe(
253
243
  // Make sure we don't save the component with a pre-defined ID
254
244
  omit("id"),
255
- // Remove the component data from the original data object ...
256
- (payload) => omitComponentData(model, payload),
257
- // ... and assign the newly created component instead
258
- assign(componentData)
245
+ assignComponentData(schema, componentData)
259
246
  );
260
247
  return strapi.db.query(uid).create({ data: transform(data) });
261
248
  };
262
249
  const updateComponent = async (uid, componentToUpdate, data) => {
263
- const model = strapi.getModel(uid);
250
+ const schema = strapi.getModel(uid);
264
251
  const componentData = await updateComponents(uid, componentToUpdate, data);
265
252
  return strapi.db.query(uid).update({
266
253
  where: {
267
254
  id: componentToUpdate.id
268
255
  },
269
- data: Object.assign(omitComponentData(model, data), componentData)
256
+ data: assignComponentData(schema, componentData, data)
270
257
  });
271
258
  };
272
259
  const updateOrCreateComponent = (componentUID, value) => {
@@ -282,7 +269,13 @@ const deleteComponent = async (uid, componentToDelete) => {
282
269
  await deleteComponents(uid, componentToDelete);
283
270
  await strapi.db.query(uid).delete({ where: { id: componentToDelete.id } });
284
271
  };
272
+ const assignComponentData = curry(
273
+ (schema, componentData, data) => {
274
+ return pipe(omitComponentData(schema), assign(componentData))(data);
275
+ }
276
+ );
285
277
  export {
278
+ assignComponentData,
286
279
  createComponents,
287
280
  deleteComponent,
288
281
  deleteComponents,
@@ -0,0 +1 @@
1
+ {"version":3,"file":"components.mjs","sources":["../../../src/services/document-service/components.ts"],"sourcesContent":["import _ from 'lodash';\nimport { has, omit, pipe, assign, curry } from 'lodash/fp';\nimport type { Utils, UID, Schema, Data, Modules } from '@strapi/types';\nimport { contentTypes as contentTypesUtils, async, errors } from '@strapi/utils';\n\n// type aliases for readability\ntype Input<T extends UID.Schema> = Modules.Documents.Params.Data.Input<T>;\n\ntype LoadedComponents<TUID extends UID.Schema> = Data.Entity<\n TUID,\n Schema.AttributeNamesByType<TUID, 'component' | 'dynamiczone'>\n>;\n\ntype SingleComponentValue = Schema.Attribute.ComponentValue<UID.Component, false>;\ntype RepeatableComponentValue = Schema.Attribute.ComponentValue<UID.Component, true>;\n\ntype ComponentValue = SingleComponentValue | RepeatableComponentValue;\n\ntype DynamicZoneValue = Schema.Attribute.DynamicZoneValue<UID.Component[]>;\n\ntype ComponentBody = {\n [key: string]: ComponentValue | DynamicZoneValue;\n};\n\nconst omitComponentData = curry(\n (schema: Schema.Schema, data: Input<UID.Schema>): Partial<Input<UID.Schema>> => {\n const { attributes } = schema;\n const componentAttributes = Object.keys(attributes).filter((attributeName) =>\n contentTypesUtils.isComponentAttribute(attributes[attributeName])\n );\n\n return omit(componentAttributes, data);\n }\n);\n\n// NOTE: we could generalize the logic to allow CRUD of relation directly in the DB layer\nconst createComponents = async <TUID extends UID.Schema, TData extends Input<TUID>>(\n uid: TUID,\n data: TData\n) => {\n const { attributes = {} } = strapi.getModel(uid);\n\n const componentBody: ComponentBody = {};\n\n const attributeNames = Object.keys(attributes);\n\n for (const attributeName of attributeNames) {\n const attribute = attributes[attributeName];\n\n if (!has(attributeName, data) || !contentTypesUtils.isComponentAttribute(attribute)) {\n continue;\n }\n\n if (attribute.type === 'component') {\n const { component: componentUID, repeatable = false } = attribute;\n\n const componentValue = data[attributeName as keyof TData];\n\n if (componentValue === null) {\n continue;\n }\n\n if (repeatable === true) {\n if (!Array.isArray(componentValue)) {\n throw new Error('Expected an array to create repeatable component');\n }\n\n const components: RepeatableComponentValue = await async.map(componentValue, (value: any) =>\n createComponent(componentUID, value)\n );\n\n componentBody[attributeName] = components.map(({ id }) => {\n return {\n id,\n __pivot: {\n field: attributeName,\n component_type: componentUID,\n },\n };\n });\n } else {\n const component = await createComponent(\n componentUID,\n componentValue as Input<UID.Component>\n );\n\n componentBody[attributeName] = {\n id: component.id,\n __pivot: {\n field: attributeName,\n component_type: componentUID,\n },\n };\n }\n\n continue;\n }\n\n if (attribute.type === 'dynamiczone') {\n const dynamiczoneValues = data[\n attributeName as keyof TData\n ] as Modules.EntityService.Params.Attribute.GetValue<Schema.Attribute.DynamicZone>;\n\n if (!Array.isArray(dynamiczoneValues)) {\n throw new Error('Expected an array to create repeatable component');\n }\n\n const createDynamicZoneComponents = async (\n value: Utils.Array.Values<typeof dynamiczoneValues>\n ) => {\n const { id } = await createComponent(value.__component, value);\n return {\n id,\n __component: value.__component,\n __pivot: {\n field: attributeName,\n },\n };\n };\n\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n componentBody[attributeName] = await async.map(\n dynamiczoneValues,\n createDynamicZoneComponents\n );\n\n continue;\n }\n }\n\n return componentBody;\n};\n\nconst getComponents = async <TUID extends UID.Schema>(\n uid: TUID,\n entity: { id: Modules.EntityService.Params.Attribute.ID }\n): Promise<LoadedComponents<TUID>> => {\n const componentAttributes = contentTypesUtils.getComponentAttributes(strapi.getModel(uid));\n\n if (_.isEmpty(componentAttributes)) {\n return {} as LoadedComponents<TUID>;\n }\n\n return strapi.db.query(uid).load(entity, componentAttributes) as Promise<LoadedComponents<TUID>>;\n};\n\n/*\n delete old components\n create or update\n*/\nconst updateComponents = async <TUID extends UID.Schema, TData extends Partial<Input<TUID>>>(\n uid: TUID,\n entityToUpdate: { id: Modules.EntityService.Params.Attribute.ID },\n data: TData\n) => {\n const { attributes = {} } = strapi.getModel(uid);\n\n const componentBody: ComponentBody = {};\n\n for (const attributeName of Object.keys(attributes)) {\n const attribute = attributes[attributeName];\n\n if (!has(attributeName, data)) {\n continue;\n }\n\n if (attribute.type === 'component') {\n const { component: componentUID, repeatable = false } = attribute;\n\n const componentValue = data[attributeName as keyof TData] as ComponentValue;\n\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\n const idsToKeep = _.castArray(componentValue).filter(has('id')).map(pickStringifiedId);\n const allIds = _.castArray(previousValue).filter(has('id')).map(pickStringifiedId);\n\n idsToKeep.forEach((id) => {\n if (!allIds.includes(id)) {\n throw new errors.ApplicationError(\n `Some of the provided components in ${attributeName} are not related to the entity`\n );\n }\n });\n\n const idsToDelete = _.difference(allIds, idsToKeep);\n\n if (idsToDelete.length > 0) {\n for (const idToDelete of idsToDelete) {\n await deleteComponent(componentUID, { id: idToDelete });\n }\n }\n};\n\nconst deleteOldDZComponents = async <TUID extends UID.Schema>(\n uid: TUID,\n entityToUpdate: { id: Modules.EntityService.Params.Attribute.ID },\n attributeName: string,\n dynamiczoneValues: DynamicZoneValue\n) => {\n const previousValue = (await strapi.db\n .query(uid)\n .load(entityToUpdate, attributeName)) as DynamicZoneValue;\n\n const idsToKeep = _.castArray(dynamiczoneValues)\n .filter(has('id'))\n .map((v) => ({\n id: pickStringifiedId(v),\n __component: v.__component,\n }));\n\n const allIds = _.castArray(previousValue)\n .filter(has('id'))\n .map((v) => ({\n id: pickStringifiedId(v),\n __component: v.__component,\n }));\n\n idsToKeep.forEach(({ id, __component }) => {\n if (!allIds.find((el) => el.id === id && el.__component === __component)) {\n const err = new Error(\n `Some of the provided components in ${attributeName} are not related to the entity`\n );\n\n Object.assign(err, { status: 400 });\n throw err;\n }\n });\n\n type IdsToDelete = DynamicZoneValue;\n\n const idsToDelete = allIds.reduce((acc, { id, __component }) => {\n if (!idsToKeep.find((el) => el.id === id && el.__component === __component)) {\n acc.push({ id, __component });\n }\n\n return acc;\n }, [] as IdsToDelete);\n\n if (idsToDelete.length > 0) {\n for (const idToDelete of idsToDelete) {\n const { id, __component } = idToDelete;\n await deleteComponent(__component, { id });\n }\n }\n};\n\nconst deleteComponents = async <TUID extends UID.Schema, TEntity extends Data.Entity<TUID>>(\n uid: TUID,\n entityToDelete: TEntity,\n { loadComponents = true } = {}\n) => {\n const { attributes = {} } = strapi.getModel(uid);\n\n const attributeNames = Object.keys(attributes);\n\n for (const attributeName of attributeNames) {\n const attribute = attributes[attributeName];\n\n if (attribute.type === 'component' || attribute.type === 'dynamiczone') {\n let value;\n\n if (loadComponents) {\n value = await strapi.db.query(uid).load(entityToDelete, attributeName);\n } else {\n value = entityToDelete[attributeName as keyof TEntity];\n }\n\n if (!value) {\n continue;\n }\n\n if (attribute.type === 'component') {\n const { component: componentUID } = attribute;\n await async.map(_.castArray(value), (subValue: any) =>\n deleteComponent(componentUID, subValue)\n );\n } else {\n await async.map(_.castArray(value), (subValue: any) =>\n deleteComponent(subValue.__component, subValue)\n );\n }\n\n continue;\n }\n }\n};\n\n/** *************************\n Component queries\n************************** */\n\n// components can have nested compos so this must be recursive\nconst createComponent = async <TUID extends UID.Component>(uid: TUID, data: Input<TUID>) => {\n const schema = strapi.getModel(uid);\n\n const componentData = await createComponents(uid, data);\n\n const transform = pipe(\n // Make sure we don't save the component with a pre-defined ID\n omit('id'),\n assignComponentData(schema, componentData)\n );\n\n return strapi.db.query(uid).create({ data: transform(data) });\n};\n\n// components can have nested compos so this must be recursive\nconst updateComponent = async <TUID extends UID.Component>(\n uid: TUID,\n componentToUpdate: { id: Modules.EntityService.Params.Attribute.ID },\n data: Input<TUID>\n) => {\n const schema = strapi.getModel(uid);\n\n const componentData = await updateComponents(uid, componentToUpdate, data);\n\n return strapi.db.query(uid).update({\n where: {\n id: componentToUpdate.id,\n },\n data: assignComponentData(schema, componentData, data),\n });\n};\n\nconst updateOrCreateComponent = <TUID extends UID.Component>(\n componentUID: TUID,\n value: Input<TUID>\n) => {\n if (value === null) {\n return null;\n }\n\n // update\n if ('id' in value && typeof value.id !== 'undefined') {\n // TODO: verify the compo is associated with the entity\n return updateComponent(componentUID, { id: value.id }, value);\n }\n\n // create\n return createComponent(componentUID, value);\n};\n\nconst deleteComponent = async <TUID extends UID.Component>(\n uid: TUID,\n componentToDelete: Data.Component<TUID>\n) => {\n await deleteComponents(uid, componentToDelete);\n await strapi.db.query(uid).delete({ where: { id: componentToDelete.id } });\n};\n\nconst assignComponentData = curry(\n (schema: Schema.Schema, componentData: ComponentBody, data: Input<UID.Schema>) => {\n return pipe(omitComponentData(schema), assign(componentData))(data);\n }\n);\n\nexport {\n omitComponentData,\n assignComponentData,\n getComponents,\n createComponents,\n updateComponents,\n deleteComponents,\n deleteComponent,\n};\n"],"names":["contentTypesUtils"],"mappings":";;;AAwBA,MAAM,oBAAoB;AAAA,EACxB,CAAC,QAAuB,SAAwD;AACxE,UAAA,EAAE,WAAe,IAAA;AACvB,UAAM,sBAAsB,OAAO,KAAK,UAAU,EAAE;AAAA,MAAO,CAAC,kBAC1DA,aAAkB,qBAAqB,WAAW,aAAa,CAAC;AAAA,IAAA;AAG3D,WAAA,KAAK,qBAAqB,IAAI;AAAA,EACvC;AACF;AAGM,MAAA,mBAAmB,OACvB,KACA,SACG;AACH,QAAM,EAAE,aAAa,OAAO,OAAO,SAAS,GAAG;AAE/C,QAAM,gBAA+B,CAAA;AAE/B,QAAA,iBAAiB,OAAO,KAAK,UAAU;AAE7C,aAAW,iBAAiB,gBAAgB;AACpC,UAAA,YAAY,WAAW,aAAa;AAEtC,QAAA,CAAC,IAAI,eAAe,IAAI,KAAK,CAACA,aAAkB,qBAAqB,SAAS,GAAG;AACnF;AAAA,IACF;AAEI,QAAA,UAAU,SAAS,aAAa;AAClC,YAAM,EAAE,WAAW,cAAc,aAAa,UAAU;AAElD,YAAA,iBAAiB,KAAK,aAA4B;AAExD,UAAI,mBAAmB,MAAM;AAC3B;AAAA,MACF;AAEA,UAAI,eAAe,MAAM;AACvB,YAAI,CAAC,MAAM,QAAQ,cAAc,GAAG;AAC5B,gBAAA,IAAI,MAAM,kDAAkD;AAAA,QACpE;AAEM,cAAA,aAAuC,MAAM,MAAM;AAAA,UAAI;AAAA,UAAgB,CAAC,UAC5E,gBAAgB,cAAc,KAAK;AAAA,QAAA;AAGrC,sBAAc,aAAa,IAAI,WAAW,IAAI,CAAC,EAAE,SAAS;AACjD,iBAAA;AAAA,YACL;AAAA,YACA,SAAS;AAAA,cACP,OAAO;AAAA,cACP,gBAAgB;AAAA,YAClB;AAAA,UAAA;AAAA,QACF,CACD;AAAA,MAAA,OACI;AACL,cAAM,YAAY,MAAM;AAAA,UACtB;AAAA,UACA;AAAA,QAAA;AAGF,sBAAc,aAAa,IAAI;AAAA,UAC7B,IAAI,UAAU;AAAA,UACd,SAAS;AAAA,YACP,OAAO;AAAA,YACP,gBAAgB;AAAA,UAClB;AAAA,QAAA;AAAA,MAEJ;AAEA;AAAA,IACF;AAEI,QAAA,UAAU,SAAS,eAAe;AAC9B,YAAA,oBAAoB,KACxB,aACF;AAEA,UAAI,CAAC,MAAM,QAAQ,iBAAiB,GAAG;AAC/B,cAAA,IAAI,MAAM,kDAAkD;AAAA,MACpE;AAEM,YAAA,8BAA8B,OAClC,UACG;AACH,cAAM,EAAE,GAAG,IAAI,MAAM,gBAAgB,MAAM,aAAa,KAAK;AACtD,eAAA;AAAA,UACL;AAAA,UACA,aAAa,MAAM;AAAA,UACnB,SAAS;AAAA,YACP,OAAO;AAAA,UACT;AAAA,QAAA;AAAA,MACF;AAIY,oBAAA,aAAa,IAAI,MAAM,MAAM;AAAA,QACzC;AAAA,QACA;AAAA,MAAA;AAGF;AAAA,IACF;AAAA,EACF;AAEO,SAAA;AACT;AAEM,MAAA,gBAAgB,OACpB,KACA,WACoC;AACpC,QAAM,sBAAsBA,aAAkB,uBAAuB,OAAO,SAAS,GAAG,CAAC;AAErF,MAAA,EAAE,QAAQ,mBAAmB,GAAG;AAClC,WAAO;EACT;AAEA,SAAO,OAAO,GAAG,MAAM,GAAG,EAAE,KAAK,QAAQ,mBAAmB;AAC9D;AAMA,MAAM,mBAAmB,OACvB,KACA,gBACA,SACG;AACH,QAAM,EAAE,aAAa,OAAO,OAAO,SAAS,GAAG;AAE/C,QAAM,gBAA+B,CAAA;AAErC,aAAW,iBAAiB,OAAO,KAAK,UAAU,GAAG;AAC7C,UAAA,YAAY,WAAW,aAAa;AAE1C,QAAI,CAAC,IAAI,eAAe,IAAI,GAAG;AAC7B;AAAA,IACF;AAEI,QAAA,UAAU,SAAS,aAAa;AAClC,YAAM,EAAE,WAAW,cAAc,aAAa,UAAU;AAElD,YAAA,iBAAiB,KAAK,aAA4B;AAExD,YAAM,oBAAoB,KAAK,cAAc,gBAAgB,eAAe,cAAc;AAE1F,UAAI,eAAe,MAAM;AACvB,YAAI,CAAC,MAAM,QAAQ,cAAc,GAAG;AAC5B,gBAAA,IAAI,MAAM,kDAAkD;AAAA,QACpE;AAGM,cAAA,aAAuC,MAAM,MAAM;AAAA,UAAI;AAAA,UAAgB,CAAC,UAC5E,wBAAwB,cAAc,KAAK;AAAA,QAAA;AAG7C,sBAAc,aAAa,IAAI,WAAW,OAAO,EAAE,OAAO,EAAE,KAAK,CAAC,EAAE,IAAI,CAAC,EAAE,SAAS;AAC3E,iBAAA;AAAA,YACL;AAAA,YACA,SAAS;AAAA,cACP,OAAO;AAAA,cACP,gBAAgB;AAAA,YAClB;AAAA,UAAA;AAAA,QACF,CACD;AAAA,MAAA,OACI;AACL,cAAM,YAAY,MAAM,wBAAwB,cAAc,cAAc;AAC9D,sBAAA,aAAa,IAAI,aAAa;AAAA,UAC1C,IAAI,UAAU;AAAA,UACd,SAAS;AAAA,YACP,OAAO;AAAA,YACP,gBAAgB;AAAA,UAClB;AAAA,QAAA;AAAA,MAEJ;AAAA,IAAA,WACS,UAAU,SAAS,eAAe;AACrC,YAAA,oBAAoB,KAAK,aAA4B;AAE3D,YAAM,sBAAsB,KAAK,gBAAgB,eAAe,iBAAiB;AAEjF,UAAI,CAAC,MAAM,QAAQ,iBAAiB,GAAG;AAC/B,cAAA,IAAI,MAAM,kDAAkD;AAAA,MACpE;AAGA,oBAAc,aAAa,IAAI,MAAM,MAAM,IAAI,mBAAmB,OAAO,UAAe;AACtF,cAAM,EAAE,GAAG,IAAI,MAAM,wBAAwB,MAAM,aAAa,KAAK;AAE9D,eAAA;AAAA,UACL;AAAA,UACA,aAAa,MAAM;AAAA,UACnB,SAAS;AAAA,YACP,OAAO;AAAA,UACT;AAAA,QAAA;AAAA,MACF,CACD;AAAA,IACH;AAAA,EACF;AAEO,SAAA;AACT;AAEA,MAAM,oBAAoB,CAAC;AAAA,EACzB;AACF,MAE0D;AACpD,MAAA,OAAO,OAAO,UAAU;AACnB,WAAA;AAAA,EACT;AAEA,SAAO,GAAG,EAAE;AACd;AAEA,MAAM,sBAAsB,OAC1B,KACA,cACA,gBACA,eACA,mBACG;AACG,QAAA,gBAAiB,MAAM,OAAO,GACjC,MAAM,GAAG,EACT,KAAK,gBAAgB,aAAa;AAE/B,QAAA,YAAY,EAAE,UAAU,cAAc,EAAE,OAAO,IAAI,IAAI,CAAC,EAAE,IAAI,iBAAiB;AAC/E,QAAA,SAAS,EAAE,UAAU,aAAa,EAAE,OAAO,IAAI,IAAI,CAAC,EAAE,IAAI,iBAAiB;AAEvE,YAAA,QAAQ,CAAC,OAAO;AACxB,QAAI,CAAC,OAAO,SAAS,EAAE,GAAG;AACxB,YAAM,IAAI,OAAO;AAAA,QACf,sCAAsC,aAAa;AAAA,MAAA;AAAA,IAEvD;AAAA,EAAA,CACD;AAED,QAAM,cAAc,EAAE,WAAW,QAAQ,SAAS;AAE9C,MAAA,YAAY,SAAS,GAAG;AAC1B,eAAW,cAAc,aAAa;AACpC,YAAM,gBAAgB,cAAc,EAAE,IAAI,WAAY,CAAA;AAAA,IACxD;AAAA,EACF;AACF;AAEA,MAAM,wBAAwB,OAC5B,KACA,gBACA,eACA,sBACG;AACG,QAAA,gBAAiB,MAAM,OAAO,GACjC,MAAM,GAAG,EACT,KAAK,gBAAgB,aAAa;AAErC,QAAM,YAAY,EAAE,UAAU,iBAAiB,EAC5C,OAAO,IAAI,IAAI,CAAC,EAChB,IAAI,CAAC,OAAO;AAAA,IACX,IAAI,kBAAkB,CAAC;AAAA,IACvB,aAAa,EAAE;AAAA,EACf,EAAA;AAEJ,QAAM,SAAS,EAAE,UAAU,aAAa,EACrC,OAAO,IAAI,IAAI,CAAC,EAChB,IAAI,CAAC,OAAO;AAAA,IACX,IAAI,kBAAkB,CAAC;AAAA,IACvB,aAAa,EAAE;AAAA,EACf,EAAA;AAEJ,YAAU,QAAQ,CAAC,EAAE,IAAI,kBAAkB;AACrC,QAAA,CAAC,OAAO,KAAK,CAAC,OAAO,GAAG,OAAO,MAAM,GAAG,gBAAgB,WAAW,GAAG;AACxE,YAAM,MAAM,IAAI;AAAA,QACd,sCAAsC,aAAa;AAAA,MAAA;AAGrD,aAAO,OAAO,KAAK,EAAE,QAAQ,IAAK,CAAA;AAC5B,YAAA;AAAA,IACR;AAAA,EAAA,CACD;AAIK,QAAA,cAAc,OAAO,OAAO,CAAC,KAAK,EAAE,IAAI,kBAAkB;AAC1D,QAAA,CAAC,UAAU,KAAK,CAAC,OAAO,GAAG,OAAO,MAAM,GAAG,gBAAgB,WAAW,GAAG;AAC3E,UAAI,KAAK,EAAE,IAAI,YAAa,CAAA;AAAA,IAC9B;AAEO,WAAA;AAAA,EACT,GAAG,CAAiB,CAAA;AAEhB,MAAA,YAAY,SAAS,GAAG;AAC1B,eAAW,cAAc,aAAa;AAC9B,YAAA,EAAE,IAAI,YAAgB,IAAA;AAC5B,YAAM,gBAAgB,aAAa,EAAE,GAAI,CAAA;AAAA,IAC3C;AAAA,EACF;AACF;AAEM,MAAA,mBAAmB,OACvB,KACA,gBACA,EAAE,iBAAiB,KAAS,IAAA,OACzB;AACH,QAAM,EAAE,aAAa,OAAO,OAAO,SAAS,GAAG;AAEzC,QAAA,iBAAiB,OAAO,KAAK,UAAU;AAE7C,aAAW,iBAAiB,gBAAgB;AACpC,UAAA,YAAY,WAAW,aAAa;AAE1C,QAAI,UAAU,SAAS,eAAe,UAAU,SAAS,eAAe;AAClE,UAAA;AAEJ,UAAI,gBAAgB;AACV,gBAAA,MAAM,OAAO,GAAG,MAAM,GAAG,EAAE,KAAK,gBAAgB,aAAa;AAAA,MAAA,OAChE;AACL,gBAAQ,eAAe,aAA8B;AAAA,MACvD;AAEA,UAAI,CAAC,OAAO;AACV;AAAA,MACF;AAEI,UAAA,UAAU,SAAS,aAAa;AAC5B,cAAA,EAAE,WAAW,aAAiB,IAAA;AACpC,cAAM,MAAM;AAAA,UAAI,EAAE,UAAU,KAAK;AAAA,UAAG,CAAC,aACnC,gBAAgB,cAAc,QAAQ;AAAA,QAAA;AAAA,MACxC,OACK;AACL,cAAM,MAAM;AAAA,UAAI,EAAE,UAAU,KAAK;AAAA,UAAG,CAAC,aACnC,gBAAgB,SAAS,aAAa,QAAQ;AAAA,QAAA;AAAA,MAElD;AAEA;AAAA,IACF;AAAA,EACF;AACF;AAOA,MAAM,kBAAkB,OAAmC,KAAW,SAAsB;AACpF,QAAA,SAAS,OAAO,SAAS,GAAG;AAElC,QAAM,gBAAgB,MAAM,iBAAiB,KAAK,IAAI;AAEtD,QAAM,YAAY;AAAA;AAAA,IAEhB,KAAK,IAAI;AAAA,IACT,oBAAoB,QAAQ,aAAa;AAAA,EAAA;AAGpC,SAAA,OAAO,GAAG,MAAM,GAAG,EAAE,OAAO,EAAE,MAAM,UAAU,IAAI,EAAG,CAAA;AAC9D;AAGA,MAAM,kBAAkB,OACtB,KACA,mBACA,SACG;AACG,QAAA,SAAS,OAAO,SAAS,GAAG;AAElC,QAAM,gBAAgB,MAAM,iBAAiB,KAAK,mBAAmB,IAAI;AAEzE,SAAO,OAAO,GAAG,MAAM,GAAG,EAAE,OAAO;AAAA,IACjC,OAAO;AAAA,MACL,IAAI,kBAAkB;AAAA,IACxB;AAAA,IACA,MAAM,oBAAoB,QAAQ,eAAe,IAAI;AAAA,EAAA,CACtD;AACH;AAEA,MAAM,0BAA0B,CAC9B,cACA,UACG;AACH,MAAI,UAAU,MAAM;AACX,WAAA;AAAA,EACT;AAGA,MAAI,QAAQ,SAAS,OAAO,MAAM,OAAO,aAAa;AAEpD,WAAO,gBAAgB,cAAc,EAAE,IAAI,MAAM,GAAA,GAAM,KAAK;AAAA,EAC9D;AAGO,SAAA,gBAAgB,cAAc,KAAK;AAC5C;AAEM,MAAA,kBAAkB,OACtB,KACA,sBACG;AACG,QAAA,iBAAiB,KAAK,iBAAiB;AAC7C,QAAM,OAAO,GAAG,MAAM,GAAG,EAAE,OAAO,EAAE,OAAO,EAAE,IAAI,kBAAkB,GAAA,EAAM,CAAA;AAC3E;AAEA,MAAM,sBAAsB;AAAA,EAC1B,CAAC,QAAuB,eAA8B,SAA4B;AACzE,WAAA,KAAK,kBAAkB,MAAM,GAAG,OAAO,aAAa,CAAC,EAAE,IAAI;AAAA,EACpE;AACF;"}
@@ -1,16 +1,16 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const _ = require("lodash/fp");
3
+ const fp = require("lodash/fp");
4
4
  const strapiUtils = require("@strapi/utils");
5
5
  const setStatusToDraft = (contentType, params) => {
6
6
  if (!strapiUtils.contentTypes.hasDraftAndPublish(contentType) && params.status) {
7
7
  return params;
8
8
  }
9
- return _.assoc("status", "draft", params);
9
+ return fp.assoc("status", "draft", params);
10
10
  };
11
11
  const defaultToDraft = (params) => {
12
12
  if (!params.status || params.status !== "published") {
13
- return _.assoc("status", "draft", params);
13
+ return fp.assoc("status", "draft", params);
14
14
  }
15
15
  return params;
16
16
  };
@@ -25,7 +25,7 @@ const defaultStatus = (contentType, params) => {
25
25
  };
26
26
  const filterDataPublishedAt = (params) => {
27
27
  if (params?.data?.publishedAt) {
28
- return _.assoc(["data", "publishedAt"], null, params);
28
+ return fp.assoc(["data", "publishedAt"], null, params);
29
29
  }
30
30
  return params;
31
31
  };
@@ -36,30 +36,30 @@ const statusToLookup = (contentType, params) => {
36
36
  const lookup = params.lookup || {};
37
37
  switch (params?.status) {
38
38
  case "published":
39
- return _.assoc(["lookup", "publishedAt"], { $notNull: true }, params);
39
+ return fp.assoc(["lookup", "publishedAt"], { $notNull: true }, params);
40
40
  case "draft":
41
- return _.assoc(["lookup", "publishedAt"], { $null: true }, params);
41
+ return fp.assoc(["lookup", "publishedAt"], { $null: true }, params);
42
42
  }
43
- return _.assoc("lookup", lookup, params);
43
+ return fp.assoc("lookup", lookup, params);
44
44
  };
45
45
  const statusToData = (contentType, params) => {
46
46
  if (!strapiUtils.contentTypes.hasDraftAndPublish(contentType)) {
47
- return _.assoc(["data", "publishedAt"], /* @__PURE__ */ new Date(), params);
47
+ return fp.assoc(["data", "publishedAt"], /* @__PURE__ */ new Date(), params);
48
48
  }
49
49
  switch (params?.status) {
50
50
  case "published":
51
- return _.assoc(["data", "publishedAt"], /* @__PURE__ */ new Date(), params);
51
+ return fp.assoc(["data", "publishedAt"], /* @__PURE__ */ new Date(), params);
52
52
  case "draft":
53
- return _.assoc(["data", "publishedAt"], null, params);
53
+ return fp.assoc(["data", "publishedAt"], null, params);
54
54
  }
55
55
  return params;
56
56
  };
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);
57
+ const setStatusToDraftCurry = fp.curry(setStatusToDraft);
58
+ const defaultToDraftCurry = fp.curry(defaultToDraft);
59
+ const defaultStatusCurry = fp.curry(defaultStatus);
60
+ const filterDataPublishedAtCurry = fp.curry(filterDataPublishedAt);
61
+ const statusToLookupCurry = fp.curry(statusToLookup);
62
+ const statusToDataCurry = fp.curry(statusToData);
63
63
  exports.defaultStatus = defaultStatusCurry;
64
64
  exports.defaultToDraft = defaultToDraftCurry;
65
65
  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 { Modules, Struct } from '@strapi/types';\nimport { contentTypes } from '@strapi/utils';\n\ntype ParamsTransform = (params: Modules.Documents.Params.All) => Modules.Documents.Params.All;\n\ntype TransformWithContentType = (\n contentType: Struct.SingleTypeSchema | Struct.CollectionTypeSchema,\n params: Modules.Documents.Params.All\n) => Modules.Documents.Params.All;\n\n/**\n * DP enabled -> set status to draft\n * DP disabled -> Used mostly for parsing relations, so there is not a need for a default.\n */\nconst setStatusToDraft: TransformWithContentType = (contentType, params) => {\n if (!contentTypes.hasDraftAndPublish(contentType) && params.status) {\n return params;\n }\n\n return assoc('status', 'draft', params);\n};\n\n/**\n * Adds a default status of `draft` to the params\n */\nconst defaultToDraft: ParamsTransform = (params) => {\n // Default to draft if no status is provided or it's invalid\n if (!params.status || params.status !== 'published') {\n return assoc('status', 'draft', params);\n }\n\n return params;\n};\n\n/**\n * DP disabled -> ignore status\n * DP enabled -> set status to draft if no status is provided or it's invalid\n */\nconst defaultStatus: TransformWithContentType = (contentType, params) => {\n if (!contentTypes.hasDraftAndPublish(contentType)) {\n return params;\n }\n\n // Default to draft if no status is provided or it's invalid\n if (!params.status || params.status !== 'published') {\n return defaultToDraft(params);\n }\n\n return params;\n};\n\n/**\n * In mutating actions we don't want user to set the publishedAt attribute.\n */\nconst filterDataPublishedAt: ParamsTransform = (params) => {\n if (params?.data?.publishedAt) {\n return assoc(['data', 'publishedAt'], null, params);\n }\n\n return params;\n};\n\n/**\n * Add status lookup query to the params\n */\nconst statusToLookup: TransformWithContentType = (contentType, params) => {\n if (!contentTypes.hasDraftAndPublish(contentType)) {\n return params;\n }\n\n const lookup = params.lookup || {};\n\n switch (params?.status) {\n case 'published':\n return assoc(['lookup', 'publishedAt'], { $notNull: true }, params);\n case 'draft':\n return assoc(['lookup', 'publishedAt'], { $null: true }, params);\n default:\n break;\n }\n\n return assoc('lookup', lookup, params);\n};\n\n/**\n * Translate publication status parameter into the data that will be saved\n */\nconst statusToData: TransformWithContentType = (contentType, params) => {\n if (!contentTypes.hasDraftAndPublish(contentType)) {\n return assoc(['data', 'publishedAt'], new Date(), params);\n }\n\n switch (params?.status) {\n case 'published':\n return assoc(['data', 'publishedAt'], new Date(), params);\n case 'draft':\n return assoc(['data', 'publishedAt'], null, params);\n default:\n break;\n }\n\n return params;\n};\n\nconst setStatusToDraftCurry = curry(setStatusToDraft);\nconst defaultToDraftCurry = curry(defaultToDraft);\nconst defaultStatusCurry = curry(defaultStatus);\nconst filterDataPublishedAtCurry = curry(filterDataPublishedAt);\nconst statusToLookupCurry = curry(statusToLookup);\nconst statusToDataCurry = curry(statusToData);\n\nexport {\n setStatusToDraftCurry as setStatusToDraft,\n defaultToDraftCurry as defaultToDraft,\n defaultStatusCurry as defaultStatus,\n filterDataPublishedAtCurry as filterDataPublishedAt,\n statusToLookupCurry as statusToLookup,\n statusToDataCurry as statusToData,\n};\n"],"names":["contentTypes","assoc","curry"],"mappings":";;;;AAgBA,MAAM,mBAA6C,CAAC,aAAa,WAAW;AAC1E,MAAI,CAACA,YAAa,aAAA,mBAAmB,WAAW,KAAK,OAAO,QAAQ;AAC3D,WAAA;AAAA,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 { Modules, Struct } from '@strapi/types';\nimport { contentTypes } from '@strapi/utils';\n\ntype ParamsTransform = (params: Modules.Documents.Params.All) => Modules.Documents.Params.All;\n\ntype TransformWithContentType = (\n contentType: Struct.SingleTypeSchema | Struct.CollectionTypeSchema,\n params: Modules.Documents.Params.All\n) => Modules.Documents.Params.All;\n\n/**\n * DP enabled -> set status to draft\n * DP disabled -> Used mostly for parsing relations, so there is not a need for a default.\n */\nconst setStatusToDraft: TransformWithContentType = (contentType, params) => {\n if (!contentTypes.hasDraftAndPublish(contentType) && params.status) {\n return params;\n }\n\n return assoc('status', 'draft', params);\n};\n\n/**\n * Adds a default status of `draft` to the params\n */\nconst defaultToDraft: ParamsTransform = (params) => {\n // Default to draft if no status is provided or it's invalid\n if (!params.status || params.status !== 'published') {\n return assoc('status', 'draft', params);\n }\n\n return params;\n};\n\n/**\n * DP disabled -> ignore status\n * DP enabled -> set status to draft if no status is provided or it's invalid\n */\nconst defaultStatus: TransformWithContentType = (contentType, params) => {\n if (!contentTypes.hasDraftAndPublish(contentType)) {\n return params;\n }\n\n // Default to draft if no status is provided or it's invalid\n if (!params.status || params.status !== 'published') {\n return defaultToDraft(params);\n }\n\n return params;\n};\n\n/**\n * In mutating actions we don't want user to set the publishedAt attribute.\n */\nconst filterDataPublishedAt: ParamsTransform = (params) => {\n if (params?.data?.publishedAt) {\n return assoc(['data', 'publishedAt'], null, params);\n }\n\n return params;\n};\n\n/**\n * Add status lookup query to the params\n */\nconst statusToLookup: TransformWithContentType = (contentType, params) => {\n if (!contentTypes.hasDraftAndPublish(contentType)) {\n return params;\n }\n\n const lookup = params.lookup || {};\n\n switch (params?.status) {\n case 'published':\n return assoc(['lookup', 'publishedAt'], { $notNull: true }, params);\n case 'draft':\n return assoc(['lookup', 'publishedAt'], { $null: true }, params);\n default:\n break;\n }\n\n return assoc('lookup', lookup, params);\n};\n\n/**\n * Translate publication status parameter into the data that will be saved\n */\nconst statusToData: TransformWithContentType = (contentType, params) => {\n if (!contentTypes.hasDraftAndPublish(contentType)) {\n return assoc(['data', 'publishedAt'], new Date(), params);\n }\n\n switch (params?.status) {\n case 'published':\n return assoc(['data', 'publishedAt'], new Date(), params);\n case 'draft':\n return assoc(['data', 'publishedAt'], null, params);\n default:\n break;\n }\n\n return params;\n};\n\nconst setStatusToDraftCurry = curry(setStatusToDraft);\nconst defaultToDraftCurry = curry(defaultToDraft);\nconst defaultStatusCurry = curry(defaultStatus);\nconst filterDataPublishedAtCurry = curry(filterDataPublishedAt);\nconst statusToLookupCurry = curry(statusToLookup);\nconst statusToDataCurry = curry(statusToData);\n\nexport {\n setStatusToDraftCurry as setStatusToDraft,\n defaultToDraftCurry as defaultToDraft,\n defaultStatusCurry as defaultStatus,\n filterDataPublishedAtCurry as filterDataPublishedAt,\n statusToLookupCurry as statusToLookup,\n statusToDataCurry as statusToData,\n};\n"],"names":["contentTypes","assoc","curry"],"mappings":";;;;AAgBA,MAAM,mBAA6C,CAAC,aAAa,WAAW;AAC1E,MAAI,CAACA,YAAa,aAAA,mBAAmB,WAAW,KAAK,OAAO,QAAQ;AAC3D,WAAA;AAAA,EACT;AAEO,SAAAC,SAAM,UAAU,SAAS,MAAM;AACxC;AAKA,MAAM,iBAAkC,CAAC,WAAW;AAElD,MAAI,CAAC,OAAO,UAAU,OAAO,WAAW,aAAa;AAC5C,WAAAA,SAAM,UAAU,SAAS,MAAM;AAAA,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,GAAAA,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,GAAA,MAAM,CAAC,UAAU,aAAa,GAAG,EAAE,UAAU,QAAQ,MAAM;AAAA,IACpE,KAAK;AACI,aAAAA,GAAA,MAAM,CAAC,UAAU,aAAa,GAAG,EAAE,OAAO,QAAQ,MAAM;AAAA,EAGnE;AAEO,SAAAA,SAAM,UAAU,QAAQ,MAAM;AACvC;AAKA,MAAM,eAAyC,CAAC,aAAa,WAAW;AACtE,MAAI,CAACD,YAAA,aAAa,mBAAmB,WAAW,GAAG;AAC1C,WAAAC,GAAAA,MAAM,CAAC,QAAQ,aAAa,GAAO,oBAAA,KAAA,GAAQ,MAAM;AAAA,EAC1D;AAEA,UAAQ,QAAQ,QAAQ;AAAA,IACtB,KAAK;AACI,aAAAA,GAAAA,MAAM,CAAC,QAAQ,aAAa,GAAO,oBAAA,KAAA,GAAQ,MAAM;AAAA,IAC1D,KAAK;AACH,aAAOA,GAAAA,MAAM,CAAC,QAAQ,aAAa,GAAG,MAAM,MAAM;AAAA,EAGtD;AAEO,SAAA;AACT;AAEM,MAAA,wBAAwBC,SAAM,gBAAgB;AAC9C,MAAA,sBAAsBA,SAAM,cAAc;AAC1C,MAAA,qBAAqBA,SAAM,aAAa;AACxC,MAAA,6BAA6BA,SAAM,qBAAqB;AACxD,MAAA,sBAAsBA,SAAM,cAAc;AAC1C,MAAA,oBAAoBA,SAAM,YAAY;;;;;;;"}
@@ -0,0 +1,10 @@
1
+ import type { UID } from '@strapi/types';
2
+ declare const createEntriesService: (uid: UID.ContentType) => {
3
+ create: (params?: any) => Promise<any>;
4
+ delete: (id: number) => Promise<any>;
5
+ update: (entryToUpdate: any, params?: any) => Promise<any>;
6
+ publish: (entry: any, params?: any) => Promise<object>;
7
+ discardDraft: (entry: any, params?: any) => Promise<object>;
8
+ };
9
+ export { createEntriesService };
10
+ //# sourceMappingURL=entries.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"entries.d.ts","sourceRoot":"","sources":["../../../src/services/document-service/entries.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,eAAe,CAAC;AAazC,QAAA,MAAM,oBAAoB,QAAS,IAAI,WAAW;;iBAkCjB,MAAM;4BAUK,GAAG;qBA4BV,GAAG;0BAaE,GAAG;CAoB5C,CAAC;AAEF,OAAO,EAAE,oBAAoB,EAAE,CAAC"}
@@ -0,0 +1,96 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const strapiUtils = require("@strapi/utils");
4
+ const fp = require("lodash/fp");
5
+ const components = require("./components.js");
6
+ const idTransform = require("./transform/id-transform.js");
7
+ const query = require("./transform/query.js");
8
+ const params = require("./params.js");
9
+ const index$1 = require("./attributes/index.js");
10
+ const data = require("./transform/data.js");
11
+ const index = require("../entity-validator/index.js");
12
+ const createEntriesService = (uid) => {
13
+ const contentType = strapi.contentType(uid);
14
+ async function createEntry(params$1 = {}) {
15
+ const { data: data2, ...restParams } = await idTransform.transformParamsDocumentId(uid, params$1);
16
+ const query$1 = query.transformParamsToQuery(uid, params.pickSelectionParams(restParams));
17
+ if (!data2) {
18
+ throw new Error("Create requires data attribute");
19
+ }
20
+ const validData = await index.validateEntityCreation(contentType, data2, {
21
+ // Note: publishedAt value will always be set when DP is disabled
22
+ isDraft: !params$1?.data?.publishedAt,
23
+ locale: params$1?.locale
24
+ });
25
+ const componentData = await components.createComponents(uid, validData);
26
+ const dataWithComponents = components.assignComponentData(
27
+ contentType,
28
+ componentData,
29
+ validData
30
+ );
31
+ const entryData = index$1.applyTransforms(contentType, dataWithComponents);
32
+ const doc = await strapi.db.query(uid).create({ ...query$1, data: entryData });
33
+ return doc;
34
+ }
35
+ async function deleteEntry(id) {
36
+ const componentsToDelete = await components.getComponents(uid, { id });
37
+ const deletedEntry = await strapi.db.query(uid).delete({ where: { id } });
38
+ await components.deleteComponents(uid, componentsToDelete, { loadComponents: false });
39
+ return deletedEntry;
40
+ }
41
+ async function updateEntry(entryToUpdate, params$1 = {}) {
42
+ const { data: data2, ...restParams } = await idTransform.transformParamsDocumentId(uid, params$1);
43
+ const query$1 = query.transformParamsToQuery(uid, params.pickSelectionParams(restParams));
44
+ const validData = await index.validateEntityUpdate(
45
+ contentType,
46
+ data2,
47
+ {
48
+ isDraft: !params$1?.data?.publishedAt,
49
+ // Always update the draft version
50
+ locale: params$1?.locale
51
+ },
52
+ entryToUpdate
53
+ );
54
+ const componentData = await components.updateComponents(uid, entryToUpdate, validData);
55
+ const dataWithComponents = components.assignComponentData(
56
+ contentType,
57
+ componentData,
58
+ validData
59
+ );
60
+ const entryData = index$1.applyTransforms(contentType, dataWithComponents);
61
+ return strapi.db.query(uid).update({ ...query$1, where: { id: entryToUpdate.id }, data: entryData });
62
+ }
63
+ async function publishEntry(entry, params2 = {}) {
64
+ return strapiUtils.async.pipe(
65
+ fp.omit("id"),
66
+ fp.assoc("publishedAt", /* @__PURE__ */ new Date()),
67
+ (draft) => {
68
+ const opts = { uid, locale: draft.locale, status: "published", allowMissingId: true };
69
+ return data.transformData(draft, opts);
70
+ },
71
+ // Create the published entry
72
+ (draft) => createEntry({ ...params2, data: draft, locale: draft.locale, status: "published" })
73
+ )(entry);
74
+ }
75
+ async function discardDraftEntry(entry, params2 = {}) {
76
+ return strapiUtils.async.pipe(
77
+ fp.omit("id"),
78
+ fp.assoc("publishedAt", null),
79
+ (entry2) => {
80
+ const opts = { uid, locale: entry2.locale, status: "draft", allowMissingId: true };
81
+ return data.transformData(entry2, opts);
82
+ },
83
+ // Create the draft entry
84
+ (data2) => createEntry({ ...params2, locale: data2.locale, data: data2, status: "draft" })
85
+ )(entry);
86
+ }
87
+ return {
88
+ create: createEntry,
89
+ delete: deleteEntry,
90
+ update: updateEntry,
91
+ publish: publishEntry,
92
+ discardDraft: discardDraftEntry
93
+ };
94
+ };
95
+ exports.createEntriesService = createEntriesService;
96
+ //# sourceMappingURL=entries.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"entries.js","sources":["../../../src/services/document-service/entries.ts"],"sourcesContent":["import type { UID } from '@strapi/types';\nimport { async } from '@strapi/utils';\nimport { assoc, omit } from 'lodash/fp';\n\nimport * as components from './components';\n\nimport { transformParamsDocumentId } from './transform/id-transform';\nimport { transformParamsToQuery } from './transform/query';\nimport { pickSelectionParams } from './params';\nimport { applyTransforms } from './attributes';\nimport { transformData } from './transform/data';\nimport entityValidator from '../entity-validator';\n\nconst createEntriesService = (uid: UID.ContentType) => {\n const contentType = strapi.contentType(uid);\n\n async function createEntry(params = {} as any) {\n const { data, ...restParams } = await transformParamsDocumentId(uid, params);\n\n const query = transformParamsToQuery(uid, pickSelectionParams(restParams) as any); // select / populate\n\n // Validation\n if (!data) {\n throw new Error('Create requires data attribute');\n }\n\n const validData = await entityValidator.validateEntityCreation(contentType, data, {\n // Note: publishedAt value will always be set when DP is disabled\n isDraft: !params?.data?.publishedAt,\n locale: params?.locale,\n });\n\n // Component handling\n const componentData = await components.createComponents(uid, validData);\n const dataWithComponents = components.assignComponentData(\n contentType,\n componentData,\n validData\n );\n\n const entryData = applyTransforms(contentType, dataWithComponents);\n\n const doc = await strapi.db.query(uid).create({ ...query, data: entryData });\n\n return doc;\n }\n\n async function deleteEntry(id: number) {\n const componentsToDelete = await components.getComponents(uid, { id });\n\n const deletedEntry = await strapi.db.query(uid).delete({ where: { id } });\n\n await components.deleteComponents(uid, componentsToDelete as any, { loadComponents: false });\n\n return deletedEntry;\n }\n\n async function updateEntry(entryToUpdate: any, params = {} as any) {\n const { data, ...restParams } = await transformParamsDocumentId(uid, params);\n const query = transformParamsToQuery(uid, pickSelectionParams(restParams) as any); // select / populate\n\n const validData = await entityValidator.validateEntityUpdate(\n contentType,\n data,\n {\n isDraft: !params?.data?.publishedAt, // Always update the draft version\n locale: params?.locale,\n },\n entryToUpdate\n );\n // Component handling\n const componentData = await components.updateComponents(uid, entryToUpdate, validData as any);\n const dataWithComponents = components.assignComponentData(\n contentType,\n componentData,\n validData\n );\n\n const entryData = applyTransforms(contentType, dataWithComponents);\n\n return strapi.db\n .query(uid)\n .update({ ...query, where: { id: entryToUpdate.id }, data: entryData });\n }\n\n async function publishEntry(entry: any, params = {} as any) {\n return async.pipe(\n omit('id'),\n assoc('publishedAt', new Date()),\n (draft) => {\n const opts = { uid, locale: draft.locale, status: 'published', allowMissingId: true };\n return transformData(draft, opts);\n },\n // Create the published entry\n (draft) => createEntry({ ...params, data: draft, locale: draft.locale, status: 'published' })\n )(entry);\n }\n\n async function discardDraftEntry(entry: any, params = {} as any) {\n return async.pipe(\n omit('id'),\n assoc('publishedAt', null),\n (entry) => {\n const opts = { uid, locale: entry.locale, status: 'draft', allowMissingId: true };\n return transformData(entry, opts);\n },\n // Create the draft entry\n (data) => createEntry({ ...params, locale: data.locale, data, status: 'draft' })\n )(entry);\n }\n\n return {\n create: createEntry,\n delete: deleteEntry,\n update: updateEntry,\n publish: publishEntry,\n discardDraft: discardDraftEntry,\n };\n};\n\nexport { createEntriesService };\n"],"names":["params","data","transformParamsDocumentId","query","transformParamsToQuery","pickSelectionParams","entityValidator","components.createComponents","components.assignComponentData","applyTransforms","components.getComponents","components.deleteComponents","components.updateComponents","async","omit","assoc","transformData","entry"],"mappings":"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"}
@@ -0,0 +1,96 @@
1
+ import { async } from "@strapi/utils";
2
+ import { omit, assoc } from "lodash/fp";
3
+ import { createComponents, assignComponentData, getComponents, deleteComponents, updateComponents } from "./components.mjs";
4
+ import { transformParamsDocumentId as curriedTransformParamsDocumentId } from "./transform/id-transform.mjs";
5
+ import { transformParamsToQuery } from "./transform/query.mjs";
6
+ import { pickSelectionParams } from "./params.mjs";
7
+ import { applyTransforms } from "./attributes/index.mjs";
8
+ import { transformData } from "./transform/data.mjs";
9
+ import entityValidator from "../entity-validator/index.mjs";
10
+ const createEntriesService = (uid) => {
11
+ const contentType = strapi.contentType(uid);
12
+ async function createEntry(params = {}) {
13
+ const { data, ...restParams } = await curriedTransformParamsDocumentId(uid, params);
14
+ const query = transformParamsToQuery(uid, pickSelectionParams(restParams));
15
+ if (!data) {
16
+ throw new Error("Create requires data attribute");
17
+ }
18
+ const validData = await entityValidator.validateEntityCreation(contentType, data, {
19
+ // Note: publishedAt value will always be set when DP is disabled
20
+ isDraft: !params?.data?.publishedAt,
21
+ locale: params?.locale
22
+ });
23
+ const componentData = await createComponents(uid, validData);
24
+ const dataWithComponents = assignComponentData(
25
+ contentType,
26
+ componentData,
27
+ validData
28
+ );
29
+ const entryData = applyTransforms(contentType, dataWithComponents);
30
+ const doc = await strapi.db.query(uid).create({ ...query, data: entryData });
31
+ return doc;
32
+ }
33
+ async function deleteEntry(id) {
34
+ const componentsToDelete = await getComponents(uid, { id });
35
+ const deletedEntry = await strapi.db.query(uid).delete({ where: { id } });
36
+ await deleteComponents(uid, componentsToDelete, { loadComponents: false });
37
+ return deletedEntry;
38
+ }
39
+ async function updateEntry(entryToUpdate, params = {}) {
40
+ const { data, ...restParams } = await curriedTransformParamsDocumentId(uid, params);
41
+ const query = transformParamsToQuery(uid, pickSelectionParams(restParams));
42
+ const validData = await entityValidator.validateEntityUpdate(
43
+ contentType,
44
+ data,
45
+ {
46
+ isDraft: !params?.data?.publishedAt,
47
+ // Always update the draft version
48
+ locale: params?.locale
49
+ },
50
+ entryToUpdate
51
+ );
52
+ const componentData = await updateComponents(uid, entryToUpdate, validData);
53
+ const dataWithComponents = assignComponentData(
54
+ contentType,
55
+ componentData,
56
+ validData
57
+ );
58
+ const entryData = applyTransforms(contentType, dataWithComponents);
59
+ return strapi.db.query(uid).update({ ...query, where: { id: entryToUpdate.id }, data: entryData });
60
+ }
61
+ async function publishEntry(entry, params = {}) {
62
+ return async.pipe(
63
+ omit("id"),
64
+ assoc("publishedAt", /* @__PURE__ */ new Date()),
65
+ (draft) => {
66
+ const opts = { uid, locale: draft.locale, status: "published", allowMissingId: true };
67
+ return transformData(draft, opts);
68
+ },
69
+ // Create the published entry
70
+ (draft) => createEntry({ ...params, data: draft, locale: draft.locale, status: "published" })
71
+ )(entry);
72
+ }
73
+ async function discardDraftEntry(entry, params = {}) {
74
+ return async.pipe(
75
+ omit("id"),
76
+ assoc("publishedAt", null),
77
+ (entry2) => {
78
+ const opts = { uid, locale: entry2.locale, status: "draft", allowMissingId: true };
79
+ return transformData(entry2, opts);
80
+ },
81
+ // Create the draft entry
82
+ (data) => createEntry({ ...params, locale: data.locale, data, status: "draft" })
83
+ )(entry);
84
+ }
85
+ return {
86
+ create: createEntry,
87
+ delete: deleteEntry,
88
+ update: updateEntry,
89
+ publish: publishEntry,
90
+ discardDraft: discardDraftEntry
91
+ };
92
+ };
93
+ export {
94
+ createEntriesService
95
+ };
96
+ //# sourceMappingURL=entries.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"entries.mjs","sources":["../../../src/services/document-service/entries.ts"],"sourcesContent":["import type { UID } from '@strapi/types';\nimport { async } from '@strapi/utils';\nimport { assoc, omit } from 'lodash/fp';\n\nimport * as components from './components';\n\nimport { transformParamsDocumentId } from './transform/id-transform';\nimport { transformParamsToQuery } from './transform/query';\nimport { pickSelectionParams } from './params';\nimport { applyTransforms } from './attributes';\nimport { transformData } from './transform/data';\nimport entityValidator from '../entity-validator';\n\nconst createEntriesService = (uid: UID.ContentType) => {\n const contentType = strapi.contentType(uid);\n\n async function createEntry(params = {} as any) {\n const { data, ...restParams } = await transformParamsDocumentId(uid, params);\n\n const query = transformParamsToQuery(uid, pickSelectionParams(restParams) as any); // select / populate\n\n // Validation\n if (!data) {\n throw new Error('Create requires data attribute');\n }\n\n const validData = await entityValidator.validateEntityCreation(contentType, data, {\n // Note: publishedAt value will always be set when DP is disabled\n isDraft: !params?.data?.publishedAt,\n locale: params?.locale,\n });\n\n // Component handling\n const componentData = await components.createComponents(uid, validData);\n const dataWithComponents = components.assignComponentData(\n contentType,\n componentData,\n validData\n );\n\n const entryData = applyTransforms(contentType, dataWithComponents);\n\n const doc = await strapi.db.query(uid).create({ ...query, data: entryData });\n\n return doc;\n }\n\n async function deleteEntry(id: number) {\n const componentsToDelete = await components.getComponents(uid, { id });\n\n const deletedEntry = await strapi.db.query(uid).delete({ where: { id } });\n\n await components.deleteComponents(uid, componentsToDelete as any, { loadComponents: false });\n\n return deletedEntry;\n }\n\n async function updateEntry(entryToUpdate: any, params = {} as any) {\n const { data, ...restParams } = await transformParamsDocumentId(uid, params);\n const query = transformParamsToQuery(uid, pickSelectionParams(restParams) as any); // select / populate\n\n const validData = await entityValidator.validateEntityUpdate(\n contentType,\n data,\n {\n isDraft: !params?.data?.publishedAt, // Always update the draft version\n locale: params?.locale,\n },\n entryToUpdate\n );\n // Component handling\n const componentData = await components.updateComponents(uid, entryToUpdate, validData as any);\n const dataWithComponents = components.assignComponentData(\n contentType,\n componentData,\n validData\n );\n\n const entryData = applyTransforms(contentType, dataWithComponents);\n\n return strapi.db\n .query(uid)\n .update({ ...query, where: { id: entryToUpdate.id }, data: entryData });\n }\n\n async function publishEntry(entry: any, params = {} as any) {\n return async.pipe(\n omit('id'),\n assoc('publishedAt', new Date()),\n (draft) => {\n const opts = { uid, locale: draft.locale, status: 'published', allowMissingId: true };\n return transformData(draft, opts);\n },\n // Create the published entry\n (draft) => createEntry({ ...params, data: draft, locale: draft.locale, status: 'published' })\n )(entry);\n }\n\n async function discardDraftEntry(entry: any, params = {} as any) {\n return async.pipe(\n omit('id'),\n assoc('publishedAt', null),\n (entry) => {\n const opts = { uid, locale: entry.locale, status: 'draft', allowMissingId: true };\n return transformData(entry, opts);\n },\n // Create the draft entry\n (data) => createEntry({ ...params, locale: data.locale, data, status: 'draft' })\n )(entry);\n }\n\n return {\n create: createEntry,\n delete: deleteEntry,\n update: updateEntry,\n publish: publishEntry,\n discardDraft: discardDraftEntry,\n };\n};\n\nexport { createEntriesService };\n"],"names":["transformParamsDocumentId","components.createComponents","components.assignComponentData","components.getComponents","components.deleteComponents","components.updateComponents","entry"],"mappings":"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"}
@@ -0,0 +1,25 @@
1
+ import { UID, Utils, Modules, Core } from '@strapi/types';
2
+ declare const EVENTS: {
3
+ ENTRY_CREATE: string;
4
+ ENTRY_UPDATE: string;
5
+ ENTRY_DELETE: string;
6
+ ENTRY_PUBLISH: string;
7
+ ENTRY_UNPUBLISH: string;
8
+ ENTRY_DRAFT_DISCARD: string;
9
+ };
10
+ type EventName = Utils.Object.Values<typeof EVENTS>;
11
+ /**
12
+ * Manager to trigger entry related events
13
+ *
14
+ * It will populate the entry if it is not a delete event.
15
+ * So the event payload will contain the full entry.
16
+ */
17
+ declare const createEventManager: (strapi: Core.Strapi, uid: UID.Schema) => {
18
+ /**
19
+ * strapi.db.query might reuse the transaction used in the doc service request,
20
+ * so this is executed after that transaction is committed.
21
+ */
22
+ emitEvent(eventName: EventName, entry: Modules.Documents.AnyDocument): void;
23
+ };
24
+ export { createEventManager };
25
+ //# sourceMappingURL=events.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"events.d.ts","sourceRoot":"","sources":["../../../src/services/document-service/events.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,KAAK,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAK1D,QAAA,MAAM,MAAM;;;;;;;CAOX,CAAC;AAEF,KAAK,SAAS,GAAG,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,MAAM,CAAC,CAAC;AAEpD;;;;;GAKG;AACH,QAAA,MAAM,kBAAkB,WAAY,KAAK,MAAM,OAAO,IAAI,MAAM;IA2B5D;;;OAGG;yBACkB,SAAS,SAAS,QAAQ,SAAS,CAAC,WAAW;CAMvE,CAAC;AAEF,OAAO,EAAE,kBAAkB,EAAE,CAAC"}
@@ -0,0 +1,47 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const strapiUtils = require("@strapi/utils");
4
+ const populate = require("./utils/populate.js");
5
+ const EVENTS = {
6
+ ENTRY_CREATE: "entry.create",
7
+ ENTRY_UPDATE: "entry.update",
8
+ ENTRY_DELETE: "entry.delete",
9
+ ENTRY_PUBLISH: "entry.publish",
10
+ ENTRY_UNPUBLISH: "entry.unpublish",
11
+ ENTRY_DRAFT_DISCARD: "entry.draft-discard"
12
+ };
13
+ const createEventManager = (strapi, uid) => {
14
+ const populate$1 = populate.getDeepPopulate(uid, {});
15
+ const model = strapi.getModel(uid);
16
+ const emitEvent = async (eventName, entry) => {
17
+ let populatedEntry = entry;
18
+ if (![EVENTS.ENTRY_DELETE, EVENTS.ENTRY_UNPUBLISH].includes(eventName)) {
19
+ populatedEntry = await strapi.db.query(uid).findOne({ where: { id: entry.id }, populate: populate$1 });
20
+ }
21
+ const sanitizedEntry = await strapiUtils.sanitize.sanitizers.defaultSanitizeOutput(
22
+ {
23
+ schema: model,
24
+ getModel: (uid2) => strapi.getModel(uid2)
25
+ },
26
+ populatedEntry
27
+ );
28
+ await strapi.eventHub.emit(eventName, {
29
+ model: model.modelName,
30
+ uid: model.uid,
31
+ entry: sanitizedEntry
32
+ });
33
+ };
34
+ return {
35
+ /**
36
+ * strapi.db.query might reuse the transaction used in the doc service request,
37
+ * so this is executed after that transaction is committed.
38
+ */
39
+ emitEvent(eventName, entry) {
40
+ strapi.db.transaction(({ onCommit }) => {
41
+ onCommit(() => emitEvent(eventName, entry));
42
+ });
43
+ }
44
+ };
45
+ };
46
+ exports.createEventManager = createEventManager;
47
+ //# sourceMappingURL=events.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"events.js","sources":["../../../src/services/document-service/events.ts"],"sourcesContent":["import { UID, Utils, Modules, Core } from '@strapi/types';\nimport { sanitize } from '@strapi/utils';\n\nimport { getDeepPopulate } from './utils/populate';\n\nconst EVENTS = {\n ENTRY_CREATE: 'entry.create',\n ENTRY_UPDATE: 'entry.update',\n ENTRY_DELETE: 'entry.delete',\n ENTRY_PUBLISH: 'entry.publish',\n ENTRY_UNPUBLISH: 'entry.unpublish',\n ENTRY_DRAFT_DISCARD: 'entry.draft-discard',\n};\n\ntype EventName = Utils.Object.Values<typeof EVENTS>;\n\n/**\n * Manager to trigger entry related events\n *\n * It will populate the entry if it is not a delete event.\n * So the event payload will contain the full entry.\n */\nconst createEventManager = (strapi: Core.Strapi, uid: UID.Schema) => {\n const populate = getDeepPopulate(uid, {});\n const model = strapi.getModel(uid);\n\n const emitEvent = async (eventName: EventName, entry: Modules.Documents.AnyDocument) => {\n // There is no need to populate the entry if it has been deleted\n let populatedEntry = entry;\n if (![EVENTS.ENTRY_DELETE, EVENTS.ENTRY_UNPUBLISH].includes(eventName)) {\n populatedEntry = await strapi.db.query(uid).findOne({ where: { id: entry.id }, populate });\n }\n\n const sanitizedEntry = await sanitize.sanitizers.defaultSanitizeOutput(\n {\n schema: model,\n getModel: (uid) => strapi.getModel(uid as UID.Schema),\n },\n populatedEntry\n );\n\n await strapi.eventHub.emit(eventName, {\n model: model.modelName,\n uid: model.uid,\n entry: sanitizedEntry,\n });\n };\n\n return {\n /**\n * strapi.db.query might reuse the transaction used in the doc service request,\n * so this is executed after that transaction is committed.\n */\n emitEvent(eventName: EventName, entry: Modules.Documents.AnyDocument) {\n strapi.db.transaction(({ onCommit }) => {\n onCommit(() => emitEvent(eventName, entry));\n });\n },\n };\n};\n\nexport { createEventManager };\n"],"names":["populate","getDeepPopulate","sanitize","uid"],"mappings":";;;;AAKA,MAAM,SAAS;AAAA,EACb,cAAc;AAAA,EACd,cAAc;AAAA,EACd,cAAc;AAAA,EACd,eAAe;AAAA,EACf,iBAAiB;AAAA,EACjB,qBAAqB;AACvB;AAUM,MAAA,qBAAqB,CAAC,QAAqB,QAAoB;AACnE,QAAMA,aAAWC,SAAAA,gBAAgB,KAAK,CAAE,CAAA;AAClC,QAAA,QAAQ,OAAO,SAAS,GAAG;AAE3B,QAAA,YAAY,OAAO,WAAsB,UAAyC;AAEtF,QAAI,iBAAiB;AACjB,QAAA,CAAC,CAAC,OAAO,cAAc,OAAO,eAAe,EAAE,SAAS,SAAS,GAAG;AACtE,uBAAiB,MAAM,OAAO,GAAG,MAAM,GAAG,EAAE,QAAQ,EAAE,OAAO,EAAE,IAAI,MAAM,GAAG,GAAGD,UAAAA,WAAU,CAAA;AAAA,IAC3F;AAEM,UAAA,iBAAiB,MAAME,qBAAS,WAAW;AAAA,MAC/C;AAAA,QACE,QAAQ;AAAA,QACR,UAAU,CAACC,SAAQ,OAAO,SAASA,IAAiB;AAAA,MACtD;AAAA,MACA;AAAA,IAAA;AAGI,UAAA,OAAO,SAAS,KAAK,WAAW;AAAA,MACpC,OAAO,MAAM;AAAA,MACb,KAAK,MAAM;AAAA,MACX,OAAO;AAAA,IAAA,CACR;AAAA,EAAA;AAGI,SAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAKL,UAAU,WAAsB,OAAsC;AACpE,aAAO,GAAG,YAAY,CAAC,EAAE,eAAe;AACtC,iBAAS,MAAM,UAAU,WAAW,KAAK,CAAC;AAAA,MAAA,CAC3C;AAAA,IACH;AAAA,EAAA;AAEJ;;"}