@strapi/core 0.0.0-experimental.baa6cf22298e591b4d52d8e59c60406d7a9f137f → 0.0.0-experimental.bd3419429b8caba37ca42ac08edb57cd4b5e1c47

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (725) hide show
  1. package/LICENSE +18 -3
  2. package/dist/Strapi.d.ts +3 -1
  3. package/dist/Strapi.d.ts.map +1 -1
  4. package/dist/configuration/index.d.ts.map +1 -1
  5. package/dist/core-api/service/collection-type.d.ts +2 -2
  6. package/dist/ee/index.d.ts.map +1 -1
  7. package/dist/index.d.ts +14 -0
  8. package/dist/index.d.ts.map +1 -1
  9. package/dist/index.js +10101 -27
  10. package/dist/index.js.map +1 -1
  11. package/dist/index.mjs +10079 -29
  12. package/dist/index.mjs.map +1 -1
  13. package/dist/loaders/plugins/get-enabled-plugins.d.ts.map +1 -1
  14. package/dist/loaders/plugins/index.d.ts.map +1 -1
  15. package/dist/middlewares/body.d.ts.map +1 -1
  16. package/dist/middlewares/cors.d.ts.map +1 -1
  17. package/dist/middlewares/query.d.ts.map +1 -1
  18. package/dist/middlewares/security.d.ts.map +1 -1
  19. package/dist/migrations/database/5.0.0-discard-drafts.d.ts +14 -11
  20. package/dist/migrations/database/5.0.0-discard-drafts.d.ts.map +1 -1
  21. package/dist/migrations/draft-publish.d.ts +2 -2
  22. package/dist/migrations/draft-publish.d.ts.map +1 -1
  23. package/dist/migrations/i18n.d.ts +5 -0
  24. package/dist/migrations/i18n.d.ts.map +1 -0
  25. package/dist/migrations/index.d.ts +5 -0
  26. package/dist/migrations/index.d.ts.map +1 -0
  27. package/dist/providers/admin.d.ts.map +1 -1
  28. package/dist/registries/policies.d.ts +1 -1
  29. package/dist/registries/policies.d.ts.map +1 -1
  30. package/dist/services/content-api/index.d.ts +10 -12
  31. package/dist/services/content-api/index.d.ts.map +1 -1
  32. package/dist/services/content-api/permissions/index.d.ts +10 -12
  33. package/dist/services/content-api/permissions/index.d.ts.map +1 -1
  34. package/dist/services/content-api/permissions/providers/action.d.ts +5 -6
  35. package/dist/services/content-api/permissions/providers/action.d.ts.map +1 -1
  36. package/dist/services/content-api/permissions/providers/condition.d.ts +5 -6
  37. package/dist/services/content-api/permissions/providers/condition.d.ts.map +1 -1
  38. package/dist/services/cron.d.ts +3 -3
  39. package/dist/services/cron.d.ts.map +1 -1
  40. package/dist/services/document-service/common.d.ts +1 -1
  41. package/dist/services/document-service/common.d.ts.map +1 -1
  42. package/dist/services/document-service/components.d.ts.map +1 -1
  43. package/dist/services/document-service/draft-and-publish.d.ts +1 -1
  44. package/dist/services/document-service/draft-and-publish.d.ts.map +1 -1
  45. package/dist/services/document-service/entries.d.ts +2 -2
  46. package/dist/services/document-service/entries.d.ts.map +1 -1
  47. package/dist/services/document-service/events.d.ts +1 -1
  48. package/dist/services/document-service/events.d.ts.map +1 -1
  49. package/dist/services/document-service/index.d.ts +2 -1
  50. package/dist/services/document-service/index.d.ts.map +1 -1
  51. package/dist/services/document-service/repository.d.ts.map +1 -1
  52. package/dist/services/document-service/transform/id-map.d.ts +1 -1
  53. package/dist/services/document-service/transform/id-map.d.ts.map +1 -1
  54. package/dist/services/document-service/transform/id-transform.d.ts +1 -1
  55. package/dist/services/document-service/transform/id-transform.d.ts.map +1 -1
  56. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +1 -1
  57. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -1
  58. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts.map +1 -1
  59. package/dist/services/document-service/transform/relations/utils/dp.d.ts +1 -1
  60. package/dist/services/document-service/transform/relations/utils/dp.d.ts.map +1 -1
  61. package/dist/services/document-service/transform/relations/utils/i18n.d.ts +1 -1
  62. package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -1
  63. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts.map +1 -1
  64. package/dist/services/document-service/utils/bidirectional-relations.d.ts +95 -0
  65. package/dist/services/document-service/utils/bidirectional-relations.d.ts.map +1 -0
  66. package/dist/services/document-service/utils/populate.d.ts +1 -1
  67. package/dist/services/document-service/utils/populate.d.ts.map +1 -1
  68. package/dist/services/document-service/utils/unidirectional-relations.d.ts +36 -0
  69. package/dist/services/document-service/utils/unidirectional-relations.d.ts.map +1 -0
  70. package/dist/services/entity-validator/blocks-validator.d.ts +1 -2
  71. package/dist/services/entity-validator/blocks-validator.d.ts.map +1 -1
  72. package/dist/services/entity-validator/index.d.ts +15 -1
  73. package/dist/services/entity-validator/index.d.ts.map +1 -1
  74. package/dist/services/entity-validator/validators.d.ts +36 -25
  75. package/dist/services/entity-validator/validators.d.ts.map +1 -1
  76. package/dist/services/metrics/middleware.d.ts.map +1 -1
  77. package/dist/services/metrics/rate-limiter.d.ts.map +1 -1
  78. package/dist/services/webhook-runner.d.ts +2 -1
  79. package/dist/services/webhook-runner.d.ts.map +1 -1
  80. package/dist/services/webhook-store.d.ts +2 -8
  81. package/dist/services/webhook-store.d.ts.map +1 -1
  82. package/dist/utils/fetch.d.ts.map +1 -1
  83. package/dist/utils/filepath-to-prop-path.d.ts +1 -1
  84. package/dist/utils/filepath-to-prop-path.d.ts.map +1 -1
  85. package/dist/utils/startup-logger.d.ts.map +1 -1
  86. package/dist/utils/transform-content-types-to-models.d.ts +355 -23
  87. package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
  88. package/dist/utils/update-notifier/index.d.ts.map +1 -1
  89. package/package.json +31 -30
  90. package/dist/Strapi.js +0 -387
  91. package/dist/Strapi.js.map +0 -1
  92. package/dist/Strapi.mjs +0 -385
  93. package/dist/Strapi.mjs.map +0 -1
  94. package/dist/compile.js +0 -18
  95. package/dist/compile.js.map +0 -1
  96. package/dist/compile.mjs +0 -17
  97. package/dist/compile.mjs.map +0 -1
  98. package/dist/configuration/config-loader.js +0 -106
  99. package/dist/configuration/config-loader.js.map +0 -1
  100. package/dist/configuration/config-loader.mjs +0 -104
  101. package/dist/configuration/config-loader.mjs.map +0 -1
  102. package/dist/configuration/get-dirs.js +0 -31
  103. package/dist/configuration/get-dirs.js.map +0 -1
  104. package/dist/configuration/get-dirs.mjs +0 -31
  105. package/dist/configuration/get-dirs.mjs.map +0 -1
  106. package/dist/configuration/index.js +0 -80
  107. package/dist/configuration/index.js.map +0 -1
  108. package/dist/configuration/index.mjs +0 -75
  109. package/dist/configuration/index.mjs.map +0 -1
  110. package/dist/configuration/urls.js +0 -68
  111. package/dist/configuration/urls.js.map +0 -1
  112. package/dist/configuration/urls.mjs +0 -66
  113. package/dist/configuration/urls.mjs.map +0 -1
  114. package/dist/container.js +0 -30
  115. package/dist/container.js.map +0 -1
  116. package/dist/container.mjs +0 -30
  117. package/dist/container.mjs.map +0 -1
  118. package/dist/core-api/controller/collection-type.js +0 -84
  119. package/dist/core-api/controller/collection-type.js.map +0 -1
  120. package/dist/core-api/controller/collection-type.mjs +0 -84
  121. package/dist/core-api/controller/collection-type.mjs.map +0 -1
  122. package/dist/core-api/controller/index.js +0 -52
  123. package/dist/core-api/controller/index.js.map +0 -1
  124. package/dist/core-api/controller/index.mjs +0 -52
  125. package/dist/core-api/controller/index.mjs.map +0 -1
  126. package/dist/core-api/controller/single-type.js +0 -46
  127. package/dist/core-api/controller/single-type.js.map +0 -1
  128. package/dist/core-api/controller/single-type.mjs +0 -46
  129. package/dist/core-api/controller/single-type.mjs.map +0 -1
  130. package/dist/core-api/controller/transform.js +0 -76
  131. package/dist/core-api/controller/transform.js.map +0 -1
  132. package/dist/core-api/controller/transform.mjs +0 -76
  133. package/dist/core-api/controller/transform.mjs.map +0 -1
  134. package/dist/core-api/routes/index.js +0 -67
  135. package/dist/core-api/routes/index.js.map +0 -1
  136. package/dist/core-api/routes/index.mjs +0 -67
  137. package/dist/core-api/routes/index.mjs.map +0 -1
  138. package/dist/core-api/service/collection-type.js +0 -67
  139. package/dist/core-api/service/collection-type.js.map +0 -1
  140. package/dist/core-api/service/collection-type.mjs +0 -67
  141. package/dist/core-api/service/collection-type.mjs.map +0 -1
  142. package/dist/core-api/service/core-service.js +0 -12
  143. package/dist/core-api/service/core-service.js.map +0 -1
  144. package/dist/core-api/service/core-service.mjs +0 -12
  145. package/dist/core-api/service/core-service.mjs.map +0 -1
  146. package/dist/core-api/service/index.js +0 -16
  147. package/dist/core-api/service/index.js.map +0 -1
  148. package/dist/core-api/service/index.mjs +0 -16
  149. package/dist/core-api/service/index.mjs.map +0 -1
  150. package/dist/core-api/service/pagination.js +0 -52
  151. package/dist/core-api/service/pagination.js.map +0 -1
  152. package/dist/core-api/service/pagination.mjs +0 -52
  153. package/dist/core-api/service/pagination.mjs.map +0 -1
  154. package/dist/core-api/service/single-type.js +0 -46
  155. package/dist/core-api/service/single-type.js.map +0 -1
  156. package/dist/core-api/service/single-type.mjs +0 -46
  157. package/dist/core-api/service/single-type.mjs.map +0 -1
  158. package/dist/domain/content-type/index.js +0 -111
  159. package/dist/domain/content-type/index.js.map +0 -1
  160. package/dist/domain/content-type/index.mjs +0 -109
  161. package/dist/domain/content-type/index.mjs.map +0 -1
  162. package/dist/domain/content-type/validator.js +0 -77
  163. package/dist/domain/content-type/validator.js.map +0 -1
  164. package/dist/domain/content-type/validator.mjs +0 -75
  165. package/dist/domain/content-type/validator.mjs.map +0 -1
  166. package/dist/domain/module/index.js +0 -107
  167. package/dist/domain/module/index.js.map +0 -1
  168. package/dist/domain/module/index.mjs +0 -105
  169. package/dist/domain/module/index.mjs.map +0 -1
  170. package/dist/domain/module/validation.js +0 -25
  171. package/dist/domain/module/validation.js.map +0 -1
  172. package/dist/domain/module/validation.mjs +0 -25
  173. package/dist/domain/module/validation.mjs.map +0 -1
  174. package/dist/ee/index.js +0 -153
  175. package/dist/ee/index.js.map +0 -1
  176. package/dist/ee/index.mjs +0 -154
  177. package/dist/ee/index.mjs.map +0 -1
  178. package/dist/ee/license.js +0 -91
  179. package/dist/ee/license.js.map +0 -1
  180. package/dist/ee/license.mjs +0 -88
  181. package/dist/ee/license.mjs.map +0 -1
  182. package/dist/factories.js +0 -80
  183. package/dist/factories.js.map +0 -1
  184. package/dist/factories.mjs +0 -80
  185. package/dist/factories.mjs.map +0 -1
  186. package/dist/loaders/admin.js +0 -26
  187. package/dist/loaders/admin.js.map +0 -1
  188. package/dist/loaders/admin.mjs +0 -25
  189. package/dist/loaders/admin.mjs.map +0 -1
  190. package/dist/loaders/apis.js +0 -137
  191. package/dist/loaders/apis.js.map +0 -1
  192. package/dist/loaders/apis.mjs +0 -135
  193. package/dist/loaders/apis.mjs.map +0 -1
  194. package/dist/loaders/components.js +0 -38
  195. package/dist/loaders/components.js.map +0 -1
  196. package/dist/loaders/components.mjs +0 -37
  197. package/dist/loaders/components.mjs.map +0 -1
  198. package/dist/loaders/index.js +0 -24
  199. package/dist/loaders/index.js.map +0 -1
  200. package/dist/loaders/index.mjs +0 -24
  201. package/dist/loaders/index.mjs.map +0 -1
  202. package/dist/loaders/middlewares.js +0 -31
  203. package/dist/loaders/middlewares.js.map +0 -1
  204. package/dist/loaders/middlewares.mjs +0 -30
  205. package/dist/loaders/middlewares.mjs.map +0 -1
  206. package/dist/loaders/plugins/get-enabled-plugins.js +0 -113
  207. package/dist/loaders/plugins/get-enabled-plugins.js.map +0 -1
  208. package/dist/loaders/plugins/get-enabled-plugins.mjs +0 -111
  209. package/dist/loaders/plugins/get-enabled-plugins.mjs.map +0 -1
  210. package/dist/loaders/plugins/get-user-plugins-config.js +0 -27
  211. package/dist/loaders/plugins/get-user-plugins-config.js.map +0 -1
  212. package/dist/loaders/plugins/get-user-plugins-config.mjs +0 -25
  213. package/dist/loaders/plugins/get-user-plugins-config.mjs.map +0 -1
  214. package/dist/loaders/plugins/index.js +0 -118
  215. package/dist/loaders/plugins/index.js.map +0 -1
  216. package/dist/loaders/plugins/index.mjs +0 -117
  217. package/dist/loaders/plugins/index.mjs.map +0 -1
  218. package/dist/loaders/policies.js +0 -25
  219. package/dist/loaders/policies.js.map +0 -1
  220. package/dist/loaders/policies.mjs +0 -24
  221. package/dist/loaders/policies.mjs.map +0 -1
  222. package/dist/loaders/sanitizers.js +0 -6
  223. package/dist/loaders/sanitizers.js.map +0 -1
  224. package/dist/loaders/sanitizers.mjs +0 -7
  225. package/dist/loaders/sanitizers.mjs.map +0 -1
  226. package/dist/loaders/src-index.js +0 -33
  227. package/dist/loaders/src-index.js.map +0 -1
  228. package/dist/loaders/src-index.mjs +0 -34
  229. package/dist/loaders/src-index.mjs.map +0 -1
  230. package/dist/loaders/validators.js +0 -6
  231. package/dist/loaders/validators.js.map +0 -1
  232. package/dist/loaders/validators.mjs +0 -7
  233. package/dist/loaders/validators.mjs.map +0 -1
  234. package/dist/middlewares/body.js +0 -65
  235. package/dist/middlewares/body.js.map +0 -1
  236. package/dist/middlewares/body.mjs +0 -61
  237. package/dist/middlewares/body.mjs.map +0 -1
  238. package/dist/middlewares/compression.js +0 -8
  239. package/dist/middlewares/compression.js.map +0 -1
  240. package/dist/middlewares/compression.mjs +0 -6
  241. package/dist/middlewares/compression.mjs.map +0 -1
  242. package/dist/middlewares/cors.js +0 -51
  243. package/dist/middlewares/cors.js.map +0 -1
  244. package/dist/middlewares/cors.mjs +0 -49
  245. package/dist/middlewares/cors.mjs.map +0 -1
  246. package/dist/middlewares/errors.js +0 -33
  247. package/dist/middlewares/errors.js.map +0 -1
  248. package/dist/middlewares/errors.mjs +0 -33
  249. package/dist/middlewares/errors.mjs.map +0 -1
  250. package/dist/middlewares/favicon.js +0 -22
  251. package/dist/middlewares/favicon.js.map +0 -1
  252. package/dist/middlewares/favicon.mjs +0 -20
  253. package/dist/middlewares/favicon.mjs.map +0 -1
  254. package/dist/middlewares/index.js +0 -34
  255. package/dist/middlewares/index.js.map +0 -1
  256. package/dist/middlewares/index.mjs +0 -34
  257. package/dist/middlewares/index.mjs.map +0 -1
  258. package/dist/middlewares/ip.js +0 -8
  259. package/dist/middlewares/ip.js.map +0 -1
  260. package/dist/middlewares/ip.mjs +0 -6
  261. package/dist/middlewares/ip.mjs.map +0 -1
  262. package/dist/middlewares/logger.js +0 -12
  263. package/dist/middlewares/logger.js.map +0 -1
  264. package/dist/middlewares/logger.mjs +0 -12
  265. package/dist/middlewares/logger.mjs.map +0 -1
  266. package/dist/middlewares/powered-by.js +0 -14
  267. package/dist/middlewares/powered-by.js.map +0 -1
  268. package/dist/middlewares/powered-by.mjs +0 -14
  269. package/dist/middlewares/powered-by.mjs.map +0 -1
  270. package/dist/middlewares/public.js +0 -34
  271. package/dist/middlewares/public.js.map +0 -1
  272. package/dist/middlewares/public.mjs +0 -32
  273. package/dist/middlewares/public.mjs.map +0 -1
  274. package/dist/middlewares/query.js +0 -40
  275. package/dist/middlewares/query.js.map +0 -1
  276. package/dist/middlewares/query.mjs +0 -38
  277. package/dist/middlewares/query.mjs.map +0 -1
  278. package/dist/middlewares/response-time.js +0 -12
  279. package/dist/middlewares/response-time.js.map +0 -1
  280. package/dist/middlewares/response-time.mjs +0 -12
  281. package/dist/middlewares/response-time.mjs.map +0 -1
  282. package/dist/middlewares/responses.js +0 -15
  283. package/dist/middlewares/responses.js.map +0 -1
  284. package/dist/middlewares/responses.mjs +0 -15
  285. package/dist/middlewares/responses.mjs.map +0 -1
  286. package/dist/middlewares/security.js +0 -71
  287. package/dist/middlewares/security.js.map +0 -1
  288. package/dist/middlewares/security.mjs +0 -69
  289. package/dist/middlewares/security.mjs.map +0 -1
  290. package/dist/middlewares/session.js +0 -30
  291. package/dist/middlewares/session.js.map +0 -1
  292. package/dist/middlewares/session.mjs +0 -28
  293. package/dist/middlewares/session.mjs.map +0 -1
  294. package/dist/migrations/database/5.0.0-discard-drafts.js +0 -50
  295. package/dist/migrations/database/5.0.0-discard-drafts.js.map +0 -1
  296. package/dist/migrations/database/5.0.0-discard-drafts.mjs +0 -50
  297. package/dist/migrations/database/5.0.0-discard-drafts.mjs.map +0 -1
  298. package/dist/migrations/draft-publish.js +0 -42
  299. package/dist/migrations/draft-publish.js.map +0 -1
  300. package/dist/migrations/draft-publish.mjs +0 -42
  301. package/dist/migrations/draft-publish.mjs.map +0 -1
  302. package/dist/providers/admin.js +0 -20
  303. package/dist/providers/admin.js.map +0 -1
  304. package/dist/providers/admin.mjs +0 -21
  305. package/dist/providers/admin.mjs.map +0 -1
  306. package/dist/providers/coreStore.js +0 -11
  307. package/dist/providers/coreStore.js.map +0 -1
  308. package/dist/providers/coreStore.mjs +0 -12
  309. package/dist/providers/coreStore.mjs.map +0 -1
  310. package/dist/providers/cron.js +0 -20
  311. package/dist/providers/cron.js.map +0 -1
  312. package/dist/providers/cron.mjs +0 -21
  313. package/dist/providers/cron.mjs.map +0 -1
  314. package/dist/providers/index.js +0 -11
  315. package/dist/providers/index.js.map +0 -1
  316. package/dist/providers/index.mjs +0 -11
  317. package/dist/providers/index.mjs.map +0 -1
  318. package/dist/providers/provider.js +0 -5
  319. package/dist/providers/provider.js.map +0 -1
  320. package/dist/providers/provider.mjs +0 -5
  321. package/dist/providers/provider.mjs.map +0 -1
  322. package/dist/providers/registries.js +0 -35
  323. package/dist/providers/registries.js.map +0 -1
  324. package/dist/providers/registries.mjs +0 -36
  325. package/dist/providers/registries.mjs.map +0 -1
  326. package/dist/providers/telemetry.js +0 -19
  327. package/dist/providers/telemetry.js.map +0 -1
  328. package/dist/providers/telemetry.mjs +0 -20
  329. package/dist/providers/telemetry.mjs.map +0 -1
  330. package/dist/providers/webhooks.js +0 -30
  331. package/dist/providers/webhooks.js.map +0 -1
  332. package/dist/providers/webhooks.mjs +0 -31
  333. package/dist/providers/webhooks.mjs.map +0 -1
  334. package/dist/registries/apis.js +0 -23
  335. package/dist/registries/apis.js.map +0 -1
  336. package/dist/registries/apis.mjs +0 -24
  337. package/dist/registries/apis.mjs.map +0 -1
  338. package/dist/registries/components.js +0 -45
  339. package/dist/registries/components.js.map +0 -1
  340. package/dist/registries/components.mjs +0 -46
  341. package/dist/registries/components.mjs.map +0 -1
  342. package/dist/registries/content-types.js +0 -70
  343. package/dist/registries/content-types.js.map +0 -1
  344. package/dist/registries/content-types.mjs +0 -71
  345. package/dist/registries/content-types.mjs.map +0 -1
  346. package/dist/registries/controllers.js +0 -80
  347. package/dist/registries/controllers.js.map +0 -1
  348. package/dist/registries/controllers.mjs +0 -81
  349. package/dist/registries/controllers.mjs.map +0 -1
  350. package/dist/registries/custom-fields.js +0 -71
  351. package/dist/registries/custom-fields.js.map +0 -1
  352. package/dist/registries/custom-fields.mjs +0 -72
  353. package/dist/registries/custom-fields.mjs.map +0 -1
  354. package/dist/registries/hooks.js +0 -58
  355. package/dist/registries/hooks.js.map +0 -1
  356. package/dist/registries/hooks.mjs +0 -59
  357. package/dist/registries/hooks.mjs.map +0 -1
  358. package/dist/registries/middlewares.js +0 -60
  359. package/dist/registries/middlewares.js.map +0 -1
  360. package/dist/registries/middlewares.mjs +0 -61
  361. package/dist/registries/middlewares.mjs.map +0 -1
  362. package/dist/registries/models.js +0 -16
  363. package/dist/registries/models.js.map +0 -1
  364. package/dist/registries/models.mjs +0 -16
  365. package/dist/registries/models.mjs.map +0 -1
  366. package/dist/registries/modules.js +0 -39
  367. package/dist/registries/modules.js.map +0 -1
  368. package/dist/registries/modules.mjs +0 -40
  369. package/dist/registries/modules.mjs.map +0 -1
  370. package/dist/registries/namespace.js +0 -27
  371. package/dist/registries/namespace.js.map +0 -1
  372. package/dist/registries/namespace.mjs +0 -27
  373. package/dist/registries/namespace.mjs.map +0 -1
  374. package/dist/registries/plugins.js +0 -23
  375. package/dist/registries/plugins.js.map +0 -1
  376. package/dist/registries/plugins.mjs +0 -24
  377. package/dist/registries/plugins.mjs.map +0 -1
  378. package/dist/registries/policies.js +0 -108
  379. package/dist/registries/policies.js.map +0 -1
  380. package/dist/registries/policies.mjs +0 -109
  381. package/dist/registries/policies.mjs.map +0 -1
  382. package/dist/registries/sanitizers.js +0 -25
  383. package/dist/registries/sanitizers.js.map +0 -1
  384. package/dist/registries/sanitizers.mjs +0 -24
  385. package/dist/registries/sanitizers.mjs.map +0 -1
  386. package/dist/registries/services.js +0 -80
  387. package/dist/registries/services.js.map +0 -1
  388. package/dist/registries/services.mjs +0 -81
  389. package/dist/registries/services.mjs.map +0 -1
  390. package/dist/registries/validators.js +0 -25
  391. package/dist/registries/validators.js.map +0 -1
  392. package/dist/registries/validators.mjs +0 -24
  393. package/dist/registries/validators.mjs.map +0 -1
  394. package/dist/services/auth/index.js +0 -81
  395. package/dist/services/auth/index.js.map +0 -1
  396. package/dist/services/auth/index.mjs +0 -80
  397. package/dist/services/auth/index.mjs.map +0 -1
  398. package/dist/services/config.js +0 -47
  399. package/dist/services/config.js.map +0 -1
  400. package/dist/services/config.mjs +0 -47
  401. package/dist/services/config.mjs.map +0 -1
  402. package/dist/services/content-api/index.js +0 -85
  403. package/dist/services/content-api/index.js.map +0 -1
  404. package/dist/services/content-api/index.mjs +0 -84
  405. package/dist/services/content-api/index.mjs.map +0 -1
  406. package/dist/services/content-api/permissions/engine.js +0 -7
  407. package/dist/services/content-api/permissions/engine.js.map +0 -1
  408. package/dist/services/content-api/permissions/engine.mjs +0 -6
  409. package/dist/services/content-api/permissions/engine.mjs.map +0 -1
  410. package/dist/services/content-api/permissions/index.js +0 -87
  411. package/dist/services/content-api/permissions/index.js.map +0 -1
  412. package/dist/services/content-api/permissions/index.mjs +0 -86
  413. package/dist/services/content-api/permissions/index.mjs.map +0 -1
  414. package/dist/services/content-api/permissions/providers/action.js +0 -16
  415. package/dist/services/content-api/permissions/providers/action.js.map +0 -1
  416. package/dist/services/content-api/permissions/providers/action.mjs +0 -17
  417. package/dist/services/content-api/permissions/providers/action.mjs.map +0 -1
  418. package/dist/services/content-api/permissions/providers/condition.js +0 -16
  419. package/dist/services/content-api/permissions/providers/condition.js.map +0 -1
  420. package/dist/services/content-api/permissions/providers/condition.mjs +0 -17
  421. package/dist/services/content-api/permissions/providers/condition.mjs.map +0 -1
  422. package/dist/services/core-store.js +0 -107
  423. package/dist/services/core-store.js.map +0 -1
  424. package/dist/services/core-store.mjs +0 -107
  425. package/dist/services/core-store.mjs.map +0 -1
  426. package/dist/services/cron.js +0 -63
  427. package/dist/services/cron.js.map +0 -1
  428. package/dist/services/cron.mjs +0 -64
  429. package/dist/services/cron.mjs.map +0 -1
  430. package/dist/services/custom-fields.js +0 -10
  431. package/dist/services/custom-fields.js.map +0 -1
  432. package/dist/services/custom-fields.mjs +0 -11
  433. package/dist/services/custom-fields.mjs.map +0 -1
  434. package/dist/services/document-service/attributes/index.js +0 -22
  435. package/dist/services/document-service/attributes/index.js.map +0 -1
  436. package/dist/services/document-service/attributes/index.mjs +0 -22
  437. package/dist/services/document-service/attributes/index.mjs.map +0 -1
  438. package/dist/services/document-service/attributes/transforms.js +0 -20
  439. package/dist/services/document-service/attributes/transforms.js.map +0 -1
  440. package/dist/services/document-service/attributes/transforms.mjs +0 -19
  441. package/dist/services/document-service/attributes/transforms.mjs.map +0 -1
  442. package/dist/services/document-service/common.js +0 -7
  443. package/dist/services/document-service/common.js.map +0 -1
  444. package/dist/services/document-service/common.mjs +0 -7
  445. package/dist/services/document-service/common.mjs.map +0 -1
  446. package/dist/services/document-service/components.js +0 -288
  447. package/dist/services/document-service/components.js.map +0 -1
  448. package/dist/services/document-service/components.mjs +0 -286
  449. package/dist/services/document-service/components.mjs.map +0 -1
  450. package/dist/services/document-service/draft-and-publish.js +0 -69
  451. package/dist/services/document-service/draft-and-publish.js.map +0 -1
  452. package/dist/services/document-service/draft-and-publish.mjs +0 -69
  453. package/dist/services/document-service/draft-and-publish.mjs.map +0 -1
  454. package/dist/services/document-service/entries.js +0 -96
  455. package/dist/services/document-service/entries.js.map +0 -1
  456. package/dist/services/document-service/entries.mjs +0 -96
  457. package/dist/services/document-service/entries.mjs.map +0 -1
  458. package/dist/services/document-service/events.js +0 -47
  459. package/dist/services/document-service/events.js.map +0 -1
  460. package/dist/services/document-service/events.mjs +0 -47
  461. package/dist/services/document-service/events.mjs.map +0 -1
  462. package/dist/services/document-service/index.js +0 -35
  463. package/dist/services/document-service/index.js.map +0 -1
  464. package/dist/services/document-service/index.mjs +0 -35
  465. package/dist/services/document-service/index.mjs.map +0 -1
  466. package/dist/services/document-service/internationalization.js +0 -63
  467. package/dist/services/document-service/internationalization.js.map +0 -1
  468. package/dist/services/document-service/internationalization.mjs +0 -63
  469. package/dist/services/document-service/internationalization.mjs.map +0 -1
  470. package/dist/services/document-service/middlewares/errors.js +0 -25
  471. package/dist/services/document-service/middlewares/errors.js.map +0 -1
  472. package/dist/services/document-service/middlewares/errors.mjs +0 -25
  473. package/dist/services/document-service/middlewares/errors.mjs.map +0 -1
  474. package/dist/services/document-service/middlewares/middleware-manager.js +0 -49
  475. package/dist/services/document-service/middlewares/middleware-manager.js.map +0 -1
  476. package/dist/services/document-service/middlewares/middleware-manager.mjs +0 -49
  477. package/dist/services/document-service/middlewares/middleware-manager.mjs.map +0 -1
  478. package/dist/services/document-service/params.js +0 -8
  479. package/dist/services/document-service/params.js.map +0 -1
  480. package/dist/services/document-service/params.mjs +0 -8
  481. package/dist/services/document-service/params.mjs.map +0 -1
  482. package/dist/services/document-service/repository.js +0 -278
  483. package/dist/services/document-service/repository.js.map +0 -1
  484. package/dist/services/document-service/repository.mjs +0 -278
  485. package/dist/services/document-service/repository.mjs.map +0 -1
  486. package/dist/services/document-service/transform/data.js +0 -15
  487. package/dist/services/document-service/transform/data.js.map +0 -1
  488. package/dist/services/document-service/transform/data.mjs +0 -15
  489. package/dist/services/document-service/transform/data.mjs.map +0 -1
  490. package/dist/services/document-service/transform/fields.js +0 -24
  491. package/dist/services/document-service/transform/fields.js.map +0 -1
  492. package/dist/services/document-service/transform/fields.mjs +0 -24
  493. package/dist/services/document-service/transform/fields.mjs.map +0 -1
  494. package/dist/services/document-service/transform/id-map.js +0 -78
  495. package/dist/services/document-service/transform/id-map.js.map +0 -1
  496. package/dist/services/document-service/transform/id-map.mjs +0 -78
  497. package/dist/services/document-service/transform/id-map.mjs.map +0 -1
  498. package/dist/services/document-service/transform/id-transform.js +0 -33
  499. package/dist/services/document-service/transform/id-transform.js.map +0 -1
  500. package/dist/services/document-service/transform/id-transform.mjs +0 -33
  501. package/dist/services/document-service/transform/id-transform.mjs.map +0 -1
  502. package/dist/services/document-service/transform/populate.js +0 -21
  503. package/dist/services/document-service/transform/populate.js.map +0 -1
  504. package/dist/services/document-service/transform/populate.mjs +0 -21
  505. package/dist/services/document-service/transform/populate.mjs.map +0 -1
  506. package/dist/services/document-service/transform/query.js +0 -9
  507. package/dist/services/document-service/transform/query.js.map +0 -1
  508. package/dist/services/document-service/transform/query.mjs +0 -9
  509. package/dist/services/document-service/transform/query.mjs.map +0 -1
  510. package/dist/services/document-service/transform/relations/extract/data-ids.js +0 -57
  511. package/dist/services/document-service/transform/relations/extract/data-ids.js.map +0 -1
  512. package/dist/services/document-service/transform/relations/extract/data-ids.mjs +0 -57
  513. package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +0 -1
  514. package/dist/services/document-service/transform/relations/transform/data-ids.js +0 -76
  515. package/dist/services/document-service/transform/relations/transform/data-ids.js.map +0 -1
  516. package/dist/services/document-service/transform/relations/transform/data-ids.mjs +0 -76
  517. package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +0 -1
  518. package/dist/services/document-service/transform/relations/transform/default-locale.js +0 -32
  519. package/dist/services/document-service/transform/relations/transform/default-locale.js.map +0 -1
  520. package/dist/services/document-service/transform/relations/transform/default-locale.mjs +0 -32
  521. package/dist/services/document-service/transform/relations/transform/default-locale.mjs.map +0 -1
  522. package/dist/services/document-service/transform/relations/utils/dp.js +0 -30
  523. package/dist/services/document-service/transform/relations/utils/dp.js.map +0 -1
  524. package/dist/services/document-service/transform/relations/utils/dp.mjs +0 -30
  525. package/dist/services/document-service/transform/relations/utils/dp.mjs.map +0 -1
  526. package/dist/services/document-service/transform/relations/utils/i18n.js +0 -25
  527. package/dist/services/document-service/transform/relations/utils/i18n.js.map +0 -1
  528. package/dist/services/document-service/transform/relations/utils/i18n.mjs +0 -25
  529. package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +0 -1
  530. package/dist/services/document-service/transform/relations/utils/map-relation.js +0 -91
  531. package/dist/services/document-service/transform/relations/utils/map-relation.js.map +0 -1
  532. package/dist/services/document-service/transform/relations/utils/map-relation.mjs +0 -91
  533. package/dist/services/document-service/transform/relations/utils/map-relation.mjs.map +0 -1
  534. package/dist/services/document-service/utils/populate.js +0 -41
  535. package/dist/services/document-service/utils/populate.js.map +0 -1
  536. package/dist/services/document-service/utils/populate.mjs +0 -41
  537. package/dist/services/document-service/utils/populate.mjs.map +0 -1
  538. package/dist/services/entity-service/index.js +0 -169
  539. package/dist/services/entity-service/index.js.map +0 -1
  540. package/dist/services/entity-service/index.mjs +0 -167
  541. package/dist/services/entity-service/index.mjs.map +0 -1
  542. package/dist/services/entity-validator/blocks-validator.js +0 -127
  543. package/dist/services/entity-validator/blocks-validator.js.map +0 -1
  544. package/dist/services/entity-validator/blocks-validator.mjs +0 -128
  545. package/dist/services/entity-validator/blocks-validator.mjs.map +0 -1
  546. package/dist/services/entity-validator/index.js +0 -333
  547. package/dist/services/entity-validator/index.js.map +0 -1
  548. package/dist/services/entity-validator/index.mjs +0 -332
  549. package/dist/services/entity-validator/index.mjs.map +0 -1
  550. package/dist/services/entity-validator/validators.js +0 -126
  551. package/dist/services/entity-validator/validators.js.map +0 -1
  552. package/dist/services/entity-validator/validators.mjs +0 -124
  553. package/dist/services/entity-validator/validators.mjs.map +0 -1
  554. package/dist/services/errors.js +0 -76
  555. package/dist/services/errors.js.map +0 -1
  556. package/dist/services/errors.mjs +0 -74
  557. package/dist/services/errors.mjs.map +0 -1
  558. package/dist/services/event-hub.js +0 -72
  559. package/dist/services/event-hub.js.map +0 -1
  560. package/dist/services/event-hub.mjs +0 -73
  561. package/dist/services/event-hub.mjs.map +0 -1
  562. package/dist/services/features.js +0 -17
  563. package/dist/services/features.js.map +0 -1
  564. package/dist/services/features.mjs +0 -17
  565. package/dist/services/features.mjs.map +0 -1
  566. package/dist/services/fs.js +0 -51
  567. package/dist/services/fs.js.map +0 -1
  568. package/dist/services/fs.mjs +0 -49
  569. package/dist/services/fs.mjs.map +0 -1
  570. package/dist/services/metrics/admin-user-hash.js +0 -14
  571. package/dist/services/metrics/admin-user-hash.js.map +0 -1
  572. package/dist/services/metrics/admin-user-hash.mjs +0 -12
  573. package/dist/services/metrics/admin-user-hash.mjs.map +0 -1
  574. package/dist/services/metrics/index.js +0 -45
  575. package/dist/services/metrics/index.js.map +0 -1
  576. package/dist/services/metrics/index.mjs +0 -46
  577. package/dist/services/metrics/index.mjs.map +0 -1
  578. package/dist/services/metrics/is-truthy.js +0 -9
  579. package/dist/services/metrics/is-truthy.js.map +0 -1
  580. package/dist/services/metrics/is-truthy.mjs +0 -8
  581. package/dist/services/metrics/is-truthy.mjs.map +0 -1
  582. package/dist/services/metrics/middleware.js +0 -25
  583. package/dist/services/metrics/middleware.js.map +0 -1
  584. package/dist/services/metrics/middleware.mjs +0 -26
  585. package/dist/services/metrics/middleware.mjs.map +0 -1
  586. package/dist/services/metrics/rate-limiter.js +0 -21
  587. package/dist/services/metrics/rate-limiter.js.map +0 -1
  588. package/dist/services/metrics/rate-limiter.mjs +0 -22
  589. package/dist/services/metrics/rate-limiter.mjs.map +0 -1
  590. package/dist/services/metrics/sender.js +0 -76
  591. package/dist/services/metrics/sender.js.map +0 -1
  592. package/dist/services/metrics/sender.mjs +0 -70
  593. package/dist/services/metrics/sender.mjs.map +0 -1
  594. package/dist/services/query-params.js +0 -12
  595. package/dist/services/query-params.js.map +0 -1
  596. package/dist/services/query-params.mjs +0 -13
  597. package/dist/services/query-params.mjs.map +0 -1
  598. package/dist/services/reloader.js +0 -36
  599. package/dist/services/reloader.js.map +0 -1
  600. package/dist/services/reloader.mjs +0 -36
  601. package/dist/services/reloader.mjs.map +0 -1
  602. package/dist/services/request-context.js +0 -13
  603. package/dist/services/request-context.js.map +0 -1
  604. package/dist/services/request-context.mjs +0 -14
  605. package/dist/services/request-context.mjs.map +0 -1
  606. package/dist/services/server/admin-api.js +0 -13
  607. package/dist/services/server/admin-api.js.map +0 -1
  608. package/dist/services/server/admin-api.mjs +0 -13
  609. package/dist/services/server/admin-api.mjs.map +0 -1
  610. package/dist/services/server/api.js +0 -30
  611. package/dist/services/server/api.js.map +0 -1
  612. package/dist/services/server/api.mjs +0 -28
  613. package/dist/services/server/api.mjs.map +0 -1
  614. package/dist/services/server/compose-endpoint.js +0 -117
  615. package/dist/services/server/compose-endpoint.js.map +0 -1
  616. package/dist/services/server/compose-endpoint.mjs +0 -116
  617. package/dist/services/server/compose-endpoint.mjs.map +0 -1
  618. package/dist/services/server/content-api.js +0 -12
  619. package/dist/services/server/content-api.js.map +0 -1
  620. package/dist/services/server/content-api.mjs +0 -12
  621. package/dist/services/server/content-api.mjs.map +0 -1
  622. package/dist/services/server/http-server.js +0 -50
  623. package/dist/services/server/http-server.js.map +0 -1
  624. package/dist/services/server/http-server.mjs +0 -48
  625. package/dist/services/server/http-server.mjs.map +0 -1
  626. package/dist/services/server/index.js +0 -87
  627. package/dist/services/server/index.js.map +0 -1
  628. package/dist/services/server/index.mjs +0 -85
  629. package/dist/services/server/index.mjs.map +0 -1
  630. package/dist/services/server/koa.js +0 -52
  631. package/dist/services/server/koa.js.map +0 -1
  632. package/dist/services/server/koa.mjs +0 -48
  633. package/dist/services/server/koa.mjs.map +0 -1
  634. package/dist/services/server/middleware.js +0 -92
  635. package/dist/services/server/middleware.js.map +0 -1
  636. package/dist/services/server/middleware.mjs +0 -90
  637. package/dist/services/server/middleware.mjs.map +0 -1
  638. package/dist/services/server/policy.js +0 -20
  639. package/dist/services/server/policy.js.map +0 -1
  640. package/dist/services/server/policy.mjs +0 -20
  641. package/dist/services/server/policy.mjs.map +0 -1
  642. package/dist/services/server/register-middlewares.js +0 -72
  643. package/dist/services/server/register-middlewares.js.map +0 -1
  644. package/dist/services/server/register-middlewares.mjs +0 -73
  645. package/dist/services/server/register-middlewares.mjs.map +0 -1
  646. package/dist/services/server/register-routes.js +0 -76
  647. package/dist/services/server/register-routes.js.map +0 -1
  648. package/dist/services/server/register-routes.mjs +0 -75
  649. package/dist/services/server/register-routes.mjs.map +0 -1
  650. package/dist/services/server/routing.js +0 -91
  651. package/dist/services/server/routing.js.map +0 -1
  652. package/dist/services/server/routing.mjs +0 -89
  653. package/dist/services/server/routing.mjs.map +0 -1
  654. package/dist/services/utils/dynamic-zones.js +0 -17
  655. package/dist/services/utils/dynamic-zones.js.map +0 -1
  656. package/dist/services/utils/dynamic-zones.mjs +0 -18
  657. package/dist/services/utils/dynamic-zones.mjs.map +0 -1
  658. package/dist/services/webhook-runner.js +0 -133
  659. package/dist/services/webhook-runner.js.map +0 -1
  660. package/dist/services/webhook-runner.mjs +0 -131
  661. package/dist/services/webhook-runner.mjs.map +0 -1
  662. package/dist/services/webhook-store.js +0 -110
  663. package/dist/services/webhook-store.js.map +0 -1
  664. package/dist/services/webhook-store.mjs +0 -110
  665. package/dist/services/webhook-store.mjs.map +0 -1
  666. package/dist/services/worker-queue.js +0 -56
  667. package/dist/services/worker-queue.js.map +0 -1
  668. package/dist/services/worker-queue.mjs +0 -55
  669. package/dist/services/worker-queue.mjs.map +0 -1
  670. package/dist/utils/convert-custom-field-type.js +0 -24
  671. package/dist/utils/convert-custom-field-type.js.map +0 -1
  672. package/dist/utils/convert-custom-field-type.mjs +0 -24
  673. package/dist/utils/convert-custom-field-type.mjs.map +0 -1
  674. package/dist/utils/cron.js +0 -38
  675. package/dist/utils/cron.js.map +0 -1
  676. package/dist/utils/cron.mjs +0 -38
  677. package/dist/utils/cron.mjs.map +0 -1
  678. package/dist/utils/fetch.js +0 -20
  679. package/dist/utils/fetch.js.map +0 -1
  680. package/dist/utils/fetch.mjs +0 -20
  681. package/dist/utils/fetch.mjs.map +0 -1
  682. package/dist/utils/filepath-to-prop-path.js +0 -12
  683. package/dist/utils/filepath-to-prop-path.js.map +0 -1
  684. package/dist/utils/filepath-to-prop-path.mjs +0 -10
  685. package/dist/utils/filepath-to-prop-path.mjs.map +0 -1
  686. package/dist/utils/is-initialized.js +0 -16
  687. package/dist/utils/is-initialized.js.map +0 -1
  688. package/dist/utils/is-initialized.mjs +0 -16
  689. package/dist/utils/is-initialized.mjs.map +0 -1
  690. package/dist/utils/lifecycles.js +0 -9
  691. package/dist/utils/lifecycles.js.map +0 -1
  692. package/dist/utils/lifecycles.mjs +0 -9
  693. package/dist/utils/lifecycles.mjs.map +0 -1
  694. package/dist/utils/load-config-file.js +0 -45
  695. package/dist/utils/load-config-file.js.map +0 -1
  696. package/dist/utils/load-config-file.mjs +0 -42
  697. package/dist/utils/load-config-file.mjs.map +0 -1
  698. package/dist/utils/load-files.js +0 -39
  699. package/dist/utils/load-files.js.map +0 -1
  700. package/dist/utils/load-files.mjs +0 -35
  701. package/dist/utils/load-files.mjs.map +0 -1
  702. package/dist/utils/open-browser.js +0 -11
  703. package/dist/utils/open-browser.js.map +0 -1
  704. package/dist/utils/open-browser.mjs +0 -9
  705. package/dist/utils/open-browser.mjs.map +0 -1
  706. package/dist/utils/resolve-working-dirs.js +0 -13
  707. package/dist/utils/resolve-working-dirs.js.map +0 -1
  708. package/dist/utils/resolve-working-dirs.mjs +0 -11
  709. package/dist/utils/resolve-working-dirs.mjs.map +0 -1
  710. package/dist/utils/signals.js +0 -17
  711. package/dist/utils/signals.js.map +0 -1
  712. package/dist/utils/signals.mjs +0 -17
  713. package/dist/utils/signals.mjs.map +0 -1
  714. package/dist/utils/startup-logger.js +0 -81
  715. package/dist/utils/startup-logger.js.map +0 -1
  716. package/dist/utils/startup-logger.mjs +0 -77
  717. package/dist/utils/startup-logger.mjs.map +0 -1
  718. package/dist/utils/transform-content-types-to-models.js +0 -275
  719. package/dist/utils/transform-content-types-to-models.js.map +0 -1
  720. package/dist/utils/transform-content-types-to-models.mjs +0 -272
  721. package/dist/utils/transform-content-types-to-models.mjs.map +0 -1
  722. package/dist/utils/update-notifier/index.js +0 -85
  723. package/dist/utils/update-notifier/index.js.map +0 -1
  724. package/dist/utils/update-notifier/index.mjs +0 -78
  725. package/dist/utils/update-notifier/index.mjs.map +0 -1
