@strapi/core 0.0.0-experimental.3f7b2587c5e3d548262671895cf11d8bf8c

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


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

Files changed (802) hide show
  1. package/LICENSE +22 -0
  2. package/README.md +1 -0
  3. package/dist/Strapi.d.ts +98 -0
  4. package/dist/Strapi.d.ts.map +1 -0
  5. package/dist/Strapi.js +443 -0
  6. package/dist/Strapi.js.map +1 -0
  7. package/dist/Strapi.mjs +442 -0
  8. package/dist/Strapi.mjs.map +1 -0
  9. package/dist/compile.d.ts +10 -0
  10. package/dist/compile.d.ts.map +1 -0
  11. package/dist/compile.js +18 -0
  12. package/dist/compile.js.map +1 -0
  13. package/dist/compile.mjs +17 -0
  14. package/dist/compile.mjs.map +1 -0
  15. package/dist/configuration/config-loader.d.ts +3 -0
  16. package/dist/configuration/config-loader.d.ts.map +1 -0
  17. package/dist/configuration/config-loader.js +102 -0
  18. package/dist/configuration/config-loader.js.map +1 -0
  19. package/dist/configuration/config-loader.mjs +100 -0
  20. package/dist/configuration/config-loader.mjs.map +1 -0
  21. package/dist/configuration/index.d.ts +51 -0
  22. package/dist/configuration/index.d.ts.map +1 -0
  23. package/dist/configuration/index.js +78 -0
  24. package/dist/configuration/index.js.map +1 -0
  25. package/dist/configuration/index.mjs +74 -0
  26. package/dist/configuration/index.mjs.map +1 -0
  27. package/dist/container.d.ts +8 -0
  28. package/dist/container.d.ts.map +1 -0
  29. package/dist/container.js +30 -0
  30. package/dist/container.js.map +1 -0
  31. package/dist/container.mjs +30 -0
  32. package/dist/container.mjs.map +1 -0
  33. package/dist/core-api/controller/collection-type.d.ts +11 -0
  34. package/dist/core-api/controller/collection-type.d.ts.map +1 -0
  35. package/dist/core-api/controller/collection-type.js +92 -0
  36. package/dist/core-api/controller/collection-type.js.map +1 -0
  37. package/dist/core-api/controller/collection-type.mjs +93 -0
  38. package/dist/core-api/controller/collection-type.mjs.map +1 -0
  39. package/dist/core-api/controller/index.d.ts +6 -0
  40. package/dist/core-api/controller/index.d.ts.map +1 -0
  41. package/dist/core-api/controller/index.js +47 -0
  42. package/dist/core-api/controller/index.js.map +1 -0
  43. package/dist/core-api/controller/index.mjs +47 -0
  44. package/dist/core-api/controller/index.mjs.map +1 -0
  45. package/dist/core-api/controller/single-type.d.ts +10 -0
  46. package/dist/core-api/controller/single-type.d.ts.map +1 -0
  47. package/dist/core-api/controller/single-type.js +50 -0
  48. package/dist/core-api/controller/single-type.js.map +1 -0
  49. package/dist/core-api/controller/single-type.mjs +51 -0
  50. package/dist/core-api/controller/single-type.mjs.map +1 -0
  51. package/dist/core-api/controller/transform.d.ts +22 -0
  52. package/dist/core-api/controller/transform.d.ts.map +1 -0
  53. package/dist/core-api/controller/transform.js +84 -0
  54. package/dist/core-api/controller/transform.js.map +1 -0
  55. package/dist/core-api/controller/transform.mjs +84 -0
  56. package/dist/core-api/controller/transform.mjs.map +1 -0
  57. package/dist/core-api/routes/index.d.ts +24 -0
  58. package/dist/core-api/routes/index.d.ts.map +1 -0
  59. package/dist/core-api/routes/index.js +67 -0
  60. package/dist/core-api/routes/index.js.map +1 -0
  61. package/dist/core-api/routes/index.mjs +67 -0
  62. package/dist/core-api/routes/index.mjs.map +1 -0
  63. package/dist/core-api/service/collection-type.d.ts +10 -0
  64. package/dist/core-api/service/collection-type.d.ts.map +1 -0
  65. package/dist/core-api/service/collection-type.js +58 -0
  66. package/dist/core-api/service/collection-type.js.map +1 -0
  67. package/dist/core-api/service/collection-type.mjs +59 -0
  68. package/dist/core-api/service/collection-type.mjs.map +1 -0
  69. package/dist/core-api/service/get-fetch-params.d.ts +7 -0
  70. package/dist/core-api/service/get-fetch-params.d.ts.map +1 -0
  71. package/dist/core-api/service/get-fetch-params.js +14 -0
  72. package/dist/core-api/service/get-fetch-params.js.map +1 -0
  73. package/dist/core-api/service/get-fetch-params.mjs +14 -0
  74. package/dist/core-api/service/get-fetch-params.mjs.map +1 -0
  75. package/dist/core-api/service/index.d.ts +9 -0
  76. package/dist/core-api/service/index.d.ts.map +1 -0
  77. package/dist/core-api/service/index.js +16 -0
  78. package/dist/core-api/service/index.js.map +1 -0
  79. package/dist/core-api/service/index.mjs +16 -0
  80. package/dist/core-api/service/index.mjs.map +1 -0
  81. package/dist/core-api/service/pagination.d.ts +41 -0
  82. package/dist/core-api/service/pagination.d.ts.map +1 -0
  83. package/dist/core-api/service/pagination.js +89 -0
  84. package/dist/core-api/service/pagination.js.map +1 -0
  85. package/dist/core-api/service/pagination.mjs +89 -0
  86. package/dist/core-api/service/pagination.mjs.map +1 -0
  87. package/dist/core-api/service/single-type.d.ts +9 -0
  88. package/dist/core-api/service/single-type.d.ts.map +1 -0
  89. package/dist/core-api/service/single-type.js +54 -0
  90. package/dist/core-api/service/single-type.js.map +1 -0
  91. package/dist/core-api/service/single-type.mjs +55 -0
  92. package/dist/core-api/service/single-type.mjs.map +1 -0
  93. package/dist/domain/content-type/index.d.ts +10 -0
  94. package/dist/domain/content-type/index.d.ts.map +1 -0
  95. package/dist/domain/content-type/index.js +108 -0
  96. package/dist/domain/content-type/index.js.map +1 -0
  97. package/dist/domain/content-type/index.mjs +106 -0
  98. package/dist/domain/content-type/index.mjs.map +1 -0
  99. package/dist/domain/content-type/validator.d.ts +23 -0
  100. package/dist/domain/content-type/validator.d.ts.map +1 -0
  101. package/dist/domain/content-type/validator.js +77 -0
  102. package/dist/domain/content-type/validator.js.map +1 -0
  103. package/dist/domain/content-type/validator.mjs +75 -0
  104. package/dist/domain/content-type/validator.mjs.map +1 -0
  105. package/dist/domain/module/index.d.ts +39 -0
  106. package/dist/domain/module/index.d.ts.map +1 -0
  107. package/dist/domain/module/index.js +107 -0
  108. package/dist/domain/module/index.js.map +1 -0
  109. package/dist/domain/module/index.mjs +105 -0
  110. package/dist/domain/module/index.mjs.map +1 -0
  111. package/dist/domain/module/validation.d.ts +15 -0
  112. package/dist/domain/module/validation.d.ts.map +1 -0
  113. package/dist/domain/module/validation.js +25 -0
  114. package/dist/domain/module/validation.js.map +1 -0
  115. package/dist/domain/module/validation.mjs +25 -0
  116. package/dist/domain/module/validation.mjs.map +1 -0
  117. package/dist/ee/index.d.ts +20 -0
  118. package/dist/ee/index.d.ts.map +1 -0
  119. package/dist/ee/index.js +153 -0
  120. package/dist/ee/index.js.map +1 -0
  121. package/dist/ee/index.mjs +154 -0
  122. package/dist/ee/index.mjs.map +1 -0
  123. package/dist/ee/license.d.ts +21 -0
  124. package/dist/ee/license.d.ts.map +1 -0
  125. package/dist/ee/license.js +90 -0
  126. package/dist/ee/license.js.map +1 -0
  127. package/dist/ee/license.mjs +87 -0
  128. package/dist/ee/license.mjs.map +1 -0
  129. package/dist/factories.d.ts +14 -0
  130. package/dist/factories.d.ts.map +1 -0
  131. package/dist/factories.js +86 -0
  132. package/dist/factories.js.map +1 -0
  133. package/dist/factories.mjs +86 -0
  134. package/dist/factories.mjs.map +1 -0
  135. package/dist/index.d.ts +4 -0
  136. package/dist/index.d.ts.map +1 -0
  137. package/dist/index.js +7 -0
  138. package/dist/index.js.map +1 -0
  139. package/dist/index.mjs +7 -0
  140. package/dist/index.mjs.map +1 -0
  141. package/dist/loaders/admin.d.ts +3 -0
  142. package/dist/loaders/admin.d.ts.map +1 -0
  143. package/dist/loaders/admin.js +27 -0
  144. package/dist/loaders/admin.js.map +1 -0
  145. package/dist/loaders/admin.mjs +26 -0
  146. package/dist/loaders/admin.mjs.map +1 -0
  147. package/dist/loaders/apis.d.ts +3 -0
  148. package/dist/loaders/apis.d.ts.map +1 -0
  149. package/dist/loaders/apis.js +137 -0
  150. package/dist/loaders/apis.js.map +1 -0
  151. package/dist/loaders/apis.mjs +135 -0
  152. package/dist/loaders/apis.mjs.map +1 -0
  153. package/dist/loaders/components.d.ts +3 -0
  154. package/dist/loaders/components.d.ts.map +1 -0
  155. package/dist/loaders/components.js +38 -0
  156. package/dist/loaders/components.js.map +1 -0
  157. package/dist/loaders/components.mjs +37 -0
  158. package/dist/loaders/components.mjs.map +1 -0
  159. package/dist/loaders/index.d.ts +3 -0
  160. package/dist/loaders/index.d.ts.map +1 -0
  161. package/dist/loaders/index.js +26 -0
  162. package/dist/loaders/index.js.map +1 -0
  163. package/dist/loaders/index.mjs +26 -0
  164. package/dist/loaders/index.mjs.map +1 -0
  165. package/dist/loaders/middlewares.d.ts +3 -0
  166. package/dist/loaders/middlewares.d.ts.map +1 -0
  167. package/dist/loaders/middlewares.js +31 -0
  168. package/dist/loaders/middlewares.js.map +1 -0
  169. package/dist/loaders/middlewares.mjs +30 -0
  170. package/dist/loaders/middlewares.mjs.map +1 -0
  171. package/dist/loaders/plugins/get-enabled-plugins.d.ts +5 -0
  172. package/dist/loaders/plugins/get-enabled-plugins.d.ts.map +1 -0
  173. package/dist/loaders/plugins/get-enabled-plugins.js +111 -0
  174. package/dist/loaders/plugins/get-enabled-plugins.js.map +1 -0
  175. package/dist/loaders/plugins/get-enabled-plugins.mjs +109 -0
  176. package/dist/loaders/plugins/get-enabled-plugins.mjs.map +1 -0
  177. package/dist/loaders/plugins/get-user-plugins-config.d.ts +7 -0
  178. package/dist/loaders/plugins/get-user-plugins-config.d.ts.map +1 -0
  179. package/dist/loaders/plugins/get-user-plugins-config.js +27 -0
  180. package/dist/loaders/plugins/get-user-plugins-config.js.map +1 -0
  181. package/dist/loaders/plugins/get-user-plugins-config.mjs +25 -0
  182. package/dist/loaders/plugins/get-user-plugins-config.mjs.map +1 -0
  183. package/dist/loaders/plugins/index.d.ts +3 -0
  184. package/dist/loaders/plugins/index.d.ts.map +1 -0
  185. package/dist/loaders/plugins/index.js +118 -0
  186. package/dist/loaders/plugins/index.js.map +1 -0
  187. package/dist/loaders/plugins/index.mjs +117 -0
  188. package/dist/loaders/plugins/index.mjs.map +1 -0
  189. package/dist/loaders/policies.d.ts +3 -0
  190. package/dist/loaders/policies.d.ts.map +1 -0
  191. package/dist/loaders/policies.js +25 -0
  192. package/dist/loaders/policies.js.map +1 -0
  193. package/dist/loaders/policies.mjs +24 -0
  194. package/dist/loaders/policies.mjs.map +1 -0
  195. package/dist/loaders/sanitizers.d.ts +4 -0
  196. package/dist/loaders/sanitizers.d.ts.map +1 -0
  197. package/dist/loaders/sanitizers.js +6 -0
  198. package/dist/loaders/sanitizers.js.map +1 -0
  199. package/dist/loaders/sanitizers.mjs +7 -0
  200. package/dist/loaders/sanitizers.mjs.map +1 -0
  201. package/dist/loaders/src-index.d.ts +4 -0
  202. package/dist/loaders/src-index.d.ts.map +1 -0
  203. package/dist/loaders/src-index.js +33 -0
  204. package/dist/loaders/src-index.js.map +1 -0
  205. package/dist/loaders/src-index.mjs +34 -0
  206. package/dist/loaders/src-index.mjs.map +1 -0
  207. package/dist/loaders/validators.d.ts +4 -0
  208. package/dist/loaders/validators.d.ts.map +1 -0
  209. package/dist/loaders/validators.js +6 -0
  210. package/dist/loaders/validators.js.map +1 -0
  211. package/dist/loaders/validators.mjs +7 -0
  212. package/dist/loaders/validators.mjs.map +1 -0
  213. package/dist/middlewares/body.d.ts +6 -0
  214. package/dist/middlewares/body.d.ts.map +1 -0
  215. package/dist/middlewares/body.js +65 -0
  216. package/dist/middlewares/body.js.map +1 -0
  217. package/dist/middlewares/body.mjs +61 -0
  218. package/dist/middlewares/body.mjs.map +1 -0
  219. package/dist/middlewares/compression.d.ts +5 -0
  220. package/dist/middlewares/compression.d.ts.map +1 -0
  221. package/dist/middlewares/compression.js +8 -0
  222. package/dist/middlewares/compression.js.map +1 -0
  223. package/dist/middlewares/compression.mjs +6 -0
  224. package/dist/middlewares/compression.mjs.map +1 -0
  225. package/dist/middlewares/cors.d.ts +13 -0
  226. package/dist/middlewares/cors.d.ts.map +1 -0
  227. package/dist/middlewares/cors.js +51 -0
  228. package/dist/middlewares/cors.js.map +1 -0
  229. package/dist/middlewares/cors.mjs +49 -0
  230. package/dist/middlewares/cors.mjs.map +1 -0
  231. package/dist/middlewares/errors.d.ts +4 -0
  232. package/dist/middlewares/errors.d.ts.map +1 -0
  233. package/dist/middlewares/errors.js +33 -0
  234. package/dist/middlewares/errors.js.map +1 -0
  235. package/dist/middlewares/errors.mjs +33 -0
  236. package/dist/middlewares/errors.mjs.map +1 -0
  237. package/dist/middlewares/favicon.d.ts +6 -0
  238. package/dist/middlewares/favicon.d.ts.map +1 -0
  239. package/dist/middlewares/favicon.js +22 -0
  240. package/dist/middlewares/favicon.js.map +1 -0
  241. package/dist/middlewares/favicon.mjs +20 -0
  242. package/dist/middlewares/favicon.mjs.map +1 -0
  243. package/dist/middlewares/index.d.ts +3 -0
  244. package/dist/middlewares/index.d.ts.map +1 -0
  245. package/dist/middlewares/index.js +34 -0
  246. package/dist/middlewares/index.js.map +1 -0
  247. package/dist/middlewares/index.mjs +34 -0
  248. package/dist/middlewares/index.mjs.map +1 -0
  249. package/dist/middlewares/ip.d.ts +5 -0
  250. package/dist/middlewares/ip.d.ts.map +1 -0
  251. package/dist/middlewares/ip.js +8 -0
  252. package/dist/middlewares/ip.js.map +1 -0
  253. package/dist/middlewares/ip.mjs +6 -0
  254. package/dist/middlewares/ip.mjs.map +1 -0
  255. package/dist/middlewares/logger.d.ts +3 -0
  256. package/dist/middlewares/logger.d.ts.map +1 -0
  257. package/dist/middlewares/logger.js +12 -0
  258. package/dist/middlewares/logger.js.map +1 -0
  259. package/dist/middlewares/logger.mjs +12 -0
  260. package/dist/middlewares/logger.mjs.map +1 -0
  261. package/dist/middlewares/powered-by.d.ts +6 -0
  262. package/dist/middlewares/powered-by.d.ts.map +1 -0
  263. package/dist/middlewares/powered-by.js +14 -0
  264. package/dist/middlewares/powered-by.js.map +1 -0
  265. package/dist/middlewares/powered-by.mjs +14 -0
  266. package/dist/middlewares/powered-by.mjs.map +1 -0
  267. package/dist/middlewares/public.d.ts +3 -0
  268. package/dist/middlewares/public.d.ts.map +1 -0
  269. package/dist/middlewares/public.js +34 -0
  270. package/dist/middlewares/public.js.map +1 -0
  271. package/dist/middlewares/public.mjs +32 -0
  272. package/dist/middlewares/public.mjs.map +1 -0
  273. package/dist/middlewares/query.d.ts +3 -0
  274. package/dist/middlewares/query.d.ts.map +1 -0
  275. package/dist/middlewares/query.js +40 -0
  276. package/dist/middlewares/query.js.map +1 -0
  277. package/dist/middlewares/query.mjs +38 -0
  278. package/dist/middlewares/query.mjs.map +1 -0
  279. package/dist/middlewares/response-time.d.ts +3 -0
  280. package/dist/middlewares/response-time.d.ts.map +1 -0
  281. package/dist/middlewares/response-time.js +12 -0
  282. package/dist/middlewares/response-time.js.map +1 -0
  283. package/dist/middlewares/response-time.mjs +12 -0
  284. package/dist/middlewares/response-time.mjs.map +1 -0
  285. package/dist/middlewares/responses.d.ts +6 -0
  286. package/dist/middlewares/responses.d.ts.map +1 -0
  287. package/dist/middlewares/responses.js +15 -0
  288. package/dist/middlewares/responses.js.map +1 -0
  289. package/dist/middlewares/responses.mjs +15 -0
  290. package/dist/middlewares/responses.mjs.map +1 -0
  291. package/dist/middlewares/security.d.ts +5 -0
  292. package/dist/middlewares/security.d.ts.map +1 -0
  293. package/dist/middlewares/security.js +71 -0
  294. package/dist/middlewares/security.js.map +1 -0
  295. package/dist/middlewares/security.mjs +69 -0
  296. package/dist/middlewares/security.mjs.map +1 -0
  297. package/dist/middlewares/session.d.ts +4 -0
  298. package/dist/middlewares/session.d.ts.map +1 -0
  299. package/dist/middlewares/session.js +30 -0
  300. package/dist/middlewares/session.js.map +1 -0
  301. package/dist/middlewares/session.mjs +28 -0
  302. package/dist/middlewares/session.mjs.map +1 -0
  303. package/dist/registries/apis.d.ts +8 -0
  304. package/dist/registries/apis.d.ts.map +1 -0
  305. package/dist/registries/apis.js +23 -0
  306. package/dist/registries/apis.js.map +1 -0
  307. package/dist/registries/apis.mjs +24 -0
  308. package/dist/registries/apis.mjs.map +1 -0
  309. package/dist/registries/components.d.ts +25 -0
  310. package/dist/registries/components.d.ts.map +1 -0
  311. package/dist/registries/components.js +45 -0
  312. package/dist/registries/components.js.map +1 -0
  313. package/dist/registries/components.mjs +46 -0
  314. package/dist/registries/components.mjs.map +1 -0
  315. package/dist/registries/config.d.ts +4 -0
  316. package/dist/registries/config.d.ts.map +1 -0
  317. package/dist/registries/config.js +23 -0
  318. package/dist/registries/config.js.map +1 -0
  319. package/dist/registries/config.mjs +22 -0
  320. package/dist/registries/config.mjs.map +1 -0
  321. package/dist/registries/content-types.d.ts +33 -0
  322. package/dist/registries/content-types.d.ts.map +1 -0
  323. package/dist/registries/content-types.js +71 -0
  324. package/dist/registries/content-types.js.map +1 -0
  325. package/dist/registries/content-types.mjs +72 -0
  326. package/dist/registries/content-types.mjs.map +1 -0
  327. package/dist/registries/controllers.d.ts +35 -0
  328. package/dist/registries/controllers.d.ts.map +1 -0
  329. package/dist/registries/controllers.js +80 -0
  330. package/dist/registries/controllers.js.map +1 -0
  331. package/dist/registries/controllers.mjs +81 -0
  332. package/dist/registries/controllers.mjs.map +1 -0
  333. package/dist/registries/custom-fields.d.ts +8 -0
  334. package/dist/registries/custom-fields.d.ts.map +1 -0
  335. package/dist/registries/custom-fields.js +71 -0
  336. package/dist/registries/custom-fields.js.map +1 -0
  337. package/dist/registries/custom-fields.mjs +72 -0
  338. package/dist/registries/custom-fields.mjs.map +1 -0
  339. package/dist/registries/hooks.d.ts +44 -0
  340. package/dist/registries/hooks.d.ts.map +1 -0
  341. package/dist/registries/hooks.js +58 -0
  342. package/dist/registries/hooks.js.map +1 -0
  343. package/dist/registries/hooks.mjs +59 -0
  344. package/dist/registries/hooks.mjs.map +1 -0
  345. package/dist/registries/index.d.ts +16 -0
  346. package/dist/registries/index.d.ts.map +1 -0
  347. package/dist/registries/middlewares.d.ts +31 -0
  348. package/dist/registries/middlewares.d.ts.map +1 -0
  349. package/dist/registries/middlewares.js +60 -0
  350. package/dist/registries/middlewares.js.map +1 -0
  351. package/dist/registries/middlewares.mjs +61 -0
  352. package/dist/registries/middlewares.mjs.map +1 -0
  353. package/dist/registries/models.d.ts +6 -0
  354. package/dist/registries/models.d.ts.map +1 -0
  355. package/dist/registries/models.js +16 -0
  356. package/dist/registries/models.js.map +1 -0
  357. package/dist/registries/models.mjs +16 -0
  358. package/dist/registries/models.mjs.map +1 -0
  359. package/dist/registries/modules.d.ts +15 -0
  360. package/dist/registries/modules.d.ts.map +1 -0
  361. package/dist/registries/modules.js +39 -0
  362. package/dist/registries/modules.js.map +1 -0
  363. package/dist/registries/modules.mjs +40 -0
  364. package/dist/registries/modules.mjs.map +1 -0
  365. package/dist/registries/namespace.d.ts +5 -0
  366. package/dist/registries/namespace.d.ts.map +1 -0
  367. package/dist/registries/namespace.js +27 -0
  368. package/dist/registries/namespace.js.map +1 -0
  369. package/dist/registries/namespace.mjs +27 -0
  370. package/dist/registries/namespace.mjs.map +1 -0
  371. package/dist/registries/plugins.d.ts +9 -0
  372. package/dist/registries/plugins.d.ts.map +1 -0
  373. package/dist/registries/plugins.js +23 -0
  374. package/dist/registries/plugins.js.map +1 -0
  375. package/dist/registries/plugins.mjs +24 -0
  376. package/dist/registries/plugins.mjs.map +1 -0
  377. package/dist/registries/policies.d.ts +34 -0
  378. package/dist/registries/policies.d.ts.map +1 -0
  379. package/dist/registries/policies.js +62 -0
  380. package/dist/registries/policies.js.map +1 -0
  381. package/dist/registries/policies.mjs +63 -0
  382. package/dist/registries/policies.mjs.map +1 -0
  383. package/dist/registries/sanitizers.d.ts +10 -0
  384. package/dist/registries/sanitizers.d.ts.map +1 -0
  385. package/dist/registries/sanitizers.js +25 -0
  386. package/dist/registries/sanitizers.js.map +1 -0
  387. package/dist/registries/sanitizers.mjs +24 -0
  388. package/dist/registries/sanitizers.mjs.map +1 -0
  389. package/dist/registries/services.d.ts +35 -0
  390. package/dist/registries/services.d.ts.map +1 -0
  391. package/dist/registries/services.js +80 -0
  392. package/dist/registries/services.js.map +1 -0
  393. package/dist/registries/services.mjs +81 -0
  394. package/dist/registries/services.mjs.map +1 -0
  395. package/dist/registries/validators.d.ts +10 -0
  396. package/dist/registries/validators.d.ts.map +1 -0
  397. package/dist/registries/validators.js +25 -0
  398. package/dist/registries/validators.js.map +1 -0
  399. package/dist/registries/validators.mjs +24 -0
  400. package/dist/registries/validators.mjs.map +1 -0
  401. package/dist/services/auth/index.d.ts +26 -0
  402. package/dist/services/auth/index.d.ts.map +1 -0
  403. package/dist/services/auth/index.js +81 -0
  404. package/dist/services/auth/index.js.map +1 -0
  405. package/dist/services/auth/index.mjs +80 -0
  406. package/dist/services/auth/index.mjs.map +1 -0
  407. package/dist/services/content-api/index.d.ts +54 -0
  408. package/dist/services/content-api/index.d.ts.map +1 -0
  409. package/dist/services/content-api/index.js +59 -0
  410. package/dist/services/content-api/index.js.map +1 -0
  411. package/dist/services/content-api/index.mjs +58 -0
  412. package/dist/services/content-api/index.mjs.map +1 -0
  413. package/dist/services/content-api/permissions/engine.d.ts +5 -0
  414. package/dist/services/content-api/permissions/engine.d.ts.map +1 -0
  415. package/dist/services/content-api/permissions/engine.js +7 -0
  416. package/dist/services/content-api/permissions/engine.js.map +1 -0
  417. package/dist/services/content-api/permissions/engine.mjs +6 -0
  418. package/dist/services/content-api/permissions/engine.mjs.map +1 -0
  419. package/dist/services/content-api/permissions/index.d.ts +52 -0
  420. package/dist/services/content-api/permissions/index.d.ts.map +1 -0
  421. package/dist/services/content-api/permissions/index.js +87 -0
  422. package/dist/services/content-api/permissions/index.js.map +1 -0
  423. package/dist/services/content-api/permissions/index.mjs +86 -0
  424. package/dist/services/content-api/permissions/index.mjs.map +1 -0
  425. package/dist/services/content-api/permissions/providers/action.d.ts +20 -0
  426. package/dist/services/content-api/permissions/providers/action.d.ts.map +1 -0
  427. package/dist/services/content-api/permissions/providers/action.js +16 -0
  428. package/dist/services/content-api/permissions/providers/action.js.map +1 -0
  429. package/dist/services/content-api/permissions/providers/action.mjs +17 -0
  430. package/dist/services/content-api/permissions/providers/action.mjs.map +1 -0
  431. package/dist/services/content-api/permissions/providers/condition.d.ts +24 -0
  432. package/dist/services/content-api/permissions/providers/condition.d.ts.map +1 -0
  433. package/dist/services/content-api/permissions/providers/condition.js +16 -0
  434. package/dist/services/content-api/permissions/providers/condition.js.map +1 -0
  435. package/dist/services/content-api/permissions/providers/condition.mjs +17 -0
  436. package/dist/services/content-api/permissions/providers/condition.mjs.map +1 -0
  437. package/dist/services/content-api/permissions/providers/index.d.ts +3 -0
  438. package/dist/services/content-api/permissions/providers/index.d.ts.map +1 -0
  439. package/dist/services/core-store.d.ts +33 -0
  440. package/dist/services/core-store.d.ts.map +1 -0
  441. package/dist/services/core-store.js +107 -0
  442. package/dist/services/core-store.js.map +1 -0
  443. package/dist/services/core-store.mjs +107 -0
  444. package/dist/services/core-store.mjs.map +1 -0
  445. package/dist/services/cron.d.ts +27 -0
  446. package/dist/services/cron.d.ts.map +1 -0
  447. package/dist/services/cron.js +63 -0
  448. package/dist/services/cron.js.map +1 -0
  449. package/dist/services/cron.mjs +64 -0
  450. package/dist/services/cron.mjs.map +1 -0
  451. package/dist/services/custom-fields.d.ts +4 -0
  452. package/dist/services/custom-fields.d.ts.map +1 -0
  453. package/dist/services/custom-fields.js +10 -0
  454. package/dist/services/custom-fields.js.map +1 -0
  455. package/dist/services/custom-fields.mjs +11 -0
  456. package/dist/services/custom-fields.mjs.map +1 -0
  457. package/dist/services/document-service/components.d.ts +2 -0
  458. package/dist/services/document-service/components.d.ts.map +1 -0
  459. package/dist/services/document-service/document-engine.d.ts +8 -0
  460. package/dist/services/document-service/document-engine.d.ts.map +1 -0
  461. package/dist/services/document-service/document-engine.js +200 -0
  462. package/dist/services/document-service/document-engine.js.map +1 -0
  463. package/dist/services/document-service/document-engine.mjs +201 -0
  464. package/dist/services/document-service/document-engine.mjs.map +1 -0
  465. package/dist/services/document-service/document-service.d.ts +21 -0
  466. package/dist/services/document-service/document-service.d.ts.map +1 -0
  467. package/dist/services/document-service/document-service.js +132 -0
  468. package/dist/services/document-service/document-service.js.map +1 -0
  469. package/dist/services/document-service/document-service.mjs +132 -0
  470. package/dist/services/document-service/document-service.mjs.map +1 -0
  471. package/dist/services/document-service/middlewares/defaults/draft-and-publish.d.ts +26 -0
  472. package/dist/services/document-service/middlewares/defaults/draft-and-publish.d.ts.map +1 -0
  473. package/dist/services/document-service/middlewares/defaults/draft-and-publish.js +58 -0
  474. package/dist/services/document-service/middlewares/defaults/draft-and-publish.js.map +1 -0
  475. package/dist/services/document-service/middlewares/defaults/draft-and-publish.mjs +58 -0
  476. package/dist/services/document-service/middlewares/defaults/draft-and-publish.mjs.map +1 -0
  477. package/dist/services/document-service/middlewares/defaults/index.d.ts +3 -0
  478. package/dist/services/document-service/middlewares/defaults/index.d.ts.map +1 -0
  479. package/dist/services/document-service/middlewares/defaults/index.js +82 -0
  480. package/dist/services/document-service/middlewares/defaults/index.js.map +1 -0
  481. package/dist/services/document-service/middlewares/defaults/index.mjs +82 -0
  482. package/dist/services/document-service/middlewares/defaults/index.mjs.map +1 -0
  483. package/dist/services/document-service/middlewares/defaults/locales.d.ts +18 -0
  484. package/dist/services/document-service/middlewares/defaults/locales.d.ts.map +1 -0
  485. package/dist/services/document-service/middlewares/defaults/locales.js +50 -0
  486. package/dist/services/document-service/middlewares/defaults/locales.js.map +1 -0
  487. package/dist/services/document-service/middlewares/defaults/locales.mjs +50 -0
  488. package/dist/services/document-service/middlewares/defaults/locales.mjs.map +1 -0
  489. package/dist/services/document-service/middlewares/index.d.ts +11 -0
  490. package/dist/services/document-service/middlewares/index.d.ts.map +1 -0
  491. package/dist/services/document-service/middlewares/index.js +59 -0
  492. package/dist/services/document-service/middlewares/index.js.map +1 -0
  493. package/dist/services/document-service/middlewares/index.mjs +59 -0
  494. package/dist/services/document-service/middlewares/index.mjs.map +1 -0
  495. package/dist/services/document-service/params.d.ts +2 -0
  496. package/dist/services/document-service/params.d.ts.map +1 -0
  497. package/dist/services/entity-service/attributes/index.d.ts +6 -0
  498. package/dist/services/entity-service/attributes/index.d.ts.map +1 -0
  499. package/dist/services/entity-service/attributes/index.js +22 -0
  500. package/dist/services/entity-service/attributes/index.js.map +1 -0
  501. package/dist/services/entity-service/attributes/index.mjs +22 -0
  502. package/dist/services/entity-service/attributes/index.mjs.map +1 -0
  503. package/dist/services/entity-service/attributes/transforms.d.ts +10 -0
  504. package/dist/services/entity-service/attributes/transforms.d.ts.map +1 -0
  505. package/dist/services/entity-service/attributes/transforms.js +20 -0
  506. package/dist/services/entity-service/attributes/transforms.js.map +1 -0
  507. package/dist/services/entity-service/attributes/transforms.mjs +19 -0
  508. package/dist/services/entity-service/attributes/transforms.mjs.map +1 -0
  509. package/dist/services/entity-service/components.d.ts +23 -0
  510. package/dist/services/entity-service/components.d.ts.map +1 -0
  511. package/dist/services/entity-service/components.js +384 -0
  512. package/dist/services/entity-service/components.js.map +1 -0
  513. package/dist/services/entity-service/components.mjs +382 -0
  514. package/dist/services/entity-service/components.mjs.map +1 -0
  515. package/dist/services/entity-service/index.d.ts +15 -0
  516. package/dist/services/entity-service/index.d.ts.map +1 -0
  517. package/dist/services/entity-service/index.js +328 -0
  518. package/dist/services/entity-service/index.js.map +1 -0
  519. package/dist/services/entity-service/index.mjs +326 -0
  520. package/dist/services/entity-service/index.mjs.map +1 -0
  521. package/dist/services/entity-service/params.d.ts +8 -0
  522. package/dist/services/entity-service/params.d.ts.map +1 -0
  523. package/dist/services/entity-service/params.js +8 -0
  524. package/dist/services/entity-service/params.js.map +1 -0
  525. package/dist/services/entity-service/params.mjs +8 -0
  526. package/dist/services/entity-service/params.mjs.map +1 -0
  527. package/dist/services/entity-validator/blocks-validator.d.ts +4 -0
  528. package/dist/services/entity-validator/blocks-validator.d.ts.map +1 -0
  529. package/dist/services/entity-validator/blocks-validator.js +107 -0
  530. package/dist/services/entity-validator/blocks-validator.js.map +1 -0
  531. package/dist/services/entity-validator/blocks-validator.mjs +108 -0
  532. package/dist/services/entity-validator/blocks-validator.mjs.map +1 -0
  533. package/dist/services/entity-validator/index.d.ts +8 -0
  534. package/dist/services/entity-validator/index.d.ts.map +1 -0
  535. package/dist/services/entity-validator/index.js +322 -0
  536. package/dist/services/entity-validator/index.js.map +1 -0
  537. package/dist/services/entity-validator/index.mjs +321 -0
  538. package/dist/services/entity-validator/index.mjs.map +1 -0
  539. package/dist/services/entity-validator/validators.d.ts +39 -0
  540. package/dist/services/entity-validator/validators.d.ts.map +1 -0
  541. package/dist/services/entity-validator/validators.js +122 -0
  542. package/dist/services/entity-validator/validators.js.map +1 -0
  543. package/dist/services/entity-validator/validators.mjs +120 -0
  544. package/dist/services/entity-validator/validators.mjs.map +1 -0
  545. package/dist/services/errors.d.ts +40 -0
  546. package/dist/services/errors.d.ts.map +1 -0
  547. package/dist/services/errors.js +76 -0
  548. package/dist/services/errors.js.map +1 -0
  549. package/dist/services/errors.mjs +74 -0
  550. package/dist/services/errors.mjs.map +1 -0
  551. package/dist/services/event-hub.d.ts +19 -0
  552. package/dist/services/event-hub.d.ts.map +1 -0
  553. package/dist/services/event-hub.js +67 -0
  554. package/dist/services/event-hub.js.map +1 -0
  555. package/dist/services/event-hub.mjs +68 -0
  556. package/dist/services/event-hub.mjs.map +1 -0
  557. package/dist/services/features.d.ts +10 -0
  558. package/dist/services/features.d.ts.map +1 -0
  559. package/dist/services/features.js +17 -0
  560. package/dist/services/features.js.map +1 -0
  561. package/dist/services/features.mjs +17 -0
  562. package/dist/services/features.mjs.map +1 -0
  563. package/dist/services/fs.d.ts +13 -0
  564. package/dist/services/fs.d.ts.map +1 -0
  565. package/dist/services/fs.js +51 -0
  566. package/dist/services/fs.js.map +1 -0
  567. package/dist/services/fs.mjs +49 -0
  568. package/dist/services/fs.mjs.map +1 -0
  569. package/dist/services/metrics/admin-user-hash.d.ts +7 -0
  570. package/dist/services/metrics/admin-user-hash.d.ts.map +1 -0
  571. package/dist/services/metrics/admin-user-hash.js +14 -0
  572. package/dist/services/metrics/admin-user-hash.js.map +1 -0
  573. package/dist/services/metrics/admin-user-hash.mjs +12 -0
  574. package/dist/services/metrics/admin-user-hash.mjs.map +1 -0
  575. package/dist/services/metrics/index.d.ts +14 -0
  576. package/dist/services/metrics/index.d.ts.map +1 -0
  577. package/dist/services/metrics/index.js +45 -0
  578. package/dist/services/metrics/index.js.map +1 -0
  579. package/dist/services/metrics/index.mjs +46 -0
  580. package/dist/services/metrics/index.mjs.map +1 -0
  581. package/dist/services/metrics/is-truthy.d.ts +3 -0
  582. package/dist/services/metrics/is-truthy.d.ts.map +1 -0
  583. package/dist/services/metrics/is-truthy.js +9 -0
  584. package/dist/services/metrics/is-truthy.js.map +1 -0
  585. package/dist/services/metrics/is-truthy.mjs +8 -0
  586. package/dist/services/metrics/is-truthy.mjs.map +1 -0
  587. package/dist/services/metrics/middleware.d.ts +7 -0
  588. package/dist/services/metrics/middleware.d.ts.map +1 -0
  589. package/dist/services/metrics/middleware.js +25 -0
  590. package/dist/services/metrics/middleware.js.map +1 -0
  591. package/dist/services/metrics/middleware.mjs +26 -0
  592. package/dist/services/metrics/middleware.mjs.map +1 -0
  593. package/dist/services/metrics/rate-limiter.d.ts +7 -0
  594. package/dist/services/metrics/rate-limiter.d.ts.map +1 -0
  595. package/dist/services/metrics/rate-limiter.js +21 -0
  596. package/dist/services/metrics/rate-limiter.js.map +1 -0
  597. package/dist/services/metrics/rate-limiter.mjs +22 -0
  598. package/dist/services/metrics/rate-limiter.mjs.map +1 -0
  599. package/dist/services/metrics/sender.d.ts +13 -0
  600. package/dist/services/metrics/sender.d.ts.map +1 -0
  601. package/dist/services/metrics/sender.js +76 -0
  602. package/dist/services/metrics/sender.js.map +1 -0
  603. package/dist/services/metrics/sender.mjs +70 -0
  604. package/dist/services/metrics/sender.mjs.map +1 -0
  605. package/dist/services/request-context.d.ts +7 -0
  606. package/dist/services/request-context.d.ts.map +1 -0
  607. package/dist/services/request-context.js +13 -0
  608. package/dist/services/request-context.js.map +1 -0
  609. package/dist/services/request-context.mjs +14 -0
  610. package/dist/services/request-context.mjs.map +1 -0
  611. package/dist/services/server/admin-api.d.ts +11 -0
  612. package/dist/services/server/admin-api.d.ts.map +1 -0
  613. package/dist/services/server/admin-api.js +13 -0
  614. package/dist/services/server/admin-api.js.map +1 -0
  615. package/dist/services/server/admin-api.mjs +13 -0
  616. package/dist/services/server/admin-api.mjs.map +1 -0
  617. package/dist/services/server/api.d.ts +15 -0
  618. package/dist/services/server/api.d.ts.map +1 -0
  619. package/dist/services/server/api.js +30 -0
  620. package/dist/services/server/api.js.map +1 -0
  621. package/dist/services/server/api.mjs +28 -0
  622. package/dist/services/server/api.mjs.map +1 -0
  623. package/dist/services/server/compose-endpoint.d.ts +7 -0
  624. package/dist/services/server/compose-endpoint.d.ts.map +1 -0
  625. package/dist/services/server/compose-endpoint.js +115 -0
  626. package/dist/services/server/compose-endpoint.js.map +1 -0
  627. package/dist/services/server/compose-endpoint.mjs +114 -0
  628. package/dist/services/server/compose-endpoint.mjs.map +1 -0
  629. package/dist/services/server/content-api.d.ts +11 -0
  630. package/dist/services/server/content-api.d.ts.map +1 -0
  631. package/dist/services/server/content-api.js +12 -0
  632. package/dist/services/server/content-api.js.map +1 -0
  633. package/dist/services/server/content-api.mjs +12 -0
  634. package/dist/services/server/content-api.mjs.map +1 -0
  635. package/dist/services/server/http-server.d.ts +10 -0
  636. package/dist/services/server/http-server.d.ts.map +1 -0
  637. package/dist/services/server/http-server.js +50 -0
  638. package/dist/services/server/http-server.js.map +1 -0
  639. package/dist/services/server/http-server.mjs +48 -0
  640. package/dist/services/server/http-server.mjs.map +1 -0
  641. package/dist/services/server/index.d.ts +4 -0
  642. package/dist/services/server/index.d.ts.map +1 -0
  643. package/dist/services/server/index.js +88 -0
  644. package/dist/services/server/index.js.map +1 -0
  645. package/dist/services/server/index.mjs +86 -0
  646. package/dist/services/server/index.mjs.map +1 -0
  647. package/dist/services/server/koa.d.ts +16 -0
  648. package/dist/services/server/koa.d.ts.map +1 -0
  649. package/dist/services/server/koa.js +52 -0
  650. package/dist/services/server/koa.js.map +1 -0
  651. package/dist/services/server/koa.mjs +48 -0
  652. package/dist/services/server/koa.mjs.map +1 -0
  653. package/dist/services/server/middleware.d.ts +11 -0
  654. package/dist/services/server/middleware.d.ts.map +1 -0
  655. package/dist/services/server/middleware.js +92 -0
  656. package/dist/services/server/middleware.js.map +1 -0
  657. package/dist/services/server/middleware.mjs +90 -0
  658. package/dist/services/server/middleware.mjs.map +1 -0
  659. package/dist/services/server/policy.d.ts +4 -0
  660. package/dist/services/server/policy.d.ts.map +1 -0
  661. package/dist/services/server/policy.js +20 -0
  662. package/dist/services/server/policy.js.map +1 -0
  663. package/dist/services/server/policy.mjs +20 -0
  664. package/dist/services/server/policy.mjs.map +1 -0
  665. package/dist/services/server/register-middlewares.d.ts +7 -0
  666. package/dist/services/server/register-middlewares.d.ts.map +1 -0
  667. package/dist/services/server/register-middlewares.js +72 -0
  668. package/dist/services/server/register-middlewares.js.map +1 -0
  669. package/dist/services/server/register-middlewares.mjs +73 -0
  670. package/dist/services/server/register-middlewares.mjs.map +1 -0
  671. package/dist/services/server/register-routes.d.ts +7 -0
  672. package/dist/services/server/register-routes.d.ts.map +1 -0
  673. package/dist/services/server/register-routes.js +76 -0
  674. package/dist/services/server/register-routes.js.map +1 -0
  675. package/dist/services/server/register-routes.mjs +75 -0
  676. package/dist/services/server/register-routes.mjs.map +1 -0
  677. package/dist/services/server/routing.d.ts +34 -0
  678. package/dist/services/server/routing.d.ts.map +1 -0
  679. package/dist/services/server/routing.js +91 -0
  680. package/dist/services/server/routing.js.map +1 -0
  681. package/dist/services/server/routing.mjs +89 -0
  682. package/dist/services/server/routing.mjs.map +1 -0
  683. package/dist/services/utils/dynamic-zones.d.ts +3 -0
  684. package/dist/services/utils/dynamic-zones.d.ts.map +1 -0
  685. package/dist/services/utils/dynamic-zones.js +16 -0
  686. package/dist/services/utils/dynamic-zones.js.map +1 -0
  687. package/dist/services/utils/dynamic-zones.mjs +17 -0
  688. package/dist/services/utils/dynamic-zones.mjs.map +1 -0
  689. package/dist/services/utils/upload-files.d.ts +8 -0
  690. package/dist/services/utils/upload-files.d.ts.map +1 -0
  691. package/dist/services/utils/upload-files.js +64 -0
  692. package/dist/services/utils/upload-files.js.map +1 -0
  693. package/dist/services/utils/upload-files.mjs +63 -0
  694. package/dist/services/utils/upload-files.mjs.map +1 -0
  695. package/dist/services/webhook-runner.d.ts +49 -0
  696. package/dist/services/webhook-runner.d.ts.map +1 -0
  697. package/dist/services/webhook-runner.js +133 -0
  698. package/dist/services/webhook-runner.js.map +1 -0
  699. package/dist/services/webhook-runner.mjs +131 -0
  700. package/dist/services/webhook-runner.mjs.map +1 -0
  701. package/dist/services/webhook-store.d.ts +30 -0
  702. package/dist/services/webhook-store.d.ts.map +1 -0
  703. package/dist/services/webhook-store.js +104 -0
  704. package/dist/services/webhook-store.js.map +1 -0
  705. package/dist/services/webhook-store.mjs +104 -0
  706. package/dist/services/webhook-store.mjs.map +1 -0
  707. package/dist/services/worker-queue.d.ts +20 -0
  708. package/dist/services/worker-queue.d.ts.map +1 -0
  709. package/dist/services/worker-queue.js +56 -0
  710. package/dist/services/worker-queue.js.map +1 -0
  711. package/dist/services/worker-queue.mjs +55 -0
  712. package/dist/services/worker-queue.mjs.map +1 -0
  713. package/dist/utils/convert-custom-field-type.d.ts +3 -0
  714. package/dist/utils/convert-custom-field-type.d.ts.map +1 -0
  715. package/dist/utils/convert-custom-field-type.js +24 -0
  716. package/dist/utils/convert-custom-field-type.js.map +1 -0
  717. package/dist/utils/convert-custom-field-type.mjs +24 -0
  718. package/dist/utils/convert-custom-field-type.mjs.map +1 -0
  719. package/dist/utils/cron.d.ts +8 -0
  720. package/dist/utils/cron.d.ts.map +1 -0
  721. package/dist/utils/cron.js +38 -0
  722. package/dist/utils/cron.js.map +1 -0
  723. package/dist/utils/cron.mjs +38 -0
  724. package/dist/utils/cron.mjs.map +1 -0
  725. package/dist/utils/ee.d.ts +2 -0
  726. package/dist/utils/ee.d.ts.map +1 -0
  727. package/dist/utils/fetch.d.ts +4 -0
  728. package/dist/utils/fetch.d.ts.map +1 -0
  729. package/dist/utils/fetch.js +20 -0
  730. package/dist/utils/fetch.js.map +1 -0
  731. package/dist/utils/fetch.mjs +20 -0
  732. package/dist/utils/fetch.mjs.map +1 -0
  733. package/dist/utils/filepath-to-prop-path.d.ts +5 -0
  734. package/dist/utils/filepath-to-prop-path.d.ts.map +1 -0
  735. package/dist/utils/filepath-to-prop-path.js +12 -0
  736. package/dist/utils/filepath-to-prop-path.js.map +1 -0
  737. package/dist/utils/filepath-to-prop-path.mjs +10 -0
  738. package/dist/utils/filepath-to-prop-path.mjs.map +1 -0
  739. package/dist/utils/get-dirs.d.ts +9 -0
  740. package/dist/utils/get-dirs.d.ts.map +1 -0
  741. package/dist/utils/get-dirs.js +30 -0
  742. package/dist/utils/get-dirs.js.map +1 -0
  743. package/dist/utils/get-dirs.mjs +30 -0
  744. package/dist/utils/get-dirs.mjs.map +1 -0
  745. package/dist/utils/index.d.ts +12 -0
  746. package/dist/utils/index.d.ts.map +1 -0
  747. package/dist/utils/is-initialized.d.ts +6 -0
  748. package/dist/utils/is-initialized.d.ts.map +1 -0
  749. package/dist/utils/is-initialized.js +16 -0
  750. package/dist/utils/is-initialized.js.map +1 -0
  751. package/dist/utils/is-initialized.mjs +16 -0
  752. package/dist/utils/is-initialized.mjs.map +1 -0
  753. package/dist/utils/lifecycles.d.ts +6 -0
  754. package/dist/utils/lifecycles.d.ts.map +1 -0
  755. package/dist/utils/lifecycles.js +9 -0
  756. package/dist/utils/lifecycles.js.map +1 -0
  757. package/dist/utils/lifecycles.mjs +9 -0
  758. package/dist/utils/lifecycles.mjs.map +1 -0
  759. package/dist/utils/load-config-file.d.ts +2 -0
  760. package/dist/utils/load-config-file.d.ts.map +1 -0
  761. package/dist/utils/load-config-file.js +45 -0
  762. package/dist/utils/load-config-file.js.map +1 -0
  763. package/dist/utils/load-config-file.mjs +42 -0
  764. package/dist/utils/load-config-file.mjs.map +1 -0
  765. package/dist/utils/load-files.d.ts +11 -0
  766. package/dist/utils/load-files.d.ts.map +1 -0
  767. package/dist/utils/load-files.js +39 -0
  768. package/dist/utils/load-files.js.map +1 -0
  769. package/dist/utils/load-files.mjs +35 -0
  770. package/dist/utils/load-files.mjs.map +1 -0
  771. package/dist/utils/open-browser.d.ts +4 -0
  772. package/dist/utils/open-browser.d.ts.map +1 -0
  773. package/dist/utils/open-browser.js +11 -0
  774. package/dist/utils/open-browser.js.map +1 -0
  775. package/dist/utils/open-browser.mjs +9 -0
  776. package/dist/utils/open-browser.mjs.map +1 -0
  777. package/dist/utils/signals.d.ts +3 -0
  778. package/dist/utils/signals.d.ts.map +1 -0
  779. package/dist/utils/signals.js +17 -0
  780. package/dist/utils/signals.js.map +1 -0
  781. package/dist/utils/signals.mjs +17 -0
  782. package/dist/utils/signals.mjs.map +1 -0
  783. package/dist/utils/startup-logger.d.ts +10 -0
  784. package/dist/utils/startup-logger.d.ts.map +1 -0
  785. package/dist/utils/startup-logger.js +81 -0
  786. package/dist/utils/startup-logger.js.map +1 -0
  787. package/dist/utils/startup-logger.mjs +77 -0
  788. package/dist/utils/startup-logger.mjs.map +1 -0
  789. package/dist/utils/transform-content-types-to-models.d.ts +6 -0
  790. package/dist/utils/transform-content-types-to-models.d.ts.map +1 -0
  791. package/dist/utils/transform-content-types-to-models.js +198 -0
  792. package/dist/utils/transform-content-types-to-models.js.map +1 -0
  793. package/dist/utils/transform-content-types-to-models.mjs +196 -0
  794. package/dist/utils/transform-content-types-to-models.mjs.map +1 -0
  795. package/dist/utils/update-notifier/index.d.ts +8 -0
  796. package/dist/utils/update-notifier/index.d.ts.map +1 -0
  797. package/dist/utils/update-notifier/index.js +88 -0
  798. package/dist/utils/update-notifier/index.js.map +1 -0
  799. package/dist/utils/update-notifier/index.mjs +81 -0
  800. package/dist/utils/update-notifier/index.mjs.map +1 -0
  801. package/package.json +134 -0
  802. package/resources/key.pub +9 -0
