@strapi/core 0.0.0-next.64bd4f3d1efcc9420d27c4f4d2013677ded62360 → 0.0.0-next.66fd5e4469bf52fd13fc9d4d8099cf66722cab24

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 (698) hide show
  1. package/dist/Strapi.d.ts.map +1 -1
  2. package/dist/configuration/index.d.ts.map +1 -1
  3. package/dist/index.js +10110 -27
  4. package/dist/index.js.map +1 -1
  5. package/dist/index.mjs +10088 -29
  6. package/dist/index.mjs.map +1 -1
  7. package/dist/middlewares/body.d.ts.map +1 -1
  8. package/dist/migrations/database/5.0.0-discard-drafts.d.ts +2 -2
  9. package/dist/migrations/database/5.0.0-discard-drafts.d.ts.map +1 -1
  10. package/dist/migrations/draft-publish.d.ts +1 -1
  11. package/dist/migrations/draft-publish.d.ts.map +1 -1
  12. package/dist/services/document-service/common.d.ts +1 -1
  13. package/dist/services/document-service/common.d.ts.map +1 -1
  14. package/dist/services/document-service/components.d.ts.map +1 -1
  15. package/dist/services/document-service/draft-and-publish.d.ts +1 -1
  16. package/dist/services/document-service/draft-and-publish.d.ts.map +1 -1
  17. package/dist/services/document-service/entries.d.ts +2 -2
  18. package/dist/services/document-service/entries.d.ts.map +1 -1
  19. package/dist/services/document-service/events.d.ts +1 -1
  20. package/dist/services/document-service/events.d.ts.map +1 -1
  21. package/dist/services/document-service/index.d.ts +2 -1
  22. package/dist/services/document-service/index.d.ts.map +1 -1
  23. package/dist/services/document-service/repository.d.ts.map +1 -1
  24. package/dist/services/document-service/transform/id-map.d.ts +1 -1
  25. package/dist/services/document-service/transform/id-map.d.ts.map +1 -1
  26. package/dist/services/document-service/transform/id-transform.d.ts +1 -1
  27. package/dist/services/document-service/transform/id-transform.d.ts.map +1 -1
  28. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +1 -1
  29. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -1
  30. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts.map +1 -1
  31. package/dist/services/document-service/transform/relations/utils/dp.d.ts +1 -1
  32. package/dist/services/document-service/transform/relations/utils/dp.d.ts.map +1 -1
  33. package/dist/services/document-service/transform/relations/utils/i18n.d.ts +1 -1
  34. package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -1
  35. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts.map +1 -1
  36. package/dist/services/document-service/utils/bidirectional-relations.d.ts +95 -0
  37. package/dist/services/document-service/utils/bidirectional-relations.d.ts.map +1 -0
  38. package/dist/services/document-service/utils/populate.d.ts +1 -1
  39. package/dist/services/document-service/utils/populate.d.ts.map +1 -1
  40. package/dist/services/document-service/utils/unidirectional-relations.d.ts +1 -1
  41. package/dist/services/document-service/utils/unidirectional-relations.d.ts.map +1 -1
  42. package/dist/services/entity-validator/index.d.ts +1 -1
  43. package/dist/services/entity-validator/index.d.ts.map +1 -1
  44. package/dist/services/metrics/middleware.d.ts.map +1 -1
  45. package/dist/services/metrics/rate-limiter.d.ts.map +1 -1
  46. package/dist/utils/startup-logger.d.ts.map +1 -1
  47. package/dist/utils/transform-content-types-to-models.d.ts +353 -21
  48. package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
  49. package/dist/utils/update-notifier/index.d.ts.map +1 -1
  50. package/package.json +27 -28
  51. package/dist/Strapi.js +0 -431
  52. package/dist/Strapi.js.map +0 -1
  53. package/dist/Strapi.mjs +0 -410
  54. package/dist/Strapi.mjs.map +0 -1
  55. package/dist/compile.js +0 -18
  56. package/dist/compile.js.map +0 -1
  57. package/dist/compile.mjs +0 -17
  58. package/dist/compile.mjs.map +0 -1
  59. package/dist/configuration/config-loader.js +0 -106
  60. package/dist/configuration/config-loader.js.map +0 -1
  61. package/dist/configuration/config-loader.mjs +0 -104
  62. package/dist/configuration/config-loader.mjs.map +0 -1
  63. package/dist/configuration/get-dirs.js +0 -31
  64. package/dist/configuration/get-dirs.js.map +0 -1
  65. package/dist/configuration/get-dirs.mjs +0 -31
  66. package/dist/configuration/get-dirs.mjs.map +0 -1
  67. package/dist/configuration/index.js +0 -80
  68. package/dist/configuration/index.js.map +0 -1
  69. package/dist/configuration/index.mjs +0 -75
  70. package/dist/configuration/index.mjs.map +0 -1
  71. package/dist/configuration/urls.js +0 -68
  72. package/dist/configuration/urls.js.map +0 -1
  73. package/dist/configuration/urls.mjs +0 -66
  74. package/dist/configuration/urls.mjs.map +0 -1
  75. package/dist/container.js +0 -30
  76. package/dist/container.js.map +0 -1
  77. package/dist/container.mjs +0 -30
  78. package/dist/container.mjs.map +0 -1
  79. package/dist/core-api/controller/collection-type.js +0 -84
  80. package/dist/core-api/controller/collection-type.js.map +0 -1
  81. package/dist/core-api/controller/collection-type.mjs +0 -84
  82. package/dist/core-api/controller/collection-type.mjs.map +0 -1
  83. package/dist/core-api/controller/index.js +0 -52
  84. package/dist/core-api/controller/index.js.map +0 -1
  85. package/dist/core-api/controller/index.mjs +0 -52
  86. package/dist/core-api/controller/index.mjs.map +0 -1
  87. package/dist/core-api/controller/single-type.js +0 -46
  88. package/dist/core-api/controller/single-type.js.map +0 -1
  89. package/dist/core-api/controller/single-type.mjs +0 -46
  90. package/dist/core-api/controller/single-type.mjs.map +0 -1
  91. package/dist/core-api/controller/transform.js +0 -76
  92. package/dist/core-api/controller/transform.js.map +0 -1
  93. package/dist/core-api/controller/transform.mjs +0 -76
  94. package/dist/core-api/controller/transform.mjs.map +0 -1
  95. package/dist/core-api/routes/index.js +0 -67
  96. package/dist/core-api/routes/index.js.map +0 -1
  97. package/dist/core-api/routes/index.mjs +0 -67
  98. package/dist/core-api/routes/index.mjs.map +0 -1
  99. package/dist/core-api/service/collection-type.js +0 -67
  100. package/dist/core-api/service/collection-type.js.map +0 -1
  101. package/dist/core-api/service/collection-type.mjs +0 -67
  102. package/dist/core-api/service/collection-type.mjs.map +0 -1
  103. package/dist/core-api/service/core-service.js +0 -12
  104. package/dist/core-api/service/core-service.js.map +0 -1
  105. package/dist/core-api/service/core-service.mjs +0 -12
  106. package/dist/core-api/service/core-service.mjs.map +0 -1
  107. package/dist/core-api/service/index.js +0 -16
  108. package/dist/core-api/service/index.js.map +0 -1
  109. package/dist/core-api/service/index.mjs +0 -16
  110. package/dist/core-api/service/index.mjs.map +0 -1
  111. package/dist/core-api/service/pagination.js +0 -52
  112. package/dist/core-api/service/pagination.js.map +0 -1
  113. package/dist/core-api/service/pagination.mjs +0 -52
  114. package/dist/core-api/service/pagination.mjs.map +0 -1
  115. package/dist/core-api/service/single-type.js +0 -46
  116. package/dist/core-api/service/single-type.js.map +0 -1
  117. package/dist/core-api/service/single-type.mjs +0 -46
  118. package/dist/core-api/service/single-type.mjs.map +0 -1
  119. package/dist/domain/content-type/index.js +0 -111
  120. package/dist/domain/content-type/index.js.map +0 -1
  121. package/dist/domain/content-type/index.mjs +0 -109
  122. package/dist/domain/content-type/index.mjs.map +0 -1
  123. package/dist/domain/content-type/validator.js +0 -77
  124. package/dist/domain/content-type/validator.js.map +0 -1
  125. package/dist/domain/content-type/validator.mjs +0 -75
  126. package/dist/domain/content-type/validator.mjs.map +0 -1
  127. package/dist/domain/module/index.js +0 -107
  128. package/dist/domain/module/index.js.map +0 -1
  129. package/dist/domain/module/index.mjs +0 -105
  130. package/dist/domain/module/index.mjs.map +0 -1
  131. package/dist/domain/module/validation.js +0 -25
  132. package/dist/domain/module/validation.js.map +0 -1
  133. package/dist/domain/module/validation.mjs +0 -25
  134. package/dist/domain/module/validation.mjs.map +0 -1
  135. package/dist/ee/index.js +0 -158
  136. package/dist/ee/index.js.map +0 -1
  137. package/dist/ee/index.mjs +0 -159
  138. package/dist/ee/index.mjs.map +0 -1
  139. package/dist/ee/license.js +0 -91
  140. package/dist/ee/license.js.map +0 -1
  141. package/dist/ee/license.mjs +0 -88
  142. package/dist/ee/license.mjs.map +0 -1
  143. package/dist/factories.js +0 -80
  144. package/dist/factories.js.map +0 -1
  145. package/dist/factories.mjs +0 -80
  146. package/dist/factories.mjs.map +0 -1
  147. package/dist/loaders/admin.js +0 -26
  148. package/dist/loaders/admin.js.map +0 -1
  149. package/dist/loaders/admin.mjs +0 -25
  150. package/dist/loaders/admin.mjs.map +0 -1
  151. package/dist/loaders/apis.js +0 -137
  152. package/dist/loaders/apis.js.map +0 -1
  153. package/dist/loaders/apis.mjs +0 -135
  154. package/dist/loaders/apis.mjs.map +0 -1
  155. package/dist/loaders/components.js +0 -38
  156. package/dist/loaders/components.js.map +0 -1
  157. package/dist/loaders/components.mjs +0 -37
  158. package/dist/loaders/components.mjs.map +0 -1
  159. package/dist/loaders/index.js +0 -24
  160. package/dist/loaders/index.js.map +0 -1
  161. package/dist/loaders/index.mjs +0 -24
  162. package/dist/loaders/index.mjs.map +0 -1
  163. package/dist/loaders/middlewares.js +0 -31
  164. package/dist/loaders/middlewares.js.map +0 -1
  165. package/dist/loaders/middlewares.mjs +0 -30
  166. package/dist/loaders/middlewares.mjs.map +0 -1
  167. package/dist/loaders/plugins/get-enabled-plugins.js +0 -141
  168. package/dist/loaders/plugins/get-enabled-plugins.js.map +0 -1
  169. package/dist/loaders/plugins/get-enabled-plugins.mjs +0 -117
  170. package/dist/loaders/plugins/get-enabled-plugins.mjs.map +0 -1
  171. package/dist/loaders/plugins/get-user-plugins-config.js +0 -27
  172. package/dist/loaders/plugins/get-user-plugins-config.js.map +0 -1
  173. package/dist/loaders/plugins/get-user-plugins-config.mjs +0 -25
  174. package/dist/loaders/plugins/get-user-plugins-config.mjs.map +0 -1
  175. package/dist/loaders/plugins/index.js +0 -145
  176. package/dist/loaders/plugins/index.js.map +0 -1
  177. package/dist/loaders/plugins/index.mjs +0 -125
  178. package/dist/loaders/plugins/index.mjs.map +0 -1
  179. package/dist/loaders/policies.js +0 -25
  180. package/dist/loaders/policies.js.map +0 -1
  181. package/dist/loaders/policies.mjs +0 -24
  182. package/dist/loaders/policies.mjs.map +0 -1
  183. package/dist/loaders/sanitizers.js +0 -6
  184. package/dist/loaders/sanitizers.js.map +0 -1
  185. package/dist/loaders/sanitizers.mjs +0 -7
  186. package/dist/loaders/sanitizers.mjs.map +0 -1
  187. package/dist/loaders/src-index.js +0 -33
  188. package/dist/loaders/src-index.js.map +0 -1
  189. package/dist/loaders/src-index.mjs +0 -34
  190. package/dist/loaders/src-index.mjs.map +0 -1
  191. package/dist/loaders/validators.js +0 -6
  192. package/dist/loaders/validators.js.map +0 -1
  193. package/dist/loaders/validators.mjs +0 -7
  194. package/dist/loaders/validators.mjs.map +0 -1
  195. package/dist/middlewares/body.js +0 -65
  196. package/dist/middlewares/body.js.map +0 -1
  197. package/dist/middlewares/body.mjs +0 -61
  198. package/dist/middlewares/body.mjs.map +0 -1
  199. package/dist/middlewares/compression.js +0 -8
  200. package/dist/middlewares/compression.js.map +0 -1
  201. package/dist/middlewares/compression.mjs +0 -6
  202. package/dist/middlewares/compression.mjs.map +0 -1
  203. package/dist/middlewares/cors.js +0 -53
  204. package/dist/middlewares/cors.js.map +0 -1
  205. package/dist/middlewares/cors.mjs +0 -51
  206. package/dist/middlewares/cors.mjs.map +0 -1
  207. package/dist/middlewares/errors.js +0 -33
  208. package/dist/middlewares/errors.js.map +0 -1
  209. package/dist/middlewares/errors.mjs +0 -33
  210. package/dist/middlewares/errors.mjs.map +0 -1
  211. package/dist/middlewares/favicon.js +0 -22
  212. package/dist/middlewares/favicon.js.map +0 -1
  213. package/dist/middlewares/favicon.mjs +0 -20
  214. package/dist/middlewares/favicon.mjs.map +0 -1
  215. package/dist/middlewares/index.js +0 -34
  216. package/dist/middlewares/index.js.map +0 -1
  217. package/dist/middlewares/index.mjs +0 -34
  218. package/dist/middlewares/index.mjs.map +0 -1
  219. package/dist/middlewares/ip.js +0 -8
  220. package/dist/middlewares/ip.js.map +0 -1
  221. package/dist/middlewares/ip.mjs +0 -6
  222. package/dist/middlewares/ip.mjs.map +0 -1
  223. package/dist/middlewares/logger.js +0 -12
  224. package/dist/middlewares/logger.js.map +0 -1
  225. package/dist/middlewares/logger.mjs +0 -12
  226. package/dist/middlewares/logger.mjs.map +0 -1
  227. package/dist/middlewares/powered-by.js +0 -14
  228. package/dist/middlewares/powered-by.js.map +0 -1
  229. package/dist/middlewares/powered-by.mjs +0 -14
  230. package/dist/middlewares/powered-by.mjs.map +0 -1
  231. package/dist/middlewares/public.js +0 -34
  232. package/dist/middlewares/public.js.map +0 -1
  233. package/dist/middlewares/public.mjs +0 -32
  234. package/dist/middlewares/public.mjs.map +0 -1
  235. package/dist/middlewares/query.js +0 -40
  236. package/dist/middlewares/query.js.map +0 -1
  237. package/dist/middlewares/query.mjs +0 -38
  238. package/dist/middlewares/query.mjs.map +0 -1
  239. package/dist/middlewares/response-time.js +0 -12
  240. package/dist/middlewares/response-time.js.map +0 -1
  241. package/dist/middlewares/response-time.mjs +0 -12
  242. package/dist/middlewares/response-time.mjs.map +0 -1
  243. package/dist/middlewares/responses.js +0 -15
  244. package/dist/middlewares/responses.js.map +0 -1
  245. package/dist/middlewares/responses.mjs +0 -15
  246. package/dist/middlewares/responses.mjs.map +0 -1
  247. package/dist/middlewares/security.js +0 -78
  248. package/dist/middlewares/security.js.map +0 -1
  249. package/dist/middlewares/security.mjs +0 -76
  250. package/dist/middlewares/security.mjs.map +0 -1
  251. package/dist/middlewares/session.js +0 -30
  252. package/dist/middlewares/session.js.map +0 -1
  253. package/dist/middlewares/session.mjs +0 -28
  254. package/dist/middlewares/session.mjs.map +0 -1
  255. package/dist/migrations/database/5.0.0-discard-drafts.js +0 -94
  256. package/dist/migrations/database/5.0.0-discard-drafts.js.map +0 -1
  257. package/dist/migrations/database/5.0.0-discard-drafts.mjs +0 -94
  258. package/dist/migrations/database/5.0.0-discard-drafts.mjs.map +0 -1
  259. package/dist/migrations/draft-publish.js +0 -42
  260. package/dist/migrations/draft-publish.js.map +0 -1
  261. package/dist/migrations/draft-publish.mjs +0 -42
  262. package/dist/migrations/draft-publish.mjs.map +0 -1
  263. package/dist/migrations/i18n.js +0 -54
  264. package/dist/migrations/i18n.js.map +0 -1
  265. package/dist/migrations/i18n.mjs +0 -54
  266. package/dist/migrations/i18n.mjs.map +0 -1
  267. package/dist/migrations/index.js +0 -15
  268. package/dist/migrations/index.js.map +0 -1
  269. package/dist/migrations/index.mjs +0 -15
  270. package/dist/migrations/index.mjs.map +0 -1
  271. package/dist/providers/admin.js +0 -20
  272. package/dist/providers/admin.js.map +0 -1
  273. package/dist/providers/admin.mjs +0 -21
  274. package/dist/providers/admin.mjs.map +0 -1
  275. package/dist/providers/coreStore.js +0 -11
  276. package/dist/providers/coreStore.js.map +0 -1
  277. package/dist/providers/coreStore.mjs +0 -12
  278. package/dist/providers/coreStore.mjs.map +0 -1
  279. package/dist/providers/cron.js +0 -20
  280. package/dist/providers/cron.js.map +0 -1
  281. package/dist/providers/cron.mjs +0 -21
  282. package/dist/providers/cron.mjs.map +0 -1
  283. package/dist/providers/index.js +0 -11
  284. package/dist/providers/index.js.map +0 -1
  285. package/dist/providers/index.mjs +0 -11
  286. package/dist/providers/index.mjs.map +0 -1
  287. package/dist/providers/provider.js +0 -5
  288. package/dist/providers/provider.js.map +0 -1
  289. package/dist/providers/provider.mjs +0 -5
  290. package/dist/providers/provider.mjs.map +0 -1
  291. package/dist/providers/registries.js +0 -35
  292. package/dist/providers/registries.js.map +0 -1
  293. package/dist/providers/registries.mjs +0 -36
  294. package/dist/providers/registries.mjs.map +0 -1
  295. package/dist/providers/telemetry.js +0 -19
  296. package/dist/providers/telemetry.js.map +0 -1
  297. package/dist/providers/telemetry.mjs +0 -20
  298. package/dist/providers/telemetry.mjs.map +0 -1
  299. package/dist/providers/webhooks.js +0 -30
  300. package/dist/providers/webhooks.js.map +0 -1
  301. package/dist/providers/webhooks.mjs +0 -31
  302. package/dist/providers/webhooks.mjs.map +0 -1
  303. package/dist/registries/apis.js +0 -23
  304. package/dist/registries/apis.js.map +0 -1
  305. package/dist/registries/apis.mjs +0 -24
  306. package/dist/registries/apis.mjs.map +0 -1
  307. package/dist/registries/components.js +0 -45
  308. package/dist/registries/components.js.map +0 -1
  309. package/dist/registries/components.mjs +0 -46
  310. package/dist/registries/components.mjs.map +0 -1
  311. package/dist/registries/content-types.js +0 -70
  312. package/dist/registries/content-types.js.map +0 -1
  313. package/dist/registries/content-types.mjs +0 -71
  314. package/dist/registries/content-types.mjs.map +0 -1
  315. package/dist/registries/controllers.js +0 -80
  316. package/dist/registries/controllers.js.map +0 -1
  317. package/dist/registries/controllers.mjs +0 -81
  318. package/dist/registries/controllers.mjs.map +0 -1
  319. package/dist/registries/custom-fields.js +0 -71
  320. package/dist/registries/custom-fields.js.map +0 -1
  321. package/dist/registries/custom-fields.mjs +0 -72
  322. package/dist/registries/custom-fields.mjs.map +0 -1
  323. package/dist/registries/hooks.js +0 -58
  324. package/dist/registries/hooks.js.map +0 -1
  325. package/dist/registries/hooks.mjs +0 -59
  326. package/dist/registries/hooks.mjs.map +0 -1
  327. package/dist/registries/middlewares.js +0 -60
  328. package/dist/registries/middlewares.js.map +0 -1
  329. package/dist/registries/middlewares.mjs +0 -61
  330. package/dist/registries/middlewares.mjs.map +0 -1
  331. package/dist/registries/models.js +0 -16
  332. package/dist/registries/models.js.map +0 -1
  333. package/dist/registries/models.mjs +0 -16
  334. package/dist/registries/models.mjs.map +0 -1
  335. package/dist/registries/modules.js +0 -39
  336. package/dist/registries/modules.js.map +0 -1
  337. package/dist/registries/modules.mjs +0 -40
  338. package/dist/registries/modules.mjs.map +0 -1
  339. package/dist/registries/namespace.js +0 -27
  340. package/dist/registries/namespace.js.map +0 -1
  341. package/dist/registries/namespace.mjs +0 -27
  342. package/dist/registries/namespace.mjs.map +0 -1
  343. package/dist/registries/plugins.js +0 -23
  344. package/dist/registries/plugins.js.map +0 -1
  345. package/dist/registries/plugins.mjs +0 -24
  346. package/dist/registries/plugins.mjs.map +0 -1
  347. package/dist/registries/policies.js +0 -108
  348. package/dist/registries/policies.js.map +0 -1
  349. package/dist/registries/policies.mjs +0 -109
  350. package/dist/registries/policies.mjs.map +0 -1
  351. package/dist/registries/sanitizers.js +0 -25
  352. package/dist/registries/sanitizers.js.map +0 -1
  353. package/dist/registries/sanitizers.mjs +0 -24
  354. package/dist/registries/sanitizers.mjs.map +0 -1
  355. package/dist/registries/services.js +0 -80
  356. package/dist/registries/services.js.map +0 -1
  357. package/dist/registries/services.mjs +0 -81
  358. package/dist/registries/services.mjs.map +0 -1
  359. package/dist/registries/validators.js +0 -25
  360. package/dist/registries/validators.js.map +0 -1
  361. package/dist/registries/validators.mjs +0 -24
  362. package/dist/registries/validators.mjs.map +0 -1
  363. package/dist/services/auth/index.js +0 -81
  364. package/dist/services/auth/index.js.map +0 -1
  365. package/dist/services/auth/index.mjs +0 -80
  366. package/dist/services/auth/index.mjs.map +0 -1
  367. package/dist/services/config.js +0 -47
  368. package/dist/services/config.js.map +0 -1
  369. package/dist/services/config.mjs +0 -47
  370. package/dist/services/config.mjs.map +0 -1
  371. package/dist/services/content-api/index.js +0 -85
  372. package/dist/services/content-api/index.js.map +0 -1
  373. package/dist/services/content-api/index.mjs +0 -84
  374. package/dist/services/content-api/index.mjs.map +0 -1
  375. package/dist/services/content-api/permissions/engine.js +0 -7
  376. package/dist/services/content-api/permissions/engine.js.map +0 -1
  377. package/dist/services/content-api/permissions/engine.mjs +0 -6
  378. package/dist/services/content-api/permissions/engine.mjs.map +0 -1
  379. package/dist/services/content-api/permissions/index.js +0 -87
  380. package/dist/services/content-api/permissions/index.js.map +0 -1
  381. package/dist/services/content-api/permissions/index.mjs +0 -86
  382. package/dist/services/content-api/permissions/index.mjs.map +0 -1
  383. package/dist/services/content-api/permissions/providers/action.js +0 -16
  384. package/dist/services/content-api/permissions/providers/action.js.map +0 -1
  385. package/dist/services/content-api/permissions/providers/action.mjs +0 -17
  386. package/dist/services/content-api/permissions/providers/action.mjs.map +0 -1
  387. package/dist/services/content-api/permissions/providers/condition.js +0 -16
  388. package/dist/services/content-api/permissions/providers/condition.js.map +0 -1
  389. package/dist/services/content-api/permissions/providers/condition.mjs +0 -17
  390. package/dist/services/content-api/permissions/providers/condition.mjs.map +0 -1
  391. package/dist/services/core-store.js +0 -107
  392. package/dist/services/core-store.js.map +0 -1
  393. package/dist/services/core-store.mjs +0 -107
  394. package/dist/services/core-store.mjs.map +0 -1
  395. package/dist/services/cron.js +0 -63
  396. package/dist/services/cron.js.map +0 -1
  397. package/dist/services/cron.mjs +0 -64
  398. package/dist/services/cron.mjs.map +0 -1
  399. package/dist/services/custom-fields.js +0 -10
  400. package/dist/services/custom-fields.js.map +0 -1
  401. package/dist/services/custom-fields.mjs +0 -11
  402. package/dist/services/custom-fields.mjs.map +0 -1
  403. package/dist/services/document-service/attributes/index.js +0 -22
  404. package/dist/services/document-service/attributes/index.js.map +0 -1
  405. package/dist/services/document-service/attributes/index.mjs +0 -22
  406. package/dist/services/document-service/attributes/index.mjs.map +0 -1
  407. package/dist/services/document-service/attributes/transforms.js +0 -20
  408. package/dist/services/document-service/attributes/transforms.js.map +0 -1
  409. package/dist/services/document-service/attributes/transforms.mjs +0 -19
  410. package/dist/services/document-service/attributes/transforms.mjs.map +0 -1
  411. package/dist/services/document-service/common.js +0 -7
  412. package/dist/services/document-service/common.js.map +0 -1
  413. package/dist/services/document-service/common.mjs +0 -7
  414. package/dist/services/document-service/common.mjs.map +0 -1
  415. package/dist/services/document-service/components.js +0 -288
  416. package/dist/services/document-service/components.js.map +0 -1
  417. package/dist/services/document-service/components.mjs +0 -286
  418. package/dist/services/document-service/components.mjs.map +0 -1
  419. package/dist/services/document-service/draft-and-publish.js +0 -69
  420. package/dist/services/document-service/draft-and-publish.js.map +0 -1
  421. package/dist/services/document-service/draft-and-publish.mjs +0 -69
  422. package/dist/services/document-service/draft-and-publish.mjs.map +0 -1
  423. package/dist/services/document-service/entries.js +0 -96
  424. package/dist/services/document-service/entries.js.map +0 -1
  425. package/dist/services/document-service/entries.mjs +0 -96
  426. package/dist/services/document-service/entries.mjs.map +0 -1
  427. package/dist/services/document-service/events.js +0 -47
  428. package/dist/services/document-service/events.js.map +0 -1
  429. package/dist/services/document-service/events.mjs +0 -47
  430. package/dist/services/document-service/events.mjs.map +0 -1
  431. package/dist/services/document-service/index.js +0 -35
  432. package/dist/services/document-service/index.js.map +0 -1
  433. package/dist/services/document-service/index.mjs +0 -35
  434. package/dist/services/document-service/index.mjs.map +0 -1
  435. package/dist/services/document-service/internationalization.js +0 -63
  436. package/dist/services/document-service/internationalization.js.map +0 -1
  437. package/dist/services/document-service/internationalization.mjs +0 -63
  438. package/dist/services/document-service/internationalization.mjs.map +0 -1
  439. package/dist/services/document-service/middlewares/errors.js +0 -25
  440. package/dist/services/document-service/middlewares/errors.js.map +0 -1
  441. package/dist/services/document-service/middlewares/errors.mjs +0 -25
  442. package/dist/services/document-service/middlewares/errors.mjs.map +0 -1
  443. package/dist/services/document-service/middlewares/middleware-manager.js +0 -49
  444. package/dist/services/document-service/middlewares/middleware-manager.js.map +0 -1
  445. package/dist/services/document-service/middlewares/middleware-manager.mjs +0 -49
  446. package/dist/services/document-service/middlewares/middleware-manager.mjs.map +0 -1
  447. package/dist/services/document-service/params.js +0 -8
  448. package/dist/services/document-service/params.js.map +0 -1
  449. package/dist/services/document-service/params.mjs +0 -8
  450. package/dist/services/document-service/params.mjs.map +0 -1
  451. package/dist/services/document-service/repository.js +0 -328
  452. package/dist/services/document-service/repository.js.map +0 -1
  453. package/dist/services/document-service/repository.mjs +0 -328
  454. package/dist/services/document-service/repository.mjs.map +0 -1
  455. package/dist/services/document-service/transform/data.js +0 -15
  456. package/dist/services/document-service/transform/data.js.map +0 -1
  457. package/dist/services/document-service/transform/data.mjs +0 -15
  458. package/dist/services/document-service/transform/data.mjs.map +0 -1
  459. package/dist/services/document-service/transform/fields.js +0 -24
  460. package/dist/services/document-service/transform/fields.js.map +0 -1
  461. package/dist/services/document-service/transform/fields.mjs +0 -24
  462. package/dist/services/document-service/transform/fields.mjs.map +0 -1
  463. package/dist/services/document-service/transform/id-map.js +0 -78
  464. package/dist/services/document-service/transform/id-map.js.map +0 -1
  465. package/dist/services/document-service/transform/id-map.mjs +0 -78
  466. package/dist/services/document-service/transform/id-map.mjs.map +0 -1
  467. package/dist/services/document-service/transform/id-transform.js +0 -33
  468. package/dist/services/document-service/transform/id-transform.js.map +0 -1
  469. package/dist/services/document-service/transform/id-transform.mjs +0 -33
  470. package/dist/services/document-service/transform/id-transform.mjs.map +0 -1
  471. package/dist/services/document-service/transform/populate.js +0 -21
  472. package/dist/services/document-service/transform/populate.js.map +0 -1
  473. package/dist/services/document-service/transform/populate.mjs +0 -21
  474. package/dist/services/document-service/transform/populate.mjs.map +0 -1
  475. package/dist/services/document-service/transform/query.js +0 -9
  476. package/dist/services/document-service/transform/query.js.map +0 -1
  477. package/dist/services/document-service/transform/query.mjs +0 -9
  478. package/dist/services/document-service/transform/query.mjs.map +0 -1
  479. package/dist/services/document-service/transform/relations/extract/data-ids.js +0 -57
  480. package/dist/services/document-service/transform/relations/extract/data-ids.js.map +0 -1
  481. package/dist/services/document-service/transform/relations/extract/data-ids.mjs +0 -57
  482. package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +0 -1
  483. package/dist/services/document-service/transform/relations/transform/data-ids.js +0 -76
  484. package/dist/services/document-service/transform/relations/transform/data-ids.js.map +0 -1
  485. package/dist/services/document-service/transform/relations/transform/data-ids.mjs +0 -76
  486. package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +0 -1
  487. package/dist/services/document-service/transform/relations/transform/default-locale.js +0 -32
  488. package/dist/services/document-service/transform/relations/transform/default-locale.js.map +0 -1
  489. package/dist/services/document-service/transform/relations/transform/default-locale.mjs +0 -32
  490. package/dist/services/document-service/transform/relations/transform/default-locale.mjs.map +0 -1
  491. package/dist/services/document-service/transform/relations/utils/dp.js +0 -30
  492. package/dist/services/document-service/transform/relations/utils/dp.js.map +0 -1
  493. package/dist/services/document-service/transform/relations/utils/dp.mjs +0 -30
  494. package/dist/services/document-service/transform/relations/utils/dp.mjs.map +0 -1
  495. package/dist/services/document-service/transform/relations/utils/i18n.js +0 -25
  496. package/dist/services/document-service/transform/relations/utils/i18n.js.map +0 -1
  497. package/dist/services/document-service/transform/relations/utils/i18n.mjs +0 -25
  498. package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +0 -1
  499. package/dist/services/document-service/transform/relations/utils/map-relation.js +0 -91
  500. package/dist/services/document-service/transform/relations/utils/map-relation.js.map +0 -1
  501. package/dist/services/document-service/transform/relations/utils/map-relation.mjs +0 -91
  502. package/dist/services/document-service/transform/relations/utils/map-relation.mjs.map +0 -1
  503. package/dist/services/document-service/utils/populate.js +0 -47
  504. package/dist/services/document-service/utils/populate.js.map +0 -1
  505. package/dist/services/document-service/utils/populate.mjs +0 -47
  506. package/dist/services/document-service/utils/populate.mjs.map +0 -1
  507. package/dist/services/document-service/utils/unidirectional-relations.js +0 -69
  508. package/dist/services/document-service/utils/unidirectional-relations.js.map +0 -1
  509. package/dist/services/document-service/utils/unidirectional-relations.mjs +0 -69
  510. package/dist/services/document-service/utils/unidirectional-relations.mjs.map +0 -1
  511. package/dist/services/entity-service/index.js +0 -169
  512. package/dist/services/entity-service/index.js.map +0 -1
  513. package/dist/services/entity-service/index.mjs +0 -167
  514. package/dist/services/entity-service/index.mjs.map +0 -1
  515. package/dist/services/entity-validator/blocks-validator.js +0 -128
  516. package/dist/services/entity-validator/blocks-validator.js.map +0 -1
  517. package/dist/services/entity-validator/blocks-validator.mjs +0 -128
  518. package/dist/services/entity-validator/blocks-validator.mjs.map +0 -1
  519. package/dist/services/entity-validator/index.js +0 -389
  520. package/dist/services/entity-validator/index.js.map +0 -1
  521. package/dist/services/entity-validator/index.mjs +0 -388
  522. package/dist/services/entity-validator/index.mjs.map +0 -1
  523. package/dist/services/entity-validator/validators.js +0 -241
  524. package/dist/services/entity-validator/validators.js.map +0 -1
  525. package/dist/services/entity-validator/validators.mjs +0 -239
  526. package/dist/services/entity-validator/validators.mjs.map +0 -1
  527. package/dist/services/errors.js +0 -76
  528. package/dist/services/errors.js.map +0 -1
  529. package/dist/services/errors.mjs +0 -74
  530. package/dist/services/errors.mjs.map +0 -1
  531. package/dist/services/event-hub.js +0 -72
  532. package/dist/services/event-hub.js.map +0 -1
  533. package/dist/services/event-hub.mjs +0 -73
  534. package/dist/services/event-hub.mjs.map +0 -1
  535. package/dist/services/features.js +0 -17
  536. package/dist/services/features.js.map +0 -1
  537. package/dist/services/features.mjs +0 -17
  538. package/dist/services/features.mjs.map +0 -1
  539. package/dist/services/fs.js +0 -51
  540. package/dist/services/fs.js.map +0 -1
  541. package/dist/services/fs.mjs +0 -49
  542. package/dist/services/fs.mjs.map +0 -1
  543. package/dist/services/metrics/admin-user-hash.js +0 -14
  544. package/dist/services/metrics/admin-user-hash.js.map +0 -1
  545. package/dist/services/metrics/admin-user-hash.mjs +0 -12
  546. package/dist/services/metrics/admin-user-hash.mjs.map +0 -1
  547. package/dist/services/metrics/index.js +0 -45
  548. package/dist/services/metrics/index.js.map +0 -1
  549. package/dist/services/metrics/index.mjs +0 -46
  550. package/dist/services/metrics/index.mjs.map +0 -1
  551. package/dist/services/metrics/is-truthy.js +0 -9
  552. package/dist/services/metrics/is-truthy.js.map +0 -1
  553. package/dist/services/metrics/is-truthy.mjs +0 -8
  554. package/dist/services/metrics/is-truthy.mjs.map +0 -1
  555. package/dist/services/metrics/middleware.js +0 -25
  556. package/dist/services/metrics/middleware.js.map +0 -1
  557. package/dist/services/metrics/middleware.mjs +0 -26
  558. package/dist/services/metrics/middleware.mjs.map +0 -1
  559. package/dist/services/metrics/rate-limiter.js +0 -21
  560. package/dist/services/metrics/rate-limiter.js.map +0 -1
  561. package/dist/services/metrics/rate-limiter.mjs +0 -22
  562. package/dist/services/metrics/rate-limiter.mjs.map +0 -1
  563. package/dist/services/metrics/sender.js +0 -76
  564. package/dist/services/metrics/sender.js.map +0 -1
  565. package/dist/services/metrics/sender.mjs +0 -70
  566. package/dist/services/metrics/sender.mjs.map +0 -1
  567. package/dist/services/query-params.js +0 -12
  568. package/dist/services/query-params.js.map +0 -1
  569. package/dist/services/query-params.mjs +0 -13
  570. package/dist/services/query-params.mjs.map +0 -1
  571. package/dist/services/reloader.js +0 -36
  572. package/dist/services/reloader.js.map +0 -1
  573. package/dist/services/reloader.mjs +0 -36
  574. package/dist/services/reloader.mjs.map +0 -1
  575. package/dist/services/request-context.js +0 -13
  576. package/dist/services/request-context.js.map +0 -1
  577. package/dist/services/request-context.mjs +0 -14
  578. package/dist/services/request-context.mjs.map +0 -1
  579. package/dist/services/server/admin-api.js +0 -13
  580. package/dist/services/server/admin-api.js.map +0 -1
  581. package/dist/services/server/admin-api.mjs +0 -13
  582. package/dist/services/server/admin-api.mjs.map +0 -1
  583. package/dist/services/server/api.js +0 -30
  584. package/dist/services/server/api.js.map +0 -1
  585. package/dist/services/server/api.mjs +0 -28
  586. package/dist/services/server/api.mjs.map +0 -1
  587. package/dist/services/server/compose-endpoint.js +0 -117
  588. package/dist/services/server/compose-endpoint.js.map +0 -1
  589. package/dist/services/server/compose-endpoint.mjs +0 -116
  590. package/dist/services/server/compose-endpoint.mjs.map +0 -1
  591. package/dist/services/server/content-api.js +0 -12
  592. package/dist/services/server/content-api.js.map +0 -1
  593. package/dist/services/server/content-api.mjs +0 -12
  594. package/dist/services/server/content-api.mjs.map +0 -1
  595. package/dist/services/server/http-server.js +0 -50
  596. package/dist/services/server/http-server.js.map +0 -1
  597. package/dist/services/server/http-server.mjs +0 -48
  598. package/dist/services/server/http-server.mjs.map +0 -1
  599. package/dist/services/server/index.js +0 -87
  600. package/dist/services/server/index.js.map +0 -1
  601. package/dist/services/server/index.mjs +0 -85
  602. package/dist/services/server/index.mjs.map +0 -1
  603. package/dist/services/server/koa.js +0 -52
  604. package/dist/services/server/koa.js.map +0 -1
  605. package/dist/services/server/koa.mjs +0 -48
  606. package/dist/services/server/koa.mjs.map +0 -1
  607. package/dist/services/server/middleware.js +0 -92
  608. package/dist/services/server/middleware.js.map +0 -1
  609. package/dist/services/server/middleware.mjs +0 -90
  610. package/dist/services/server/middleware.mjs.map +0 -1
  611. package/dist/services/server/policy.js +0 -20
  612. package/dist/services/server/policy.js.map +0 -1
  613. package/dist/services/server/policy.mjs +0 -20
  614. package/dist/services/server/policy.mjs.map +0 -1
  615. package/dist/services/server/register-middlewares.js +0 -72
  616. package/dist/services/server/register-middlewares.js.map +0 -1
  617. package/dist/services/server/register-middlewares.mjs +0 -73
  618. package/dist/services/server/register-middlewares.mjs.map +0 -1
  619. package/dist/services/server/register-routes.js +0 -76
  620. package/dist/services/server/register-routes.js.map +0 -1
  621. package/dist/services/server/register-routes.mjs +0 -75
  622. package/dist/services/server/register-routes.mjs.map +0 -1
  623. package/dist/services/server/routing.js +0 -91
  624. package/dist/services/server/routing.js.map +0 -1
  625. package/dist/services/server/routing.mjs +0 -89
  626. package/dist/services/server/routing.mjs.map +0 -1
  627. package/dist/services/utils/dynamic-zones.js +0 -17
  628. package/dist/services/utils/dynamic-zones.js.map +0 -1
  629. package/dist/services/utils/dynamic-zones.mjs +0 -18
  630. package/dist/services/utils/dynamic-zones.mjs.map +0 -1
  631. package/dist/services/webhook-runner.js +0 -133
  632. package/dist/services/webhook-runner.js.map +0 -1
  633. package/dist/services/webhook-runner.mjs +0 -131
  634. package/dist/services/webhook-runner.mjs.map +0 -1
  635. package/dist/services/webhook-store.js +0 -110
  636. package/dist/services/webhook-store.js.map +0 -1
  637. package/dist/services/webhook-store.mjs +0 -110
  638. package/dist/services/webhook-store.mjs.map +0 -1
  639. package/dist/services/worker-queue.js +0 -56
  640. package/dist/services/worker-queue.js.map +0 -1
  641. package/dist/services/worker-queue.mjs +0 -55
  642. package/dist/services/worker-queue.mjs.map +0 -1
  643. package/dist/utils/convert-custom-field-type.js +0 -24
  644. package/dist/utils/convert-custom-field-type.js.map +0 -1
  645. package/dist/utils/convert-custom-field-type.mjs +0 -24
  646. package/dist/utils/convert-custom-field-type.mjs.map +0 -1
  647. package/dist/utils/cron.js +0 -38
  648. package/dist/utils/cron.js.map +0 -1
  649. package/dist/utils/cron.mjs +0 -38
  650. package/dist/utils/cron.mjs.map +0 -1
  651. package/dist/utils/fetch.js +0 -21
  652. package/dist/utils/fetch.js.map +0 -1
  653. package/dist/utils/fetch.mjs +0 -21
  654. package/dist/utils/fetch.mjs.map +0 -1
  655. package/dist/utils/filepath-to-prop-path.js +0 -33
  656. package/dist/utils/filepath-to-prop-path.js.map +0 -1
  657. package/dist/utils/filepath-to-prop-path.mjs +0 -30
  658. package/dist/utils/filepath-to-prop-path.mjs.map +0 -1
  659. package/dist/utils/is-initialized.js +0 -16
  660. package/dist/utils/is-initialized.js.map +0 -1
  661. package/dist/utils/is-initialized.mjs +0 -16
  662. package/dist/utils/is-initialized.mjs.map +0 -1
  663. package/dist/utils/lifecycles.js +0 -9
  664. package/dist/utils/lifecycles.js.map +0 -1
  665. package/dist/utils/lifecycles.mjs +0 -9
  666. package/dist/utils/lifecycles.mjs.map +0 -1
  667. package/dist/utils/load-config-file.js +0 -45
  668. package/dist/utils/load-config-file.js.map +0 -1
  669. package/dist/utils/load-config-file.mjs +0 -42
  670. package/dist/utils/load-config-file.mjs.map +0 -1
  671. package/dist/utils/load-files.js +0 -39
  672. package/dist/utils/load-files.js.map +0 -1
  673. package/dist/utils/load-files.mjs +0 -35
  674. package/dist/utils/load-files.mjs.map +0 -1
  675. package/dist/utils/open-browser.js +0 -11
  676. package/dist/utils/open-browser.js.map +0 -1
  677. package/dist/utils/open-browser.mjs +0 -9
  678. package/dist/utils/open-browser.mjs.map +0 -1
  679. package/dist/utils/resolve-working-dirs.js +0 -13
  680. package/dist/utils/resolve-working-dirs.js.map +0 -1
  681. package/dist/utils/resolve-working-dirs.mjs +0 -11
  682. package/dist/utils/resolve-working-dirs.mjs.map +0 -1
  683. package/dist/utils/signals.js +0 -17
  684. package/dist/utils/signals.js.map +0 -1
  685. package/dist/utils/signals.mjs +0 -17
  686. package/dist/utils/signals.mjs.map +0 -1
  687. package/dist/utils/startup-logger.js +0 -81
  688. package/dist/utils/startup-logger.js.map +0 -1
  689. package/dist/utils/startup-logger.mjs +0 -77
  690. package/dist/utils/startup-logger.mjs.map +0 -1
  691. package/dist/utils/transform-content-types-to-models.js +0 -288
  692. package/dist/utils/transform-content-types-to-models.js.map +0 -1
  693. package/dist/utils/transform-content-types-to-models.mjs +0 -285
  694. package/dist/utils/transform-content-types-to-models.mjs.map +0 -1
  695. package/dist/utils/update-notifier/index.js +0 -85
  696. package/dist/utils/update-notifier/index.js.map +0 -1
  697. package/dist/utils/update-notifier/index.mjs +0 -78
  698. package/dist/utils/update-notifier/index.mjs.map +0 -1
