@strapi/core 0.0.0-experimental.e9122b401c96877b6707775c4f893660eab93ae3 → 0.0.0-experimental.eb2d102c03f0984bece7258f6e0e8ab9ee39c82d

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 +1 -0
  3. package/dist/configuration/index.d.ts.map +1 -1
  4. package/dist/ee/index.d.ts.map +1 -1
  5. package/dist/ee/license.d.ts.map +1 -1
  6. package/dist/index.js +10105 -27
  7. package/dist/index.js.map +1 -1
  8. package/dist/index.mjs +10083 -29
  9. package/dist/index.mjs.map +1 -1
  10. package/dist/loaders/plugins/get-enabled-plugins.d.ts.map +1 -1
  11. package/dist/loaders/plugins/index.d.ts.map +1 -1
  12. package/dist/middlewares/body.d.ts.map +1 -1
  13. package/dist/migrations/database/5.0.0-discard-drafts.d.ts +14 -11
  14. package/dist/migrations/database/5.0.0-discard-drafts.d.ts.map +1 -1
  15. package/dist/migrations/draft-publish.d.ts +2 -2
  16. package/dist/migrations/draft-publish.d.ts.map +1 -1
  17. package/dist/migrations/i18n.d.ts +5 -0
  18. package/dist/migrations/i18n.d.ts.map +1 -0
  19. package/dist/migrations/index.d.ts +5 -0
  20. package/dist/migrations/index.d.ts.map +1 -0
  21. package/dist/providers/admin.d.ts.map +1 -1
  22. package/dist/services/document-service/common.d.ts +1 -1
  23. package/dist/services/document-service/common.d.ts.map +1 -1
  24. package/dist/services/document-service/components.d.ts.map +1 -1
  25. package/dist/services/document-service/draft-and-publish.d.ts +1 -1
  26. package/dist/services/document-service/draft-and-publish.d.ts.map +1 -1
  27. package/dist/services/document-service/entries.d.ts +2 -2
  28. package/dist/services/document-service/entries.d.ts.map +1 -1
  29. package/dist/services/document-service/events.d.ts +1 -1
  30. package/dist/services/document-service/events.d.ts.map +1 -1
  31. package/dist/services/document-service/index.d.ts +2 -1
  32. package/dist/services/document-service/index.d.ts.map +1 -1
  33. package/dist/services/document-service/repository.d.ts.map +1 -1
  34. package/dist/services/document-service/transform/id-map.d.ts +1 -1
  35. package/dist/services/document-service/transform/id-map.d.ts.map +1 -1
  36. package/dist/services/document-service/transform/id-transform.d.ts +1 -1
  37. package/dist/services/document-service/transform/id-transform.d.ts.map +1 -1
  38. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +1 -1
  39. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -1
  40. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts.map +1 -1
  41. package/dist/services/document-service/transform/relations/utils/dp.d.ts +1 -1
  42. package/dist/services/document-service/transform/relations/utils/dp.d.ts.map +1 -1
  43. package/dist/services/document-service/transform/relations/utils/i18n.d.ts +1 -1
  44. package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -1
  45. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts.map +1 -1
  46. package/dist/services/document-service/utils/bidirectional-relations.d.ts +95 -0
  47. package/dist/services/document-service/utils/bidirectional-relations.d.ts.map +1 -0
  48. package/dist/services/document-service/utils/populate.d.ts +1 -1
  49. package/dist/services/document-service/utils/populate.d.ts.map +1 -1
  50. package/dist/services/document-service/utils/unidirectional-relations.d.ts +36 -0
  51. package/dist/services/document-service/utils/unidirectional-relations.d.ts.map +1 -0
  52. package/dist/services/entity-validator/index.d.ts +1 -1
  53. package/dist/services/entity-validator/index.d.ts.map +1 -1
  54. package/dist/services/metrics/admin-user-hash.d.ts.map +1 -1
  55. package/dist/services/metrics/middleware.d.ts.map +1 -1
  56. package/dist/services/metrics/rate-limiter.d.ts.map +1 -1
  57. package/dist/services/metrics/sender.d.ts.map +1 -1
  58. package/dist/utils/startup-logger.d.ts.map +1 -1
  59. package/dist/utils/transform-content-types-to-models.d.ts +353 -21
  60. package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
  61. package/dist/utils/update-notifier/index.d.ts.map +1 -1
  62. package/package.json +28 -28
  63. package/dist/Strapi.js +0 -431
  64. package/dist/Strapi.js.map +0 -1
  65. package/dist/Strapi.mjs +0 -410
  66. package/dist/Strapi.mjs.map +0 -1
  67. package/dist/compile.js +0 -18
  68. package/dist/compile.js.map +0 -1
  69. package/dist/compile.mjs +0 -17
  70. package/dist/compile.mjs.map +0 -1
  71. package/dist/configuration/config-loader.js +0 -106
  72. package/dist/configuration/config-loader.js.map +0 -1
  73. package/dist/configuration/config-loader.mjs +0 -104
  74. package/dist/configuration/config-loader.mjs.map +0 -1
  75. package/dist/configuration/get-dirs.js +0 -31
  76. package/dist/configuration/get-dirs.js.map +0 -1
  77. package/dist/configuration/get-dirs.mjs +0 -31
  78. package/dist/configuration/get-dirs.mjs.map +0 -1
  79. package/dist/configuration/index.js +0 -80
  80. package/dist/configuration/index.js.map +0 -1
  81. package/dist/configuration/index.mjs +0 -75
  82. package/dist/configuration/index.mjs.map +0 -1
  83. package/dist/configuration/urls.js +0 -68
  84. package/dist/configuration/urls.js.map +0 -1
  85. package/dist/configuration/urls.mjs +0 -66
  86. package/dist/configuration/urls.mjs.map +0 -1
  87. package/dist/container.js +0 -30
  88. package/dist/container.js.map +0 -1
  89. package/dist/container.mjs +0 -30
  90. package/dist/container.mjs.map +0 -1
  91. package/dist/core-api/controller/collection-type.js +0 -84
  92. package/dist/core-api/controller/collection-type.js.map +0 -1
  93. package/dist/core-api/controller/collection-type.mjs +0 -84
  94. package/dist/core-api/controller/collection-type.mjs.map +0 -1
  95. package/dist/core-api/controller/index.js +0 -52
  96. package/dist/core-api/controller/index.js.map +0 -1
  97. package/dist/core-api/controller/index.mjs +0 -52
  98. package/dist/core-api/controller/index.mjs.map +0 -1
  99. package/dist/core-api/controller/single-type.js +0 -46
  100. package/dist/core-api/controller/single-type.js.map +0 -1
  101. package/dist/core-api/controller/single-type.mjs +0 -46
  102. package/dist/core-api/controller/single-type.mjs.map +0 -1
  103. package/dist/core-api/controller/transform.js +0 -76
  104. package/dist/core-api/controller/transform.js.map +0 -1
  105. package/dist/core-api/controller/transform.mjs +0 -76
  106. package/dist/core-api/controller/transform.mjs.map +0 -1
  107. package/dist/core-api/routes/index.js +0 -67
  108. package/dist/core-api/routes/index.js.map +0 -1
  109. package/dist/core-api/routes/index.mjs +0 -67
  110. package/dist/core-api/routes/index.mjs.map +0 -1
  111. package/dist/core-api/service/collection-type.js +0 -67
  112. package/dist/core-api/service/collection-type.js.map +0 -1
  113. package/dist/core-api/service/collection-type.mjs +0 -67
  114. package/dist/core-api/service/collection-type.mjs.map +0 -1
  115. package/dist/core-api/service/core-service.js +0 -12
  116. package/dist/core-api/service/core-service.js.map +0 -1
  117. package/dist/core-api/service/core-service.mjs +0 -12
  118. package/dist/core-api/service/core-service.mjs.map +0 -1
  119. package/dist/core-api/service/index.js +0 -16
  120. package/dist/core-api/service/index.js.map +0 -1
  121. package/dist/core-api/service/index.mjs +0 -16
  122. package/dist/core-api/service/index.mjs.map +0 -1
  123. package/dist/core-api/service/pagination.js +0 -52
  124. package/dist/core-api/service/pagination.js.map +0 -1
  125. package/dist/core-api/service/pagination.mjs +0 -52
  126. package/dist/core-api/service/pagination.mjs.map +0 -1
  127. package/dist/core-api/service/single-type.js +0 -46
  128. package/dist/core-api/service/single-type.js.map +0 -1
  129. package/dist/core-api/service/single-type.mjs +0 -46
  130. package/dist/core-api/service/single-type.mjs.map +0 -1
  131. package/dist/domain/content-type/index.js +0 -111
  132. package/dist/domain/content-type/index.js.map +0 -1
  133. package/dist/domain/content-type/index.mjs +0 -109
  134. package/dist/domain/content-type/index.mjs.map +0 -1
  135. package/dist/domain/content-type/validator.js +0 -77
  136. package/dist/domain/content-type/validator.js.map +0 -1
  137. package/dist/domain/content-type/validator.mjs +0 -75
  138. package/dist/domain/content-type/validator.mjs.map +0 -1
  139. package/dist/domain/module/index.js +0 -107
  140. package/dist/domain/module/index.js.map +0 -1
  141. package/dist/domain/module/index.mjs +0 -105
  142. package/dist/domain/module/index.mjs.map +0 -1
  143. package/dist/domain/module/validation.js +0 -25
  144. package/dist/domain/module/validation.js.map +0 -1
  145. package/dist/domain/module/validation.mjs +0 -25
  146. package/dist/domain/module/validation.mjs.map +0 -1
  147. package/dist/ee/index.js +0 -153
  148. package/dist/ee/index.js.map +0 -1
  149. package/dist/ee/index.mjs +0 -154
  150. package/dist/ee/index.mjs.map +0 -1
  151. package/dist/ee/license.js +0 -91
  152. package/dist/ee/license.js.map +0 -1
  153. package/dist/ee/license.mjs +0 -88
  154. package/dist/ee/license.mjs.map +0 -1
  155. package/dist/factories.js +0 -80
  156. package/dist/factories.js.map +0 -1
  157. package/dist/factories.mjs +0 -80
  158. package/dist/factories.mjs.map +0 -1
  159. package/dist/loaders/admin.js +0 -26
  160. package/dist/loaders/admin.js.map +0 -1
  161. package/dist/loaders/admin.mjs +0 -25
  162. package/dist/loaders/admin.mjs.map +0 -1
  163. package/dist/loaders/apis.js +0 -137
  164. package/dist/loaders/apis.js.map +0 -1
  165. package/dist/loaders/apis.mjs +0 -135
  166. package/dist/loaders/apis.mjs.map +0 -1
  167. package/dist/loaders/components.js +0 -38
  168. package/dist/loaders/components.js.map +0 -1
  169. package/dist/loaders/components.mjs +0 -37
  170. package/dist/loaders/components.mjs.map +0 -1
  171. package/dist/loaders/index.js +0 -24
  172. package/dist/loaders/index.js.map +0 -1
  173. package/dist/loaders/index.mjs +0 -24
  174. package/dist/loaders/index.mjs.map +0 -1
  175. package/dist/loaders/middlewares.js +0 -31
  176. package/dist/loaders/middlewares.js.map +0 -1
  177. package/dist/loaders/middlewares.mjs +0 -30
  178. package/dist/loaders/middlewares.mjs.map +0 -1
  179. package/dist/loaders/plugins/get-enabled-plugins.js +0 -138
  180. package/dist/loaders/plugins/get-enabled-plugins.js.map +0 -1
  181. package/dist/loaders/plugins/get-enabled-plugins.mjs +0 -114
  182. package/dist/loaders/plugins/get-enabled-plugins.mjs.map +0 -1
  183. package/dist/loaders/plugins/get-user-plugins-config.js +0 -27
  184. package/dist/loaders/plugins/get-user-plugins-config.js.map +0 -1
  185. package/dist/loaders/plugins/get-user-plugins-config.mjs +0 -25
  186. package/dist/loaders/plugins/get-user-plugins-config.mjs.map +0 -1
  187. package/dist/loaders/plugins/index.js +0 -118
  188. package/dist/loaders/plugins/index.js.map +0 -1
  189. package/dist/loaders/plugins/index.mjs +0 -117
  190. package/dist/loaders/plugins/index.mjs.map +0 -1
  191. package/dist/loaders/policies.js +0 -25
  192. package/dist/loaders/policies.js.map +0 -1
  193. package/dist/loaders/policies.mjs +0 -24
  194. package/dist/loaders/policies.mjs.map +0 -1
  195. package/dist/loaders/sanitizers.js +0 -6
  196. package/dist/loaders/sanitizers.js.map +0 -1
  197. package/dist/loaders/sanitizers.mjs +0 -7
  198. package/dist/loaders/sanitizers.mjs.map +0 -1
  199. package/dist/loaders/src-index.js +0 -33
  200. package/dist/loaders/src-index.js.map +0 -1
  201. package/dist/loaders/src-index.mjs +0 -34
  202. package/dist/loaders/src-index.mjs.map +0 -1
  203. package/dist/loaders/validators.js +0 -6
  204. package/dist/loaders/validators.js.map +0 -1
  205. package/dist/loaders/validators.mjs +0 -7
  206. package/dist/loaders/validators.mjs.map +0 -1
  207. package/dist/middlewares/body.js +0 -65
  208. package/dist/middlewares/body.js.map +0 -1
  209. package/dist/middlewares/body.mjs +0 -61
  210. package/dist/middlewares/body.mjs.map +0 -1
  211. package/dist/middlewares/compression.js +0 -8
  212. package/dist/middlewares/compression.js.map +0 -1
  213. package/dist/middlewares/compression.mjs +0 -6
  214. package/dist/middlewares/compression.mjs.map +0 -1
  215. package/dist/middlewares/cors.js +0 -53
  216. package/dist/middlewares/cors.js.map +0 -1
  217. package/dist/middlewares/cors.mjs +0 -51
  218. package/dist/middlewares/cors.mjs.map +0 -1
  219. package/dist/middlewares/errors.js +0 -33
  220. package/dist/middlewares/errors.js.map +0 -1
  221. package/dist/middlewares/errors.mjs +0 -33
  222. package/dist/middlewares/errors.mjs.map +0 -1
  223. package/dist/middlewares/favicon.js +0 -22
  224. package/dist/middlewares/favicon.js.map +0 -1
  225. package/dist/middlewares/favicon.mjs +0 -20
  226. package/dist/middlewares/favicon.mjs.map +0 -1
  227. package/dist/middlewares/index.js +0 -34
  228. package/dist/middlewares/index.js.map +0 -1
  229. package/dist/middlewares/index.mjs +0 -34
  230. package/dist/middlewares/index.mjs.map +0 -1
  231. package/dist/middlewares/ip.js +0 -8
  232. package/dist/middlewares/ip.js.map +0 -1
  233. package/dist/middlewares/ip.mjs +0 -6
  234. package/dist/middlewares/ip.mjs.map +0 -1
  235. package/dist/middlewares/logger.js +0 -12
  236. package/dist/middlewares/logger.js.map +0 -1
  237. package/dist/middlewares/logger.mjs +0 -12
  238. package/dist/middlewares/logger.mjs.map +0 -1
  239. package/dist/middlewares/powered-by.js +0 -14
  240. package/dist/middlewares/powered-by.js.map +0 -1
  241. package/dist/middlewares/powered-by.mjs +0 -14
  242. package/dist/middlewares/powered-by.mjs.map +0 -1
  243. package/dist/middlewares/public.js +0 -34
  244. package/dist/middlewares/public.js.map +0 -1
  245. package/dist/middlewares/public.mjs +0 -32
  246. package/dist/middlewares/public.mjs.map +0 -1
  247. package/dist/middlewares/query.js +0 -40
  248. package/dist/middlewares/query.js.map +0 -1
  249. package/dist/middlewares/query.mjs +0 -38
  250. package/dist/middlewares/query.mjs.map +0 -1
  251. package/dist/middlewares/response-time.js +0 -12
  252. package/dist/middlewares/response-time.js.map +0 -1
  253. package/dist/middlewares/response-time.mjs +0 -12
  254. package/dist/middlewares/response-time.mjs.map +0 -1
  255. package/dist/middlewares/responses.js +0 -15
  256. package/dist/middlewares/responses.js.map +0 -1
  257. package/dist/middlewares/responses.mjs +0 -15
  258. package/dist/middlewares/responses.mjs.map +0 -1
  259. package/dist/middlewares/security.js +0 -78
  260. package/dist/middlewares/security.js.map +0 -1
  261. package/dist/middlewares/security.mjs +0 -76
  262. package/dist/middlewares/security.mjs.map +0 -1
  263. package/dist/middlewares/session.js +0 -30
  264. package/dist/middlewares/session.js.map +0 -1
  265. package/dist/middlewares/session.mjs +0 -28
  266. package/dist/middlewares/session.mjs.map +0 -1
  267. package/dist/migrations/database/5.0.0-discard-drafts.js +0 -50
  268. package/dist/migrations/database/5.0.0-discard-drafts.js.map +0 -1
  269. package/dist/migrations/database/5.0.0-discard-drafts.mjs +0 -50
  270. package/dist/migrations/database/5.0.0-discard-drafts.mjs.map +0 -1
  271. package/dist/migrations/draft-publish.js +0 -42
  272. package/dist/migrations/draft-publish.js.map +0 -1
  273. package/dist/migrations/draft-publish.mjs +0 -42
  274. package/dist/migrations/draft-publish.mjs.map +0 -1
  275. package/dist/providers/admin.js +0 -20
  276. package/dist/providers/admin.js.map +0 -1
  277. package/dist/providers/admin.mjs +0 -21
  278. package/dist/providers/admin.mjs.map +0 -1
  279. package/dist/providers/coreStore.js +0 -11
  280. package/dist/providers/coreStore.js.map +0 -1
  281. package/dist/providers/coreStore.mjs +0 -12
  282. package/dist/providers/coreStore.mjs.map +0 -1
  283. package/dist/providers/cron.js +0 -20
  284. package/dist/providers/cron.js.map +0 -1
  285. package/dist/providers/cron.mjs +0 -21
  286. package/dist/providers/cron.mjs.map +0 -1
  287. package/dist/providers/index.js +0 -11
  288. package/dist/providers/index.js.map +0 -1
  289. package/dist/providers/index.mjs +0 -11
  290. package/dist/providers/index.mjs.map +0 -1
  291. package/dist/providers/provider.js +0 -5
  292. package/dist/providers/provider.js.map +0 -1
  293. package/dist/providers/provider.mjs +0 -5
  294. package/dist/providers/provider.mjs.map +0 -1
  295. package/dist/providers/registries.js +0 -35
  296. package/dist/providers/registries.js.map +0 -1
  297. package/dist/providers/registries.mjs +0 -36
  298. package/dist/providers/registries.mjs.map +0 -1
  299. package/dist/providers/telemetry.js +0 -19
  300. package/dist/providers/telemetry.js.map +0 -1
  301. package/dist/providers/telemetry.mjs +0 -20
  302. package/dist/providers/telemetry.mjs.map +0 -1
  303. package/dist/providers/webhooks.js +0 -30
  304. package/dist/providers/webhooks.js.map +0 -1
  305. package/dist/providers/webhooks.mjs +0 -31
  306. package/dist/providers/webhooks.mjs.map +0 -1
  307. package/dist/registries/apis.js +0 -23
  308. package/dist/registries/apis.js.map +0 -1
  309. package/dist/registries/apis.mjs +0 -24
  310. package/dist/registries/apis.mjs.map +0 -1
  311. package/dist/registries/components.js +0 -45
  312. package/dist/registries/components.js.map +0 -1
  313. package/dist/registries/components.mjs +0 -46
  314. package/dist/registries/components.mjs.map +0 -1
  315. package/dist/registries/content-types.js +0 -70
  316. package/dist/registries/content-types.js.map +0 -1
  317. package/dist/registries/content-types.mjs +0 -71
  318. package/dist/registries/content-types.mjs.map +0 -1
  319. package/dist/registries/controllers.js +0 -80
  320. package/dist/registries/controllers.js.map +0 -1
  321. package/dist/registries/controllers.mjs +0 -81
  322. package/dist/registries/controllers.mjs.map +0 -1
  323. package/dist/registries/custom-fields.js +0 -71
  324. package/dist/registries/custom-fields.js.map +0 -1
  325. package/dist/registries/custom-fields.mjs +0 -72
  326. package/dist/registries/custom-fields.mjs.map +0 -1
  327. package/dist/registries/hooks.js +0 -58
  328. package/dist/registries/hooks.js.map +0 -1
  329. package/dist/registries/hooks.mjs +0 -59
  330. package/dist/registries/hooks.mjs.map +0 -1
  331. package/dist/registries/middlewares.js +0 -60
  332. package/dist/registries/middlewares.js.map +0 -1
  333. package/dist/registries/middlewares.mjs +0 -61
  334. package/dist/registries/middlewares.mjs.map +0 -1
  335. package/dist/registries/models.js +0 -16
  336. package/dist/registries/models.js.map +0 -1
  337. package/dist/registries/models.mjs +0 -16
  338. package/dist/registries/models.mjs.map +0 -1
  339. package/dist/registries/modules.js +0 -39
  340. package/dist/registries/modules.js.map +0 -1
  341. package/dist/registries/modules.mjs +0 -40
  342. package/dist/registries/modules.mjs.map +0 -1
  343. package/dist/registries/namespace.js +0 -27
  344. package/dist/registries/namespace.js.map +0 -1
  345. package/dist/registries/namespace.mjs +0 -27
  346. package/dist/registries/namespace.mjs.map +0 -1
  347. package/dist/registries/plugins.js +0 -23
  348. package/dist/registries/plugins.js.map +0 -1
  349. package/dist/registries/plugins.mjs +0 -24
  350. package/dist/registries/plugins.mjs.map +0 -1
  351. package/dist/registries/policies.js +0 -108
  352. package/dist/registries/policies.js.map +0 -1
  353. package/dist/registries/policies.mjs +0 -109
  354. package/dist/registries/policies.mjs.map +0 -1
  355. package/dist/registries/sanitizers.js +0 -25
  356. package/dist/registries/sanitizers.js.map +0 -1
  357. package/dist/registries/sanitizers.mjs +0 -24
  358. package/dist/registries/sanitizers.mjs.map +0 -1
  359. package/dist/registries/services.js +0 -80
  360. package/dist/registries/services.js.map +0 -1
  361. package/dist/registries/services.mjs +0 -81
  362. package/dist/registries/services.mjs.map +0 -1
  363. package/dist/registries/validators.js +0 -25
  364. package/dist/registries/validators.js.map +0 -1
  365. package/dist/registries/validators.mjs +0 -24
  366. package/dist/registries/validators.mjs.map +0 -1
  367. package/dist/services/auth/index.js +0 -81
  368. package/dist/services/auth/index.js.map +0 -1
  369. package/dist/services/auth/index.mjs +0 -80
  370. package/dist/services/auth/index.mjs.map +0 -1
  371. package/dist/services/config.js +0 -47
  372. package/dist/services/config.js.map +0 -1
  373. package/dist/services/config.mjs +0 -47
  374. package/dist/services/config.mjs.map +0 -1
  375. package/dist/services/content-api/index.js +0 -85
  376. package/dist/services/content-api/index.js.map +0 -1
  377. package/dist/services/content-api/index.mjs +0 -84
  378. package/dist/services/content-api/index.mjs.map +0 -1
  379. package/dist/services/content-api/permissions/engine.js +0 -7
  380. package/dist/services/content-api/permissions/engine.js.map +0 -1
  381. package/dist/services/content-api/permissions/engine.mjs +0 -6
  382. package/dist/services/content-api/permissions/engine.mjs.map +0 -1
  383. package/dist/services/content-api/permissions/index.js +0 -87
  384. package/dist/services/content-api/permissions/index.js.map +0 -1
  385. package/dist/services/content-api/permissions/index.mjs +0 -86
  386. package/dist/services/content-api/permissions/index.mjs.map +0 -1
  387. package/dist/services/content-api/permissions/providers/action.js +0 -16
  388. package/dist/services/content-api/permissions/providers/action.js.map +0 -1
  389. package/dist/services/content-api/permissions/providers/action.mjs +0 -17
  390. package/dist/services/content-api/permissions/providers/action.mjs.map +0 -1
  391. package/dist/services/content-api/permissions/providers/condition.js +0 -16
  392. package/dist/services/content-api/permissions/providers/condition.js.map +0 -1
  393. package/dist/services/content-api/permissions/providers/condition.mjs +0 -17
  394. package/dist/services/content-api/permissions/providers/condition.mjs.map +0 -1
  395. package/dist/services/core-store.js +0 -107
  396. package/dist/services/core-store.js.map +0 -1
  397. package/dist/services/core-store.mjs +0 -107
  398. package/dist/services/core-store.mjs.map +0 -1
  399. package/dist/services/cron.js +0 -63
  400. package/dist/services/cron.js.map +0 -1
  401. package/dist/services/cron.mjs +0 -64
  402. package/dist/services/cron.mjs.map +0 -1
  403. package/dist/services/custom-fields.js +0 -10
  404. package/dist/services/custom-fields.js.map +0 -1
  405. package/dist/services/custom-fields.mjs +0 -11
  406. package/dist/services/custom-fields.mjs.map +0 -1
  407. package/dist/services/document-service/attributes/index.js +0 -22
  408. package/dist/services/document-service/attributes/index.js.map +0 -1
  409. package/dist/services/document-service/attributes/index.mjs +0 -22
  410. package/dist/services/document-service/attributes/index.mjs.map +0 -1
  411. package/dist/services/document-service/attributes/transforms.js +0 -20
  412. package/dist/services/document-service/attributes/transforms.js.map +0 -1
  413. package/dist/services/document-service/attributes/transforms.mjs +0 -19
  414. package/dist/services/document-service/attributes/transforms.mjs.map +0 -1
  415. package/dist/services/document-service/common.js +0 -7
  416. package/dist/services/document-service/common.js.map +0 -1
  417. package/dist/services/document-service/common.mjs +0 -7
  418. package/dist/services/document-service/common.mjs.map +0 -1
  419. package/dist/services/document-service/components.js +0 -288
  420. package/dist/services/document-service/components.js.map +0 -1
  421. package/dist/services/document-service/components.mjs +0 -286
  422. package/dist/services/document-service/components.mjs.map +0 -1
  423. package/dist/services/document-service/draft-and-publish.js +0 -69
  424. package/dist/services/document-service/draft-and-publish.js.map +0 -1
  425. package/dist/services/document-service/draft-and-publish.mjs +0 -69
  426. package/dist/services/document-service/draft-and-publish.mjs.map +0 -1
  427. package/dist/services/document-service/entries.js +0 -96
  428. package/dist/services/document-service/entries.js.map +0 -1
  429. package/dist/services/document-service/entries.mjs +0 -96
  430. package/dist/services/document-service/entries.mjs.map +0 -1
  431. package/dist/services/document-service/events.js +0 -47
  432. package/dist/services/document-service/events.js.map +0 -1
  433. package/dist/services/document-service/events.mjs +0 -47
  434. package/dist/services/document-service/events.mjs.map +0 -1
  435. package/dist/services/document-service/index.js +0 -35
  436. package/dist/services/document-service/index.js.map +0 -1
  437. package/dist/services/document-service/index.mjs +0 -35
  438. package/dist/services/document-service/index.mjs.map +0 -1
  439. package/dist/services/document-service/internationalization.js +0 -63
  440. package/dist/services/document-service/internationalization.js.map +0 -1
  441. package/dist/services/document-service/internationalization.mjs +0 -63
  442. package/dist/services/document-service/internationalization.mjs.map +0 -1
  443. package/dist/services/document-service/middlewares/errors.js +0 -25
  444. package/dist/services/document-service/middlewares/errors.js.map +0 -1
  445. package/dist/services/document-service/middlewares/errors.mjs +0 -25
  446. package/dist/services/document-service/middlewares/errors.mjs.map +0 -1
  447. package/dist/services/document-service/middlewares/middleware-manager.js +0 -49
  448. package/dist/services/document-service/middlewares/middleware-manager.js.map +0 -1
  449. package/dist/services/document-service/middlewares/middleware-manager.mjs +0 -49
  450. package/dist/services/document-service/middlewares/middleware-manager.mjs.map +0 -1
  451. package/dist/services/document-service/params.js +0 -8
  452. package/dist/services/document-service/params.js.map +0 -1
  453. package/dist/services/document-service/params.mjs +0 -8
  454. package/dist/services/document-service/params.mjs.map +0 -1
  455. package/dist/services/document-service/repository.js +0 -309
  456. package/dist/services/document-service/repository.js.map +0 -1
  457. package/dist/services/document-service/repository.mjs +0 -309
  458. package/dist/services/document-service/repository.mjs.map +0 -1
  459. package/dist/services/document-service/transform/data.js +0 -15
  460. package/dist/services/document-service/transform/data.js.map +0 -1
  461. package/dist/services/document-service/transform/data.mjs +0 -15
  462. package/dist/services/document-service/transform/data.mjs.map +0 -1
  463. package/dist/services/document-service/transform/fields.js +0 -24
  464. package/dist/services/document-service/transform/fields.js.map +0 -1
  465. package/dist/services/document-service/transform/fields.mjs +0 -24
  466. package/dist/services/document-service/transform/fields.mjs.map +0 -1
  467. package/dist/services/document-service/transform/id-map.js +0 -78
  468. package/dist/services/document-service/transform/id-map.js.map +0 -1
  469. package/dist/services/document-service/transform/id-map.mjs +0 -78
  470. package/dist/services/document-service/transform/id-map.mjs.map +0 -1
  471. package/dist/services/document-service/transform/id-transform.js +0 -33
  472. package/dist/services/document-service/transform/id-transform.js.map +0 -1
  473. package/dist/services/document-service/transform/id-transform.mjs +0 -33
  474. package/dist/services/document-service/transform/id-transform.mjs.map +0 -1
  475. package/dist/services/document-service/transform/populate.js +0 -21
  476. package/dist/services/document-service/transform/populate.js.map +0 -1
  477. package/dist/services/document-service/transform/populate.mjs +0 -21
  478. package/dist/services/document-service/transform/populate.mjs.map +0 -1
  479. package/dist/services/document-service/transform/query.js +0 -9
  480. package/dist/services/document-service/transform/query.js.map +0 -1
  481. package/dist/services/document-service/transform/query.mjs +0 -9
  482. package/dist/services/document-service/transform/query.mjs.map +0 -1
  483. package/dist/services/document-service/transform/relations/extract/data-ids.js +0 -57
  484. package/dist/services/document-service/transform/relations/extract/data-ids.js.map +0 -1
  485. package/dist/services/document-service/transform/relations/extract/data-ids.mjs +0 -57
  486. package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +0 -1
  487. package/dist/services/document-service/transform/relations/transform/data-ids.js +0 -76
  488. package/dist/services/document-service/transform/relations/transform/data-ids.js.map +0 -1
  489. package/dist/services/document-service/transform/relations/transform/data-ids.mjs +0 -76
  490. package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +0 -1
  491. package/dist/services/document-service/transform/relations/transform/default-locale.js +0 -32
  492. package/dist/services/document-service/transform/relations/transform/default-locale.js.map +0 -1
  493. package/dist/services/document-service/transform/relations/transform/default-locale.mjs +0 -32
  494. package/dist/services/document-service/transform/relations/transform/default-locale.mjs.map +0 -1
  495. package/dist/services/document-service/transform/relations/utils/dp.js +0 -30
  496. package/dist/services/document-service/transform/relations/utils/dp.js.map +0 -1
  497. package/dist/services/document-service/transform/relations/utils/dp.mjs +0 -30
  498. package/dist/services/document-service/transform/relations/utils/dp.mjs.map +0 -1
  499. package/dist/services/document-service/transform/relations/utils/i18n.js +0 -25
  500. package/dist/services/document-service/transform/relations/utils/i18n.js.map +0 -1
  501. package/dist/services/document-service/transform/relations/utils/i18n.mjs +0 -25
  502. package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +0 -1
  503. package/dist/services/document-service/transform/relations/utils/map-relation.js +0 -91
  504. package/dist/services/document-service/transform/relations/utils/map-relation.js.map +0 -1
  505. package/dist/services/document-service/transform/relations/utils/map-relation.mjs +0 -91
  506. package/dist/services/document-service/transform/relations/utils/map-relation.mjs.map +0 -1
  507. package/dist/services/document-service/utils/populate.js +0 -45
  508. package/dist/services/document-service/utils/populate.js.map +0 -1
  509. package/dist/services/document-service/utils/populate.mjs +0 -45
  510. package/dist/services/document-service/utils/populate.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 -385
  520. package/dist/services/entity-validator/index.js.map +0 -1
  521. package/dist/services/entity-validator/index.mjs +0 -384
  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 +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;"}
