@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,93 @@
1
+ import { isObject } from "lodash/fp";
2
+ import { errors } from "@strapi/utils";
3
+ import { parseBody } from "./transform.mjs";
4
+ const createCollectionTypeController = ({
5
+ contentType
6
+ }) => {
7
+ const uid = contentType.uid;
8
+ return {
9
+ /**
10
+ * Retrieve records.
11
+ */
12
+ async find(ctx) {
13
+ await this.validateQuery(ctx);
14
+ const sanitizedQuery = await this.sanitizeQuery(ctx);
15
+ const { results, pagination } = await strapi.service(uid).find(sanitizedQuery);
16
+ const sanitizedResults = await this.sanitizeOutput(results, ctx);
17
+ return this.transformResponse(sanitizedResults, { pagination });
18
+ },
19
+ /**
20
+ * Retrieve a record.
21
+ *
22
+ * @return {Object}
23
+ */
24
+ async findOne(ctx) {
25
+ const { id } = ctx.params;
26
+ await this.validateQuery(ctx);
27
+ const sanitizedQuery = await this.sanitizeQuery(ctx);
28
+ const entity = await strapi.service(uid).findOne(id, sanitizedQuery);
29
+ const sanitizedEntity = await this.sanitizeOutput(entity, ctx);
30
+ return this.transformResponse(sanitizedEntity);
31
+ },
32
+ /**
33
+ * Create a record.
34
+ *
35
+ * @return {Object}
36
+ */
37
+ async create(ctx) {
38
+ await this.validateQuery(ctx);
39
+ const sanitizedQuery = await this.sanitizeQuery(ctx);
40
+ const body = parseBody(ctx);
41
+ if (!isObject(body.data)) {
42
+ throw new errors.ValidationError('Missing "data" payload in the request body');
43
+ }
44
+ const sanitizedInputData = await this.sanitizeInput(body.data, ctx);
45
+ const entity = await strapi.service(uid).create({
46
+ ...sanitizedQuery,
47
+ data: sanitizedInputData,
48
+ files: "files" in body ? body.files : void 0
49
+ });
50
+ const sanitizedEntity = await this.sanitizeOutput(entity, ctx);
51
+ return this.transformResponse(sanitizedEntity);
52
+ },
53
+ /**
54
+ * Update a record.
55
+ *
56
+ * @return {Object}
57
+ */
58
+ async update(ctx) {
59
+ const { id } = ctx.params;
60
+ await this.validateQuery(ctx);
61
+ const sanitizedQuery = await this.sanitizeQuery(ctx);
62
+ const body = parseBody(ctx);
63
+ if (!isObject(body.data)) {
64
+ throw new errors.ValidationError('Missing "data" payload in the request body');
65
+ }
66
+ const sanitizedInputData = await this.sanitizeInput(body.data, ctx);
67
+ const entity = await strapi.service(uid).update(id, {
68
+ ...sanitizedQuery,
69
+ data: sanitizedInputData,
70
+ files: "files" in body ? body.files : void 0
71
+ });
72
+ const sanitizedEntity = await this.sanitizeOutput(entity, ctx);
73
+ return this.transformResponse(sanitizedEntity);
74
+ },
75
+ /**
76
+ * Destroy a record.
77
+ *
78
+ * @return {Object}
79
+ */
80
+ async delete(ctx) {
81
+ const { id } = ctx.params;
82
+ await this.validateQuery(ctx);
83
+ const sanitizedQuery = await this.sanitizeQuery(ctx);
84
+ const entity = await strapi.service(uid).delete(id, sanitizedQuery);
85
+ const sanitizedEntity = await this.sanitizeOutput(entity, ctx);
86
+ return this.transformResponse(sanitizedEntity);
87
+ }
88
+ };
89
+ };
90
+ export {
91
+ createCollectionTypeController as default
92
+ };
93
+ //# sourceMappingURL=collection-type.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"collection-type.mjs","sources":["../../../src/core-api/controller/collection-type.ts"],"sourcesContent":["import { isObject } from 'lodash/fp';\nimport { errors } from '@strapi/utils';\nimport type { CoreApi, Schema, Utils, Common } from '@strapi/types';\nimport type Koa from 'koa';\n\nimport { parseBody } from './transform';\n\ninterface Options {\n contentType: Schema.CollectionType;\n}\n\n/**\n *\n * Returns a collection type controller to handle default core-api actions\n */\nconst createCollectionTypeController = ({\n contentType,\n}: Options): Utils.PartialWithThis<CoreApi.Controller.CollectionType> => {\n const uid = contentType.uid as Common.UID.Service;\n\n return {\n /**\n * Retrieve records.\n */\n async find(ctx) {\n await this.validateQuery(ctx);\n const sanitizedQuery = await this.sanitizeQuery(ctx);\n\n const { results, pagination } = await strapi.service(uid).find(sanitizedQuery);\n const sanitizedResults = await this.sanitizeOutput(results, ctx);\n return this.transformResponse(sanitizedResults, { pagination });\n },\n\n /**\n * Retrieve a record.\n *\n * @return {Object}\n */\n async findOne(ctx) {\n const { id } = ctx.params;\n await this.validateQuery(ctx);\n const sanitizedQuery = await this.sanitizeQuery(ctx);\n\n const entity = await strapi.service(uid).findOne(id, sanitizedQuery);\n const sanitizedEntity = await this.sanitizeOutput(entity, ctx);\n\n return this.transformResponse(sanitizedEntity);\n },\n\n /**\n * Create a record.\n *\n * @return {Object}\n */\n async create(ctx) {\n await this.validateQuery(ctx);\n const sanitizedQuery = await this.sanitizeQuery(ctx);\n\n const body = parseBody(ctx);\n\n if (!isObject(body.data)) {\n throw new errors.ValidationError('Missing \"data\" payload in the request body');\n }\n\n const sanitizedInputData = await this.sanitizeInput(body.data, ctx);\n\n const entity = await strapi.service(uid).create({\n ...sanitizedQuery,\n data: sanitizedInputData,\n files: 'files' in body ? body.files : undefined,\n });\n\n const sanitizedEntity = await this.sanitizeOutput(entity, ctx);\n\n return this.transformResponse(sanitizedEntity);\n },\n\n /**\n * Update a record.\n *\n * @return {Object}\n */\n async update(ctx: Koa.Context) {\n const { id } = ctx.params;\n await this.validateQuery(ctx);\n const sanitizedQuery = await this.sanitizeQuery(ctx);\n\n const body = parseBody(ctx);\n\n if (!isObject(body.data)) {\n throw new errors.ValidationError('Missing \"data\" payload in the request body');\n }\n\n const sanitizedInputData = await this.sanitizeInput(body.data, ctx);\n\n const entity = await strapi.service(uid).update(id, {\n ...sanitizedQuery,\n data: sanitizedInputData,\n files: 'files' in body ? body.files : undefined,\n });\n\n const sanitizedEntity = await this.sanitizeOutput(entity, ctx);\n\n return this.transformResponse(sanitizedEntity);\n },\n\n /**\n * Destroy a record.\n *\n * @return {Object}\n */\n async delete(ctx) {\n const { id } = ctx.params;\n await this.validateQuery(ctx);\n const sanitizedQuery = await this.sanitizeQuery(ctx);\n\n const entity = await strapi.service(uid).delete(id, sanitizedQuery);\n const sanitizedEntity = await this.sanitizeOutput(entity, ctx);\n\n return this.transformResponse(sanitizedEntity);\n },\n };\n};\n\nexport default createCollectionTypeController;\n"],"names":[],"mappings":";;;AAeA,MAAM,iCAAiC,CAAC;AAAA,EACtC;AACF,MAAyE;AACvE,QAAM,MAAM,YAAY;AAEjB,SAAA;AAAA;AAAA;AAAA;AAAA,IAIL,MAAM,KAAK,KAAK;AACR,YAAA,KAAK,cAAc,GAAG;AAC5B,YAAM,iBAAiB,MAAM,KAAK,cAAc,GAAG;AAE7C,YAAA,EAAE,SAAS,WAAA,IAAe,MAAM,OAAO,QAAQ,GAAG,EAAE,KAAK,cAAc;AAC7E,YAAM,mBAAmB,MAAM,KAAK,eAAe,SAAS,GAAG;AAC/D,aAAO,KAAK,kBAAkB,kBAAkB,EAAE,WAAY,CAAA;AAAA,IAChE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOA,MAAM,QAAQ,KAAK;AACX,YAAA,EAAE,GAAG,IAAI,IAAI;AACb,YAAA,KAAK,cAAc,GAAG;AAC5B,YAAM,iBAAiB,MAAM,KAAK,cAAc,GAAG;AAE7C,YAAA,SAAS,MAAM,OAAO,QAAQ,GAAG,EAAE,QAAQ,IAAI,cAAc;AACnE,YAAM,kBAAkB,MAAM,KAAK,eAAe,QAAQ,GAAG;AAEtD,aAAA,KAAK,kBAAkB,eAAe;AAAA,IAC/C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOA,MAAM,OAAO,KAAK;AACV,YAAA,KAAK,cAAc,GAAG;AAC5B,YAAM,iBAAiB,MAAM,KAAK,cAAc,GAAG;AAE7C,YAAA,OAAO,UAAU,GAAG;AAE1B,UAAI,CAAC,SAAS,KAAK,IAAI,GAAG;AAClB,cAAA,IAAI,OAAO,gBAAgB,4CAA4C;AAAA,MAC/E;AAEA,YAAM,qBAAqB,MAAM,KAAK,cAAc,KAAK,MAAM,GAAG;AAElE,YAAM,SAAS,MAAM,OAAO,QAAQ,GAAG,EAAE,OAAO;AAAA,QAC9C,GAAG;AAAA,QACH,MAAM;AAAA,QACN,OAAO,WAAW,OAAO,KAAK,QAAQ;AAAA,MAAA,CACvC;AAED,YAAM,kBAAkB,MAAM,KAAK,eAAe,QAAQ,GAAG;AAEtD,aAAA,KAAK,kBAAkB,eAAe;AAAA,IAC/C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOA,MAAM,OAAO,KAAkB;AACvB,YAAA,EAAE,GAAG,IAAI,IAAI;AACb,YAAA,KAAK,cAAc,GAAG;AAC5B,YAAM,iBAAiB,MAAM,KAAK,cAAc,GAAG;AAE7C,YAAA,OAAO,UAAU,GAAG;AAE1B,UAAI,CAAC,SAAS,KAAK,IAAI,GAAG;AAClB,cAAA,IAAI,OAAO,gBAAgB,4CAA4C;AAAA,MAC/E;AAEA,YAAM,qBAAqB,MAAM,KAAK,cAAc,KAAK,MAAM,GAAG;AAElE,YAAM,SAAS,MAAM,OAAO,QAAQ,GAAG,EAAE,OAAO,IAAI;AAAA,QAClD,GAAG;AAAA,QACH,MAAM;AAAA,QACN,OAAO,WAAW,OAAO,KAAK,QAAQ;AAAA,MAAA,CACvC;AAED,YAAM,kBAAkB,MAAM,KAAK,eAAe,QAAQ,GAAG;AAEtD,aAAA,KAAK,kBAAkB,eAAe;AAAA,IAC/C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOA,MAAM,OAAO,KAAK;AACV,YAAA,EAAE,GAAG,IAAI,IAAI;AACb,YAAA,KAAK,cAAc,GAAG;AAC5B,YAAM,iBAAiB,MAAM,KAAK,cAAc,GAAG;AAE7C,YAAA,SAAS,MAAM,OAAO,QAAQ,GAAG,EAAE,OAAO,IAAI,cAAc;AAClE,YAAM,kBAAkB,MAAM,KAAK,eAAe,QAAQ,GAAG;AAEtD,aAAA,KAAK,kBAAkB,eAAe;AAAA,IAC/C;AAAA,EAAA;AAEJ;"}
@@ -0,0 +1,6 @@
1
+ import type { CoreApi, Schema } from '@strapi/types';
2
+ declare function createController<T extends Schema.SingleType | Schema.CollectionType>(opts: {
3
+ contentType: T;
4
+ }): T extends Schema.SingleType ? CoreApi.Controller.SingleType : CoreApi.Controller.CollectionType;
5
+ export { createController };
6
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/core-api/controller/index.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAWrD,iBAAS,gBAAgB,CAAC,CAAC,SAAS,MAAM,CAAC,UAAU,GAAG,MAAM,CAAC,cAAc,EAAE,IAAI,EAAE;IACnF,WAAW,EAAE,CAAC,CAAC;CAChB,GAAG,CAAC,SAAS,MAAM,CAAC,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC,cAAc,CAAC;AAqDpG,OAAO,EAAE,gBAAgB,EAAE,CAAC"}
@@ -0,0 +1,47 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const _ = require("lodash/fp");
4
+ const strapiUtils = require("@strapi/utils");
5
+ const transform = require("./transform.js");
6
+ const singleType = require("./single-type.js");
7
+ const collectionType = require("./collection-type.js");
8
+ const isSingleType = (contentType) => strapiUtils.contentTypes.isSingleType(contentType);
9
+ const getAuthFromKoaContext = (ctx) => _.prop("state.auth", ctx) ?? {};
10
+ function createController({
11
+ contentType
12
+ }) {
13
+ const proto = {
14
+ transformResponse(data, meta) {
15
+ return transform.transformResponse(data, meta, { contentType });
16
+ },
17
+ async sanitizeOutput(data, ctx) {
18
+ const auth = getAuthFromKoaContext(ctx);
19
+ return strapiUtils.sanitize.contentAPI.output(data, contentType, { auth });
20
+ },
21
+ async sanitizeInput(data, ctx) {
22
+ const auth = getAuthFromKoaContext(ctx);
23
+ return strapiUtils.sanitize.contentAPI.input(data, contentType, { auth });
24
+ },
25
+ async sanitizeQuery(ctx) {
26
+ const auth = getAuthFromKoaContext(ctx);
27
+ return strapiUtils.sanitize.contentAPI.query(ctx.query, contentType, { auth });
28
+ },
29
+ async validateQuery(ctx) {
30
+ const auth = getAuthFromKoaContext(ctx);
31
+ return strapiUtils.validate.contentAPI.query(ctx.query, contentType, { auth });
32
+ },
33
+ async validateInput(data, ctx) {
34
+ const auth = getAuthFromKoaContext(ctx);
35
+ return strapiUtils.validate.contentAPI.input(data, contentType, { auth });
36
+ }
37
+ };
38
+ let ctrl;
39
+ if (isSingleType(contentType)) {
40
+ ctrl = singleType({ contentType });
41
+ } else {
42
+ ctrl = collectionType({ contentType });
43
+ }
44
+ return Object.assign(Object.create(proto), ctrl);
45
+ }
46
+ exports.createController = createController;
47
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../../../src/core-api/controller/index.ts"],"sourcesContent":["import { prop } from 'lodash/fp';\nimport type Koa from 'koa';\nimport { contentTypes as contentTypeUtils, sanitize, validate } from '@strapi/utils';\nimport type { CoreApi, Schema } from '@strapi/types';\n\nimport { transformResponse } from './transform';\nimport createSingleTypeController from './single-type';\nimport createCollectionTypeController from './collection-type';\n\nconst isSingleType = (contentType: Schema.ContentType): contentType is Schema.SingleType =>\n contentTypeUtils.isSingleType(contentType);\n\nconst getAuthFromKoaContext = (ctx: Koa.Context) => prop('state.auth', ctx) ?? {};\n\nfunction createController<T extends Schema.SingleType | Schema.CollectionType>(opts: {\n contentType: T;\n}): T extends Schema.SingleType ? CoreApi.Controller.SingleType : CoreApi.Controller.CollectionType;\nfunction createController({\n contentType,\n}: {\n contentType: Schema.SingleType | Schema.CollectionType;\n}) {\n const proto: CoreApi.Controller.Base = {\n transformResponse(data, meta) {\n return transformResponse(data, meta, { contentType });\n },\n\n async sanitizeOutput(data, ctx) {\n const auth = getAuthFromKoaContext(ctx);\n\n return sanitize.contentAPI.output(data, contentType, { auth });\n },\n\n async sanitizeInput(data, ctx) {\n const auth = getAuthFromKoaContext(ctx);\n\n return sanitize.contentAPI.input(data, contentType, { auth });\n },\n\n async sanitizeQuery(ctx) {\n const auth = getAuthFromKoaContext(ctx);\n\n return sanitize.contentAPI.query(ctx.query, contentType, { auth });\n },\n\n async validateQuery(ctx) {\n const auth = getAuthFromKoaContext(ctx);\n\n return validate.contentAPI.query(ctx.query, contentType, { auth });\n },\n\n async validateInput(data, ctx) {\n const auth = getAuthFromKoaContext(ctx);\n\n return validate.contentAPI.input(data, contentType, { auth });\n },\n };\n\n let ctrl;\n\n if (isSingleType(contentType)) {\n ctrl = createSingleTypeController({ contentType });\n } else {\n ctrl = createCollectionTypeController({ contentType });\n }\n\n return Object.assign(Object.create(proto), ctrl);\n}\n\nexport { createController };\n"],"names":["contentTypeUtils","prop","transformResponse","sanitize","validate","createSingleTypeController","createCollectionTypeController"],"mappings":";;;;;;;AASA,MAAM,eAAe,CAAC,gBACpBA,YAAA,aAAiB,aAAa,WAAW;AAE3C,MAAM,wBAAwB,CAAC,QAAqBC,EAAAA,KAAK,cAAc,GAAG,KAAK;AAK/E,SAAS,iBAAiB;AAAA,EACxB;AACF,GAEG;AACD,QAAM,QAAiC;AAAA,IACrC,kBAAkB,MAAM,MAAM;AAC5B,aAAOC,UAAkB,kBAAA,MAAM,MAAM,EAAE,YAAa,CAAA;AAAA,IACtD;AAAA,IAEA,MAAM,eAAe,MAAM,KAAK;AACxB,YAAA,OAAO,sBAAsB,GAAG;AAEtC,aAAOC,YAAAA,SAAS,WAAW,OAAO,MAAM,aAAa,EAAE,MAAM;AAAA,IAC/D;AAAA,IAEA,MAAM,cAAc,MAAM,KAAK;AACvB,YAAA,OAAO,sBAAsB,GAAG;AAEtC,aAAOA,YAAAA,SAAS,WAAW,MAAM,MAAM,aAAa,EAAE,MAAM;AAAA,IAC9D;AAAA,IAEA,MAAM,cAAc,KAAK;AACjB,YAAA,OAAO,sBAAsB,GAAG;AAE/B,aAAAA,YAAA,SAAS,WAAW,MAAM,IAAI,OAAO,aAAa,EAAE,MAAM;AAAA,IACnE;AAAA,IAEA,MAAM,cAAc,KAAK;AACjB,YAAA,OAAO,sBAAsB,GAAG;AAE/B,aAAAC,YAAA,SAAS,WAAW,MAAM,IAAI,OAAO,aAAa,EAAE,MAAM;AAAA,IACnE;AAAA,IAEA,MAAM,cAAc,MAAM,KAAK;AACvB,YAAA,OAAO,sBAAsB,GAAG;AAEtC,aAAOA,YAAAA,SAAS,WAAW,MAAM,MAAM,aAAa,EAAE,MAAM;AAAA,IAC9D;AAAA,EAAA;AAGE,MAAA;AAEA,MAAA,aAAa,WAAW,GAAG;AACtB,WAAAC,WAA2B,EAAE,YAAA,CAAa;AAAA,EAAA,OAC5C;AACE,WAAAC,eAA+B,EAAE,YAAA,CAAa;AAAA,EACvD;AAEA,SAAO,OAAO,OAAO,OAAO,OAAO,KAAK,GAAG,IAAI;AACjD;;"}
@@ -0,0 +1,47 @@
1
+ import { prop } from "lodash/fp";
2
+ import { contentTypes, sanitize, validate } from "@strapi/utils";
3
+ import { transformResponse } from "./transform.mjs";
4
+ import createSingleTypeController from "./single-type.mjs";
5
+ import createCollectionTypeController from "./collection-type.mjs";
6
+ const isSingleType = (contentType) => contentTypes.isSingleType(contentType);
7
+ const getAuthFromKoaContext = (ctx) => prop("state.auth", ctx) ?? {};
8
+ function createController({
9
+ contentType
10
+ }) {
11
+ const proto = {
12
+ transformResponse(data, meta) {
13
+ return transformResponse(data, meta, { contentType });
14
+ },
15
+ async sanitizeOutput(data, ctx) {
16
+ const auth = getAuthFromKoaContext(ctx);
17
+ return sanitize.contentAPI.output(data, contentType, { auth });
18
+ },
19
+ async sanitizeInput(data, ctx) {
20
+ const auth = getAuthFromKoaContext(ctx);
21
+ return sanitize.contentAPI.input(data, contentType, { auth });
22
+ },
23
+ async sanitizeQuery(ctx) {
24
+ const auth = getAuthFromKoaContext(ctx);
25
+ return sanitize.contentAPI.query(ctx.query, contentType, { auth });
26
+ },
27
+ async validateQuery(ctx) {
28
+ const auth = getAuthFromKoaContext(ctx);
29
+ return validate.contentAPI.query(ctx.query, contentType, { auth });
30
+ },
31
+ async validateInput(data, ctx) {
32
+ const auth = getAuthFromKoaContext(ctx);
33
+ return validate.contentAPI.input(data, contentType, { auth });
34
+ }
35
+ };
36
+ let ctrl;
37
+ if (isSingleType(contentType)) {
38
+ ctrl = createSingleTypeController({ contentType });
39
+ } else {
40
+ ctrl = createCollectionTypeController({ contentType });
41
+ }
42
+ return Object.assign(Object.create(proto), ctrl);
43
+ }
44
+ export {
45
+ createController
46
+ };
47
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.mjs","sources":["../../../src/core-api/controller/index.ts"],"sourcesContent":["import { prop } from 'lodash/fp';\nimport type Koa from 'koa';\nimport { contentTypes as contentTypeUtils, sanitize, validate } from '@strapi/utils';\nimport type { CoreApi, Schema } from '@strapi/types';\n\nimport { transformResponse } from './transform';\nimport createSingleTypeController from './single-type';\nimport createCollectionTypeController from './collection-type';\n\nconst isSingleType = (contentType: Schema.ContentType): contentType is Schema.SingleType =>\n contentTypeUtils.isSingleType(contentType);\n\nconst getAuthFromKoaContext = (ctx: Koa.Context) => prop('state.auth', ctx) ?? {};\n\nfunction createController<T extends Schema.SingleType | Schema.CollectionType>(opts: {\n contentType: T;\n}): T extends Schema.SingleType ? CoreApi.Controller.SingleType : CoreApi.Controller.CollectionType;\nfunction createController({\n contentType,\n}: {\n contentType: Schema.SingleType | Schema.CollectionType;\n}) {\n const proto: CoreApi.Controller.Base = {\n transformResponse(data, meta) {\n return transformResponse(data, meta, { contentType });\n },\n\n async sanitizeOutput(data, ctx) {\n const auth = getAuthFromKoaContext(ctx);\n\n return sanitize.contentAPI.output(data, contentType, { auth });\n },\n\n async sanitizeInput(data, ctx) {\n const auth = getAuthFromKoaContext(ctx);\n\n return sanitize.contentAPI.input(data, contentType, { auth });\n },\n\n async sanitizeQuery(ctx) {\n const auth = getAuthFromKoaContext(ctx);\n\n return sanitize.contentAPI.query(ctx.query, contentType, { auth });\n },\n\n async validateQuery(ctx) {\n const auth = getAuthFromKoaContext(ctx);\n\n return validate.contentAPI.query(ctx.query, contentType, { auth });\n },\n\n async validateInput(data, ctx) {\n const auth = getAuthFromKoaContext(ctx);\n\n return validate.contentAPI.input(data, contentType, { auth });\n },\n };\n\n let ctrl;\n\n if (isSingleType(contentType)) {\n ctrl = createSingleTypeController({ contentType });\n } else {\n ctrl = createCollectionTypeController({ contentType });\n }\n\n return Object.assign(Object.create(proto), ctrl);\n}\n\nexport { createController };\n"],"names":["contentTypeUtils"],"mappings":";;;;;AASA,MAAM,eAAe,CAAC,gBACpBA,aAAiB,aAAa,WAAW;AAE3C,MAAM,wBAAwB,CAAC,QAAqB,KAAK,cAAc,GAAG,KAAK;AAK/E,SAAS,iBAAiB;AAAA,EACxB;AACF,GAEG;AACD,QAAM,QAAiC;AAAA,IACrC,kBAAkB,MAAM,MAAM;AAC5B,aAAO,kBAAkB,MAAM,MAAM,EAAE,YAAa,CAAA;AAAA,IACtD;AAAA,IAEA,MAAM,eAAe,MAAM,KAAK;AACxB,YAAA,OAAO,sBAAsB,GAAG;AAEtC,aAAO,SAAS,WAAW,OAAO,MAAM,aAAa,EAAE,MAAM;AAAA,IAC/D;AAAA,IAEA,MAAM,cAAc,MAAM,KAAK;AACvB,YAAA,OAAO,sBAAsB,GAAG;AAEtC,aAAO,SAAS,WAAW,MAAM,MAAM,aAAa,EAAE,MAAM;AAAA,IAC9D;AAAA,IAEA,MAAM,cAAc,KAAK;AACjB,YAAA,OAAO,sBAAsB,GAAG;AAE/B,aAAA,SAAS,WAAW,MAAM,IAAI,OAAO,aAAa,EAAE,MAAM;AAAA,IACnE;AAAA,IAEA,MAAM,cAAc,KAAK;AACjB,YAAA,OAAO,sBAAsB,GAAG;AAE/B,aAAA,SAAS,WAAW,MAAM,IAAI,OAAO,aAAa,EAAE,MAAM;AAAA,IACnE;AAAA,IAEA,MAAM,cAAc,MAAM,KAAK;AACvB,YAAA,OAAO,sBAAsB,GAAG;AAEtC,aAAO,SAAS,WAAW,MAAM,MAAM,aAAa,EAAE,MAAM;AAAA,IAC9D;AAAA,EAAA;AAGE,MAAA;AAEA,MAAA,aAAa,WAAW,GAAG;AACtB,WAAA,2BAA2B,EAAE,YAAA,CAAa;AAAA,EAAA,OAC5C;AACE,WAAA,+BAA+B,EAAE,YAAA,CAAa;AAAA,EACvD;AAEA,SAAO,OAAO,OAAO,OAAO,OAAO,KAAK,GAAG,IAAI;AACjD;"}
@@ -0,0 +1,10 @@
1
+ import type { Schema, CoreApi, Utils } from '@strapi/types';
2
+ interface Options {
3
+ contentType: Schema.SingleType;
4
+ }
5
+ /**
6
+ * Returns a single type controller to handle default core-api actions
7
+ */
8
+ declare const createSingleTypeController: ({ contentType, }: Options) => Utils.PartialWithThis<CoreApi.Controller.SingleType>;
9
+ export default createSingleTypeController;
10
+ //# sourceMappingURL=single-type.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"single-type.d.ts","sourceRoot":"","sources":["../../../src/core-api/controller/single-type.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,KAAK,EAAU,MAAM,eAAe,CAAC;AAIpE,UAAU,OAAO;IACf,WAAW,EAAE,MAAM,CAAC,UAAU,CAAC;CAChC;AAED;;GAEG;AACH,QAAA,MAAM,0BAA0B,qBAE7B,OAAO,KAAG,MAAM,eAAe,CAAC,QAAQ,UAAU,CAAC,UAAU,CAsD/D,CAAC;AAEF,eAAe,0BAA0B,CAAC"}
@@ -0,0 +1,50 @@
1
+ "use strict";
2
+ const _ = require("lodash/fp");
3
+ const strapiUtils = require("@strapi/utils");
4
+ const transform = require("./transform.js");
5
+ const createSingleTypeController = ({
6
+ contentType
7
+ }) => {
8
+ const uid = contentType.uid;
9
+ return {
10
+ /**
11
+ * Retrieve single type content
12
+ *
13
+ */
14
+ async find(ctx) {
15
+ await this.validateQuery(ctx);
16
+ const sanitizedQuery = await this.sanitizeQuery(ctx);
17
+ const entity = await strapi.service(uid).find(sanitizedQuery);
18
+ const sanitizedEntity = await this.sanitizeOutput(entity, ctx);
19
+ return this.transformResponse(sanitizedEntity);
20
+ },
21
+ /**
22
+ * create or update single type content.
23
+ *
24
+ * @return {Object}
25
+ */
26
+ async update(ctx) {
27
+ const { query } = ctx.request;
28
+ const body = transform.parseBody(ctx);
29
+ if (!_.isObject(body.data)) {
30
+ throw new strapiUtils.errors.ValidationError('Missing "data" payload in the request body');
31
+ }
32
+ const sanitizedInputData = await this.sanitizeInput(body.data, ctx);
33
+ const entity = await strapi.service(uid).createOrUpdate({
34
+ ...query,
35
+ data: sanitizedInputData,
36
+ files: "files" in body ? body.files : void 0
37
+ });
38
+ const sanitizedEntity = await this.sanitizeOutput(entity, ctx);
39
+ return this.transformResponse(sanitizedEntity);
40
+ },
41
+ async delete(ctx) {
42
+ const { query } = ctx;
43
+ const entity = await strapi.service(uid).delete(query);
44
+ const sanitizedEntity = await this.sanitizeOutput(entity, ctx);
45
+ return this.transformResponse(sanitizedEntity);
46
+ }
47
+ };
48
+ };
49
+ module.exports = createSingleTypeController;
50
+ //# sourceMappingURL=single-type.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"single-type.js","sources":["../../../src/core-api/controller/single-type.ts"],"sourcesContent":["import { isObject } from 'lodash/fp';\nimport { errors } from '@strapi/utils';\nimport type { Schema, CoreApi, Utils, Common } from '@strapi/types';\n\nimport { parseBody } from './transform';\n\ninterface Options {\n contentType: Schema.SingleType;\n}\n\n/**\n * Returns a single type controller to handle default core-api actions\n */\nconst createSingleTypeController = ({\n contentType,\n}: Options): Utils.PartialWithThis<CoreApi.Controller.SingleType> => {\n const uid = contentType.uid as Common.UID.Service;\n\n return {\n /**\n * Retrieve single type content\n *\n */\n async find(ctx) {\n await this.validateQuery(ctx);\n const sanitizedQuery = await this.sanitizeQuery(ctx);\n\n const entity = await strapi.service(uid).find(sanitizedQuery);\n\n const sanitizedEntity = await this.sanitizeOutput(entity, ctx);\n\n return this.transformResponse(sanitizedEntity);\n },\n\n /**\n * create or update single type content.\n *\n * @return {Object}\n */\n async update(ctx) {\n const { query } = ctx.request;\n const body = parseBody(ctx);\n\n if (!isObject(body.data)) {\n throw new errors.ValidationError('Missing \"data\" payload in the request body');\n }\n\n const sanitizedInputData = await this.sanitizeInput(body.data, ctx);\n\n const entity = await strapi.service(uid).createOrUpdate({\n ...query,\n data: sanitizedInputData,\n files: 'files' in body ? body.files : undefined,\n });\n\n const sanitizedEntity = await this.sanitizeOutput(entity, ctx);\n\n return this.transformResponse(sanitizedEntity);\n },\n\n async delete(ctx) {\n const { query } = ctx;\n\n const entity = await strapi.service(uid).delete(query);\n const sanitizedEntity = await this.sanitizeOutput(entity, ctx);\n\n return this.transformResponse(sanitizedEntity);\n },\n };\n};\n\nexport default createSingleTypeController;\n"],"names":["parseBody","isObject","errors"],"mappings":";;;;AAaA,MAAM,6BAA6B,CAAC;AAAA,EAClC;AACF,MAAqE;AACnE,QAAM,MAAM,YAAY;AAEjB,SAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAKL,MAAM,KAAK,KAAK;AACR,YAAA,KAAK,cAAc,GAAG;AAC5B,YAAM,iBAAiB,MAAM,KAAK,cAAc,GAAG;AAEnD,YAAM,SAAS,MAAM,OAAO,QAAQ,GAAG,EAAE,KAAK,cAAc;AAE5D,YAAM,kBAAkB,MAAM,KAAK,eAAe,QAAQ,GAAG;AAEtD,aAAA,KAAK,kBAAkB,eAAe;AAAA,IAC/C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOA,MAAM,OAAO,KAAK;AACV,YAAA,EAAE,MAAM,IAAI,IAAI;AAChB,YAAA,OAAOA,oBAAU,GAAG;AAE1B,UAAI,CAACC,EAAA,SAAS,KAAK,IAAI,GAAG;AAClB,cAAA,IAAIC,YAAO,OAAA,gBAAgB,4CAA4C;AAAA,MAC/E;AAEA,YAAM,qBAAqB,MAAM,KAAK,cAAc,KAAK,MAAM,GAAG;AAElE,YAAM,SAAS,MAAM,OAAO,QAAQ,GAAG,EAAE,eAAe;AAAA,QACtD,GAAG;AAAA,QACH,MAAM;AAAA,QACN,OAAO,WAAW,OAAO,KAAK,QAAQ;AAAA,MAAA,CACvC;AAED,YAAM,kBAAkB,MAAM,KAAK,eAAe,QAAQ,GAAG;AAEtD,aAAA,KAAK,kBAAkB,eAAe;AAAA,IAC/C;AAAA,IAEA,MAAM,OAAO,KAAK;AACV,YAAA,EAAE,MAAU,IAAA;AAElB,YAAM,SAAS,MAAM,OAAO,QAAQ,GAAG,EAAE,OAAO,KAAK;AACrD,YAAM,kBAAkB,MAAM,KAAK,eAAe,QAAQ,GAAG;AAEtD,aAAA,KAAK,kBAAkB,eAAe;AAAA,IAC/C;AAAA,EAAA;AAEJ;;"}
@@ -0,0 +1,51 @@
1
+ import { isObject } from "lodash/fp";
2
+ import { errors } from "@strapi/utils";
3
+ import { parseBody } from "./transform.mjs";
4
+ const createSingleTypeController = ({
5
+ contentType
6
+ }) => {
7
+ const uid = contentType.uid;
8
+ return {
9
+ /**
10
+ * Retrieve single type content
11
+ *
12
+ */
13
+ async find(ctx) {
14
+ await this.validateQuery(ctx);
15
+ const sanitizedQuery = await this.sanitizeQuery(ctx);
16
+ const entity = await strapi.service(uid).find(sanitizedQuery);
17
+ const sanitizedEntity = await this.sanitizeOutput(entity, ctx);
18
+ return this.transformResponse(sanitizedEntity);
19
+ },
20
+ /**
21
+ * create or update single type content.
22
+ *
23
+ * @return {Object}
24
+ */
25
+ async update(ctx) {
26
+ const { query } = ctx.request;
27
+ const body = parseBody(ctx);
28
+ if (!isObject(body.data)) {
29
+ throw new errors.ValidationError('Missing "data" payload in the request body');
30
+ }
31
+ const sanitizedInputData = await this.sanitizeInput(body.data, ctx);
32
+ const entity = await strapi.service(uid).createOrUpdate({
33
+ ...query,
34
+ data: sanitizedInputData,
35
+ files: "files" in body ? body.files : void 0
36
+ });
37
+ const sanitizedEntity = await this.sanitizeOutput(entity, ctx);
38
+ return this.transformResponse(sanitizedEntity);
39
+ },
40
+ async delete(ctx) {
41
+ const { query } = ctx;
42
+ const entity = await strapi.service(uid).delete(query);
43
+ const sanitizedEntity = await this.sanitizeOutput(entity, ctx);
44
+ return this.transformResponse(sanitizedEntity);
45
+ }
46
+ };
47
+ };
48
+ export {
49
+ createSingleTypeController as default
50
+ };
51
+ //# sourceMappingURL=single-type.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"single-type.mjs","sources":["../../../src/core-api/controller/single-type.ts"],"sourcesContent":["import { isObject } from 'lodash/fp';\nimport { errors } from '@strapi/utils';\nimport type { Schema, CoreApi, Utils, Common } from '@strapi/types';\n\nimport { parseBody } from './transform';\n\ninterface Options {\n contentType: Schema.SingleType;\n}\n\n/**\n * Returns a single type controller to handle default core-api actions\n */\nconst createSingleTypeController = ({\n contentType,\n}: Options): Utils.PartialWithThis<CoreApi.Controller.SingleType> => {\n const uid = contentType.uid as Common.UID.Service;\n\n return {\n /**\n * Retrieve single type content\n *\n */\n async find(ctx) {\n await this.validateQuery(ctx);\n const sanitizedQuery = await this.sanitizeQuery(ctx);\n\n const entity = await strapi.service(uid).find(sanitizedQuery);\n\n const sanitizedEntity = await this.sanitizeOutput(entity, ctx);\n\n return this.transformResponse(sanitizedEntity);\n },\n\n /**\n * create or update single type content.\n *\n * @return {Object}\n */\n async update(ctx) {\n const { query } = ctx.request;\n const body = parseBody(ctx);\n\n if (!isObject(body.data)) {\n throw new errors.ValidationError('Missing \"data\" payload in the request body');\n }\n\n const sanitizedInputData = await this.sanitizeInput(body.data, ctx);\n\n const entity = await strapi.service(uid).createOrUpdate({\n ...query,\n data: sanitizedInputData,\n files: 'files' in body ? body.files : undefined,\n });\n\n const sanitizedEntity = await this.sanitizeOutput(entity, ctx);\n\n return this.transformResponse(sanitizedEntity);\n },\n\n async delete(ctx) {\n const { query } = ctx;\n\n const entity = await strapi.service(uid).delete(query);\n const sanitizedEntity = await this.sanitizeOutput(entity, ctx);\n\n return this.transformResponse(sanitizedEntity);\n },\n };\n};\n\nexport default createSingleTypeController;\n"],"names":[],"mappings":";;;AAaA,MAAM,6BAA6B,CAAC;AAAA,EAClC;AACF,MAAqE;AACnE,QAAM,MAAM,YAAY;AAEjB,SAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAKL,MAAM,KAAK,KAAK;AACR,YAAA,KAAK,cAAc,GAAG;AAC5B,YAAM,iBAAiB,MAAM,KAAK,cAAc,GAAG;AAEnD,YAAM,SAAS,MAAM,OAAO,QAAQ,GAAG,EAAE,KAAK,cAAc;AAE5D,YAAM,kBAAkB,MAAM,KAAK,eAAe,QAAQ,GAAG;AAEtD,aAAA,KAAK,kBAAkB,eAAe;AAAA,IAC/C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOA,MAAM,OAAO,KAAK;AACV,YAAA,EAAE,MAAM,IAAI,IAAI;AAChB,YAAA,OAAO,UAAU,GAAG;AAE1B,UAAI,CAAC,SAAS,KAAK,IAAI,GAAG;AAClB,cAAA,IAAI,OAAO,gBAAgB,4CAA4C;AAAA,MAC/E;AAEA,YAAM,qBAAqB,MAAM,KAAK,cAAc,KAAK,MAAM,GAAG;AAElE,YAAM,SAAS,MAAM,OAAO,QAAQ,GAAG,EAAE,eAAe;AAAA,QACtD,GAAG;AAAA,QACH,MAAM;AAAA,QACN,OAAO,WAAW,OAAO,KAAK,QAAQ;AAAA,MAAA,CACvC;AAED,YAAM,kBAAkB,MAAM,KAAK,eAAe,QAAQ,GAAG;AAEtD,aAAA,KAAK,kBAAkB,eAAe;AAAA,IAC/C;AAAA,IAEA,MAAM,OAAO,KAAK;AACV,YAAA,EAAE,MAAU,IAAA;AAElB,YAAM,SAAS,MAAM,OAAO,QAAQ,GAAG,EAAE,OAAO,KAAK;AACrD,YAAM,kBAAkB,MAAM,KAAK,eAAe,QAAQ,GAAG;AAEtD,aAAA,KAAK,kBAAkB,eAAe;AAAA,IAC/C;AAAA,EAAA;AAEJ;"}
@@ -0,0 +1,22 @@
1
+ /// <reference types="formidable" />
2
+ import type Koa from 'koa';
3
+ import type { Schema } from '@strapi/types';
4
+ type TransformedEntry = {
5
+ id: string;
6
+ attributes: Record<string, unknown>;
7
+ meta?: Record<string, unknown>;
8
+ };
9
+ declare const parseBody: (ctx: Koa.Context) => Koa.Context | {
10
+ data: any;
11
+ files: import("formidable").Files;
12
+ } | {
13
+ data: any;
14
+ };
15
+ declare const transformResponse: (resource: any, meta?: unknown, opts?: {
16
+ contentType?: Schema.ContentType | Schema.Component;
17
+ }) => {
18
+ data: TransformedEntry | TransformedEntry[] | null;
19
+ meta: unknown;
20
+ } | null | undefined;
21
+ export { parseBody, transformResponse };
22
+ //# sourceMappingURL=transform.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"transform.d.ts","sourceRoot":"","sources":["../../../src/core-api/controller/transform.ts"],"names":[],"mappings":";AAEA,OAAO,KAAK,GAAG,MAAM,KAAK,CAAC;AAC3B,OAAO,KAAK,EAAU,MAAM,EAAO,MAAM,eAAe,CAAC;AAEzD,KAAK,gBAAgB,GAAG;IACtB,EAAE,EAAE,MAAM,CAAC;IACX,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACpC,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CAChC,CAAC;AAoBF,QAAA,MAAM,SAAS,QAAS,IAAI,OAAO;;;;;CAQlC,CAAC;AAEF,QAAA,MAAM,iBAAiB,aACX,GAAG,SACP,OAAO,SACP;IAAE,WAAW,CAAC,EAAE,OAAO,WAAW,GAAG,OAAO,SAAS,CAAA;CAAE;;;oBAU9D,CAAC;AAsFF,OAAO,EAAE,SAAS,EAAE,iBAAiB,EAAE,CAAC"}
@@ -0,0 +1,84 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const _ = require("lodash/fp");
4
+ const strapiUtils = require("@strapi/utils");
5
+ function isEntry(property) {
6
+ return property === null || _.isPlainObject(property) || Array.isArray(property);
7
+ }
8
+ function isDZEntries(property) {
9
+ return Array.isArray(property);
10
+ }
11
+ const parseBody = (ctx) => {
12
+ if (ctx.is("multipart")) {
13
+ return strapiUtils.parseMultipartData(ctx);
14
+ }
15
+ const { data } = ctx.request.body || {};
16
+ return { data };
17
+ };
18
+ const transformResponse = (resource, meta = {}, opts = {}) => {
19
+ if (_.isNil(resource)) {
20
+ return resource;
21
+ }
22
+ return {
23
+ data: transformEntry(resource, opts?.contentType),
24
+ meta
25
+ };
26
+ };
27
+ function transformComponent(data, component) {
28
+ if (Array.isArray(data)) {
29
+ return data.map((datum) => transformComponent(datum, component));
30
+ }
31
+ const res = transformEntry(data, component);
32
+ if (_.isNil(res)) {
33
+ return res;
34
+ }
35
+ const { id, attributes } = res;
36
+ return { id, ...attributes };
37
+ }
38
+ function transformEntry(entry, type) {
39
+ if (_.isNil(entry)) {
40
+ return entry;
41
+ }
42
+ if (Array.isArray(entry)) {
43
+ return entry.map((singleEntry) => transformEntry(singleEntry, type));
44
+ }
45
+ if (!_.isPlainObject(entry)) {
46
+ throw new Error("Entry must be an object");
47
+ }
48
+ const { id, ...properties } = entry;
49
+ const attributeValues = {};
50
+ for (const key of Object.keys(properties)) {
51
+ const property = properties[key];
52
+ const attribute = type && type.attributes[key];
53
+ if (attribute && attribute.type === "relation" && isEntry(property) && "target" in attribute) {
54
+ const data = transformEntry(
55
+ property,
56
+ strapi.contentType(attribute.target)
57
+ );
58
+ attributeValues[key] = { data };
59
+ } else if (attribute && attribute.type === "component" && isEntry(property)) {
60
+ attributeValues[key] = transformComponent(property, strapi.components[attribute.component]);
61
+ } else if (attribute && attribute.type === "dynamiczone" && isDZEntries(property)) {
62
+ if (_.isNil(property)) {
63
+ attributeValues[key] = property;
64
+ }
65
+ attributeValues[key] = property.map((subProperty) => {
66
+ return transformComponent(subProperty, strapi.components[subProperty.__component]);
67
+ });
68
+ } else if (attribute && attribute.type === "media" && isEntry(property)) {
69
+ const data = transformEntry(property, strapi.contentType("plugin::upload.file"));
70
+ attributeValues[key] = { data };
71
+ } else {
72
+ attributeValues[key] = property;
73
+ }
74
+ }
75
+ return {
76
+ id,
77
+ attributes: attributeValues
78
+ // NOTE: not necessary for now
79
+ // meta: {},
80
+ };
81
+ }
82
+ exports.parseBody = parseBody;
83
+ exports.transformResponse = transformResponse;
84
+ //# sourceMappingURL=transform.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"transform.js","sources":["../../../src/core-api/controller/transform.ts"],"sourcesContent":["import { isNil, isPlainObject } from 'lodash/fp';\nimport { parseMultipartData } from '@strapi/utils';\nimport type Koa from 'koa';\nimport type { Common, Schema, UID } from '@strapi/types';\n\ntype TransformedEntry = {\n id: string;\n attributes: Record<string, unknown>;\n meta?: Record<string, unknown>;\n};\n\ntype TransformedComponent = {\n id: string;\n [key: string]: unknown;\n};\n\ntype Entry = {\n id: string;\n [key: string]: Entry | Entry[] | string | number | null | boolean | Date;\n};\n\nfunction isEntry(property: unknown): property is Entry | Entry[] {\n return property === null || isPlainObject(property) || Array.isArray(property);\n}\n\nfunction isDZEntries(property: unknown): property is (Entry & { __component: UID.Component })[] {\n return Array.isArray(property);\n}\n\nconst parseBody = (ctx: Koa.Context) => {\n if (ctx.is('multipart')) {\n return parseMultipartData(ctx);\n }\n\n const { data } = ctx.request.body || {};\n\n return { data };\n};\n\nconst transformResponse = (\n resource: any,\n meta: unknown = {},\n opts: { contentType?: Schema.ContentType | Schema.Component } = {}\n) => {\n if (isNil(resource)) {\n return resource;\n }\n\n return {\n data: transformEntry(resource, opts?.contentType),\n meta,\n };\n};\n\nfunction transformComponent<T extends Entry | Entry[] | null>(\n data: T,\n component: Schema.Component\n): T extends Entry[] ? TransformedComponent[] : T extends Entry ? TransformedComponent : null;\nfunction transformComponent(\n data: Entry | Entry[] | null,\n component: Schema.Component\n): TransformedComponent | TransformedComponent[] | null {\n if (Array.isArray(data)) {\n return data.map((datum) => transformComponent(datum, component));\n }\n\n const res = transformEntry(data, component);\n\n if (isNil(res)) {\n return res;\n }\n\n const { id, attributes } = res;\n return { id, ...attributes };\n}\n\nfunction transformEntry<T extends Entry | Entry[] | null>(\n entry: T,\n type?: Schema.ContentType | Schema.Component\n): T extends Entry[] ? TransformedEntry[] : T extends Entry ? TransformedEntry : null;\nfunction transformEntry(\n entry: Entry | Entry[] | null,\n type?: Schema.ContentType | Schema.Component\n): TransformedEntry | TransformedEntry[] | null {\n if (isNil(entry)) {\n return entry;\n }\n\n if (Array.isArray(entry)) {\n return entry.map((singleEntry) => transformEntry(singleEntry, type));\n }\n\n if (!isPlainObject(entry)) {\n throw new Error('Entry must be an object');\n }\n\n const { id, ...properties } = entry;\n\n const attributeValues: Record<string, unknown> = {};\n\n for (const key of Object.keys(properties)) {\n const property = properties[key];\n const attribute = type && type.attributes[key];\n\n if (attribute && attribute.type === 'relation' && isEntry(property) && 'target' in attribute) {\n const data = transformEntry(\n property,\n strapi.contentType(attribute.target as Common.UID.ContentType)\n );\n\n attributeValues[key] = { data };\n } else if (attribute && attribute.type === 'component' && isEntry(property)) {\n attributeValues[key] = transformComponent(property, strapi.components[attribute.component]);\n } else if (attribute && attribute.type === 'dynamiczone' && isDZEntries(property)) {\n if (isNil(property)) {\n attributeValues[key] = property;\n }\n\n attributeValues[key] = property.map((subProperty) => {\n return transformComponent(subProperty, strapi.components[subProperty.__component]);\n });\n } else if (attribute && attribute.type === 'media' && isEntry(property)) {\n const data = transformEntry(property, strapi.contentType('plugin::upload.file'));\n\n attributeValues[key] = { data };\n } else {\n attributeValues[key] = property;\n }\n }\n\n return {\n id,\n attributes: attributeValues,\n // NOTE: not necessary for now\n // meta: {},\n };\n}\n\nexport { parseBody, transformResponse };\n"],"names":["isPlainObject","parseMultipartData","isNil"],"mappings":";;;;AAqBA,SAAS,QAAQ,UAAgD;AAC/D,SAAO,aAAa,QAAQA,gBAAc,QAAQ,KAAK,MAAM,QAAQ,QAAQ;AAC/E;AAEA,SAAS,YAAY,UAA2E;AACvF,SAAA,MAAM,QAAQ,QAAQ;AAC/B;AAEM,MAAA,YAAY,CAAC,QAAqB;AAClC,MAAA,IAAI,GAAG,WAAW,GAAG;AACvB,WAAOC,YAAAA,mBAAmB,GAAG;AAAA,EAC/B;AAEA,QAAM,EAAE,KAAK,IAAI,IAAI,QAAQ,QAAQ,CAAA;AAErC,SAAO,EAAE,KAAK;AAChB;AAEM,MAAA,oBAAoB,CACxB,UACA,OAAgB,CAAA,GAChB,OAAgE,CAAA,MAC7D;AACC,MAAAC,EAAAA,MAAM,QAAQ,GAAG;AACZ,WAAA;AAAA,EACT;AAEO,SAAA;AAAA,IACL,MAAM,eAAe,UAAU,MAAM,WAAW;AAAA,IAChD;AAAA,EAAA;AAEJ;AAMA,SAAS,mBACP,MACA,WACsD;AAClD,MAAA,MAAM,QAAQ,IAAI,GAAG;AACvB,WAAO,KAAK,IAAI,CAAC,UAAU,mBAAmB,OAAO,SAAS,CAAC;AAAA,EACjE;AAEM,QAAA,MAAM,eAAe,MAAM,SAAS;AAEtC,MAAAA,EAAAA,MAAM,GAAG,GAAG;AACP,WAAA;AAAA,EACT;AAEM,QAAA,EAAE,IAAI,WAAe,IAAA;AACpB,SAAA,EAAE,IAAI,GAAG;AAClB;AAMA,SAAS,eACP,OACA,MAC8C;AAC1C,MAAAA,EAAAA,MAAM,KAAK,GAAG;AACT,WAAA;AAAA,EACT;AAEI,MAAA,MAAM,QAAQ,KAAK,GAAG;AACxB,WAAO,MAAM,IAAI,CAAC,gBAAgB,eAAe,aAAa,IAAI,CAAC;AAAA,EACrE;AAEI,MAAA,CAACF,EAAAA,cAAc,KAAK,GAAG;AACnB,UAAA,IAAI,MAAM,yBAAyB;AAAA,EAC3C;AAEA,QAAM,EAAE,IAAI,GAAG,WAAA,IAAe;AAE9B,QAAM,kBAA2C,CAAA;AAEjD,aAAW,OAAO,OAAO,KAAK,UAAU,GAAG;AACnC,UAAA,WAAW,WAAW,GAAG;AAC/B,UAAM,YAAY,QAAQ,KAAK,WAAW,GAAG;AAEzC,QAAA,aAAa,UAAU,SAAS,cAAc,QAAQ,QAAQ,KAAK,YAAY,WAAW;AAC5F,YAAM,OAAO;AAAA,QACX;AAAA,QACA,OAAO,YAAY,UAAU,MAAgC;AAAA,MAAA;AAG/C,sBAAA,GAAG,IAAI,EAAE;IAAK,WACrB,aAAa,UAAU,SAAS,eAAe,QAAQ,QAAQ,GAAG;AAC3D,sBAAA,GAAG,IAAI,mBAAmB,UAAU,OAAO,WAAW,UAAU,SAAS,CAAC;AAAA,IAAA,WACjF,aAAa,UAAU,SAAS,iBAAiB,YAAY,QAAQ,GAAG;AAC7E,UAAAE,EAAAA,MAAM,QAAQ,GAAG;AACnB,wBAAgB,GAAG,IAAI;AAAA,MACzB;AAEA,sBAAgB,GAAG,IAAI,SAAS,IAAI,CAAC,gBAAgB;AACnD,eAAO,mBAAmB,aAAa,OAAO,WAAW,YAAY,WAAW,CAAC;AAAA,MAAA,CAClF;AAAA,IAAA,WACQ,aAAa,UAAU,SAAS,WAAW,QAAQ,QAAQ,GAAG;AACvE,YAAM,OAAO,eAAe,UAAU,OAAO,YAAY,qBAAqB,CAAC;AAE/D,sBAAA,GAAG,IAAI,EAAE;IAAK,OACzB;AACL,sBAAgB,GAAG,IAAI;AAAA,IACzB;AAAA,EACF;AAEO,SAAA;AAAA,IACL;AAAA,IACA,YAAY;AAAA;AAAA;AAAA,EAAA;AAIhB;;;"}
@@ -0,0 +1,84 @@
1
+ import { isNil, isPlainObject } from "lodash/fp";
2
+ import { parseMultipartData } from "@strapi/utils";
3
+ function isEntry(property) {
4
+ return property === null || isPlainObject(property) || Array.isArray(property);
5
+ }
6
+ function isDZEntries(property) {
7
+ return Array.isArray(property);
8
+ }
9
+ const parseBody = (ctx) => {
10
+ if (ctx.is("multipart")) {
11
+ return parseMultipartData(ctx);
12
+ }
13
+ const { data } = ctx.request.body || {};
14
+ return { data };
15
+ };
16
+ const transformResponse = (resource, meta = {}, opts = {}) => {
17
+ if (isNil(resource)) {
18
+ return resource;
19
+ }
20
+ return {
21
+ data: transformEntry(resource, opts?.contentType),
22
+ meta
23
+ };
24
+ };
25
+ function transformComponent(data, component) {
26
+ if (Array.isArray(data)) {
27
+ return data.map((datum) => transformComponent(datum, component));
28
+ }
29
+ const res = transformEntry(data, component);
30
+ if (isNil(res)) {
31
+ return res;
32
+ }
33
+ const { id, attributes } = res;
34
+ return { id, ...attributes };
35
+ }
36
+ function transformEntry(entry, type) {
37
+ if (isNil(entry)) {
38
+ return entry;
39
+ }
40
+ if (Array.isArray(entry)) {
41
+ return entry.map((singleEntry) => transformEntry(singleEntry, type));
42
+ }
43
+ if (!isPlainObject(entry)) {
44
+ throw new Error("Entry must be an object");
45
+ }
46
+ const { id, ...properties } = entry;
47
+ const attributeValues = {};
48
+ for (const key of Object.keys(properties)) {
49
+ const property = properties[key];
50
+ const attribute = type && type.attributes[key];
51
+ if (attribute && attribute.type === "relation" && isEntry(property) && "target" in attribute) {
52
+ const data = transformEntry(
53
+ property,
54
+ strapi.contentType(attribute.target)
55
+ );
56
+ attributeValues[key] = { data };
57
+ } else if (attribute && attribute.type === "component" && isEntry(property)) {
58
+ attributeValues[key] = transformComponent(property, strapi.components[attribute.component]);
59
+ } else if (attribute && attribute.type === "dynamiczone" && isDZEntries(property)) {
60
+ if (isNil(property)) {
61
+ attributeValues[key] = property;
62
+ }
63
+ attributeValues[key] = property.map((subProperty) => {
64
+ return transformComponent(subProperty, strapi.components[subProperty.__component]);
65
+ });
66
+ } else if (attribute && attribute.type === "media" && isEntry(property)) {
67
+ const data = transformEntry(property, strapi.contentType("plugin::upload.file"));
68
+ attributeValues[key] = { data };
69
+ } else {
70
+ attributeValues[key] = property;
71
+ }
72
+ }
73
+ return {
74
+ id,
75
+ attributes: attributeValues
76
+ // NOTE: not necessary for now
77
+ // meta: {},
78
+ };
79
+ }
80
+ export {
81
+ parseBody,
82
+ transformResponse
83
+ };
84
+ //# sourceMappingURL=transform.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"transform.mjs","sources":["../../../src/core-api/controller/transform.ts"],"sourcesContent":["import { isNil, isPlainObject } from 'lodash/fp';\nimport { parseMultipartData } from '@strapi/utils';\nimport type Koa from 'koa';\nimport type { Common, Schema, UID } from '@strapi/types';\n\ntype TransformedEntry = {\n id: string;\n attributes: Record<string, unknown>;\n meta?: Record<string, unknown>;\n};\n\ntype TransformedComponent = {\n id: string;\n [key: string]: unknown;\n};\n\ntype Entry = {\n id: string;\n [key: string]: Entry | Entry[] | string | number | null | boolean | Date;\n};\n\nfunction isEntry(property: unknown): property is Entry | Entry[] {\n return property === null || isPlainObject(property) || Array.isArray(property);\n}\n\nfunction isDZEntries(property: unknown): property is (Entry & { __component: UID.Component })[] {\n return Array.isArray(property);\n}\n\nconst parseBody = (ctx: Koa.Context) => {\n if (ctx.is('multipart')) {\n return parseMultipartData(ctx);\n }\n\n const { data } = ctx.request.body || {};\n\n return { data };\n};\n\nconst transformResponse = (\n resource: any,\n meta: unknown = {},\n opts: { contentType?: Schema.ContentType | Schema.Component } = {}\n) => {\n if (isNil(resource)) {\n return resource;\n }\n\n return {\n data: transformEntry(resource, opts?.contentType),\n meta,\n };\n};\n\nfunction transformComponent<T extends Entry | Entry[] | null>(\n data: T,\n component: Schema.Component\n): T extends Entry[] ? TransformedComponent[] : T extends Entry ? TransformedComponent : null;\nfunction transformComponent(\n data: Entry | Entry[] | null,\n component: Schema.Component\n): TransformedComponent | TransformedComponent[] | null {\n if (Array.isArray(data)) {\n return data.map((datum) => transformComponent(datum, component));\n }\n\n const res = transformEntry(data, component);\n\n if (isNil(res)) {\n return res;\n }\n\n const { id, attributes } = res;\n return { id, ...attributes };\n}\n\nfunction transformEntry<T extends Entry | Entry[] | null>(\n entry: T,\n type?: Schema.ContentType | Schema.Component\n): T extends Entry[] ? TransformedEntry[] : T extends Entry ? TransformedEntry : null;\nfunction transformEntry(\n entry: Entry | Entry[] | null,\n type?: Schema.ContentType | Schema.Component\n): TransformedEntry | TransformedEntry[] | null {\n if (isNil(entry)) {\n return entry;\n }\n\n if (Array.isArray(entry)) {\n return entry.map((singleEntry) => transformEntry(singleEntry, type));\n }\n\n if (!isPlainObject(entry)) {\n throw new Error('Entry must be an object');\n }\n\n const { id, ...properties } = entry;\n\n const attributeValues: Record<string, unknown> = {};\n\n for (const key of Object.keys(properties)) {\n const property = properties[key];\n const attribute = type && type.attributes[key];\n\n if (attribute && attribute.type === 'relation' && isEntry(property) && 'target' in attribute) {\n const data = transformEntry(\n property,\n strapi.contentType(attribute.target as Common.UID.ContentType)\n );\n\n attributeValues[key] = { data };\n } else if (attribute && attribute.type === 'component' && isEntry(property)) {\n attributeValues[key] = transformComponent(property, strapi.components[attribute.component]);\n } else if (attribute && attribute.type === 'dynamiczone' && isDZEntries(property)) {\n if (isNil(property)) {\n attributeValues[key] = property;\n }\n\n attributeValues[key] = property.map((subProperty) => {\n return transformComponent(subProperty, strapi.components[subProperty.__component]);\n });\n } else if (attribute && attribute.type === 'media' && isEntry(property)) {\n const data = transformEntry(property, strapi.contentType('plugin::upload.file'));\n\n attributeValues[key] = { data };\n } else {\n attributeValues[key] = property;\n }\n }\n\n return {\n id,\n attributes: attributeValues,\n // NOTE: not necessary for now\n // meta: {},\n };\n}\n\nexport { parseBody, transformResponse };\n"],"names":[],"mappings":";;AAqBA,SAAS,QAAQ,UAAgD;AAC/D,SAAO,aAAa,QAAQ,cAAc,QAAQ,KAAK,MAAM,QAAQ,QAAQ;AAC/E;AAEA,SAAS,YAAY,UAA2E;AACvF,SAAA,MAAM,QAAQ,QAAQ;AAC/B;AAEM,MAAA,YAAY,CAAC,QAAqB;AAClC,MAAA,IAAI,GAAG,WAAW,GAAG;AACvB,WAAO,mBAAmB,GAAG;AAAA,EAC/B;AAEA,QAAM,EAAE,KAAK,IAAI,IAAI,QAAQ,QAAQ,CAAA;AAErC,SAAO,EAAE,KAAK;AAChB;AAEM,MAAA,oBAAoB,CACxB,UACA,OAAgB,CAAA,GAChB,OAAgE,CAAA,MAC7D;AACC,MAAA,MAAM,QAAQ,GAAG;AACZ,WAAA;AAAA,EACT;AAEO,SAAA;AAAA,IACL,MAAM,eAAe,UAAU,MAAM,WAAW;AAAA,IAChD;AAAA,EAAA;AAEJ;AAMA,SAAS,mBACP,MACA,WACsD;AAClD,MAAA,MAAM,QAAQ,IAAI,GAAG;AACvB,WAAO,KAAK,IAAI,CAAC,UAAU,mBAAmB,OAAO,SAAS,CAAC;AAAA,EACjE;AAEM,QAAA,MAAM,eAAe,MAAM,SAAS;AAEtC,MAAA,MAAM,GAAG,GAAG;AACP,WAAA;AAAA,EACT;AAEM,QAAA,EAAE,IAAI,WAAe,IAAA;AACpB,SAAA,EAAE,IAAI,GAAG;AAClB;AAMA,SAAS,eACP,OACA,MAC8C;AAC1C,MAAA,MAAM,KAAK,GAAG;AACT,WAAA;AAAA,EACT;AAEI,MAAA,MAAM,QAAQ,KAAK,GAAG;AACxB,WAAO,MAAM,IAAI,CAAC,gBAAgB,eAAe,aAAa,IAAI,CAAC;AAAA,EACrE;AAEI,MAAA,CAAC,cAAc,KAAK,GAAG;AACnB,UAAA,IAAI,MAAM,yBAAyB;AAAA,EAC3C;AAEA,QAAM,EAAE,IAAI,GAAG,WAAA,IAAe;AAE9B,QAAM,kBAA2C,CAAA;AAEjD,aAAW,OAAO,OAAO,KAAK,UAAU,GAAG;AACnC,UAAA,WAAW,WAAW,GAAG;AAC/B,UAAM,YAAY,QAAQ,KAAK,WAAW,GAAG;AAEzC,QAAA,aAAa,UAAU,SAAS,cAAc,QAAQ,QAAQ,KAAK,YAAY,WAAW;AAC5F,YAAM,OAAO;AAAA,QACX;AAAA,QACA,OAAO,YAAY,UAAU,MAAgC;AAAA,MAAA;AAG/C,sBAAA,GAAG,IAAI,EAAE;IAAK,WACrB,aAAa,UAAU,SAAS,eAAe,QAAQ,QAAQ,GAAG;AAC3D,sBAAA,GAAG,IAAI,mBAAmB,UAAU,OAAO,WAAW,UAAU,SAAS,CAAC;AAAA,IAAA,WACjF,aAAa,UAAU,SAAS,iBAAiB,YAAY,QAAQ,GAAG;AAC7E,UAAA,MAAM,QAAQ,GAAG;AACnB,wBAAgB,GAAG,IAAI;AAAA,MACzB;AAEA,sBAAgB,GAAG,IAAI,SAAS,IAAI,CAAC,gBAAgB;AACnD,eAAO,mBAAmB,aAAa,OAAO,WAAW,YAAY,WAAW,CAAC;AAAA,MAAA,CAClF;AAAA,IAAA,WACQ,aAAa,UAAU,SAAS,WAAW,QAAQ,QAAQ,GAAG;AACvE,YAAM,OAAO,eAAe,UAAU,OAAO,YAAY,qBAAqB,CAAC;AAE/D,sBAAA,GAAG,IAAI,EAAE;IAAK,OACzB;AACL,sBAAgB,GAAG,IAAI;AAAA,IACzB;AAAA,EACF;AAEO,SAAA;AAAA,IACL;AAAA,IACA,YAAY;AAAA;AAAA;AAAA,EAAA;AAIhB;"}
@@ -0,0 +1,24 @@
1
+ import type { Schema } from '@strapi/types';
2
+ export declare const createRoutes: ({ contentType }: {
3
+ contentType: Schema.ContentType;
4
+ }) => {
5
+ find: {
6
+ method: string;
7
+ path: string;
8
+ handler: string;
9
+ config: {};
10
+ };
11
+ update: {
12
+ method: string;
13
+ path: string;
14
+ handler: string;
15
+ config: {};
16
+ };
17
+ delete: {
18
+ method: string;
19
+ path: string;
20
+ handler: string;
21
+ config: {};
22
+ };
23
+ };
24
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/core-api/routes/index.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAE5C,eAAO,MAAM,YAAY;iBAAoC,OAAO,WAAW;;;;;;;;;;;;;;;;;;;;CAM9E,CAAC"}