@@ -1,69 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const fp = require("lodash/fp");
4
- const strapiUtils = require("@strapi/utils");
5
- const setStatusToDraft = (contentType, params) => {
6
- if (!strapiUtils.contentTypes.hasDraftAndPublish(contentType) && params.status) {
7
- return params;
8
- }
9
- return fp.assoc("status", "draft", params);
10
- };
11
- const defaultToDraft = (params) => {
12
- if (!params.status || params.status !== "published") {
13
- return fp.assoc("status", "draft", params);
14
- }
15
- return params;
16
- };
17
- const defaultStatus = (contentType, params) => {
18
- if (!strapiUtils.contentTypes.hasDraftAndPublish(contentType)) {
19
- return params;
20
- }
21
- if (!params.status || params.status !== "published") {
22
- return defaultToDraft(params);
23
- }
24
- return params;
25
- };
26
- const filterDataPublishedAt = (params) => {
27
- if (params?.data?.publishedAt) {
28
- return fp.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 fp.assoc(["lookup", "publishedAt"], { $notNull: true }, params);
40
- case "draft":
41
- return fp.assoc(["lookup", "publishedAt"], { $null: true }, params);
42
- }
43
- return fp.assoc("lookup", lookup, params);
44
- };
45
- const statusToData = (contentType, params) => {
46
- if (!strapiUtils.contentTypes.hasDraftAndPublish(contentType)) {
47
- return fp.assoc(["data", "publishedAt"], /* @__PURE__ */ new Date(), params);
48
- }
49
- switch (params?.status) {
50
- case "published":
51
- return fp.assoc(["data", "publishedAt"], /* @__PURE__ */ new Date(), params);
52
- case "draft":
53
- return fp.assoc(["data", "publishedAt"], null, params);
54
- }
55
- return params;
56
- };
57
- const setStatusToDraftCurry = fp.curry(setStatusToDraft);
58
- const defaultToDraftCurry = fp.curry(defaultToDraft);
59
- const defaultStatusCurry = fp.curry(defaultStatus);
60
- const filterDataPublishedAtCurry = fp.curry(filterDataPublishedAt);
61
- const statusToLookupCurry = fp.curry(statusToLookup);
62
- const statusToDataCurry = fp.curry(statusToData);
63
- exports.defaultStatus = defaultStatusCurry;
64
- exports.defaultToDraft = defaultToDraftCurry;
65
- exports.filterDataPublishedAt = filterDataPublishedAtCurry;
66
- exports.setStatusToDraft = setStatusToDraftCurry;
67
- exports.statusToData = statusToDataCurry;
68
- exports.statusToLookup = statusToLookupCurry;
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,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;;;;;;;"}
@@ -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 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
@@ -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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"}
@@ -1,96 +0,0 @@
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
@@ -1 +0,0 @@
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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"}
@@ -1,47 +0,0 @@
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
@@ -1 +0,0 @@
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;;"}
@@ -1,47 +0,0 @@
1
- import { sanitize } from "@strapi/utils";
2
- import { getDeepPopulate } from "./utils/populate.mjs";
3
- const EVENTS = {
4
- ENTRY_CREATE: "entry.create",
5
- ENTRY_UPDATE: "entry.update",
6
- ENTRY_DELETE: "entry.delete",
7
- ENTRY_PUBLISH: "entry.publish",
8
- ENTRY_UNPUBLISH: "entry.unpublish",
9
- ENTRY_DRAFT_DISCARD: "entry.draft-discard"
10
- };
11
- const createEventManager = (strapi, uid) => {
12
- const populate = getDeepPopulate(uid, {});
13
- const model = strapi.getModel(uid);
14
- const emitEvent = async (eventName, entry) => {
15
- let populatedEntry = entry;
16
- if (![EVENTS.ENTRY_DELETE, EVENTS.ENTRY_UNPUBLISH].includes(eventName)) {
17
- populatedEntry = await strapi.db.query(uid).findOne({ where: { id: entry.id }, populate });
18
- }
19
- const sanitizedEntry = await sanitize.sanitizers.defaultSanitizeOutput(
20
- {
21
- schema: model,
22
- getModel: (uid2) => strapi.getModel(uid2)
23
- },
24
- populatedEntry
25
- );
26
- await strapi.eventHub.emit(eventName, {
27
- model: model.modelName,
28
- uid: model.uid,
29
- entry: sanitizedEntry
30
- });
31
- };
32
- return {
33
- /**
34
- * strapi.db.query might reuse the transaction used in the doc service request,
35
- * so this is executed after that transaction is committed.
36
- */
37
- emitEvent(eventName, entry) {
38
- strapi.db.transaction(({ onCommit }) => {
39
- onCommit(() => emitEvent(eventName, entry));
40
- });
41
- }
42
- };
43
- };
44
- export {
45
- createEventManager
46
- };
47
- //# sourceMappingURL=events.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"events.mjs","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":["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,QAAM,WAAW,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,GAAG,SAAU,CAAA;AAAA,IAC3F;AAEM,UAAA,iBAAiB,MAAM,SAAS,WAAW;AAAA,MAC/C;AAAA,QACE,QAAQ;AAAA,QACR,UAAU,CAACA,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;"}
@@ -1,35 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const errors = require("./middlewares/errors.js");
4
- const middlewareManager = require("./middlewares/middleware-manager.js");
5
- const repository = require("./repository.js");
6
- const data = require("./transform/data.js");
7
- const createDocumentService = (strapi) => {
8
- const repositories = /* @__PURE__ */ new Map();
9
- const middlewares = middlewareManager.createMiddlewareManager();
10
- middlewares.use(errors.databaseErrorsMiddleware);
11
- const factory = function factory2(uid) {
12
- if (repositories.has(uid)) {
13
- return repositories.get(uid);
14
- }
15
- const contentType = strapi.contentType(uid);
16
- const repository$1 = repository.createContentTypeRepository(uid);
17
- const instance = middlewares.wrapObject(
18
- repository$1,
19
- { uid, contentType },
20
- {
21
- exclude: ["updateComponents", "omitComponentData"]
22
- }
23
- );
24
- repositories.set(uid, instance);
25
- return instance;
26
- };
27
- return Object.assign(factory, {
28
- utils: {
29
- transformData: data.transformData
30
- },
31
- use: middlewares.use.bind(middlewares)
32
- });
33
- };
34
- exports.createDocumentService = createDocumentService;
35
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sources":["../../../src/services/document-service/index.ts"],"sourcesContent":["import type { Core, Modules, UID } from '@strapi/types';\n\nimport { createMiddlewareManager, databaseErrorsMiddleware } from './middlewares';\nimport { createContentTypeRepository } from './repository';\nimport { transformData } from './transform/data';\n\n/**\n * Repository to :\n * - Access documents via actions (findMany, findOne, create, update, delete, ...)\n * - Execute middlewares on document actions\n * - Apply default parameters to document actions\n *\n * @param strapi\n * @returns DocumentService\n *\n * @example Access documents\n * const article = strapi.documents('api::article.article').create(params)\n * const allArticles = strapi.documents('api::article.article').findMany(params)\n *\n */\nexport const createDocumentService = (strapi: Core.Strapi): Modules.Documents.Service => {\n // Cache the repositories (one per content type)\n const repositories = new Map<string, Modules.Documents.ServiceInstance>();\n\n // Manager to handle document service middlewares\n const middlewares = createMiddlewareManager();\n middlewares.use(databaseErrorsMiddleware);\n\n const factory = function factory(uid: UID.ContentType) {\n if (repositories.has(uid)) {\n return repositories.get(uid)!;\n }\n\n const contentType = strapi.contentType(uid);\n const repository = createContentTypeRepository(uid);\n\n const instance = middlewares.wrapObject(\n repository,\n { uid, contentType },\n {\n exclude: ['updateComponents', 'omitComponentData'],\n }\n );\n\n repositories.set(uid, instance);\n\n return instance;\n } as Modules.Documents.Service;\n\n return Object.assign(factory, {\n utils: {\n transformData,\n },\n use: middlewares.use.bind(middlewares),\n });\n};\n"],"names":["createMiddlewareManager","databaseErrorsMiddleware","factory","repository","createContentTypeRepository","transformData"],"mappings":";;;;;;AAoBa,MAAA,wBAAwB,CAAC,WAAmD;AAEjF,QAAA,mCAAmB;AAGzB,QAAM,cAAcA,kBAAAA;AACpB,cAAY,IAAIC,OAAAA,wBAAwB;AAElC,QAAA,UAAU,SAASC,SAAQ,KAAsB;AACjD,QAAA,aAAa,IAAI,GAAG,GAAG;AAClB,aAAA,aAAa,IAAI,GAAG;AAAA,IAC7B;AAEM,UAAA,cAAc,OAAO,YAAY,GAAG;AACpC,UAAAC,eAAaC,uCAA4B,GAAG;AAElD,UAAM,WAAW,YAAY;AAAA,MAC3BD;AAAAA,MACA,EAAE,KAAK,YAAY;AAAA,MACnB;AAAA,QACE,SAAS,CAAC,oBAAoB,mBAAmB;AAAA,MACnD;AAAA,IAAA;AAGW,iBAAA,IAAI,KAAK,QAAQ;AAEvB,WAAA;AAAA,EAAA;AAGF,SAAA,OAAO,OAAO,SAAS;AAAA,IAC5B,OAAO;AAAA,MAAA,eACLE,KAAA;AAAA,IACF;AAAA,IACA,KAAK,YAAY,IAAI,KAAK,WAAW;AAAA,EAAA,CACtC;AACH;;"}
@@ -1,35 +0,0 @@
1
- import { databaseErrorsMiddleware } from "./middlewares/errors.mjs";
2
- import { createMiddlewareManager } from "./middlewares/middleware-manager.mjs";
3
- import { createContentTypeRepository } from "./repository.mjs";
4
- import { transformData } from "./transform/data.mjs";
5
- const createDocumentService = (strapi) => {
6
- const repositories = /* @__PURE__ */ new Map();
7
- const middlewares = createMiddlewareManager();
8
- middlewares.use(databaseErrorsMiddleware);
9
- const factory = function factory2(uid) {
10
- if (repositories.has(uid)) {
11
- return repositories.get(uid);
12
- }
13
- const contentType = strapi.contentType(uid);
14
- const repository = createContentTypeRepository(uid);
15
- const instance = middlewares.wrapObject(
16
- repository,
17
- { uid, contentType },
18
- {
19
- exclude: ["updateComponents", "omitComponentData"]
20
- }
21
- );
22
- repositories.set(uid, instance);
23
- return instance;
24
- };
25
- return Object.assign(factory, {
26
- utils: {
27
- transformData
28
- },
29
- use: middlewares.use.bind(middlewares)
30
- });
31
- };
32
- export {
33
- createDocumentService
34
- };
35
- //# sourceMappingURL=index.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.mjs","sources":["../../../src/services/document-service/index.ts"],"sourcesContent":["import type { Core, Modules, UID } from '@strapi/types';\n\nimport { createMiddlewareManager, databaseErrorsMiddleware } from './middlewares';\nimport { createContentTypeRepository } from './repository';\nimport { transformData } from './transform/data';\n\n/**\n * Repository to :\n * - Access documents via actions (findMany, findOne, create, update, delete, ...)\n * - Execute middlewares on document actions\n * - Apply default parameters to document actions\n *\n * @param strapi\n * @returns DocumentService\n *\n * @example Access documents\n * const article = strapi.documents('api::article.article').create(params)\n * const allArticles = strapi.documents('api::article.article').findMany(params)\n *\n */\nexport const createDocumentService = (strapi: Core.Strapi): Modules.Documents.Service => {\n // Cache the repositories (one per content type)\n const repositories = new Map<string, Modules.Documents.ServiceInstance>();\n\n // Manager to handle document service middlewares\n const middlewares = createMiddlewareManager();\n middlewares.use(databaseErrorsMiddleware);\n\n const factory = function factory(uid: UID.ContentType) {\n if (repositories.has(uid)) {\n return repositories.get(uid)!;\n }\n\n const contentType = strapi.contentType(uid);\n const repository = createContentTypeRepository(uid);\n\n const instance = middlewares.wrapObject(\n repository,\n { uid, contentType },\n {\n exclude: ['updateComponents', 'omitComponentData'],\n }\n );\n\n repositories.set(uid, instance);\n\n return instance;\n } as Modules.Documents.Service;\n\n return Object.assign(factory, {\n utils: {\n transformData,\n },\n use: middlewares.use.bind(middlewares),\n });\n};\n"],"names":["factory"],"mappings":";;;;AAoBa,MAAA,wBAAwB,CAAC,WAAmD;AAEjF,QAAA,mCAAmB;AAGzB,QAAM,cAAc;AACpB,cAAY,IAAI,wBAAwB;AAElC,QAAA,UAAU,SAASA,SAAQ,KAAsB;AACjD,QAAA,aAAa,IAAI,GAAG,GAAG;AAClB,aAAA,aAAa,IAAI,GAAG;AAAA,IAC7B;AAEM,UAAA,cAAc,OAAO,YAAY,GAAG;AACpC,UAAA,aAAa,4BAA4B,GAAG;AAElD,UAAM,WAAW,YAAY;AAAA,MAC3B;AAAA,MACA,EAAE,KAAK,YAAY;AAAA,MACnB;AAAA,QACE,SAAS,CAAC,oBAAoB,mBAAmB;AAAA,MACnD;AAAA,IAAA;AAGW,iBAAA,IAAI,KAAK,QAAQ;AAEvB,WAAA;AAAA,EAAA;AAGF,SAAA,OAAO,OAAO,SAAS;AAAA,IAC5B,OAAO;AAAA,MACL;AAAA,IACF;AAAA,IACA,KAAK,YAAY,IAAI,KAAK,WAAW;AAAA,EAAA,CACtC;AACH;"}