@@ -1,63 +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 getDefaultLocale = async () => {
6
- return strapi.plugin("i18n").service("locales").getDefaultLocale();
7
- };
8
- const defaultLocale = async (contentType, params) => {
9
- if (!strapi.plugin("i18n").service("content-types").isLocalizedContentType(contentType)) {
10
- return params;
11
- }
12
- if (!params.locale) {
13
- return fp.assoc("locale", await getDefaultLocale(), params);
14
- }
15
- return params;
16
- };
17
- const localeToLookup = (contentType, params) => {
18
- if (!params.locale || !strapi.plugin("i18n").service("content-types").isLocalizedContentType(contentType)) {
19
- return params;
20
- }
21
- if (typeof params.locale !== "string") {
22
- throw new strapiUtils.errors.ValidationError(
23
- `Invalid locale param ${String(params.locale)} provided. Document locales must be strings.`
24
- );
25
- }
26
- return fp.assoc(["lookup", "locale"], params.locale, params);
27
- };
28
- const multiLocaleToLookup = (contentType, params) => {
29
- if (!strapi.plugin("i18n").service("content-types").isLocalizedContentType(contentType)) {
30
- return params;
31
- }
32
- if (params.locale) {
33
- if (params.locale === "*") {
34
- return params;
35
- }
36
- return fp.assoc(["lookup", "locale"], params.locale, params);
37
- }
38
- return params;
39
- };
40
- const localeToData = (contentType, params) => {
41
- if (!strapi.plugin("i18n").service("content-types").isLocalizedContentType(contentType)) {
42
- return params;
43
- }
44
- if (params.locale) {
45
- const isValidLocale = typeof params.locale === "string" && params.locale !== "*";
46
- if (isValidLocale) {
47
- return fp.assoc(["data", "locale"], params.locale, params);
48
- }
49
- throw new strapiUtils.errors.ValidationError(
50
- `Invalid locale param ${params.locale} provided. Document locales must be strings.`
51
- );
52
- }
53
- return params;
54
- };
55
- const defaultLocaleCurry = fp.curry(defaultLocale);
56
- const localeToLookupCurry = fp.curry(localeToLookup);
57
- const multiLocaleToLookupCurry = fp.curry(multiLocaleToLookup);
58
- const localeToDataCurry = fp.curry(localeToData);
59
- exports.defaultLocale = defaultLocaleCurry;
60
- exports.localeToData = localeToDataCurry;
61
- exports.localeToLookup = localeToLookupCurry;
62
- exports.multiLocaleToLookup = multiLocaleToLookupCurry;
63
- //# sourceMappingURL=internationalization.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"internationalization.js","sources":["../../../src/services/document-service/internationalization.ts"],"sourcesContent":["import type { Struct, Modules } from '@strapi/types';\nimport { errors } from '@strapi/utils';\nimport { curry, assoc } from 'lodash/fp';\n\ntype Transform = (\n contentType: Struct.SingleTypeSchema | Struct.CollectionTypeSchema,\n params: Modules.Documents.Params.All\n) => Modules.Documents.Params.All;\n\ntype AsyncTransform = (\n contentType: Struct.SingleTypeSchema | Struct.CollectionTypeSchema,\n params: Modules.Documents.Params.All\n) => Promise<Modules.Documents.Params.All>;\n\nconst getDefaultLocale = async (): Promise<string> => {\n return strapi.plugin('i18n').service('locales').getDefaultLocale();\n};\n\nconst defaultLocale: AsyncTransform = async (contentType, params) => {\n if (!strapi.plugin('i18n').service('content-types').isLocalizedContentType(contentType)) {\n return params;\n }\n\n if (!params.locale) {\n return assoc('locale', await getDefaultLocale(), params);\n }\n\n return params;\n};\n\n/**\n * Add locale lookup query to the params\n */\nconst localeToLookup: Transform = (contentType, params) => {\n if (\n !params.locale ||\n !strapi.plugin('i18n').service('content-types').isLocalizedContentType(contentType)\n ) {\n return params;\n }\n\n if (typeof params.locale !== 'string') {\n // localeToLookup accepts locales of '*'. This is because the document\n // service functions that use this transform work with the '*' locale\n // to return all locales.\n throw new errors.ValidationError(\n `Invalid locale param ${String(params.locale)} provided. Document locales must be strings.`\n );\n }\n\n return assoc(['lookup', 'locale'], params.locale, params);\n};\n\n/**\n * Add locale lookup query to the params\n */\nconst multiLocaleToLookup: Transform = (contentType, params) => {\n if (!strapi.plugin('i18n').service('content-types').isLocalizedContentType(contentType)) {\n return params;\n }\n\n if (params.locale) {\n if (params.locale === '*') {\n return params;\n }\n\n return assoc(['lookup', 'locale'], params.locale, params);\n }\n\n return params;\n};\n\n/**\n * Translate locale status parameter into the data that will be saved\n */\nconst localeToData: Transform = (contentType, params) => {\n if (!strapi.plugin('i18n').service('content-types').isLocalizedContentType(contentType)) {\n return params;\n }\n\n if (params.locale) {\n const isValidLocale = typeof params.locale === 'string' && params.locale !== '*';\n if (isValidLocale) {\n return assoc(['data', 'locale'], params.locale, params);\n }\n\n throw new errors.ValidationError(\n `Invalid locale param ${params.locale} provided. Document locales must be strings.`\n );\n }\n\n return params;\n};\n\nconst defaultLocaleCurry = curry(defaultLocale);\nconst localeToLookupCurry = curry(localeToLookup);\nconst multiLocaleToLookupCurry = curry(multiLocaleToLookup);\nconst localeToDataCurry = curry(localeToData);\n\nexport {\n defaultLocaleCurry as defaultLocale,\n localeToLookupCurry as localeToLookup,\n localeToDataCurry as localeToData,\n multiLocaleToLookupCurry as multiLocaleToLookup,\n};\n"],"names":["assoc","errors","curry"],"mappings":";;;;AAcA,MAAM,mBAAmB,YAA6B;AACpD,SAAO,OAAO,OAAO,MAAM,EAAE,QAAQ,SAAS,EAAE;AAClD;AAEA,MAAM,gBAAgC,OAAO,aAAa,WAAW;AAC/D,MAAA,CAAC,OAAO,OAAO,MAAM,EAAE,QAAQ,eAAe,EAAE,uBAAuB,WAAW,GAAG;AAChF,WAAA;AAAA,EACT;AAEI,MAAA,CAAC,OAAO,QAAQ;AAClB,WAAOA,GAAM,MAAA,UAAU,MAAM,oBAAoB,MAAM;AAAA,EACzD;AAEO,SAAA;AACT;AAKA,MAAM,iBAA4B,CAAC,aAAa,WAAW;AACzD,MACE,CAAC,OAAO,UACR,CAAC,OAAO,OAAO,MAAM,EAAE,QAAQ,eAAe,EAAE,uBAAuB,WAAW,GAClF;AACO,WAAA;AAAA,EACT;AAEI,MAAA,OAAO,OAAO,WAAW,UAAU;AAIrC,UAAM,IAAIC,YAAO,OAAA;AAAA,MACf,wBAAwB,OAAO,OAAO,MAAM,CAAC;AAAA,IAAA;AAAA,EAEjD;AAEA,SAAOD,GAAAA,MAAM,CAAC,UAAU,QAAQ,GAAG,OAAO,QAAQ,MAAM;AAC1D;AAKA,MAAM,sBAAiC,CAAC,aAAa,WAAW;AAC1D,MAAA,CAAC,OAAO,OAAO,MAAM,EAAE,QAAQ,eAAe,EAAE,uBAAuB,WAAW,GAAG;AAChF,WAAA;AAAA,EACT;AAEA,MAAI,OAAO,QAAQ;AACb,QAAA,OAAO,WAAW,KAAK;AAClB,aAAA;AAAA,IACT;AAEA,WAAOA,GAAAA,MAAM,CAAC,UAAU,QAAQ,GAAG,OAAO,QAAQ,MAAM;AAAA,EAC1D;AAEO,SAAA;AACT;AAKA,MAAM,eAA0B,CAAC,aAAa,WAAW;AACnD,MAAA,CAAC,OAAO,OAAO,MAAM,EAAE,QAAQ,eAAe,EAAE,uBAAuB,WAAW,GAAG;AAChF,WAAA;AAAA,EACT;AAEA,MAAI,OAAO,QAAQ;AACjB,UAAM,gBAAgB,OAAO,OAAO,WAAW,YAAY,OAAO,WAAW;AAC7E,QAAI,eAAe;AACjB,aAAOA,GAAAA,MAAM,CAAC,QAAQ,QAAQ,GAAG,OAAO,QAAQ,MAAM;AAAA,IACxD;AAEA,UAAM,IAAIC,YAAO,OAAA;AAAA,MACf,wBAAwB,OAAO,MAAM;AAAA,IAAA;AAAA,EAEzC;AAEO,SAAA;AACT;AAEM,MAAA,qBAAqBC,SAAM,aAAa;AACxC,MAAA,sBAAsBA,SAAM,cAAc;AAC1C,MAAA,2BAA2BA,SAAM,mBAAmB;AACpD,MAAA,oBAAoBA,SAAM,YAAY;;;;;"}
@@ -1,63 +0,0 @@
1
- import { errors } from "@strapi/utils";
2
- import { curry, assoc } from "lodash/fp";
3
- const getDefaultLocale = async () => {
4
- return strapi.plugin("i18n").service("locales").getDefaultLocale();
5
- };
6
- const defaultLocale = async (contentType, params) => {
7
- if (!strapi.plugin("i18n").service("content-types").isLocalizedContentType(contentType)) {
8
- return params;
9
- }
10
- if (!params.locale) {
11
- return assoc("locale", await getDefaultLocale(), params);
12
- }
13
- return params;
14
- };
15
- const localeToLookup = (contentType, params) => {
16
- if (!params.locale || !strapi.plugin("i18n").service("content-types").isLocalizedContentType(contentType)) {
17
- return params;
18
- }
19
- if (typeof params.locale !== "string") {
20
- throw new errors.ValidationError(
21
- `Invalid locale param ${String(params.locale)} provided. Document locales must be strings.`
22
- );
23
- }
24
- return assoc(["lookup", "locale"], params.locale, params);
25
- };
26
- const multiLocaleToLookup = (contentType, params) => {
27
- if (!strapi.plugin("i18n").service("content-types").isLocalizedContentType(contentType)) {
28
- return params;
29
- }
30
- if (params.locale) {
31
- if (params.locale === "*") {
32
- return params;
33
- }
34
- return assoc(["lookup", "locale"], params.locale, params);
35
- }
36
- return params;
37
- };
38
- const localeToData = (contentType, params) => {
39
- if (!strapi.plugin("i18n").service("content-types").isLocalizedContentType(contentType)) {
40
- return params;
41
- }
42
- if (params.locale) {
43
- const isValidLocale = typeof params.locale === "string" && params.locale !== "*";
44
- if (isValidLocale) {
45
- return assoc(["data", "locale"], params.locale, params);
46
- }
47
- throw new errors.ValidationError(
48
- `Invalid locale param ${params.locale} provided. Document locales must be strings.`
49
- );
50
- }
51
- return params;
52
- };
53
- const defaultLocaleCurry = curry(defaultLocale);
54
- const localeToLookupCurry = curry(localeToLookup);
55
- const multiLocaleToLookupCurry = curry(multiLocaleToLookup);
56
- const localeToDataCurry = curry(localeToData);
57
- export {
58
- defaultLocaleCurry as defaultLocale,
59
- localeToDataCurry as localeToData,
60
- localeToLookupCurry as localeToLookup,
61
- multiLocaleToLookupCurry as multiLocaleToLookup
62
- };
63
- //# sourceMappingURL=internationalization.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"internationalization.mjs","sources":["../../../src/services/document-service/internationalization.ts"],"sourcesContent":["import type { Struct, Modules } from '@strapi/types';\nimport { errors } from '@strapi/utils';\nimport { curry, assoc } from 'lodash/fp';\n\ntype Transform = (\n contentType: Struct.SingleTypeSchema | Struct.CollectionTypeSchema,\n params: Modules.Documents.Params.All\n) => Modules.Documents.Params.All;\n\ntype AsyncTransform = (\n contentType: Struct.SingleTypeSchema | Struct.CollectionTypeSchema,\n params: Modules.Documents.Params.All\n) => Promise<Modules.Documents.Params.All>;\n\nconst getDefaultLocale = async (): Promise<string> => {\n return strapi.plugin('i18n').service('locales').getDefaultLocale();\n};\n\nconst defaultLocale: AsyncTransform = async (contentType, params) => {\n if (!strapi.plugin('i18n').service('content-types').isLocalizedContentType(contentType)) {\n return params;\n }\n\n if (!params.locale) {\n return assoc('locale', await getDefaultLocale(), params);\n }\n\n return params;\n};\n\n/**\n * Add locale lookup query to the params\n */\nconst localeToLookup: Transform = (contentType, params) => {\n if (\n !params.locale ||\n !strapi.plugin('i18n').service('content-types').isLocalizedContentType(contentType)\n ) {\n return params;\n }\n\n if (typeof params.locale !== 'string') {\n // localeToLookup accepts locales of '*'. This is because the document\n // service functions that use this transform work with the '*' locale\n // to return all locales.\n throw new errors.ValidationError(\n `Invalid locale param ${String(params.locale)} provided. Document locales must be strings.`\n );\n }\n\n return assoc(['lookup', 'locale'], params.locale, params);\n};\n\n/**\n * Add locale lookup query to the params\n */\nconst multiLocaleToLookup: Transform = (contentType, params) => {\n if (!strapi.plugin('i18n').service('content-types').isLocalizedContentType(contentType)) {\n return params;\n }\n\n if (params.locale) {\n if (params.locale === '*') {\n return params;\n }\n\n return assoc(['lookup', 'locale'], params.locale, params);\n }\n\n return params;\n};\n\n/**\n * Translate locale status parameter into the data that will be saved\n */\nconst localeToData: Transform = (contentType, params) => {\n if (!strapi.plugin('i18n').service('content-types').isLocalizedContentType(contentType)) {\n return params;\n }\n\n if (params.locale) {\n const isValidLocale = typeof params.locale === 'string' && params.locale !== '*';\n if (isValidLocale) {\n return assoc(['data', 'locale'], params.locale, params);\n }\n\n throw new errors.ValidationError(\n `Invalid locale param ${params.locale} provided. Document locales must be strings.`\n );\n }\n\n return params;\n};\n\nconst defaultLocaleCurry = curry(defaultLocale);\nconst localeToLookupCurry = curry(localeToLookup);\nconst multiLocaleToLookupCurry = curry(multiLocaleToLookup);\nconst localeToDataCurry = curry(localeToData);\n\nexport {\n defaultLocaleCurry as defaultLocale,\n localeToLookupCurry as localeToLookup,\n localeToDataCurry as localeToData,\n multiLocaleToLookupCurry as multiLocaleToLookup,\n};\n"],"names":[],"mappings":";;AAcA,MAAM,mBAAmB,YAA6B;AACpD,SAAO,OAAO,OAAO,MAAM,EAAE,QAAQ,SAAS,EAAE;AAClD;AAEA,MAAM,gBAAgC,OAAO,aAAa,WAAW;AAC/D,MAAA,CAAC,OAAO,OAAO,MAAM,EAAE,QAAQ,eAAe,EAAE,uBAAuB,WAAW,GAAG;AAChF,WAAA;AAAA,EACT;AAEI,MAAA,CAAC,OAAO,QAAQ;AAClB,WAAO,MAAM,UAAU,MAAM,oBAAoB,MAAM;AAAA,EACzD;AAEO,SAAA;AACT;AAKA,MAAM,iBAA4B,CAAC,aAAa,WAAW;AACzD,MACE,CAAC,OAAO,UACR,CAAC,OAAO,OAAO,MAAM,EAAE,QAAQ,eAAe,EAAE,uBAAuB,WAAW,GAClF;AACO,WAAA;AAAA,EACT;AAEI,MAAA,OAAO,OAAO,WAAW,UAAU;AAIrC,UAAM,IAAI,OAAO;AAAA,MACf,wBAAwB,OAAO,OAAO,MAAM,CAAC;AAAA,IAAA;AAAA,EAEjD;AAEA,SAAO,MAAM,CAAC,UAAU,QAAQ,GAAG,OAAO,QAAQ,MAAM;AAC1D;AAKA,MAAM,sBAAiC,CAAC,aAAa,WAAW;AAC1D,MAAA,CAAC,OAAO,OAAO,MAAM,EAAE,QAAQ,eAAe,EAAE,uBAAuB,WAAW,GAAG;AAChF,WAAA;AAAA,EACT;AAEA,MAAI,OAAO,QAAQ;AACb,QAAA,OAAO,WAAW,KAAK;AAClB,aAAA;AAAA,IACT;AAEA,WAAO,MAAM,CAAC,UAAU,QAAQ,GAAG,OAAO,QAAQ,MAAM;AAAA,EAC1D;AAEO,SAAA;AACT;AAKA,MAAM,eAA0B,CAAC,aAAa,WAAW;AACnD,MAAA,CAAC,OAAO,OAAO,MAAM,EAAE,QAAQ,eAAe,EAAE,uBAAuB,WAAW,GAAG;AAChF,WAAA;AAAA,EACT;AAEA,MAAI,OAAO,QAAQ;AACjB,UAAM,gBAAgB,OAAO,OAAO,WAAW,YAAY,OAAO,WAAW;AAC7E,QAAI,eAAe;AACjB,aAAO,MAAM,CAAC,QAAQ,QAAQ,GAAG,OAAO,QAAQ,MAAM;AAAA,IACxD;AAEA,UAAM,IAAI,OAAO;AAAA,MACf,wBAAwB,OAAO,MAAM;AAAA,IAAA;AAAA,EAEzC;AAEO,SAAA;AACT;AAEM,MAAA,qBAAqB,MAAM,aAAa;AACxC,MAAA,sBAAsB,MAAM,cAAc;AAC1C,MAAA,2BAA2B,MAAM,mBAAmB;AACpD,MAAA,oBAAoB,MAAM,YAAY;"}
@@ -1,25 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const database = require("@strapi/database");
4
- const strapiUtils = require("@strapi/utils");
5
- const databaseErrorsToTransform = [
6
- database.errors.InvalidTimeError,
7
- database.errors.InvalidDateTimeError,
8
- database.errors.InvalidDateError,
9
- database.errors.InvalidRelationError
10
- ];
11
- const databaseErrorsMiddleware = async (ctx, next) => {
12
- try {
13
- return await next();
14
- } catch (error) {
15
- if (databaseErrorsToTransform.some((errorToTransform) => error instanceof errorToTransform)) {
16
- if (error instanceof Error) {
17
- throw new strapiUtils.errors.ValidationError(error.message);
18
- }
19
- throw error;
20
- }
21
- throw error;
22
- }
23
- };
24
- exports.databaseErrorsMiddleware = databaseErrorsMiddleware;
25
- //# sourceMappingURL=errors.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"errors.js","sources":["../../../../src/services/document-service/middlewares/errors.ts"],"sourcesContent":["import { errors as databaseErrors } from '@strapi/database';\nimport { errors } from '@strapi/utils';\n\nimport type { Middleware } from './middleware-manager';\n\nconst databaseErrorsToTransform = [\n databaseErrors.InvalidTimeError,\n databaseErrors.InvalidDateTimeError,\n databaseErrors.InvalidDateError,\n databaseErrors.InvalidRelationError,\n];\n\n/**\n * Handle database errors\n */\nexport const databaseErrorsMiddleware: Middleware = async (ctx, next) => {\n try {\n return await next();\n } catch (error) {\n if (databaseErrorsToTransform.some((errorToTransform) => error instanceof errorToTransform)) {\n if (error instanceof Error) {\n throw new errors.ValidationError(error.message);\n }\n\n throw error;\n }\n throw error;\n }\n};\n"],"names":["databaseErrors","errors"],"mappings":";;;;AAKA,MAAM,4BAA4B;AAAA,EAChCA,SAAAA,OAAe;AAAA,EACfA,SAAAA,OAAe;AAAA,EACfA,SAAAA,OAAe;AAAA,EACfA,SAAAA,OAAe;AACjB;AAKa,MAAA,2BAAuC,OAAO,KAAK,SAAS;AACnE,MAAA;AACF,WAAO,MAAM,KAAK;AAAA,WACX,OAAO;AACd,QAAI,0BAA0B,KAAK,CAAC,qBAAqB,iBAAiB,gBAAgB,GAAG;AAC3F,UAAI,iBAAiB,OAAO;AAC1B,cAAM,IAAIC,YAAAA,OAAO,gBAAgB,MAAM,OAAO;AAAA,MAChD;AAEM,YAAA;AAAA,IACR;AACM,UAAA;AAAA,EACR;AACF;;"}
@@ -1,25 +0,0 @@
1
- import { errors } from "@strapi/database";
2
- import { errors as errors$1 } from "@strapi/utils";
3
- const databaseErrorsToTransform = [
4
- errors.InvalidTimeError,
5
- errors.InvalidDateTimeError,
6
- errors.InvalidDateError,
7
- errors.InvalidRelationError
8
- ];
9
- const databaseErrorsMiddleware = async (ctx, next) => {
10
- try {
11
- return await next();
12
- } catch (error) {
13
- if (databaseErrorsToTransform.some((errorToTransform) => error instanceof errorToTransform)) {
14
- if (error instanceof Error) {
15
- throw new errors$1.ValidationError(error.message);
16
- }
17
- throw error;
18
- }
19
- throw error;
20
- }
21
- };
22
- export {
23
- databaseErrorsMiddleware
24
- };
25
- //# sourceMappingURL=errors.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"errors.mjs","sources":["../../../../src/services/document-service/middlewares/errors.ts"],"sourcesContent":["import { errors as databaseErrors } from '@strapi/database';\nimport { errors } from '@strapi/utils';\n\nimport type { Middleware } from './middleware-manager';\n\nconst databaseErrorsToTransform = [\n databaseErrors.InvalidTimeError,\n databaseErrors.InvalidDateTimeError,\n databaseErrors.InvalidDateError,\n databaseErrors.InvalidRelationError,\n];\n\n/**\n * Handle database errors\n */\nexport const databaseErrorsMiddleware: Middleware = async (ctx, next) => {\n try {\n return await next();\n } catch (error) {\n if (databaseErrorsToTransform.some((errorToTransform) => error instanceof errorToTransform)) {\n if (error instanceof Error) {\n throw new errors.ValidationError(error.message);\n }\n\n throw error;\n }\n throw error;\n }\n};\n"],"names":["databaseErrors","errors"],"mappings":";;AAKA,MAAM,4BAA4B;AAAA,EAChCA,OAAe;AAAA,EACfA,OAAe;AAAA,EACfA,OAAe;AAAA,EACfA,OAAe;AACjB;AAKa,MAAA,2BAAuC,OAAO,KAAK,SAAS;AACnE,MAAA;AACF,WAAO,MAAM,KAAK;AAAA,WACX,OAAO;AACd,QAAI,0BAA0B,KAAK,CAAC,qBAAqB,iBAAiB,gBAAgB,GAAG;AAC3F,UAAI,iBAAiB,OAAO;AAC1B,cAAM,IAAIC,SAAO,gBAAgB,MAAM,OAAO;AAAA,MAChD;AAEM,YAAA;AAAA,IACR;AACM,UAAA;AAAA,EACR;AACF;"}
@@ -1,49 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const createMiddlewareManager = () => {
4
- const middlewares = [];
5
- const manager = {
6
- use(middleware) {
7
- middlewares.push(middleware);
8
- return () => middlewares.splice(middlewares.indexOf(middleware), 1);
9
- },
10
- async run(ctx, cb) {
11
- let index = 0;
12
- const next = async () => {
13
- if (index < middlewares.length) {
14
- return middlewares[index++](ctx, next);
15
- }
16
- return cb();
17
- };
18
- return next();
19
- },
20
- wrapObject(source, ctxDefaults = {}, opts = {}) {
21
- const facade = {};
22
- const { exclude = [] } = opts;
23
- for (const key in source) {
24
- if (Object.hasOwnProperty.call(source, key)) {
25
- const prop = source[key];
26
- if (exclude.includes(key)) {
27
- facade[key] = prop;
28
- } else if (typeof prop === "function") {
29
- const newMethod = async (params = {}) => {
30
- const ctx = {
31
- ...ctxDefaults,
32
- action: key,
33
- params
34
- };
35
- return manager.run(ctx, () => prop(ctx.params));
36
- };
37
- facade[key] = newMethod;
38
- } else {
39
- facade[key] = prop;
40
- }
41
- }
42
- }
43
- return facade;
44
- }
45
- };
46
- return manager;
47
- };
48
- exports.createMiddlewareManager = createMiddlewareManager;
49
- //# sourceMappingURL=middleware-manager.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"middleware-manager.js","sources":["../../../../src/services/document-service/middlewares/middleware-manager.ts"],"sourcesContent":["export type Middleware = (ctx: any, next: () => Promise<void>) => Promise<void> | void;\n\nexport type Options = {\n exclude?: string[];\n};\n\nexport const createMiddlewareManager = () => {\n const middlewares: Middleware[] = [];\n\n const manager = {\n use(middleware: Middleware) {\n middlewares.push(middleware);\n\n return () => middlewares.splice(middlewares.indexOf(middleware), 1);\n },\n\n async run(ctx: any, cb: () => void) {\n let index = 0;\n const next = async () => {\n if (index < middlewares.length) {\n // eslint-disable-next-line no-plusplus\n return middlewares[index++](ctx, next);\n }\n\n return cb();\n };\n\n return next();\n },\n\n wrapObject<TSource>(source: TSource, ctxDefaults = {}, opts: Options = {}): TSource {\n const facade: TSource = {} as TSource;\n const { exclude = [] } = opts;\n\n for (const key in source) {\n if (Object.hasOwnProperty.call(source, key)) {\n const prop = source[key];\n\n if (exclude.includes(key)) {\n facade[key] = prop;\n } else if (typeof prop === 'function') {\n const newMethod = async (params: any = {}) => {\n const ctx = {\n ...ctxDefaults,\n action: key,\n params,\n };\n\n return manager.run(ctx, () => prop(ctx.params));\n };\n\n facade[key] = newMethod as typeof prop;\n } else {\n facade[key] = prop;\n }\n }\n }\n\n return facade;\n },\n };\n\n return manager;\n};\n"],"names":[],"mappings":";;AAMO,MAAM,0BAA0B,MAAM;AAC3C,QAAM,cAA4B,CAAA;AAElC,QAAM,UAAU;AAAA,IACd,IAAI,YAAwB;AAC1B,kBAAY,KAAK,UAAU;AAE3B,aAAO,MAAM,YAAY,OAAO,YAAY,QAAQ,UAAU,GAAG,CAAC;AAAA,IACpE;AAAA,IAEA,MAAM,IAAI,KAAU,IAAgB;AAClC,UAAI,QAAQ;AACZ,YAAM,OAAO,YAAY;AACnB,YAAA,QAAQ,YAAY,QAAQ;AAE9B,iBAAO,YAAY,OAAO,EAAE,KAAK,IAAI;AAAA,QACvC;AAEA,eAAO,GAAG;AAAA,MAAA;AAGZ,aAAO,KAAK;AAAA,IACd;AAAA,IAEA,WAAoB,QAAiB,cAAc,CAAA,GAAI,OAAgB,CAAA,GAAa;AAClF,YAAM,SAAkB,CAAA;AACxB,YAAM,EAAE,UAAU,GAAO,IAAA;AAEzB,iBAAW,OAAO,QAAQ;AACxB,YAAI,OAAO,eAAe,KAAK,QAAQ,GAAG,GAAG;AACrC,gBAAA,OAAO,OAAO,GAAG;AAEnB,cAAA,QAAQ,SAAS,GAAG,GAAG;AACzB,mBAAO,GAAG,IAAI;AAAA,UAAA,WACL,OAAO,SAAS,YAAY;AACrC,kBAAM,YAAY,OAAO,SAAc,OAAO;AAC5C,oBAAM,MAAM;AAAA,gBACV,GAAG;AAAA,gBACH,QAAQ;AAAA,gBACR;AAAA,cAAA;AAGF,qBAAO,QAAQ,IAAI,KAAK,MAAM,KAAK,IAAI,MAAM,CAAC;AAAA,YAAA;AAGhD,mBAAO,GAAG,IAAI;AAAA,UAAA,OACT;AACL,mBAAO,GAAG,IAAI;AAAA,UAChB;AAAA,QACF;AAAA,MACF;AAEO,aAAA;AAAA,IACT;AAAA,EAAA;AAGK,SAAA;AACT;;"}