@@ -0,0 +1,64 @@
1
+ import { Job } from "node-schedule";
2
+ import { isFunction } from "lodash/fp";
3
+ const createCronService = () => {
4
+ let jobsSpecs = [];
5
+ let running = false;
6
+ return {
7
+ add(tasks = {}) {
8
+ for (const taskExpression of Object.keys(tasks)) {
9
+ const taskValue = tasks[taskExpression];
10
+ let fn;
11
+ let options;
12
+ let taskName;
13
+ if (isFunction(taskValue)) {
14
+ taskName = null;
15
+ fn = taskValue.bind(tasks);
16
+ options = taskExpression;
17
+ } else if (isFunction(taskValue.task)) {
18
+ taskName = taskExpression;
19
+ fn = taskValue.task.bind(taskValue);
20
+ options = taskValue.options;
21
+ } else {
22
+ throw new Error(
23
+ `Could not schedule a cron job for "${taskExpression}": no function found.`
24
+ );
25
+ }
26
+ const fnWithStrapi = (...args) => fn({ strapi }, ...args);
27
+ const job = new Job(fnWithStrapi);
28
+ jobsSpecs.push({ job, options, name: taskName });
29
+ if (running) {
30
+ job.schedule(options);
31
+ }
32
+ }
33
+ return this;
34
+ },
35
+ remove(name) {
36
+ if (!name) {
37
+ throw new Error("You must provide a name to remove a cron job.");
38
+ }
39
+ jobsSpecs.filter(({ name: jobSpecName }) => jobSpecName === name).forEach(({ job }) => job.cancel());
40
+ jobsSpecs = jobsSpecs.filter(({ name: jobSpecName }) => jobSpecName !== name);
41
+ return this;
42
+ },
43
+ start() {
44
+ jobsSpecs.forEach(({ job, options }) => job.schedule(options));
45
+ running = true;
46
+ return this;
47
+ },
48
+ stop() {
49
+ jobsSpecs.forEach(({ job }) => job.cancel());
50
+ running = false;
51
+ return this;
52
+ },
53
+ destroy() {
54
+ this.stop();
55
+ jobsSpecs = [];
56
+ return this;
57
+ },
58
+ jobs: jobsSpecs
59
+ };
60
+ };
61
+ export {
62
+ createCronService as default
63
+ };
64
+ //# sourceMappingURL=cron.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cron.mjs","sources":["../../src/services/cron.ts"],"sourcesContent":["import { Job } from 'node-schedule';\nimport { isFunction } from 'lodash/fp';\nimport type { Strapi } from '@strapi/types';\n\ninterface JobSpec {\n job: Job;\n options: string | number | Date;\n name: string | null;\n}\n\ntype TaskFn = ({ strapi }: { strapi: Strapi }, ...args: unknown[]) => Promise<unknown>;\n\ntype Task =\n | TaskFn\n | {\n task: TaskFn;\n options: string;\n };\n\ninterface Tasks {\n [key: string]: Task;\n}\n\nconst createCronService = () => {\n let jobsSpecs: JobSpec[] = [];\n let running = false;\n\n return {\n add(tasks: Tasks = {}) {\n for (const taskExpression of Object.keys(tasks)) {\n const taskValue = tasks[taskExpression];\n\n let fn: TaskFn;\n let options: string | number | Date;\n let taskName: string | null;\n if (isFunction(taskValue)) {\n // don't use task name if key is the rule\n taskName = null;\n fn = taskValue.bind(tasks);\n options = taskExpression;\n } else if (isFunction(taskValue.task)) {\n // set task name if key is not the rule\n taskName = taskExpression;\n fn = taskValue.task.bind(taskValue);\n options = taskValue.options;\n } else {\n throw new Error(\n `Could not schedule a cron job for \"${taskExpression}\": no function found.`\n );\n }\n\n const fnWithStrapi = (...args: unknown[]) => fn({ strapi }, ...args);\n\n // const job = new Job(null, fnWithStrapi);\n const job = new Job(fnWithStrapi);\n jobsSpecs.push({ job, options, name: taskName });\n\n if (running) {\n job.schedule(options);\n }\n }\n return this;\n },\n\n remove(name: string) {\n if (!name) {\n throw new Error('You must provide a name to remove a cron job.');\n }\n\n jobsSpecs\n .filter(({ name: jobSpecName }) => jobSpecName === name)\n .forEach(({ job }) => job.cancel());\n\n jobsSpecs = jobsSpecs.filter(({ name: jobSpecName }) => jobSpecName !== name);\n return this;\n },\n\n start() {\n jobsSpecs.forEach(({ job, options }) => job.schedule(options));\n running = true;\n return this;\n },\n\n stop() {\n jobsSpecs.forEach(({ job }) => job.cancel());\n running = false;\n return this;\n },\n\n destroy() {\n this.stop();\n jobsSpecs = [];\n return this;\n },\n jobs: jobsSpecs,\n };\n};\n\nexport default createCronService;\n"],"names":[],"mappings":";;AAuBA,MAAM,oBAAoB,MAAM;AAC9B,MAAI,YAAuB,CAAA;AAC3B,MAAI,UAAU;AAEP,SAAA;AAAA,IACL,IAAI,QAAe,IAAI;AACrB,iBAAW,kBAAkB,OAAO,KAAK,KAAK,GAAG;AACzC,cAAA,YAAY,MAAM,cAAc;AAElC,YAAA;AACA,YAAA;AACA,YAAA;AACA,YAAA,WAAW,SAAS,GAAG;AAEd,qBAAA;AACN,eAAA,UAAU,KAAK,KAAK;AACf,oBAAA;AAAA,QACD,WAAA,WAAW,UAAU,IAAI,GAAG;AAE1B,qBAAA;AACN,eAAA,UAAU,KAAK,KAAK,SAAS;AAClC,oBAAU,UAAU;AAAA,QAAA,OACf;AACL,gBAAM,IAAI;AAAA,YACR,sCAAsC,cAAc;AAAA,UAAA;AAAA,QAExD;AAEM,cAAA,eAAe,IAAI,SAAoB,GAAG,EAAE,OAAO,GAAG,GAAG,IAAI;AAG7D,cAAA,MAAM,IAAI,IAAI,YAAY;AAChC,kBAAU,KAAK,EAAE,KAAK,SAAS,MAAM,UAAU;AAE/C,YAAI,SAAS;AACX,cAAI,SAAS,OAAO;AAAA,QACtB;AAAA,MACF;AACO,aAAA;AAAA,IACT;AAAA,IAEA,OAAO,MAAc;AACnB,UAAI,CAAC,MAAM;AACH,cAAA,IAAI,MAAM,+CAA+C;AAAA,MACjE;AAEA,gBACG,OAAO,CAAC,EAAE,MAAM,YAAA,MAAkB,gBAAgB,IAAI,EACtD,QAAQ,CAAC,EAAE,IAAA,MAAU,IAAI,OAAQ,CAAA;AAExB,kBAAA,UAAU,OAAO,CAAC,EAAE,MAAM,YAAY,MAAM,gBAAgB,IAAI;AACrE,aAAA;AAAA,IACT;AAAA,IAEA,QAAQ;AACI,gBAAA,QAAQ,CAAC,EAAE,KAAK,QAAc,MAAA,IAAI,SAAS,OAAO,CAAC;AACnD,gBAAA;AACH,aAAA;AAAA,IACT;AAAA,IAEA,OAAO;AACL,gBAAU,QAAQ,CAAC,EAAE,IAAU,MAAA,IAAI,QAAQ;AACjC,gBAAA;AACH,aAAA;AAAA,IACT;AAAA,IAEA,UAAU;AACR,WAAK,KAAK;AACV,kBAAY,CAAA;AACL,aAAA;AAAA,IACT;AAAA,IACA,MAAM;AAAA,EAAA;AAEV;"}
@@ -0,0 +1,4 @@
1
+ import type { Strapi, CustomFields } from '@strapi/types';
2
+ declare const createCustomFields: (strapi: Strapi) => CustomFields.CustomFields;
3
+ export default createCustomFields;
4
+ //# sourceMappingURL=custom-fields.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"custom-fields.d.ts","sourceRoot":"","sources":["../../src/services/custom-fields.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAE1D,QAAA,MAAM,kBAAkB,WAAY,MAAM,KAAG,yBAM5C,CAAC;AAEF,eAAe,kBAAkB,CAAC"}
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+ const createCustomFields = (strapi) => {
3
+ return {
4
+ register(customField) {
5
+ strapi.get("custom-fields").add(customField);
6
+ }
7
+ };
8
+ };
9
+ module.exports = createCustomFields;
10
+ //# sourceMappingURL=custom-fields.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"custom-fields.js","sources":["../../src/services/custom-fields.ts"],"sourcesContent":["import type { Strapi, CustomFields } from '@strapi/types';\n\nconst createCustomFields = (strapi: Strapi): CustomFields.CustomFields => {\n return {\n register(customField) {\n strapi.get('custom-fields').add(customField);\n },\n };\n};\n\nexport default createCustomFields;\n"],"names":[],"mappings":";AAEM,MAAA,qBAAqB,CAAC,WAA8C;AACjE,SAAA;AAAA,IACL,SAAS,aAAa;AACpB,aAAO,IAAI,eAAe,EAAE,IAAI,WAAW;AAAA,IAC7C;AAAA,EAAA;AAEJ;;"}
@@ -0,0 +1,11 @@
1
+ const createCustomFields = (strapi) => {
2
+ return {
3
+ register(customField) {
4
+ strapi.get("custom-fields").add(customField);
5
+ }
6
+ };
7
+ };
8
+ export {
9
+ createCustomFields as default
10
+ };
11
+ //# sourceMappingURL=custom-fields.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"custom-fields.mjs","sources":["../../src/services/custom-fields.ts"],"sourcesContent":["import type { Strapi, CustomFields } from '@strapi/types';\n\nconst createCustomFields = (strapi: Strapi): CustomFields.CustomFields => {\n return {\n register(customField) {\n strapi.get('custom-fields').add(customField);\n },\n };\n};\n\nexport default createCustomFields;\n"],"names":[],"mappings":"AAEM,MAAA,qBAAqB,CAAC,WAA8C;AACjE,SAAA;AAAA,IACL,SAAS,aAAa;AACpB,aAAO,IAAI,eAAe,EAAE,IAAI,WAAW;AAAA,IAC7C;AAAA,EAAA;AAEJ;"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=components.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"components.d.ts","sourceRoot":"","sources":["../../../src/services/document-service/components.ts"],"names":[],"mappings":""}
@@ -0,0 +1,8 @@
1
+ import type { Database } from '@strapi/database';
2
+ import type { Documents, Strapi } from '@strapi/types';
3
+ declare const _default: (ctx: {
4
+ strapi: Strapi;
5
+ db: Database;
6
+ }) => Documents.Engine;
7
+ export default _default;
8
+ //# sourceMappingURL=document-engine.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"document-engine.d.ts","sourceRoot":"","sources":["../../../src/services/document-service/document-engine.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AACjD,OAAO,KAAK,EAAU,SAAS,EAAkB,MAAM,EAAE,MAAM,eAAe,CAAC;8BA2S1D;IAAE,QAAQ,MAAM,CAAC;IAAC,EAAE,EAAE,QAAQ,CAAA;CAAE,KAAG,UAAU,MAAM;AAAxE,wBAKE"}
@@ -0,0 +1,200 @@
1
+ "use strict";
2
+ const strapiUtils = require("@strapi/utils");
3
+ const _ = require("lodash/fp");
4
+ const uploadFiles = require("../utils/upload-files.js");
5
+ const components = require("../entity-service/components.js");
6
+ const transformContentTypesToModels = require("../../utils/transform-content-types-to-models.js");
7
+ const index$1 = require("../entity-service/attributes/index.js");
8
+ const index = require("../entity-validator/index.js");
9
+ const params = require("../entity-service/params.js");
10
+ const { transformParamsToQuery } = strapiUtils.convertQueryParams;
11
+ const createPipeline = (data, context) => {
12
+ return index$1.applyTransforms(data, context);
13
+ };
14
+ const updatePipeline = (data, context) => {
15
+ return index$1.applyTransforms(data, context);
16
+ };
17
+ const createDocumentEngine = ({
18
+ strapi,
19
+ db
20
+ }) => ({
21
+ uploadFiles,
22
+ async findMany(uid, params2) {
23
+ const { kind } = strapi.getModel(uid);
24
+ const query = transformParamsToQuery(uid, params2 || {});
25
+ query.where = { ...params2?.lookup, ...query.where };
26
+ if (kind === "singleType") {
27
+ return db.query(uid).findOne(query);
28
+ }
29
+ return db.query(uid).findMany(query);
30
+ },
31
+ async findFirst(uid, params2) {
32
+ const query = transformParamsToQuery(uid, params2 || {});
33
+ return db.query(uid).findOne({ ...query, where: { ...params2?.lookup, ...query.where } });
34
+ },
35
+ async findOne(uid, documentId, params2) {
36
+ const query = transformParamsToQuery(uid, params2 || {});
37
+ return db.query(uid).findOne({ ...query, where: { ...params2?.lookup, ...query.where, documentId } });
38
+ },
39
+ async delete(uid, documentId, params2 = {}) {
40
+ const query = transformParamsToQuery(uid, params2);
41
+ if (params2.status === "draft") {
42
+ throw new Error("Cannot delete a draft document");
43
+ }
44
+ const entriesToDelete = await db.query(uid).findMany({
45
+ ...query,
46
+ where: {
47
+ ...params2.lookup,
48
+ ...query?.where,
49
+ documentId
50
+ }
51
+ });
52
+ await strapiUtils.mapAsync(entriesToDelete, async (entryToDelete) => {
53
+ const componentsToDelete = await components.getComponents(uid, entryToDelete);
54
+ await db.query(uid).delete({ where: { id: entryToDelete.id } });
55
+ await components.deleteComponents(uid, componentsToDelete, { loadComponents: false });
56
+ });
57
+ return { versions: entriesToDelete };
58
+ },
59
+ // TODO: should we provide two separate methods?
60
+ async deleteMany(uid, paramsOrIds) {
61
+ let queryParams;
62
+ if (_.isArray(paramsOrIds)) {
63
+ queryParams = { filter: { documentID: { $in: paramsOrIds } } };
64
+ } else {
65
+ queryParams = paramsOrIds;
66
+ }
67
+ const query = transformParamsToQuery(uid, queryParams || {});
68
+ return db.query(uid).deleteMany(query);
69
+ },
70
+ async create(uid, params$1) {
71
+ const { data } = params$1;
72
+ if (!data) {
73
+ throw new Error("Create requires data attribute");
74
+ }
75
+ const model = strapi.getModel(uid);
76
+ const validData = await index.validateEntityCreation(model, data, {
77
+ isDraft: true,
78
+ locale: params$1?.locale
79
+ });
80
+ const componentData = await components.createComponents(uid, validData);
81
+ const entryData = createPipeline(
82
+ Object.assign(components.omitComponentData(model, validData), componentData),
83
+ {
84
+ contentType: model
85
+ }
86
+ );
87
+ const query = transformParamsToQuery(uid, params.pickSelectionParams(params$1));
88
+ return db.query(uid).create({ ...query, data: entryData });
89
+ },
90
+ // NOTE: What happens if user doesn't provide specific publications state and locale to update?
91
+ async update(uid, documentId, params$1) {
92
+ const { data } = params$1 || {};
93
+ const model = strapi.getModel(uid);
94
+ const query = transformParamsToQuery(uid, params.pickSelectionParams(params$1 || {}));
95
+ const entryToUpdate = await db.query(uid).findOne({ ...query, where: { ...params$1?.lookup, ...query?.where, documentId } });
96
+ if (!entryToUpdate) {
97
+ return null;
98
+ }
99
+ const validData = await index.validateEntityUpdate(
100
+ model,
101
+ data,
102
+ {
103
+ isDraft: true,
104
+ // Always update the draft version
105
+ locale: params$1?.locale
106
+ },
107
+ entryToUpdate
108
+ );
109
+ const componentData = await components.updateComponents(uid, entryToUpdate, validData);
110
+ const entryData = updatePipeline(
111
+ Object.assign(components.omitComponentData(model, validData), componentData),
112
+ { contentType: model }
113
+ );
114
+ return db.query(uid).update({ ...query, where: { id: entryToUpdate.id }, data: entryData });
115
+ },
116
+ async count(uid, params2 = void 0) {
117
+ const query = transformParamsToQuery(uid, params2 || {});
118
+ query.where = { ...params2?.lookup, ...query.where };
119
+ return db.query(uid).count(query);
120
+ },
121
+ async clone(uid, documentId, params$1) {
122
+ const { data = {} } = params$1;
123
+ const model = strapi.getModel(uid);
124
+ const query = transformParamsToQuery(uid, params.pickSelectionParams(params$1));
125
+ const entries = await db.query(uid).findMany({
126
+ ...query,
127
+ where: { ...params$1?.lookup, ...query.where, documentId }
128
+ });
129
+ if (!entries.length) {
130
+ return null;
131
+ }
132
+ const newDocumentId = transformContentTypesToModels.createDocumentId();
133
+ const versions = await strapiUtils.mapAsync(entries, async (entryToClone) => {
134
+ const isDraft = strapiUtils.contentTypes.isDraft(data);
135
+ const validData = await index.validateEntityUpdate(
136
+ model,
137
+ // Omit id fields, the cloned entity id will be generated by the database
138
+ _.omit(["id"], data),
139
+ { isDraft, ...params$1?.lookup },
140
+ entryToClone
141
+ );
142
+ const componentData = await components.cloneComponents(uid, entryToClone, validData);
143
+ const entityData = createPipeline(
144
+ Object.assign(components.omitComponentData(model, validData), componentData),
145
+ { contentType: model }
146
+ );
147
+ return db.query(uid).clone(entryToClone.id, {
148
+ ...query,
149
+ // Allows entityData to override the documentId (e.g. when publishing)
150
+ data: { documentId: newDocumentId, ...entityData, locale: entryToClone.locale }
151
+ });
152
+ });
153
+ return { id: newDocumentId, versions };
154
+ },
155
+ // TODO: Handle relations so they target the published version
156
+ async publish(uid, documentId, params2) {
157
+ await this.delete(uid, documentId, {
158
+ ...params2,
159
+ lookup: { ...params2?.lookup, publishedAt: { $ne: null } }
160
+ });
161
+ const clonedDocuments = await this.clone(uid, documentId, {
162
+ ...params2 || {},
163
+ // @ts-expect-error - Generic type does not have publishedAt attribute by default
164
+ data: { documentId, publishedAt: /* @__PURE__ */ new Date() }
165
+ });
166
+ return { versions: clonedDocuments?.versions || [] };
167
+ },
168
+ async unpublish(uid, documentId, params2) {
169
+ return this.delete(uid, documentId, {
170
+ ...params2,
171
+ lookup: { ...params2?.lookup, publishedAt: { $ne: null } }
172
+ });
173
+ },
174
+ /**
175
+ * Steps:
176
+ * - Delete the matching draft versions (publishedAt = null)
177
+ * - Clone the matching published versions into draft versions
178
+ */
179
+ async discardDraft(uid, documentId, params2) {
180
+ await this.delete(uid, documentId, {
181
+ ...params2,
182
+ // Delete all drafts that match query
183
+ lookup: { ...params2?.lookup, publishedAt: null }
184
+ });
185
+ const clonedDocuments = await this.clone(uid, documentId, {
186
+ ...params2 || {},
187
+ // Clone only published versions
188
+ lookup: { ...params2?.lookup, publishedAt: { $ne: null } },
189
+ // @ts-expect-error - Generic type does not have publishedAt attribute by default
190
+ data: { documentId, publishedAt: null }
191
+ });
192
+ return { versions: clonedDocuments?.versions || [] };
193
+ }
194
+ });
195
+ const createDocumentRepository = (ctx) => {
196
+ const implementation = createDocumentEngine(ctx);
197
+ return implementation;
198
+ };
199
+ module.exports = createDocumentRepository;
200
+ //# sourceMappingURL=document-engine.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"document-engine.js","sources":["../../../src/services/document-service/document-engine.ts"],"sourcesContent":["import type { Database } from '@strapi/database';\nimport type { Common, Documents, Schema, Shared, Strapi } from '@strapi/types';\nimport { contentTypes as contentTypesUtils, convertQueryParams, mapAsync } from '@strapi/utils';\n\nimport { isArray, omit } from 'lodash/fp';\nimport uploadFiles from '../utils/upload-files';\n\nimport {\n cloneComponents,\n createComponents,\n deleteComponents,\n getComponents,\n omitComponentData,\n updateComponents,\n} from '../entity-service/components';\n\nimport { createDocumentId } from '../../utils/transform-content-types-to-models';\nimport { applyTransforms } from '../entity-service/attributes';\nimport entityValidator from '../entity-validator';\nimport { pickSelectionParams } from './params';\n\nconst { transformParamsToQuery } = convertQueryParams;\n\n/**\n * TODO: Sanitization / validation built-in\n * TODO: i18n - Move logic to i18n package\n * TODO: Webhooks\n * TODO: Audit logs\n * TODO: Entity Validation - Uniqueness across same locale and publication status\n * TODO: File upload\n * TODO: replace 'any'\n * TODO: availableLocales\n *\n */\ntype Context = {\n contentType: Schema.ContentType;\n};\n\nconst createPipeline = (data: Record<string, unknown>, context: Context) => {\n return applyTransforms(data, context);\n};\n\nconst updatePipeline = (data: Record<string, unknown>, context: Context) => {\n return applyTransforms(data, context);\n};\n\nconst createDocumentEngine = ({\n strapi,\n db,\n}: {\n strapi: Strapi;\n db: Database;\n}): Documents.Engine => ({\n uploadFiles,\n\n async findMany(uid, params) {\n const { kind } = strapi.getModel(uid);\n\n const query = transformParamsToQuery(uid, params || ({} as any));\n query.where = { ...params?.lookup, ...query.where };\n\n if (kind === 'singleType') {\n return db.query(uid).findOne(query);\n }\n\n return db.query(uid).findMany(query);\n },\n\n async findFirst(uid, params) {\n const query = transformParamsToQuery(uid, params || ({} as any));\n\n return db.query(uid).findOne({ ...query, where: { ...params?.lookup, ...query.where } });\n },\n\n async findOne(uid, documentId, params) {\n const query = transformParamsToQuery(uid, params || ({} as any));\n return db\n .query(uid)\n .findOne({ ...query, where: { ...params?.lookup, ...query.where, documentId } });\n },\n\n async delete(uid, documentId, params = {} as any) {\n const query = transformParamsToQuery(uid, params as any);\n\n if (params.status === 'draft') {\n throw new Error('Cannot delete a draft document');\n }\n\n const entriesToDelete = await db.query(uid).findMany({\n ...query,\n where: {\n ...params.lookup,\n ...query?.where,\n documentId,\n },\n });\n\n // Delete all matched entries and its components\n await mapAsync(entriesToDelete, async (entryToDelete: any) => {\n const componentsToDelete = await getComponents(uid, entryToDelete);\n await db.query(uid).delete({ where: { id: entryToDelete.id } });\n await deleteComponents(uid, componentsToDelete as any, { loadComponents: false });\n });\n\n // TODO: Change return value to actual count\n return { versions: entriesToDelete };\n },\n\n // TODO: should we provide two separate methods?\n async deleteMany(uid, paramsOrIds) {\n let queryParams;\n if (isArray(paramsOrIds)) {\n queryParams = { filter: { documentID: { $in: paramsOrIds } } };\n } else {\n queryParams = paramsOrIds;\n }\n\n const query = transformParamsToQuery(uid, queryParams || ({} as any));\n\n return db.query(uid).deleteMany(query);\n },\n\n async create(uid, params) {\n // TODO: Entity validator.\n // TODO: File upload - Probably in the lifecycles?\n const { data } = params;\n\n if (!data) {\n throw new Error('Create requires data attribute');\n }\n\n const model = strapi.getModel(uid) as Shared.ContentTypes[Common.UID.ContentType];\n\n const validData = await entityValidator.validateEntityCreation(model, data, {\n isDraft: true,\n locale: params?.locale,\n });\n\n const componentData = await createComponents(uid, validData);\n const entryData = createPipeline(\n Object.assign(omitComponentData(model, validData), componentData),\n {\n contentType: model,\n }\n );\n\n // select / populate\n const query = transformParamsToQuery(uid, pickSelectionParams(params) as any);\n\n return db.query(uid).create({ ...query, data: entryData });\n },\n\n // NOTE: What happens if user doesn't provide specific publications state and locale to update?\n async update(uid, documentId, params) {\n // TODO: Prevent updating a published document\n // TODO: Entity validator.\n // TODO: File upload\n const { data } = params || {};\n const model = strapi.getModel(uid) as Shared.ContentTypes[Common.UID.ContentType];\n\n const query = transformParamsToQuery(uid, pickSelectionParams(params || {}) as any);\n\n // Find all locales of the document\n const entryToUpdate = await db\n .query(uid)\n .findOne({ ...query, where: { ...params?.lookup, ...query?.where, documentId } });\n\n // Document does not exist\n if (!entryToUpdate) {\n return null;\n }\n\n const validData = await entityValidator.validateEntityUpdate(\n model,\n data,\n {\n isDraft: true, // Always update the draft version\n locale: params?.locale,\n },\n entryToUpdate\n );\n\n const componentData = await updateComponents(uid, entryToUpdate, validData);\n const entryData = updatePipeline(\n Object.assign(omitComponentData(model, validData), componentData),\n { contentType: model }\n );\n\n return db.query(uid).update({ ...query, where: { id: entryToUpdate.id }, data: entryData });\n },\n\n async count(uid, params = undefined) {\n const query = transformParamsToQuery(uid, params || ({} as any));\n query.where = { ...params?.lookup, ...query.where };\n\n return db.query(uid).count(query);\n },\n\n async clone(uid, documentId, params) {\n // TODO: File upload\n // TODO: Entity validator.\n const { data = {} as any } = params!;\n\n const model = strapi.getModel(uid);\n const query = transformParamsToQuery(uid, pickSelectionParams(params) as any);\n\n // Find all locales of the document\n const entries = await db.query(uid).findMany({\n ...query,\n where: { ...params?.lookup, ...query.where, documentId },\n });\n\n // Document does not exist\n if (!entries.length) {\n return null;\n }\n\n const newDocumentId = createDocumentId();\n\n const versions = await mapAsync(entries, async (entryToClone: any) => {\n const isDraft = contentTypesUtils.isDraft(data);\n // Todo: Merge data with entry to clone\n const validData = await entityValidator.validateEntityUpdate(\n model,\n // Omit id fields, the cloned entity id will be generated by the database\n omit(['id'], data),\n { isDraft, ...params?.lookup },\n entryToClone\n );\n\n const componentData = await cloneComponents(uid, entryToClone, validData);\n const entityData = createPipeline(\n Object.assign(omitComponentData(model, validData), componentData),\n { contentType: model }\n );\n\n // TODO: Transform params to query\n return db.query(uid).clone(entryToClone.id, {\n ...query,\n // Allows entityData to override the documentId (e.g. when publishing)\n data: { documentId: newDocumentId, ...entityData, locale: entryToClone.locale },\n });\n });\n\n return { id: newDocumentId, versions };\n },\n\n // TODO: Handle relations so they target the published version\n async publish(uid, documentId, params) {\n // Delete already published versions that match the locales to be published\n await this.delete(uid, documentId, {\n ...params,\n lookup: { ...params?.lookup, publishedAt: { $ne: null } },\n });\n\n // Clone every draft version to be published\n const clonedDocuments = (await this.clone(uid, documentId, {\n ...(params || {}),\n // @ts-expect-error - Generic type does not have publishedAt attribute by default\n data: { documentId, publishedAt: new Date() },\n })) as any;\n\n // TODO: Return actual count\n return { versions: clonedDocuments?.versions || [] };\n },\n\n async unpublish(uid, documentId, params) {\n // Delete all published versions\n return this.delete(uid, documentId, {\n ...params,\n lookup: { ...params?.lookup, publishedAt: { $ne: null } },\n }) as any;\n },\n\n /**\n * Steps:\n * - Delete the matching draft versions (publishedAt = null)\n * - Clone the matching published versions into draft versions\n */\n async discardDraft(uid, documentId, params) {\n // Delete draft versions, clone published versions into draft versions\n await this.delete(uid, documentId, {\n ...params,\n // Delete all drafts that match query\n lookup: { ...params?.lookup, publishedAt: null },\n });\n\n // Clone published versions into draft versions\n const clonedDocuments = (await this.clone(uid, documentId, {\n ...(params || {}),\n // Clone only published versions\n lookup: { ...params?.lookup, publishedAt: { $ne: null } },\n // @ts-expect-error - Generic type does not have publishedAt attribute by default\n data: { documentId, publishedAt: null },\n })) as any;\n\n return { versions: clonedDocuments?.versions || [] };\n },\n});\n\nexport default (ctx: { strapi: Strapi; db: Database }): Documents.Engine => {\n const implementation = createDocumentEngine(ctx);\n\n // TODO: Wrap with database error handling\n return implementation;\n};\n"],"names":["convertQueryParams","applyTransforms","params","mapAsync","getComponents","deleteComponents","isArray","entityValidator","createComponents","omitComponentData","pickSelectionParams","updateComponents","createDocumentId","contentTypesUtils","omit","cloneComponents"],"mappings":"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"}
@@ -0,0 +1,201 @@
1
+ import { mapAsync, contentTypes, convertQueryParams } from "@strapi/utils";
2
+ import { isArray, omit } from "lodash/fp";
3
+ import uploadFile from "../utils/upload-files.mjs";
4
+ import { getComponents, deleteComponents, createComponents, omitComponentData, updateComponents, cloneComponents } from "../entity-service/components.mjs";
5
+ import { createDocumentId } from "../../utils/transform-content-types-to-models.mjs";
6
+ import { applyTransforms } from "../entity-service/attributes/index.mjs";
7
+ import entityValidator from "../entity-validator/index.mjs";
8
+ import { pickSelectionParams } from "../entity-service/params.mjs";
9
+ const { transformParamsToQuery } = convertQueryParams;
10
+ const createPipeline = (data, context) => {
11
+ return applyTransforms(data, context);
12
+ };
13
+ const updatePipeline = (data, context) => {
14
+ return applyTransforms(data, context);
15
+ };
16
+ const createDocumentEngine = ({
17
+ strapi,
18
+ db
19
+ }) => ({
20
+ uploadFiles: uploadFile,
21
+ async findMany(uid, params) {
22
+ const { kind } = strapi.getModel(uid);
23
+ const query = transformParamsToQuery(uid, params || {});
24
+ query.where = { ...params?.lookup, ...query.where };
25
+ if (kind === "singleType") {
26
+ return db.query(uid).findOne(query);
27
+ }
28
+ return db.query(uid).findMany(query);
29
+ },
30
+ async findFirst(uid, params) {
31
+ const query = transformParamsToQuery(uid, params || {});
32
+ return db.query(uid).findOne({ ...query, where: { ...params?.lookup, ...query.where } });
33
+ },
34
+ async findOne(uid, documentId, params) {
35
+ const query = transformParamsToQuery(uid, params || {});
36
+ return db.query(uid).findOne({ ...query, where: { ...params?.lookup, ...query.where, documentId } });
37
+ },
38
+ async delete(uid, documentId, params = {}) {
39
+ const query = transformParamsToQuery(uid, params);
40
+ if (params.status === "draft") {
41
+ throw new Error("Cannot delete a draft document");
42
+ }
43
+ const entriesToDelete = await db.query(uid).findMany({
44
+ ...query,
45
+ where: {
46
+ ...params.lookup,
47
+ ...query?.where,
48
+ documentId
49
+ }
50
+ });
51
+ await mapAsync(entriesToDelete, async (entryToDelete) => {
52
+ const componentsToDelete = await getComponents(uid, entryToDelete);
53
+ await db.query(uid).delete({ where: { id: entryToDelete.id } });
54
+ await deleteComponents(uid, componentsToDelete, { loadComponents: false });
55
+ });
56
+ return { versions: entriesToDelete };
57
+ },
58
+ // TODO: should we provide two separate methods?
59
+ async deleteMany(uid, paramsOrIds) {
60
+ let queryParams;
61
+ if (isArray(paramsOrIds)) {
62
+ queryParams = { filter: { documentID: { $in: paramsOrIds } } };
63
+ } else {
64
+ queryParams = paramsOrIds;
65
+ }
66
+ const query = transformParamsToQuery(uid, queryParams || {});
67
+ return db.query(uid).deleteMany(query);
68
+ },
69
+ async create(uid, params) {
70
+ const { data } = params;
71
+ if (!data) {
72
+ throw new Error("Create requires data attribute");
73
+ }
74
+ const model = strapi.getModel(uid);
75
+ const validData = await entityValidator.validateEntityCreation(model, data, {
76
+ isDraft: true,
77
+ locale: params?.locale
78
+ });
79
+ const componentData = await createComponents(uid, validData);
80
+ const entryData = createPipeline(
81
+ Object.assign(omitComponentData(model, validData), componentData),
82
+ {
83
+ contentType: model
84
+ }
85
+ );
86
+ const query = transformParamsToQuery(uid, pickSelectionParams(params));
87
+ return db.query(uid).create({ ...query, data: entryData });
88
+ },
89
+ // NOTE: What happens if user doesn't provide specific publications state and locale to update?
90
+ async update(uid, documentId, params) {
91
+ const { data } = params || {};
92
+ const model = strapi.getModel(uid);
93
+ const query = transformParamsToQuery(uid, pickSelectionParams(params || {}));
94
+ const entryToUpdate = await db.query(uid).findOne({ ...query, where: { ...params?.lookup, ...query?.where, documentId } });
95
+ if (!entryToUpdate) {
96
+ return null;
97
+ }
98
+ const validData = await entityValidator.validateEntityUpdate(
99
+ model,
100
+ data,
101
+ {
102
+ isDraft: true,
103
+ // Always update the draft version
104
+ locale: params?.locale
105
+ },
106
+ entryToUpdate
107
+ );
108
+ const componentData = await updateComponents(uid, entryToUpdate, validData);
109
+ const entryData = updatePipeline(
110
+ Object.assign(omitComponentData(model, validData), componentData),
111
+ { contentType: model }
112
+ );
113
+ return db.query(uid).update({ ...query, where: { id: entryToUpdate.id }, data: entryData });
114
+ },
115
+ async count(uid, params = void 0) {
116
+ const query = transformParamsToQuery(uid, params || {});
117
+ query.where = { ...params?.lookup, ...query.where };
118
+ return db.query(uid).count(query);
119
+ },
120
+ async clone(uid, documentId, params) {
121
+ const { data = {} } = params;
122
+ const model = strapi.getModel(uid);
123
+ const query = transformParamsToQuery(uid, pickSelectionParams(params));
124
+ const entries = await db.query(uid).findMany({
125
+ ...query,
126
+ where: { ...params?.lookup, ...query.where, documentId }
127
+ });
128
+ if (!entries.length) {
129
+ return null;
130
+ }
131
+ const newDocumentId = createDocumentId();
132
+ const versions = await mapAsync(entries, async (entryToClone) => {
133
+ const isDraft = contentTypes.isDraft(data);
134
+ const validData = await entityValidator.validateEntityUpdate(
135
+ model,
136
+ // Omit id fields, the cloned entity id will be generated by the database
137
+ omit(["id"], data),
138
+ { isDraft, ...params?.lookup },
139
+ entryToClone
140
+ );
141
+ const componentData = await cloneComponents(uid, entryToClone, validData);
142
+ const entityData = createPipeline(
143
+ Object.assign(omitComponentData(model, validData), componentData),
144
+ { contentType: model }
145
+ );
146
+ return db.query(uid).clone(entryToClone.id, {
147
+ ...query,
148
+ // Allows entityData to override the documentId (e.g. when publishing)
149
+ data: { documentId: newDocumentId, ...entityData, locale: entryToClone.locale }
150
+ });
151
+ });
152
+ return { id: newDocumentId, versions };
153
+ },
154
+ // TODO: Handle relations so they target the published version
155
+ async publish(uid, documentId, params) {
156
+ await this.delete(uid, documentId, {
157
+ ...params,
158
+ lookup: { ...params?.lookup, publishedAt: { $ne: null } }
159
+ });
160
+ const clonedDocuments = await this.clone(uid, documentId, {
161
+ ...params || {},
162
+ // @ts-expect-error - Generic type does not have publishedAt attribute by default
163
+ data: { documentId, publishedAt: /* @__PURE__ */ new Date() }
164
+ });
165
+ return { versions: clonedDocuments?.versions || [] };
166
+ },
167
+ async unpublish(uid, documentId, params) {
168
+ return this.delete(uid, documentId, {
169
+ ...params,
170
+ lookup: { ...params?.lookup, publishedAt: { $ne: null } }
171
+ });
172
+ },
173
+ /**
174
+ * Steps:
175
+ * - Delete the matching draft versions (publishedAt = null)
176
+ * - Clone the matching published versions into draft versions
177
+ */
178
+ async discardDraft(uid, documentId, params) {
179
+ await this.delete(uid, documentId, {
180
+ ...params,
181
+ // Delete all drafts that match query
182
+ lookup: { ...params?.lookup, publishedAt: null }
183
+ });
184
+ const clonedDocuments = await this.clone(uid, documentId, {
185
+ ...params || {},
186
+ // Clone only published versions
187
+ lookup: { ...params?.lookup, publishedAt: { $ne: null } },
188
+ // @ts-expect-error - Generic type does not have publishedAt attribute by default
189
+ data: { documentId, publishedAt: null }
190
+ });
191
+ return { versions: clonedDocuments?.versions || [] };
192
+ }
193
+ });
194
+ const createDocumentRepository = (ctx) => {
195
+ const implementation = createDocumentEngine(ctx);
196
+ return implementation;
197
+ };
198
+ export {
199
+ createDocumentRepository as default
200
+ };
201
+ //# sourceMappingURL=document-engine.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"document-engine.mjs","sources":["../../../src/services/document-service/document-engine.ts"],"sourcesContent":["import type { Database } from '@strapi/database';\nimport type { Common, Documents, Schema, Shared, Strapi } from '@strapi/types';\nimport { contentTypes as contentTypesUtils, convertQueryParams, mapAsync } from '@strapi/utils';\n\nimport { isArray, omit } from 'lodash/fp';\nimport uploadFiles from '../utils/upload-files';\n\nimport {\n cloneComponents,\n createComponents,\n deleteComponents,\n getComponents,\n omitComponentData,\n updateComponents,\n} from '../entity-service/components';\n\nimport { createDocumentId } from '../../utils/transform-content-types-to-models';\nimport { applyTransforms } from '../entity-service/attributes';\nimport entityValidator from '../entity-validator';\nimport { pickSelectionParams } from './params';\n\nconst { transformParamsToQuery } = convertQueryParams;\n\n/**\n * TODO: Sanitization / validation built-in\n * TODO: i18n - Move logic to i18n package\n * TODO: Webhooks\n * TODO: Audit logs\n * TODO: Entity Validation - Uniqueness across same locale and publication status\n * TODO: File upload\n * TODO: replace 'any'\n * TODO: availableLocales\n *\n */\ntype Context = {\n contentType: Schema.ContentType;\n};\n\nconst createPipeline = (data: Record<string, unknown>, context: Context) => {\n return applyTransforms(data, context);\n};\n\nconst updatePipeline = (data: Record<string, unknown>, context: Context) => {\n return applyTransforms(data, context);\n};\n\nconst createDocumentEngine = ({\n strapi,\n db,\n}: {\n strapi: Strapi;\n db: Database;\n}): Documents.Engine => ({\n uploadFiles,\n\n async findMany(uid, params) {\n const { kind } = strapi.getModel(uid);\n\n const query = transformParamsToQuery(uid, params || ({} as any));\n query.where = { ...params?.lookup, ...query.where };\n\n if (kind === 'singleType') {\n return db.query(uid).findOne(query);\n }\n\n return db.query(uid).findMany(query);\n },\n\n async findFirst(uid, params) {\n const query = transformParamsToQuery(uid, params || ({} as any));\n\n return db.query(uid).findOne({ ...query, where: { ...params?.lookup, ...query.where } });\n },\n\n async findOne(uid, documentId, params) {\n const query = transformParamsToQuery(uid, params || ({} as any));\n return db\n .query(uid)\n .findOne({ ...query, where: { ...params?.lookup, ...query.where, documentId } });\n },\n\n async delete(uid, documentId, params = {} as any) {\n const query = transformParamsToQuery(uid, params as any);\n\n if (params.status === 'draft') {\n throw new Error('Cannot delete a draft document');\n }\n\n const entriesToDelete = await db.query(uid).findMany({\n ...query,\n where: {\n ...params.lookup,\n ...query?.where,\n documentId,\n },\n });\n\n // Delete all matched entries and its components\n await mapAsync(entriesToDelete, async (entryToDelete: any) => {\n const componentsToDelete = await getComponents(uid, entryToDelete);\n await db.query(uid).delete({ where: { id: entryToDelete.id } });\n await deleteComponents(uid, componentsToDelete as any, { loadComponents: false });\n });\n\n // TODO: Change return value to actual count\n return { versions: entriesToDelete };\n },\n\n // TODO: should we provide two separate methods?\n async deleteMany(uid, paramsOrIds) {\n let queryParams;\n if (isArray(paramsOrIds)) {\n queryParams = { filter: { documentID: { $in: paramsOrIds } } };\n } else {\n queryParams = paramsOrIds;\n }\n\n const query = transformParamsToQuery(uid, queryParams || ({} as any));\n\n return db.query(uid).deleteMany(query);\n },\n\n async create(uid, params) {\n // TODO: Entity validator.\n // TODO: File upload - Probably in the lifecycles?\n const { data } = params;\n\n if (!data) {\n throw new Error('Create requires data attribute');\n }\n\n const model = strapi.getModel(uid) as Shared.ContentTypes[Common.UID.ContentType];\n\n const validData = await entityValidator.validateEntityCreation(model, data, {\n isDraft: true,\n locale: params?.locale,\n });\n\n const componentData = await createComponents(uid, validData);\n const entryData = createPipeline(\n Object.assign(omitComponentData(model, validData), componentData),\n {\n contentType: model,\n }\n );\n\n // select / populate\n const query = transformParamsToQuery(uid, pickSelectionParams(params) as any);\n\n return db.query(uid).create({ ...query, data: entryData });\n },\n\n // NOTE: What happens if user doesn't provide specific publications state and locale to update?\n async update(uid, documentId, params) {\n // TODO: Prevent updating a published document\n // TODO: Entity validator.\n // TODO: File upload\n const { data } = params || {};\n const model = strapi.getModel(uid) as Shared.ContentTypes[Common.UID.ContentType];\n\n const query = transformParamsToQuery(uid, pickSelectionParams(params || {}) as any);\n\n // Find all locales of the document\n const entryToUpdate = await db\n .query(uid)\n .findOne({ ...query, where: { ...params?.lookup, ...query?.where, documentId } });\n\n // Document does not exist\n if (!entryToUpdate) {\n return null;\n }\n\n const validData = await entityValidator.validateEntityUpdate(\n model,\n data,\n {\n isDraft: true, // Always update the draft version\n locale: params?.locale,\n },\n entryToUpdate\n );\n\n const componentData = await updateComponents(uid, entryToUpdate, validData);\n const entryData = updatePipeline(\n Object.assign(omitComponentData(model, validData), componentData),\n { contentType: model }\n );\n\n return db.query(uid).update({ ...query, where: { id: entryToUpdate.id }, data: entryData });\n },\n\n async count(uid, params = undefined) {\n const query = transformParamsToQuery(uid, params || ({} as any));\n query.where = { ...params?.lookup, ...query.where };\n\n return db.query(uid).count(query);\n },\n\n async clone(uid, documentId, params) {\n // TODO: File upload\n // TODO: Entity validator.\n const { data = {} as any } = params!;\n\n const model = strapi.getModel(uid);\n const query = transformParamsToQuery(uid, pickSelectionParams(params) as any);\n\n // Find all locales of the document\n const entries = await db.query(uid).findMany({\n ...query,\n where: { ...params?.lookup, ...query.where, documentId },\n });\n\n // Document does not exist\n if (!entries.length) {\n return null;\n }\n\n const newDocumentId = createDocumentId();\n\n const versions = await mapAsync(entries, async (entryToClone: any) => {\n const isDraft = contentTypesUtils.isDraft(data);\n // Todo: Merge data with entry to clone\n const validData = await entityValidator.validateEntityUpdate(\n model,\n // Omit id fields, the cloned entity id will be generated by the database\n omit(['id'], data),\n { isDraft, ...params?.lookup },\n entryToClone\n );\n\n const componentData = await cloneComponents(uid, entryToClone, validData);\n const entityData = createPipeline(\n Object.assign(omitComponentData(model, validData), componentData),\n { contentType: model }\n );\n\n // TODO: Transform params to query\n return db.query(uid).clone(entryToClone.id, {\n ...query,\n // Allows entityData to override the documentId (e.g. when publishing)\n data: { documentId: newDocumentId, ...entityData, locale: entryToClone.locale },\n });\n });\n\n return { id: newDocumentId, versions };\n },\n\n // TODO: Handle relations so they target the published version\n async publish(uid, documentId, params) {\n // Delete already published versions that match the locales to be published\n await this.delete(uid, documentId, {\n ...params,\n lookup: { ...params?.lookup, publishedAt: { $ne: null } },\n });\n\n // Clone every draft version to be published\n const clonedDocuments = (await this.clone(uid, documentId, {\n ...(params || {}),\n // @ts-expect-error - Generic type does not have publishedAt attribute by default\n data: { documentId, publishedAt: new Date() },\n })) as any;\n\n // TODO: Return actual count\n return { versions: clonedDocuments?.versions || [] };\n },\n\n async unpublish(uid, documentId, params) {\n // Delete all published versions\n return this.delete(uid, documentId, {\n ...params,\n lookup: { ...params?.lookup, publishedAt: { $ne: null } },\n }) as any;\n },\n\n /**\n * Steps:\n * - Delete the matching draft versions (publishedAt = null)\n * - Clone the matching published versions into draft versions\n */\n async discardDraft(uid, documentId, params) {\n // Delete draft versions, clone published versions into draft versions\n await this.delete(uid, documentId, {\n ...params,\n // Delete all drafts that match query\n lookup: { ...params?.lookup, publishedAt: null },\n });\n\n // Clone published versions into draft versions\n const clonedDocuments = (await this.clone(uid, documentId, {\n ...(params || {}),\n // Clone only published versions\n lookup: { ...params?.lookup, publishedAt: { $ne: null } },\n // @ts-expect-error - Generic type does not have publishedAt attribute by default\n data: { documentId, publishedAt: null },\n })) as any;\n\n return { versions: clonedDocuments?.versions || [] };\n },\n});\n\nexport default (ctx: { strapi: Strapi; db: Database }): Documents.Engine => {\n const implementation = createDocumentEngine(ctx);\n\n // TODO: Wrap with database error handling\n return implementation;\n};\n"],"names":["uploadFiles","contentTypesUtils"],"mappings":"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"}
@@ -0,0 +1,21 @@
1
+ import { Strapi, Documents } from '@strapi/types';
2
+ /**
3
+ * Repository to :
4
+ * - Access documents via actions (findMany, findOne, create, update, delete, ...)
5
+ * - Execute middlewares on document actions
6
+ * - Apply default parameters to document actions
7
+ *
8
+ * @param strapi
9
+ * @param options.defaults - Default parameters to apply to all actions
10
+ * @param options.parent - Parent repository, used when creating a new repository with .with()
11
+ * @returns DocumentService
12
+ *
13
+ * @example Access documents
14
+ * const article = strapi.documents('api::article.article').create(params)
15
+ * const allArticles = strapi.documents('api::article.article').findMany(params)
16
+ *
17
+ */
18
+ export declare const createDocumentService: (strapi: Strapi, { defaults }?: {
19
+ defaults?: any;
20
+ }) => Documents.Service;
21
+ //# sourceMappingURL=document-service.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"document-service.d.ts","sourceRoot":"","sources":["../../../src/services/document-service/document-service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAU,SAAS,EAAE,MAAM,eAAe,CAAC;AAK1D;;;;;;;;;;;;;;;GAeG;AACH,eAAO,MAAM,qBAAqB,WACxB,MAAM;eACkB,GAAG;MAClC,UAAU,OAsIZ,CAAC"}