@@ -1,286 +0,0 @@
1
- import _ from "lodash";
2
- import { curry, omit, pipe, assign, has } from "lodash/fp";
3
- import { contentTypes, async, errors } from "@strapi/utils";
4
- const omitComponentData = curry(
5
- (schema, data) => {
6
- const { attributes } = schema;
7
- const componentAttributes = Object.keys(attributes).filter(
8
- (attributeName) => contentTypes.isComponentAttribute(attributes[attributeName])
9
- );
10
- return omit(componentAttributes, data);
11
- }
12
- );
13
- const createComponents = async (uid, data) => {
14
- const { attributes = {} } = strapi.getModel(uid);
15
- const componentBody = {};
16
- const attributeNames = Object.keys(attributes);
17
- for (const attributeName of attributeNames) {
18
- const attribute = attributes[attributeName];
19
- if (!has(attributeName, data) || !contentTypes.isComponentAttribute(attribute)) {
20
- continue;
21
- }
22
- if (attribute.type === "component") {
23
- const { component: componentUID, repeatable = false } = attribute;
24
- const componentValue = data[attributeName];
25
- if (componentValue === null) {
26
- continue;
27
- }
28
- if (repeatable === true) {
29
- if (!Array.isArray(componentValue)) {
30
- throw new Error("Expected an array to create repeatable component");
31
- }
32
- const components = await async.map(
33
- componentValue,
34
- (value) => createComponent(componentUID, value)
35
- );
36
- componentBody[attributeName] = components.map(({ id }) => {
37
- return {
38
- id,
39
- __pivot: {
40
- field: attributeName,
41
- component_type: componentUID
42
- }
43
- };
44
- });
45
- } else {
46
- const component = await createComponent(
47
- componentUID,
48
- componentValue
49
- );
50
- componentBody[attributeName] = {
51
- id: component.id,
52
- __pivot: {
53
- field: attributeName,
54
- component_type: componentUID
55
- }
56
- };
57
- }
58
- continue;
59
- }
60
- if (attribute.type === "dynamiczone") {
61
- const dynamiczoneValues = data[attributeName];
62
- if (!Array.isArray(dynamiczoneValues)) {
63
- throw new Error("Expected an array to create repeatable component");
64
- }
65
- const createDynamicZoneComponents = async (value) => {
66
- const { id } = await createComponent(value.__component, value);
67
- return {
68
- id,
69
- __component: value.__component,
70
- __pivot: {
71
- field: attributeName
72
- }
73
- };
74
- };
75
- componentBody[attributeName] = await async.map(
76
- dynamiczoneValues,
77
- createDynamicZoneComponents
78
- );
79
- continue;
80
- }
81
- }
82
- return componentBody;
83
- };
84
- const getComponents = async (uid, entity) => {
85
- const componentAttributes = contentTypes.getComponentAttributes(strapi.getModel(uid));
86
- if (_.isEmpty(componentAttributes)) {
87
- return {};
88
- }
89
- return strapi.db.query(uid).load(entity, componentAttributes);
90
- };
91
- const updateComponents = async (uid, entityToUpdate, data) => {
92
- const { attributes = {} } = strapi.getModel(uid);
93
- const componentBody = {};
94
- for (const attributeName of Object.keys(attributes)) {
95
- const attribute = attributes[attributeName];
96
- if (!has(attributeName, data)) {
97
- continue;
98
- }
99
- if (attribute.type === "component") {
100
- const { component: componentUID, repeatable = false } = attribute;
101
- const componentValue = data[attributeName];
102
- await deleteOldComponents(uid, componentUID, entityToUpdate, attributeName, componentValue);
103
- if (repeatable === true) {
104
- if (!Array.isArray(componentValue)) {
105
- throw new Error("Expected an array to create repeatable component");
106
- }
107
- const components = await async.map(
108
- componentValue,
109
- (value) => updateOrCreateComponent(componentUID, value)
110
- );
111
- componentBody[attributeName] = components.filter(_.negate(_.isNil)).map(({ id }) => {
112
- return {
113
- id,
114
- __pivot: {
115
- field: attributeName,
116
- component_type: componentUID
117
- }
118
- };
119
- });
120
- } else {
121
- const component = await updateOrCreateComponent(componentUID, componentValue);
122
- componentBody[attributeName] = component && {
123
- id: component.id,
124
- __pivot: {
125
- field: attributeName,
126
- component_type: componentUID
127
- }
128
- };
129
- }
130
- } else if (attribute.type === "dynamiczone") {
131
- const dynamiczoneValues = data[attributeName];
132
- await deleteOldDZComponents(uid, entityToUpdate, attributeName, dynamiczoneValues);
133
- if (!Array.isArray(dynamiczoneValues)) {
134
- throw new Error("Expected an array to create repeatable component");
135
- }
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
- });
146
- }
147
- }
148
- return componentBody;
149
- };
150
- const pickStringifiedId = ({
151
- id
152
- }) => {
153
- if (typeof id === "string") {
154
- return id;
155
- }
156
- return `${id}`;
157
- };
158
- const deleteOldComponents = async (uid, componentUID, entityToUpdate, attributeName, componentValue) => {
159
- const previousValue = await strapi.db.query(uid).load(entityToUpdate, attributeName);
160
- const idsToKeep = _.castArray(componentValue).filter(has("id")).map(pickStringifiedId);
161
- const allIds = _.castArray(previousValue).filter(has("id")).map(pickStringifiedId);
162
- idsToKeep.forEach((id) => {
163
- if (!allIds.includes(id)) {
164
- throw new errors.ApplicationError(
165
- `Some of the provided components in ${attributeName} are not related to the entity`
166
- );
167
- }
168
- });
169
- const idsToDelete = _.difference(allIds, idsToKeep);
170
- if (idsToDelete.length > 0) {
171
- for (const idToDelete of idsToDelete) {
172
- await deleteComponent(componentUID, { id: idToDelete });
173
- }
174
- }
175
- };
176
- const deleteOldDZComponents = async (uid, entityToUpdate, attributeName, dynamiczoneValues) => {
177
- const previousValue = await strapi.db.query(uid).load(entityToUpdate, attributeName);
178
- const idsToKeep = _.castArray(dynamiczoneValues).filter(has("id")).map((v) => ({
179
- id: pickStringifiedId(v),
180
- __component: v.__component
181
- }));
182
- const allIds = _.castArray(previousValue).filter(has("id")).map((v) => ({
183
- id: pickStringifiedId(v),
184
- __component: v.__component
185
- }));
186
- idsToKeep.forEach(({ id, __component }) => {
187
- if (!allIds.find((el) => el.id === id && el.__component === __component)) {
188
- const err = new Error(
189
- `Some of the provided components in ${attributeName} are not related to the entity`
190
- );
191
- Object.assign(err, { status: 400 });
192
- throw err;
193
- }
194
- });
195
- const idsToDelete = allIds.reduce((acc, { id, __component }) => {
196
- if (!idsToKeep.find((el) => el.id === id && el.__component === __component)) {
197
- acc.push({ id, __component });
198
- }
199
- return acc;
200
- }, []);
201
- if (idsToDelete.length > 0) {
202
- for (const idToDelete of idsToDelete) {
203
- const { id, __component } = idToDelete;
204
- await deleteComponent(__component, { id });
205
- }
206
- }
207
- };
208
- const deleteComponents = async (uid, entityToDelete, { loadComponents = true } = {}) => {
209
- const { attributes = {} } = strapi.getModel(uid);
210
- const attributeNames = Object.keys(attributes);
211
- for (const attributeName of attributeNames) {
212
- const attribute = attributes[attributeName];
213
- if (attribute.type === "component" || attribute.type === "dynamiczone") {
214
- let value;
215
- if (loadComponents) {
216
- value = await strapi.db.query(uid).load(entityToDelete, attributeName);
217
- } else {
218
- value = entityToDelete[attributeName];
219
- }
220
- if (!value) {
221
- continue;
222
- }
223
- if (attribute.type === "component") {
224
- const { component: componentUID } = attribute;
225
- await async.map(
226
- _.castArray(value),
227
- (subValue) => deleteComponent(componentUID, subValue)
228
- );
229
- } else {
230
- await async.map(
231
- _.castArray(value),
232
- (subValue) => deleteComponent(subValue.__component, subValue)
233
- );
234
- }
235
- continue;
236
- }
237
- }
238
- };
239
- const createComponent = async (uid, data) => {
240
- const schema = strapi.getModel(uid);
241
- const componentData = await createComponents(uid, data);
242
- const transform = pipe(
243
- // Make sure we don't save the component with a pre-defined ID
244
- omit("id"),
245
- assignComponentData(schema, componentData)
246
- );
247
- return strapi.db.query(uid).create({ data: transform(data) });
248
- };
249
- const updateComponent = async (uid, componentToUpdate, data) => {
250
- const schema = strapi.getModel(uid);
251
- const componentData = await updateComponents(uid, componentToUpdate, data);
252
- return strapi.db.query(uid).update({
253
- where: {
254
- id: componentToUpdate.id
255
- },
256
- data: assignComponentData(schema, componentData, data)
257
- });
258
- };
259
- const updateOrCreateComponent = (componentUID, value) => {
260
- if (value === null) {
261
- return null;
262
- }
263
- if ("id" in value && typeof value.id !== "undefined") {
264
- return updateComponent(componentUID, { id: value.id }, value);
265
- }
266
- return createComponent(componentUID, value);
267
- };
268
- const deleteComponent = async (uid, componentToDelete) => {
269
- await deleteComponents(uid, componentToDelete);
270
- await strapi.db.query(uid).delete({ where: { id: componentToDelete.id } });
271
- };
272
- const assignComponentData = curry(
273
- (schema, componentData, data) => {
274
- return pipe(omitComponentData(schema), assign(componentData))(data);
275
- }
276
- );
277
- export {
278
- assignComponentData,
279
- createComponents,
280
- deleteComponent,
281
- deleteComponents,
282
- getComponents,
283
- omitComponentData,
284
- updateComponents
285
- };
286
- //# sourceMappingURL=components.mjs.map
@@ -1 +0,0 @@
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":"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"}
@@ -1,69 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const _ = require("lodash/fp");
4
- const strapiUtils = require("@strapi/utils");
5
- const setStatusToDraft = (contentType, params) => {
6
- if (!strapiUtils.contentTypes.hasDraftAndPublish(contentType) && params.status) {
7
- return params;
8
- }
9
- return _.assoc("status", "draft", params);
10
- };
11
- const defaultToDraft = (params) => {
12
- if (!params.status || params.status !== "published") {
13
- return _.assoc("status", "draft", params);
14
- }
15
- return params;
16
- };
17
- const defaultStatus = (contentType, params) => {
18
- if (!strapiUtils.contentTypes.hasDraftAndPublish(contentType)) {
19
- return params;
20
- }
21
- if (!params.status || params.status !== "published") {
22
- return defaultToDraft(params);
23
- }
24
- return params;
25
- };
26
- const filterDataPublishedAt = (params) => {
27
- if (params?.data?.publishedAt) {
28
- return _.assoc(["data", "publishedAt"], null, params);
29
- }
30
- return params;
31
- };
32
- const statusToLookup = (contentType, params) => {
33
- if (!strapiUtils.contentTypes.hasDraftAndPublish(contentType)) {
34
- return params;
35
- }
36
- const lookup = params.lookup || {};
37
- switch (params?.status) {
38
- case "published":
39
- return _.assoc(["lookup", "publishedAt"], { $notNull: true }, params);
40
- case "draft":
41
- return _.assoc(["lookup", "publishedAt"], { $null: true }, params);
42
- }
43
- return _.assoc("lookup", lookup, params);
44
- };
45
- const statusToData = (contentType, params) => {
46
- if (!strapiUtils.contentTypes.hasDraftAndPublish(contentType)) {
47
- return _.assoc(["data", "publishedAt"], /* @__PURE__ */ new Date(), params);
48
- }
49
- switch (params?.status) {
50
- case "published":
51
- return _.assoc(["data", "publishedAt"], /* @__PURE__ */ new Date(), params);
52
- case "draft":
53
- return _.assoc(["data", "publishedAt"], null, params);
54
- }
55
- return params;
56
- };
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);
63
- exports.defaultStatus = defaultStatusCurry;
64
- exports.defaultToDraft = defaultToDraftCurry;
65
- exports.filterDataPublishedAt = filterDataPublishedAtCurry;
66
- exports.setStatusToDraft = setStatusToDraftCurry;
67
- exports.statusToData = statusToDataCurry;
68
- exports.statusToLookup = statusToLookupCurry;
69
- //# sourceMappingURL=draft-and-publish.js.map
@@ -1 +0,0 @@
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,69 +0,0 @@
1
- import { curry, assoc } from "lodash/fp";
2
- import { contentTypes } from "@strapi/utils";
3
- const setStatusToDraft = (contentType, params) => {
4
- if (!contentTypes.hasDraftAndPublish(contentType) && params.status) {
5
- return params;
6
- }
7
- return assoc("status", "draft", params);
8
- };
9
- const defaultToDraft = (params) => {
10
- if (!params.status || params.status !== "published") {
11
- return assoc("status", "draft", params);
12
- }
13
- return params;
14
- };
15
- const defaultStatus = (contentType, params) => {
16
- if (!contentTypes.hasDraftAndPublish(contentType)) {
17
- return params;
18
- }
19
- if (!params.status || params.status !== "published") {
20
- return defaultToDraft(params);
21
- }
22
- return params;
23
- };
24
- const filterDataPublishedAt = (params) => {
25
- if (params?.data?.publishedAt) {
26
- return assoc(["data", "publishedAt"], null, params);
27
- }
28
- return params;
29
- };
30
- const statusToLookup = (contentType, params) => {
31
- if (!contentTypes.hasDraftAndPublish(contentType)) {
32
- return params;
33
- }
34
- const lookup = params.lookup || {};
35
- switch (params?.status) {
36
- case "published":
37
- return assoc(["lookup", "publishedAt"], { $notNull: true }, params);
38
- case "draft":
39
- return assoc(["lookup", "publishedAt"], { $null: true }, params);
40
- }
41
- return assoc("lookup", lookup, params);
42
- };
43
- const statusToData = (contentType, params) => {
44
- if (!contentTypes.hasDraftAndPublish(contentType)) {
45
- return assoc(["data", "publishedAt"], /* @__PURE__ */ new Date(), params);
46
- }
47
- switch (params?.status) {
48
- case "published":
49
- return assoc(["data", "publishedAt"], /* @__PURE__ */ new Date(), params);
50
- case "draft":
51
- return assoc(["data", "publishedAt"], null, params);
52
- }
53
- return params;
54
- };
55
- const setStatusToDraftCurry = curry(setStatusToDraft);
56
- const defaultToDraftCurry = curry(defaultToDraft);
57
- const defaultStatusCurry = curry(defaultStatus);
58
- const filterDataPublishedAtCurry = curry(filterDataPublishedAt);
59
- const statusToLookupCurry = curry(statusToLookup);
60
- const statusToDataCurry = curry(statusToData);
61
- export {
62
- defaultStatusCurry as defaultStatus,
63
- defaultToDraftCurry as defaultToDraft,
64
- filterDataPublishedAtCurry as filterDataPublishedAt,
65
- setStatusToDraftCurry as setStatusToDraft,
66
- statusToDataCurry as statusToData,
67
- statusToLookupCurry as statusToLookup
68
- };
69
- //# sourceMappingURL=draft-and-publish.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"draft-and-publish.mjs","sources":["../../../src/services/document-service/draft-and-publish.ts"],"sourcesContent":["import { assoc, curry } from 'lodash/fp';\n\nimport { Modules, Struct } from '@strapi/types';\nimport { contentTypes } from '@strapi/utils';\n\ntype ParamsTransform = (params: Modules.Documents.Params.All) => Modules.Documents.Params.All;\n\ntype TransformWithContentType = (\n contentType: Struct.SingleTypeSchema | Struct.CollectionTypeSchema,\n params: Modules.Documents.Params.All\n) => Modules.Documents.Params.All;\n\n/**\n * DP enabled -> set status to draft\n * DP disabled -> Used mostly for parsing relations, so there is not a need for a default.\n */\nconst setStatusToDraft: TransformWithContentType = (contentType, params) => {\n if (!contentTypes.hasDraftAndPublish(contentType) && params.status) {\n return params;\n }\n\n return assoc('status', 'draft', params);\n};\n\n/**\n * Adds a default status of `draft` to the params\n */\nconst defaultToDraft: ParamsTransform = (params) => {\n // Default to draft if no status is provided or it's invalid\n if (!params.status || params.status !== 'published') {\n return assoc('status', 'draft', params);\n }\n\n return params;\n};\n\n/**\n * DP disabled -> ignore status\n * DP enabled -> set status to draft if no status is provided or it's invalid\n */\nconst defaultStatus: TransformWithContentType = (contentType, params) => {\n if (!contentTypes.hasDraftAndPublish(contentType)) {\n return params;\n }\n\n // Default to draft if no status is provided or it's invalid\n if (!params.status || params.status !== 'published') {\n return defaultToDraft(params);\n }\n\n return params;\n};\n\n/**\n * In mutating actions we don't want user to set the publishedAt attribute.\n */\nconst filterDataPublishedAt: ParamsTransform = (params) => {\n if (params?.data?.publishedAt) {\n return assoc(['data', 'publishedAt'], null, params);\n }\n\n return params;\n};\n\n/**\n * Add status lookup query to the params\n */\nconst statusToLookup: TransformWithContentType = (contentType, params) => {\n if (!contentTypes.hasDraftAndPublish(contentType)) {\n return params;\n }\n\n const lookup = params.lookup || {};\n\n switch (params?.status) {\n case 'published':\n return assoc(['lookup', 'publishedAt'], { $notNull: true }, params);\n case 'draft':\n return assoc(['lookup', 'publishedAt'], { $null: true }, params);\n default:\n break;\n }\n\n return assoc('lookup', lookup, params);\n};\n\n/**\n * Translate publication status parameter into the data that will be saved\n */\nconst statusToData: TransformWithContentType = (contentType, params) => {\n if (!contentTypes.hasDraftAndPublish(contentType)) {\n return assoc(['data', 'publishedAt'], new Date(), params);\n }\n\n switch (params?.status) {\n case 'published':\n return assoc(['data', 'publishedAt'], new Date(), params);\n case 'draft':\n return assoc(['data', 'publishedAt'], null, params);\n default:\n break;\n }\n\n return params;\n};\n\nconst setStatusToDraftCurry = curry(setStatusToDraft);\nconst defaultToDraftCurry = curry(defaultToDraft);\nconst defaultStatusCurry = curry(defaultStatus);\nconst filterDataPublishedAtCurry = curry(filterDataPublishedAt);\nconst statusToLookupCurry = curry(statusToLookup);\nconst statusToDataCurry = curry(statusToData);\n\nexport {\n setStatusToDraftCurry as setStatusToDraft,\n defaultToDraftCurry as defaultToDraft,\n defaultStatusCurry as defaultStatus,\n filterDataPublishedAtCurry as filterDataPublishedAt,\n statusToLookupCurry as statusToLookup,\n statusToDataCurry as statusToData,\n};\n"],"names":[],"mappings":";;AAgBA,MAAM,mBAA6C,CAAC,aAAa,WAAW;AAC1E,MAAI,CAAC,aAAa,mBAAmB,WAAW,KAAK,OAAO,QAAQ;AAC3D,WAAA;AAAA,EACT;AAEO,SAAA,MAAM,UAAU,SAAS,MAAM;AACxC;AAKA,MAAM,iBAAkC,CAAC,WAAW;AAElD,MAAI,CAAC,OAAO,UAAU,OAAO,WAAW,aAAa;AAC5C,WAAA,MAAM,UAAU,SAAS,MAAM;AAAA,EACxC;AAEO,SAAA;AACT;AAMA,MAAM,gBAA0C,CAAC,aAAa,WAAW;AACvE,MAAI,CAAC,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,WAAO,MAAM,CAAC,QAAQ,aAAa,GAAG,MAAM,MAAM;AAAA,EACpD;AAEO,SAAA;AACT;AAKA,MAAM,iBAA2C,CAAC,aAAa,WAAW;AACxE,MAAI,CAAC,aAAa,mBAAmB,WAAW,GAAG;AAC1C,WAAA;AAAA,EACT;AAEM,QAAA,SAAS,OAAO,UAAU;AAEhC,UAAQ,QAAQ,QAAQ;AAAA,IACtB,KAAK;AACI,aAAA,MAAM,CAAC,UAAU,aAAa,GAAG,EAAE,UAAU,QAAQ,MAAM;AAAA,IACpE,KAAK;AACI,aAAA,MAAM,CAAC,UAAU,aAAa,GAAG,EAAE,OAAO,QAAQ,MAAM;AAAA,EAGnE;AAEO,SAAA,MAAM,UAAU,QAAQ,MAAM;AACvC;AAKA,MAAM,eAAyC,CAAC,aAAa,WAAW;AACtE,MAAI,CAAC,aAAa,mBAAmB,WAAW,GAAG;AAC1C,WAAA,MAAM,CAAC,QAAQ,aAAa,GAAO,oBAAA,KAAA,GAAQ,MAAM;AAAA,EAC1D;AAEA,UAAQ,QAAQ,QAAQ;AAAA,IACtB,KAAK;AACI,aAAA,MAAM,CAAC,QAAQ,aAAa,GAAO,oBAAA,KAAA,GAAQ,MAAM;AAAA,IAC1D,KAAK;AACH,aAAO,MAAM,CAAC,QAAQ,aAAa,GAAG,MAAM,MAAM;AAAA,EAGtD;AAEO,SAAA;AACT;AAEM,MAAA,wBAAwB,MAAM,gBAAgB;AAC9C,MAAA,sBAAsB,MAAM,cAAc;AAC1C,MAAA,qBAAqB,MAAM,aAAa;AACxC,MAAA,6BAA6B,MAAM,qBAAqB;AACxD,MAAA,sBAAsB,MAAM,cAAc;AAC1C,MAAA,oBAAoB,MAAM,YAAY;"}
@@ -1,96 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const strapiUtils = require("@strapi/utils");
4
- const _ = 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
- _.omit("id"),
66
- _.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
- _.omit("id"),
78
- _.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
@@ -1 +0,0 @@
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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"}