@strapi/core 0.0.0 → 5.0.0-alpha.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (881) hide show
  1. package/dist/Strapi.d.ts +9 -4
  2. package/dist/Strapi.d.ts.map +1 -1
  3. package/dist/Strapi.js +78 -52
  4. package/dist/Strapi.js.map +1 -1
  5. package/dist/Strapi.mjs +80 -53
  6. package/dist/Strapi.mjs.map +1 -1
  7. package/dist/configuration/config-loader.d.ts.map +1 -0
  8. package/dist/configuration/config-loader.js +102 -0
  9. package/dist/configuration/config-loader.js.map +1 -0
  10. package/dist/configuration/config-loader.mjs +100 -0
  11. package/dist/configuration/config-loader.mjs.map +1 -0
  12. package/dist/{core/app-configuration → configuration}/index.d.ts +20 -5
  13. package/dist/configuration/index.d.ts.map +1 -0
  14. package/dist/{core/app-configuration → configuration}/index.js +28 -5
  15. package/dist/configuration/index.js.map +1 -0
  16. package/dist/{core/app-configuration → configuration}/index.mjs +28 -5
  17. package/dist/configuration/index.mjs.map +1 -0
  18. package/dist/configuration/urls.d.ts +8 -0
  19. package/dist/configuration/urls.d.ts.map +1 -0
  20. package/dist/configuration/urls.js +68 -0
  21. package/dist/configuration/urls.js.map +1 -0
  22. package/dist/configuration/urls.mjs +66 -0
  23. package/dist/configuration/urls.mjs.map +1 -0
  24. package/dist/core-api/controller/collection-type.d.ts +1 -1
  25. package/dist/core-api/controller/collection-type.d.ts.map +1 -1
  26. package/dist/core-api/controller/collection-type.js +9 -20
  27. package/dist/core-api/controller/collection-type.js.map +1 -1
  28. package/dist/core-api/controller/collection-type.mjs +8 -20
  29. package/dist/core-api/controller/collection-type.mjs.map +1 -1
  30. package/dist/core-api/controller/index.d.ts.map +1 -1
  31. package/dist/core-api/controller/index.js +8 -3
  32. package/dist/core-api/controller/index.js.map +1 -1
  33. package/dist/core-api/controller/index.mjs +8 -3
  34. package/dist/core-api/controller/index.mjs.map +1 -1
  35. package/dist/core-api/controller/single-type.d.ts +1 -1
  36. package/dist/core-api/controller/single-type.d.ts.map +1 -1
  37. package/dist/core-api/controller/single-type.js +6 -11
  38. package/dist/core-api/controller/single-type.js.map +1 -1
  39. package/dist/core-api/controller/single-type.mjs +5 -11
  40. package/dist/core-api/controller/single-type.mjs.map +1 -1
  41. package/dist/core-api/controller/transform.d.ts +9 -17
  42. package/dist/core-api/controller/transform.d.ts.map +1 -1
  43. package/dist/core-api/controller/transform.js +9 -14
  44. package/dist/core-api/controller/transform.js.map +1 -1
  45. package/dist/core-api/controller/transform.mjs +9 -14
  46. package/dist/core-api/controller/transform.mjs.map +1 -1
  47. package/dist/core-api/service/collection-type.d.ts +28 -5
  48. package/dist/core-api/service/collection-type.d.ts.map +1 -1
  49. package/dist/core-api/service/collection-type.js +47 -49
  50. package/dist/core-api/service/collection-type.js.map +1 -1
  51. package/dist/core-api/service/collection-type.mjs +47 -50
  52. package/dist/core-api/service/collection-type.mjs.map +1 -1
  53. package/dist/core-api/service/core-service.d.ts +4 -0
  54. package/dist/core-api/service/core-service.d.ts.map +1 -0
  55. package/dist/core-api/service/core-service.js +12 -0
  56. package/dist/core-api/service/core-service.js.map +1 -0
  57. package/dist/core-api/service/core-service.mjs +12 -0
  58. package/dist/core-api/service/core-service.mjs.map +1 -0
  59. package/dist/core-api/service/index.js +2 -2
  60. package/dist/core-api/service/index.js.map +1 -1
  61. package/dist/core-api/service/index.mjs +4 -4
  62. package/dist/core-api/service/index.mjs.map +1 -1
  63. package/dist/core-api/service/pagination.d.ts +1 -5
  64. package/dist/core-api/service/pagination.d.ts.map +1 -1
  65. package/dist/core-api/service/pagination.js +0 -11
  66. package/dist/core-api/service/pagination.js.map +1 -1
  67. package/dist/core-api/service/pagination.mjs +0 -11
  68. package/dist/core-api/service/pagination.mjs.map +1 -1
  69. package/dist/core-api/service/single-type.d.ts +14 -8
  70. package/dist/core-api/service/single-type.d.ts.map +1 -1
  71. package/dist/core-api/service/single-type.js +35 -50
  72. package/dist/core-api/service/single-type.js.map +1 -1
  73. package/dist/core-api/service/single-type.mjs +34 -50
  74. package/dist/core-api/service/single-type.mjs.map +1 -1
  75. package/dist/{core/domain → domain}/content-type/index.d.ts +2 -1
  76. package/dist/domain/content-type/index.d.ts.map +1 -0
  77. package/dist/{core/domain → domain}/content-type/index.js +23 -34
  78. package/dist/domain/content-type/index.js.map +1 -0
  79. package/dist/{core/domain → domain}/content-type/index.mjs +24 -35
  80. package/dist/domain/content-type/index.mjs.map +1 -0
  81. package/dist/domain/content-type/validator.d.ts.map +1 -0
  82. package/dist/{core/domain → domain}/content-type/validator.js +1 -1
  83. package/dist/domain/content-type/validator.js.map +1 -0
  84. package/dist/{core/domain → domain}/content-type/validator.mjs +2 -2
  85. package/dist/domain/content-type/validator.mjs.map +1 -0
  86. package/dist/domain/module/index.d.ts.map +1 -0
  87. package/dist/{core/domain → domain}/module/index.js +30 -31
  88. package/dist/domain/module/index.js.map +1 -0
  89. package/dist/{core/domain → domain}/module/index.mjs +3 -4
  90. package/dist/domain/module/index.mjs.map +1 -0
  91. package/dist/domain/module/validation.d.ts.map +1 -0
  92. package/dist/domain/module/validation.js.map +1 -0
  93. package/dist/domain/module/validation.mjs.map +1 -0
  94. package/dist/ee/index.js +2 -2
  95. package/dist/ee/index.js.map +1 -1
  96. package/dist/ee/index.mjs +2 -2
  97. package/dist/ee/index.mjs.map +1 -1
  98. package/dist/ee/license.d.ts.map +1 -1
  99. package/dist/ee/license.js +2 -1
  100. package/dist/ee/license.js.map +1 -1
  101. package/dist/ee/license.mjs +2 -1
  102. package/dist/ee/license.mjs.map +1 -1
  103. package/dist/factories.d.ts +2 -1
  104. package/dist/factories.d.ts.map +1 -1
  105. package/dist/factories.js +16 -11
  106. package/dist/factories.js.map +1 -1
  107. package/dist/factories.mjs +17 -12
  108. package/dist/factories.mjs.map +1 -1
  109. package/dist/index.d.ts +3 -2
  110. package/dist/index.d.ts.map +1 -1
  111. package/dist/index.js +3 -1
  112. package/dist/index.js.map +1 -1
  113. package/dist/index.mjs +3 -1
  114. package/dist/index.mjs.map +1 -1
  115. package/dist/loaders/admin.d.ts.map +1 -0
  116. package/dist/{core/loaders → loaders}/admin.js +12 -1
  117. package/dist/loaders/admin.js.map +1 -0
  118. package/dist/{core/loaders → loaders}/admin.mjs +12 -1
  119. package/dist/loaders/admin.mjs.map +1 -0
  120. package/dist/loaders/apis.d.ts.map +1 -0
  121. package/dist/{core/loaders → loaders}/apis.js +20 -13
  122. package/dist/loaders/apis.js.map +1 -0
  123. package/dist/{core/loaders → loaders}/apis.mjs +19 -12
  124. package/dist/loaders/apis.mjs.map +1 -0
  125. package/dist/loaders/components.d.ts.map +1 -0
  126. package/dist/{core/loaders → loaders}/components.js +2 -2
  127. package/dist/loaders/components.js.map +1 -0
  128. package/dist/{core/loaders → loaders}/components.mjs +1 -1
  129. package/dist/loaders/components.mjs.map +1 -0
  130. package/dist/loaders/index.d.ts.map +1 -0
  131. package/dist/loaders/index.js.map +1 -0
  132. package/dist/loaders/index.mjs.map +1 -0
  133. package/dist/loaders/middlewares.d.ts.map +1 -0
  134. package/dist/{core/loaders → loaders}/middlewares.js +1 -1
  135. package/dist/loaders/middlewares.js.map +1 -0
  136. package/dist/{core/loaders → loaders}/middlewares.mjs +1 -1
  137. package/dist/loaders/middlewares.mjs.map +1 -0
  138. package/dist/loaders/plugins/get-enabled-plugins.d.ts.map +1 -0
  139. package/dist/{core/loaders → loaders}/plugins/get-enabled-plugins.js +3 -2
  140. package/dist/loaders/plugins/get-enabled-plugins.js.map +1 -0
  141. package/dist/{core/loaders → loaders}/plugins/get-enabled-plugins.mjs +4 -3
  142. package/dist/loaders/plugins/get-enabled-plugins.mjs.map +1 -0
  143. package/dist/loaders/plugins/get-user-plugins-config.d.ts.map +1 -0
  144. package/dist/{core/loaders → loaders}/plugins/get-user-plugins-config.js +3 -3
  145. package/dist/loaders/plugins/get-user-plugins-config.js.map +1 -0
  146. package/dist/{core/loaders → loaders}/plugins/get-user-plugins-config.mjs +3 -3
  147. package/dist/loaders/plugins/get-user-plugins-config.mjs.map +1 -0
  148. package/dist/loaders/plugins/index.d.ts.map +1 -0
  149. package/dist/{core/loaders → loaders}/plugins/index.js +18 -5
  150. package/dist/loaders/plugins/index.js.map +1 -0
  151. package/dist/{core/loaders → loaders}/plugins/index.mjs +16 -3
  152. package/dist/loaders/plugins/index.mjs.map +1 -0
  153. package/dist/loaders/policies.d.ts.map +1 -0
  154. package/dist/loaders/policies.js.map +1 -0
  155. package/dist/loaders/policies.mjs.map +1 -0
  156. package/dist/loaders/sanitizers.d.ts.map +1 -0
  157. package/dist/loaders/sanitizers.js.map +1 -0
  158. package/dist/loaders/sanitizers.mjs.map +1 -0
  159. package/dist/loaders/src-index.d.ts.map +1 -0
  160. package/dist/loaders/src-index.js.map +1 -0
  161. package/dist/loaders/src-index.mjs.map +1 -0
  162. package/dist/loaders/validators.d.ts.map +1 -0
  163. package/dist/loaders/validators.js.map +1 -0
  164. package/dist/loaders/validators.mjs.map +1 -0
  165. package/dist/middlewares/favicon.d.ts +1 -0
  166. package/dist/middlewares/favicon.d.ts.map +1 -1
  167. package/dist/middlewares/index.js +2 -2
  168. package/dist/middlewares/index.js.map +1 -1
  169. package/dist/middlewares/index.mjs +1 -1
  170. package/dist/middlewares/{public/index.d.ts → public.d.ts} +1 -1
  171. package/dist/middlewares/public.d.ts.map +1 -0
  172. package/dist/middlewares/public.js +34 -0
  173. package/dist/middlewares/public.js.map +1 -0
  174. package/dist/middlewares/public.mjs +32 -0
  175. package/dist/middlewares/public.mjs.map +1 -0
  176. package/dist/middlewares/security.d.ts.map +1 -1
  177. package/dist/middlewares/security.js +24 -3
  178. package/dist/middlewares/security.js.map +1 -1
  179. package/dist/middlewares/security.mjs +24 -3
  180. package/dist/middlewares/security.mjs.map +1 -1
  181. package/dist/migrations/draft-publish.d.ts +17 -0
  182. package/dist/migrations/draft-publish.d.ts.map +1 -0
  183. package/dist/migrations/draft-publish.js +59 -0
  184. package/dist/migrations/draft-publish.js.map +1 -0
  185. package/dist/migrations/draft-publish.mjs +59 -0
  186. package/dist/migrations/draft-publish.mjs.map +1 -0
  187. package/dist/registries/apis.d.ts.map +1 -0
  188. package/dist/registries/apis.js.map +1 -0
  189. package/dist/registries/apis.mjs.map +1 -0
  190. package/dist/registries/components.d.ts.map +1 -0
  191. package/dist/registries/components.js.map +1 -0
  192. package/dist/registries/components.mjs.map +1 -0
  193. package/dist/registries/config.d.ts +4 -0
  194. package/dist/registries/config.d.ts.map +1 -0
  195. package/dist/registries/config.js +31 -0
  196. package/dist/registries/config.js.map +1 -0
  197. package/dist/registries/config.mjs +32 -0
  198. package/dist/registries/config.mjs.map +1 -0
  199. package/dist/registries/content-types.d.ts.map +1 -0
  200. package/dist/{core/registries → registries}/content-types.js +6 -7
  201. package/dist/registries/content-types.js.map +1 -0
  202. package/dist/{core/registries → registries}/content-types.mjs +2 -3
  203. package/dist/registries/content-types.mjs.map +1 -0
  204. package/dist/registries/controllers.d.ts.map +1 -0
  205. package/dist/{core/registries → registries}/controllers.js +5 -5
  206. package/dist/registries/controllers.js.map +1 -0
  207. package/dist/{core/registries → registries}/controllers.mjs +1 -1
  208. package/dist/registries/controllers.mjs.map +1 -0
  209. package/dist/registries/custom-fields.d.ts.map +1 -0
  210. package/dist/registries/custom-fields.js.map +1 -0
  211. package/dist/registries/custom-fields.mjs.map +1 -0
  212. package/dist/registries/hooks.d.ts.map +1 -0
  213. package/dist/{core/registries → registries}/hooks.js +5 -5
  214. package/dist/registries/hooks.js.map +1 -0
  215. package/dist/{core/registries → registries}/hooks.mjs +1 -1
  216. package/dist/registries/hooks.mjs.map +1 -0
  217. package/dist/{core/registries → registries}/index.d.ts +1 -0
  218. package/dist/registries/index.d.ts.map +1 -0
  219. package/dist/registries/middlewares.d.ts.map +1 -0
  220. package/dist/{core/registries → registries}/middlewares.js +5 -5
  221. package/dist/registries/middlewares.js.map +1 -0
  222. package/dist/{core/registries → registries}/middlewares.mjs +1 -1
  223. package/dist/registries/middlewares.mjs.map +1 -0
  224. package/dist/registries/models.d.ts +6 -0
  225. package/dist/registries/models.d.ts.map +1 -0
  226. package/dist/registries/models.js +16 -0
  227. package/dist/registries/models.js.map +1 -0
  228. package/dist/registries/models.mjs +16 -0
  229. package/dist/registries/models.mjs.map +1 -0
  230. package/dist/registries/modules.d.ts.map +1 -0
  231. package/dist/registries/modules.js.map +1 -0
  232. package/dist/registries/modules.mjs.map +1 -0
  233. package/dist/{core/utils.d.ts → registries/namespace.d.ts} +1 -1
  234. package/dist/registries/namespace.d.ts.map +1 -0
  235. package/dist/{core/utils.js → registries/namespace.js} +1 -1
  236. package/dist/registries/namespace.js.map +1 -0
  237. package/dist/{core/utils.mjs → registries/namespace.mjs} +1 -1
  238. package/dist/registries/namespace.mjs.map +1 -0
  239. package/dist/registries/plugins.d.ts.map +1 -0
  240. package/dist/registries/plugins.js.map +1 -0
  241. package/dist/registries/plugins.mjs.map +1 -0
  242. package/dist/registries/policies.d.ts.map +1 -0
  243. package/dist/{core/registries → registries}/policies.js +5 -5
  244. package/dist/registries/policies.js.map +1 -0
  245. package/dist/{core/registries → registries}/policies.mjs +1 -1
  246. package/dist/registries/policies.mjs.map +1 -0
  247. package/dist/registries/sanitizers.d.ts.map +1 -0
  248. package/dist/registries/sanitizers.js.map +1 -0
  249. package/dist/registries/sanitizers.mjs.map +1 -0
  250. package/dist/registries/services.d.ts.map +1 -0
  251. package/dist/{core/registries → registries}/services.js +5 -5
  252. package/dist/registries/services.js.map +1 -0
  253. package/dist/{core/registries → registries}/services.mjs +1 -1
  254. package/dist/registries/services.mjs.map +1 -0
  255. package/dist/registries/validators.d.ts.map +1 -0
  256. package/dist/registries/validators.js.map +1 -0
  257. package/dist/registries/validators.mjs.map +1 -0
  258. package/dist/services/core-store.d.ts +2 -22
  259. package/dist/services/core-store.d.ts.map +1 -1
  260. package/dist/services/core-store.js +5 -1
  261. package/dist/services/core-store.js.map +1 -1
  262. package/dist/services/core-store.mjs +5 -1
  263. package/dist/services/core-store.mjs.map +1 -1
  264. package/dist/services/document-service/common.d.ts +4 -0
  265. package/dist/services/document-service/common.d.ts.map +1 -0
  266. package/dist/services/document-service/common.js +7 -0
  267. package/dist/services/document-service/common.js.map +1 -0
  268. package/dist/services/document-service/common.mjs +7 -0
  269. package/dist/services/document-service/common.mjs.map +1 -0
  270. package/dist/services/document-service/draft-and-publish.d.ts +10 -0
  271. package/dist/services/document-service/draft-and-publish.d.ts.map +1 -0
  272. package/dist/services/document-service/draft-and-publish.js +69 -0
  273. package/dist/services/document-service/draft-and-publish.js.map +1 -0
  274. package/dist/services/document-service/draft-and-publish.mjs +69 -0
  275. package/dist/services/document-service/draft-and-publish.mjs.map +1 -0
  276. package/dist/services/document-service/index.d.ts +18 -7
  277. package/dist/services/document-service/index.d.ts.map +1 -1
  278. package/dist/services/document-service/index.js +20 -190
  279. package/dist/services/document-service/index.js.map +1 -1
  280. package/dist/services/document-service/index.mjs +19 -190
  281. package/dist/services/document-service/index.mjs.map +1 -1
  282. package/dist/services/document-service/internationalization.d.ts +8 -0
  283. package/dist/services/document-service/internationalization.d.ts.map +1 -0
  284. package/dist/services/document-service/internationalization.js +54 -0
  285. package/dist/services/document-service/internationalization.js.map +1 -0
  286. package/dist/services/document-service/internationalization.mjs +54 -0
  287. package/dist/services/document-service/internationalization.mjs.map +1 -0
  288. package/dist/services/document-service/middlewares/errors.d.ts +6 -0
  289. package/dist/services/document-service/middlewares/errors.d.ts.map +1 -0
  290. package/dist/services/document-service/middlewares/errors.js +25 -0
  291. package/dist/services/document-service/middlewares/errors.js.map +1 -0
  292. package/dist/services/document-service/middlewares/errors.mjs +25 -0
  293. package/dist/services/document-service/middlewares/errors.mjs.map +1 -0
  294. package/dist/services/document-service/middlewares/index.d.ts +2 -10
  295. package/dist/services/document-service/middlewares/index.d.ts.map +1 -1
  296. package/dist/services/document-service/middlewares/middleware-manager.d.ts +7 -0
  297. package/dist/services/document-service/middlewares/middleware-manager.d.ts.map +1 -0
  298. package/dist/services/document-service/middlewares/middleware-manager.js +46 -0
  299. package/dist/services/document-service/middlewares/middleware-manager.js.map +1 -0
  300. package/dist/services/document-service/middlewares/middleware-manager.mjs +46 -0
  301. package/dist/services/document-service/middlewares/middleware-manager.mjs.map +1 -0
  302. package/dist/services/document-service/repository.d.ts +3 -0
  303. package/dist/services/document-service/repository.d.ts.map +1 -0
  304. package/dist/services/document-service/repository.js +295 -0
  305. package/dist/services/document-service/repository.js.map +1 -0
  306. package/dist/services/document-service/repository.mjs +295 -0
  307. package/dist/services/document-service/repository.mjs.map +1 -0
  308. package/dist/services/document-service/transform/data.d.ts +5 -0
  309. package/dist/services/document-service/transform/data.d.ts.map +1 -0
  310. package/dist/services/document-service/transform/data.js +13 -0
  311. package/dist/services/document-service/transform/data.js.map +1 -0
  312. package/dist/services/document-service/transform/data.mjs +13 -0
  313. package/dist/services/document-service/transform/data.mjs.map +1 -0
  314. package/dist/services/document-service/transform/fields.d.ts +5 -0
  315. package/dist/services/document-service/transform/fields.d.ts.map +1 -0
  316. package/dist/services/document-service/transform/fields.js +24 -0
  317. package/dist/services/document-service/transform/fields.js.map +1 -0
  318. package/dist/services/document-service/transform/fields.mjs +24 -0
  319. package/dist/services/document-service/transform/fields.mjs.map +1 -0
  320. package/dist/services/document-service/transform/id-map.d.ts +23 -0
  321. package/dist/services/document-service/transform/id-map.d.ts.map +1 -0
  322. package/dist/services/document-service/transform/id-map.js +78 -0
  323. package/dist/services/document-service/transform/id-map.js.map +1 -0
  324. package/dist/services/document-service/transform/id-map.mjs +78 -0
  325. package/dist/services/document-service/transform/id-map.mjs.map +1 -0
  326. package/dist/services/document-service/transform/id-transform.d.ts +5 -0
  327. package/dist/services/document-service/transform/id-transform.d.ts.map +1 -0
  328. package/dist/services/document-service/transform/id-transform.js +33 -0
  329. package/dist/services/document-service/transform/id-transform.js.map +1 -0
  330. package/dist/services/document-service/transform/id-transform.mjs +33 -0
  331. package/dist/services/document-service/transform/id-transform.mjs.map +1 -0
  332. package/dist/services/document-service/transform/populate.d.ts +6 -0
  333. package/dist/services/document-service/transform/populate.d.ts.map +1 -0
  334. package/dist/services/document-service/transform/populate.js +21 -0
  335. package/dist/services/document-service/transform/populate.js.map +1 -0
  336. package/dist/services/document-service/transform/populate.mjs +21 -0
  337. package/dist/services/document-service/transform/populate.mjs.map +1 -0
  338. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +13 -0
  339. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -0
  340. package/dist/services/document-service/transform/relations/extract/data-ids.js +90 -0
  341. package/dist/services/document-service/transform/relations/extract/data-ids.js.map +1 -0
  342. package/dist/services/document-service/transform/relations/extract/data-ids.mjs +90 -0
  343. package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +1 -0
  344. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts +10 -0
  345. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts.map +1 -0
  346. package/dist/services/document-service/transform/relations/transform/data-ids.js +141 -0
  347. package/dist/services/document-service/transform/relations/transform/data-ids.js.map +1 -0
  348. package/dist/services/document-service/transform/relations/transform/data-ids.mjs +141 -0
  349. package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +1 -0
  350. package/dist/services/document-service/transform/relations/utils/data.d.ts +4 -0
  351. package/dist/services/document-service/transform/relations/utils/data.d.ts.map +1 -0
  352. package/dist/services/document-service/transform/relations/utils/data.js +12 -0
  353. package/dist/services/document-service/transform/relations/utils/data.js.map +1 -0
  354. package/dist/services/document-service/transform/relations/utils/data.mjs +12 -0
  355. package/dist/services/document-service/transform/relations/utils/data.mjs.map +1 -0
  356. package/dist/services/document-service/transform/relations/utils/dp.d.ts +10 -0
  357. package/dist/services/document-service/transform/relations/utils/dp.d.ts.map +1 -0
  358. package/dist/services/document-service/transform/relations/utils/dp.js +30 -0
  359. package/dist/services/document-service/transform/relations/utils/dp.js.map +1 -0
  360. package/dist/services/document-service/transform/relations/utils/dp.mjs +30 -0
  361. package/dist/services/document-service/transform/relations/utils/dp.mjs.map +1 -0
  362. package/dist/services/document-service/transform/relations/utils/i18n.d.ts +10 -0
  363. package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -0
  364. package/dist/services/document-service/transform/relations/utils/i18n.js +31 -0
  365. package/dist/services/document-service/transform/relations/utils/i18n.js.map +1 -0
  366. package/dist/services/document-service/transform/relations/utils/i18n.mjs +31 -0
  367. package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +1 -0
  368. package/dist/services/document-service/transform/relations/utils/types.d.ts +15 -0
  369. package/dist/services/document-service/transform/relations/utils/types.d.ts.map +1 -0
  370. package/dist/services/document-service/transform/types.d.ts +13 -0
  371. package/dist/services/document-service/transform/types.d.ts.map +1 -0
  372. package/dist/services/document-service/utils/populate.d.ts +10 -0
  373. package/dist/services/document-service/utils/populate.d.ts.map +1 -0
  374. package/dist/services/document-service/utils/populate.js +41 -0
  375. package/dist/services/document-service/utils/populate.js.map +1 -0
  376. package/dist/services/document-service/utils/populate.mjs +41 -0
  377. package/dist/services/document-service/utils/populate.mjs.map +1 -0
  378. package/dist/services/entity-service/components.d.ts +1 -4
  379. package/dist/services/entity-service/components.d.ts.map +1 -1
  380. package/dist/services/entity-service/components.js +13 -99
  381. package/dist/services/entity-service/components.js.map +1 -1
  382. package/dist/services/entity-service/components.mjs +14 -100
  383. package/dist/services/entity-service/components.mjs.map +1 -1
  384. package/dist/services/entity-service/index.d.ts +1 -3
  385. package/dist/services/entity-service/index.d.ts.map +1 -1
  386. package/dist/services/entity-service/index.js +34 -199
  387. package/dist/services/entity-service/index.js.map +1 -1
  388. package/dist/services/entity-service/index.mjs +27 -192
  389. package/dist/services/entity-service/index.mjs.map +1 -1
  390. package/dist/services/entity-service/params.d.ts +4 -4
  391. package/dist/services/entity-service/params.d.ts.map +1 -1
  392. package/dist/services/entity-service/params.js +1 -1
  393. package/dist/services/entity-service/params.js.map +1 -1
  394. package/dist/services/entity-service/params.mjs +1 -1
  395. package/dist/services/entity-service/params.mjs.map +1 -1
  396. package/dist/services/entity-validator/blocks-validator.d.ts.map +1 -1
  397. package/dist/services/entity-validator/blocks-validator.js +22 -2
  398. package/dist/services/entity-validator/blocks-validator.js.map +1 -1
  399. package/dist/services/entity-validator/blocks-validator.mjs +22 -2
  400. package/dist/services/entity-validator/blocks-validator.mjs.map +1 -1
  401. package/dist/services/entity-validator/index.d.ts.map +1 -1
  402. package/dist/services/entity-validator/index.js +5 -2
  403. package/dist/services/entity-validator/index.js.map +1 -1
  404. package/dist/services/entity-validator/index.mjs +5 -2
  405. package/dist/services/entity-validator/index.mjs.map +1 -1
  406. package/dist/services/entity-validator/validators.d.ts +14 -13
  407. package/dist/services/entity-validator/validators.d.ts.map +1 -1
  408. package/dist/services/entity-validator/validators.js +20 -16
  409. package/dist/services/entity-validator/validators.js.map +1 -1
  410. package/dist/services/entity-validator/validators.mjs +20 -16
  411. package/dist/services/entity-validator/validators.mjs.map +1 -1
  412. package/dist/services/features.d.ts +10 -0
  413. package/dist/services/features.d.ts.map +1 -0
  414. package/dist/services/features.js +17 -0
  415. package/dist/services/features.js.map +1 -0
  416. package/dist/services/features.mjs +17 -0
  417. package/dist/services/features.mjs.map +1 -0
  418. package/dist/services/server/compose-endpoint.d.ts.map +1 -1
  419. package/dist/services/server/compose-endpoint.js +3 -0
  420. package/dist/services/server/compose-endpoint.js.map +1 -1
  421. package/dist/services/server/compose-endpoint.mjs +3 -0
  422. package/dist/services/server/compose-endpoint.mjs.map +1 -1
  423. package/dist/services/server/middleware.d.ts +1 -5
  424. package/dist/services/server/middleware.d.ts.map +1 -1
  425. package/dist/services/server/middleware.js.map +1 -1
  426. package/dist/services/server/middleware.mjs.map +1 -1
  427. package/dist/services/server/register-middlewares.js +1 -1
  428. package/dist/services/server/register-middlewares.js.map +1 -1
  429. package/dist/services/server/register-middlewares.mjs +1 -1
  430. package/dist/services/server/register-middlewares.mjs.map +1 -1
  431. package/dist/services/webhook-runner.d.ts +10 -1
  432. package/dist/services/webhook-runner.d.ts.map +1 -1
  433. package/dist/services/webhook-store.d.ts +2 -22
  434. package/dist/services/webhook-store.d.ts.map +1 -1
  435. package/dist/services/webhook-store.js +7 -3
  436. package/dist/services/webhook-store.js.map +1 -1
  437. package/dist/services/webhook-store.mjs +7 -3
  438. package/dist/services/webhook-store.mjs.map +1 -1
  439. package/dist/utils/convert-custom-field-type.d.ts +1 -2
  440. package/dist/utils/convert-custom-field-type.d.ts.map +1 -1
  441. package/dist/utils/convert-custom-field-type.js +2 -1
  442. package/dist/utils/convert-custom-field-type.js.map +1 -1
  443. package/dist/utils/convert-custom-field-type.mjs +1 -1
  444. package/dist/utils/convert-custom-field-type.mjs.map +1 -1
  445. package/dist/utils/ee.d.ts +1 -2
  446. package/dist/utils/ee.d.ts.map +1 -1
  447. package/dist/utils/fetch.d.ts +2 -1
  448. package/dist/utils/fetch.d.ts.map +1 -1
  449. package/dist/utils/fetch.js +2 -2
  450. package/dist/utils/fetch.js.map +1 -1
  451. package/dist/utils/fetch.mjs +2 -2
  452. package/dist/utils/fetch.mjs.map +1 -1
  453. package/dist/utils/filepath-to-prop-path.d.ts +5 -0
  454. package/dist/utils/filepath-to-prop-path.d.ts.map +1 -0
  455. package/dist/{load → utils}/filepath-to-prop-path.js +3 -2
  456. package/dist/utils/filepath-to-prop-path.js.map +1 -0
  457. package/dist/{load → utils}/filepath-to-prop-path.mjs +2 -2
  458. package/dist/utils/filepath-to-prop-path.mjs.map +1 -0
  459. package/dist/utils/get-dirs.d.ts +1 -2
  460. package/dist/utils/get-dirs.d.ts.map +1 -1
  461. package/dist/utils/get-dirs.js +2 -1
  462. package/dist/utils/get-dirs.js.map +1 -1
  463. package/dist/utils/get-dirs.mjs +1 -1
  464. package/dist/utils/get-dirs.mjs.map +1 -1
  465. package/dist/utils/index.d.ts +11 -4
  466. package/dist/utils/index.d.ts.map +1 -1
  467. package/dist/utils/is-initialized.d.ts +1 -1
  468. package/dist/utils/is-initialized.d.ts.map +1 -1
  469. package/dist/utils/is-initialized.js +5 -4
  470. package/dist/utils/is-initialized.js.map +1 -1
  471. package/dist/utils/is-initialized.mjs +4 -4
  472. package/dist/utils/is-initialized.mjs.map +1 -1
  473. package/dist/utils/load-config-file.d.ts +2 -0
  474. package/dist/utils/load-config-file.d.ts.map +1 -0
  475. package/dist/{core/app-configuration → utils}/load-config-file.js +3 -3
  476. package/dist/utils/load-config-file.js.map +1 -0
  477. package/dist/{core/app-configuration → utils}/load-config-file.mjs +4 -4
  478. package/dist/utils/load-config-file.mjs.map +1 -0
  479. package/dist/{load → utils}/load-files.d.ts +2 -2
  480. package/dist/utils/load-files.d.ts.map +1 -0
  481. package/dist/{load → utils}/load-files.js +7 -6
  482. package/dist/utils/load-files.js.map +1 -0
  483. package/dist/{load → utils}/load-files.mjs +7 -7
  484. package/dist/utils/load-files.mjs.map +1 -0
  485. package/dist/utils/open-browser.d.ts +1 -2
  486. package/dist/utils/open-browser.d.ts.map +1 -1
  487. package/dist/utils/open-browser.js +5 -5
  488. package/dist/utils/open-browser.js.map +1 -1
  489. package/dist/utils/open-browser.mjs +4 -5
  490. package/dist/utils/open-browser.mjs.map +1 -1
  491. package/dist/utils/startup-logger.d.ts +1 -2
  492. package/dist/utils/startup-logger.d.ts.map +1 -1
  493. package/dist/utils/startup-logger.js +19 -13
  494. package/dist/utils/startup-logger.js.map +1 -1
  495. package/dist/utils/startup-logger.mjs +18 -13
  496. package/dist/utils/startup-logger.mjs.map +1 -1
  497. package/dist/utils/transform-content-types-to-models.d.ts +176 -4
  498. package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
  499. package/dist/utils/transform-content-types-to-models.js +202 -15
  500. package/dist/utils/transform-content-types-to-models.js.map +1 -1
  501. package/dist/utils/transform-content-types-to-models.mjs +199 -15
  502. package/dist/utils/transform-content-types-to-models.mjs.map +1 -1
  503. package/dist/utils/update-notifier/index.d.ts +1 -2
  504. package/dist/utils/update-notifier/index.d.ts.map +1 -1
  505. package/dist/utils/update-notifier/index.js +8 -2
  506. package/dist/utils/update-notifier/index.js.map +1 -1
  507. package/dist/utils/update-notifier/index.mjs +7 -2
  508. package/dist/utils/update-notifier/index.mjs.map +1 -1
  509. package/package.json +19 -26
  510. package/bin/strapi.js +0 -2
  511. package/dist/admin.d.ts +0 -5
  512. package/dist/admin.d.ts.map +0 -1
  513. package/dist/cli.d.ts +0 -2
  514. package/dist/cli.d.ts.map +0 -1
  515. package/dist/commands/actions/admin/create-user/action.d.ts +0 -12
  516. package/dist/commands/actions/admin/create-user/action.d.ts.map +0 -1
  517. package/dist/commands/actions/admin/create-user/command.d.ts +0 -7
  518. package/dist/commands/actions/admin/create-user/command.d.ts.map +0 -1
  519. package/dist/commands/actions/admin/reset-user-password/action.d.ts +0 -10
  520. package/dist/commands/actions/admin/reset-user-password/action.d.ts.map +0 -1
  521. package/dist/commands/actions/admin/reset-user-password/command.d.ts +0 -7
  522. package/dist/commands/actions/admin/reset-user-password/command.d.ts.map +0 -1
  523. package/dist/commands/actions/components/list/action.d.ts +0 -3
  524. package/dist/commands/actions/components/list/action.d.ts.map +0 -1
  525. package/dist/commands/actions/components/list/command.d.ts +0 -7
  526. package/dist/commands/actions/components/list/command.d.ts.map +0 -1
  527. package/dist/commands/actions/configuration/dump/action.d.ts +0 -11
  528. package/dist/commands/actions/configuration/dump/action.d.ts.map +0 -1
  529. package/dist/commands/actions/configuration/dump/command.d.ts +0 -7
  530. package/dist/commands/actions/configuration/dump/command.d.ts.map +0 -1
  531. package/dist/commands/actions/configuration/restore/action.d.ts +0 -11
  532. package/dist/commands/actions/configuration/restore/action.d.ts.map +0 -1
  533. package/dist/commands/actions/configuration/restore/command.d.ts +0 -7
  534. package/dist/commands/actions/configuration/restore/command.d.ts.map +0 -1
  535. package/dist/commands/actions/console/action.d.ts +0 -6
  536. package/dist/commands/actions/console/action.d.ts.map +0 -1
  537. package/dist/commands/actions/console/command.d.ts +0 -7
  538. package/dist/commands/actions/console/command.d.ts.map +0 -1
  539. package/dist/commands/actions/content-types/list/action.d.ts +0 -3
  540. package/dist/commands/actions/content-types/list/action.d.ts.map +0 -1
  541. package/dist/commands/actions/content-types/list/command.d.ts +0 -7
  542. package/dist/commands/actions/content-types/list/command.d.ts.map +0 -1
  543. package/dist/commands/actions/controllers/list/action.d.ts +0 -3
  544. package/dist/commands/actions/controllers/list/action.d.ts.map +0 -1
  545. package/dist/commands/actions/controllers/list/command.d.ts +0 -7
  546. package/dist/commands/actions/controllers/list/command.d.ts.map +0 -1
  547. package/dist/commands/actions/generate/command.d.ts +0 -7
  548. package/dist/commands/actions/generate/command.d.ts.map +0 -1
  549. package/dist/commands/actions/hooks/list/action.d.ts +0 -3
  550. package/dist/commands/actions/hooks/list/action.d.ts.map +0 -1
  551. package/dist/commands/actions/hooks/list/command.d.ts +0 -7
  552. package/dist/commands/actions/hooks/list/command.d.ts.map +0 -1
  553. package/dist/commands/actions/install/action.d.ts +0 -3
  554. package/dist/commands/actions/install/action.d.ts.map +0 -1
  555. package/dist/commands/actions/install/command.d.ts +0 -7
  556. package/dist/commands/actions/install/command.d.ts.map +0 -1
  557. package/dist/commands/actions/middlewares/list/action.d.ts +0 -3
  558. package/dist/commands/actions/middlewares/list/action.d.ts.map +0 -1
  559. package/dist/commands/actions/middlewares/list/command.d.ts +0 -7
  560. package/dist/commands/actions/middlewares/list/command.d.ts.map +0 -1
  561. package/dist/commands/actions/new/action.d.ts +0 -8
  562. package/dist/commands/actions/new/action.d.ts.map +0 -1
  563. package/dist/commands/actions/new/command.d.ts +0 -7
  564. package/dist/commands/actions/new/command.d.ts.map +0 -1
  565. package/dist/commands/actions/plugin/build-command/action.d.ts +0 -7
  566. package/dist/commands/actions/plugin/build-command/action.d.ts.map +0 -1
  567. package/dist/commands/actions/plugin/build-command/command.d.ts +0 -7
  568. package/dist/commands/actions/plugin/build-command/command.d.ts.map +0 -1
  569. package/dist/commands/actions/plugin/watch/action.d.ts +0 -7
  570. package/dist/commands/actions/plugin/watch/action.d.ts.map +0 -1
  571. package/dist/commands/actions/plugin/watch/command.d.ts +0 -7
  572. package/dist/commands/actions/plugin/watch/command.d.ts.map +0 -1
  573. package/dist/commands/actions/policies/list/action.d.ts +0 -3
  574. package/dist/commands/actions/policies/list/action.d.ts.map +0 -1
  575. package/dist/commands/actions/policies/list/command.d.ts +0 -7
  576. package/dist/commands/actions/policies/list/command.d.ts.map +0 -1
  577. package/dist/commands/actions/report/action.d.ts +0 -8
  578. package/dist/commands/actions/report/action.d.ts.map +0 -1
  579. package/dist/commands/actions/report/command.d.ts +0 -7
  580. package/dist/commands/actions/report/command.d.ts.map +0 -1
  581. package/dist/commands/actions/routes/list/action.d.ts +0 -3
  582. package/dist/commands/actions/routes/list/action.d.ts.map +0 -1
  583. package/dist/commands/actions/routes/list/command.d.ts +0 -7
  584. package/dist/commands/actions/routes/list/command.d.ts.map +0 -1
  585. package/dist/commands/actions/services/list/action.d.ts +0 -3
  586. package/dist/commands/actions/services/list/action.d.ts.map +0 -1
  587. package/dist/commands/actions/services/list/command.d.ts +0 -7
  588. package/dist/commands/actions/services/list/command.d.ts.map +0 -1
  589. package/dist/commands/actions/start/action.d.ts +0 -6
  590. package/dist/commands/actions/start/action.d.ts.map +0 -1
  591. package/dist/commands/actions/start/command.d.ts +0 -7
  592. package/dist/commands/actions/start/command.d.ts.map +0 -1
  593. package/dist/commands/actions/telemetry/disable/action.d.ts +0 -2
  594. package/dist/commands/actions/telemetry/disable/action.d.ts.map +0 -1
  595. package/dist/commands/actions/telemetry/disable/command.d.ts +0 -7
  596. package/dist/commands/actions/telemetry/disable/command.d.ts.map +0 -1
  597. package/dist/commands/actions/telemetry/enable/action.d.ts +0 -3
  598. package/dist/commands/actions/telemetry/enable/action.d.ts.map +0 -1
  599. package/dist/commands/actions/telemetry/enable/command.d.ts +0 -7
  600. package/dist/commands/actions/telemetry/enable/command.d.ts.map +0 -1
  601. package/dist/commands/actions/templates/generate/action.d.ts +0 -2
  602. package/dist/commands/actions/templates/generate/action.d.ts.map +0 -1
  603. package/dist/commands/actions/templates/generate/command.d.ts +0 -7
  604. package/dist/commands/actions/templates/generate/command.d.ts.map +0 -1
  605. package/dist/commands/actions/ts/generate-types/action.d.ts +0 -9
  606. package/dist/commands/actions/ts/generate-types/action.d.ts.map +0 -1
  607. package/dist/commands/actions/ts/generate-types/command.d.ts +0 -7
  608. package/dist/commands/actions/ts/generate-types/command.d.ts.map +0 -1
  609. package/dist/commands/actions/uninstall/action.d.ts +0 -6
  610. package/dist/commands/actions/uninstall/action.d.ts.map +0 -1
  611. package/dist/commands/actions/uninstall/command.d.ts +0 -7
  612. package/dist/commands/actions/uninstall/command.d.ts.map +0 -1
  613. package/dist/commands/actions/version/command.d.ts +0 -7
  614. package/dist/commands/actions/version/command.d.ts.map +0 -1
  615. package/dist/commands/actions/watch-admin/action.d.ts +0 -7
  616. package/dist/commands/actions/watch-admin/action.d.ts.map +0 -1
  617. package/dist/commands/actions/watch-admin/command.d.ts +0 -7
  618. package/dist/commands/actions/watch-admin/command.d.ts.map +0 -1
  619. package/dist/commands/index.d.ts +0 -37
  620. package/dist/commands/index.d.ts.map +0 -1
  621. package/dist/commands/types.d.ts +0 -14
  622. package/dist/commands/types.d.ts.map +0 -1
  623. package/dist/commands/utils/commander.d.ts +0 -36
  624. package/dist/commands/utils/commander.d.ts.map +0 -1
  625. package/dist/commands/utils/helpers.d.ts +0 -49
  626. package/dist/commands/utils/helpers.d.ts.map +0 -1
  627. package/dist/commands/utils/logger.d.ts +0 -19
  628. package/dist/commands/utils/logger.d.ts.map +0 -1
  629. package/dist/commands/utils/pkg.d.ts +0 -119
  630. package/dist/commands/utils/pkg.d.ts.map +0 -1
  631. package/dist/commands/utils/tsconfig.d.ts +0 -19
  632. package/dist/commands/utils/tsconfig.d.ts.map +0 -1
  633. package/dist/core/app-configuration/config-loader.d.ts.map +0 -1
  634. package/dist/core/app-configuration/config-loader.js +0 -19
  635. package/dist/core/app-configuration/config-loader.js.map +0 -1
  636. package/dist/core/app-configuration/config-loader.mjs +0 -17
  637. package/dist/core/app-configuration/config-loader.mjs.map +0 -1
  638. package/dist/core/app-configuration/index.d.ts.map +0 -1
  639. package/dist/core/app-configuration/index.js.map +0 -1
  640. package/dist/core/app-configuration/index.mjs.map +0 -1
  641. package/dist/core/app-configuration/load-config-file.d.ts +0 -2
  642. package/dist/core/app-configuration/load-config-file.d.ts.map +0 -1
  643. package/dist/core/app-configuration/load-config-file.js.map +0 -1
  644. package/dist/core/app-configuration/load-config-file.mjs.map +0 -1
  645. package/dist/core/bootstrap.d.ts +0 -5
  646. package/dist/core/bootstrap.d.ts.map +0 -1
  647. package/dist/core/bootstrap.js +0 -28
  648. package/dist/core/bootstrap.js.map +0 -1
  649. package/dist/core/bootstrap.mjs +0 -27
  650. package/dist/core/bootstrap.mjs.map +0 -1
  651. package/dist/core/domain/content-type/index.d.ts.map +0 -1
  652. package/dist/core/domain/content-type/index.js.map +0 -1
  653. package/dist/core/domain/content-type/index.mjs.map +0 -1
  654. package/dist/core/domain/content-type/validator.d.ts.map +0 -1
  655. package/dist/core/domain/content-type/validator.js.map +0 -1
  656. package/dist/core/domain/content-type/validator.mjs.map +0 -1
  657. package/dist/core/domain/module/index.d.ts.map +0 -1
  658. package/dist/core/domain/module/index.js.map +0 -1
  659. package/dist/core/domain/module/index.mjs.map +0 -1
  660. package/dist/core/domain/module/validation.d.ts.map +0 -1
  661. package/dist/core/domain/module/validation.js.map +0 -1
  662. package/dist/core/domain/module/validation.mjs.map +0 -1
  663. package/dist/core/loaders/admin.d.ts.map +0 -1
  664. package/dist/core/loaders/admin.js.map +0 -1
  665. package/dist/core/loaders/admin.mjs.map +0 -1
  666. package/dist/core/loaders/apis.d.ts.map +0 -1
  667. package/dist/core/loaders/apis.js.map +0 -1
  668. package/dist/core/loaders/apis.mjs.map +0 -1
  669. package/dist/core/loaders/components.d.ts.map +0 -1
  670. package/dist/core/loaders/components.js.map +0 -1
  671. package/dist/core/loaders/components.mjs.map +0 -1
  672. package/dist/core/loaders/index.d.ts.map +0 -1
  673. package/dist/core/loaders/index.js.map +0 -1
  674. package/dist/core/loaders/index.mjs.map +0 -1
  675. package/dist/core/loaders/middlewares.d.ts.map +0 -1
  676. package/dist/core/loaders/middlewares.js.map +0 -1
  677. package/dist/core/loaders/middlewares.mjs.map +0 -1
  678. package/dist/core/loaders/plugins/get-enabled-plugins.d.ts.map +0 -1
  679. package/dist/core/loaders/plugins/get-enabled-plugins.js.map +0 -1
  680. package/dist/core/loaders/plugins/get-enabled-plugins.mjs.map +0 -1
  681. package/dist/core/loaders/plugins/get-user-plugins-config.d.ts.map +0 -1
  682. package/dist/core/loaders/plugins/get-user-plugins-config.js.map +0 -1
  683. package/dist/core/loaders/plugins/get-user-plugins-config.mjs.map +0 -1
  684. package/dist/core/loaders/plugins/index.d.ts.map +0 -1
  685. package/dist/core/loaders/plugins/index.js.map +0 -1
  686. package/dist/core/loaders/plugins/index.mjs.map +0 -1
  687. package/dist/core/loaders/policies.d.ts.map +0 -1
  688. package/dist/core/loaders/policies.js.map +0 -1
  689. package/dist/core/loaders/policies.mjs.map +0 -1
  690. package/dist/core/loaders/sanitizers.d.ts.map +0 -1
  691. package/dist/core/loaders/sanitizers.js.map +0 -1
  692. package/dist/core/loaders/sanitizers.mjs.map +0 -1
  693. package/dist/core/loaders/src-index.d.ts.map +0 -1
  694. package/dist/core/loaders/src-index.js.map +0 -1
  695. package/dist/core/loaders/src-index.mjs.map +0 -1
  696. package/dist/core/loaders/validators.d.ts.map +0 -1
  697. package/dist/core/loaders/validators.js.map +0 -1
  698. package/dist/core/loaders/validators.mjs.map +0 -1
  699. package/dist/core/registries/apis.d.ts.map +0 -1
  700. package/dist/core/registries/apis.js.map +0 -1
  701. package/dist/core/registries/apis.mjs.map +0 -1
  702. package/dist/core/registries/components.d.ts.map +0 -1
  703. package/dist/core/registries/components.js.map +0 -1
  704. package/dist/core/registries/components.mjs.map +0 -1
  705. package/dist/core/registries/config.d.ts +0 -4
  706. package/dist/core/registries/config.d.ts.map +0 -1
  707. package/dist/core/registries/config.js +0 -23
  708. package/dist/core/registries/config.js.map +0 -1
  709. package/dist/core/registries/config.mjs +0 -22
  710. package/dist/core/registries/config.mjs.map +0 -1
  711. package/dist/core/registries/content-types.d.ts.map +0 -1
  712. package/dist/core/registries/content-types.js.map +0 -1
  713. package/dist/core/registries/content-types.mjs.map +0 -1
  714. package/dist/core/registries/controllers.d.ts.map +0 -1
  715. package/dist/core/registries/controllers.js.map +0 -1
  716. package/dist/core/registries/controllers.mjs.map +0 -1
  717. package/dist/core/registries/custom-fields.d.ts.map +0 -1
  718. package/dist/core/registries/custom-fields.js.map +0 -1
  719. package/dist/core/registries/custom-fields.mjs.map +0 -1
  720. package/dist/core/registries/hooks.d.ts.map +0 -1
  721. package/dist/core/registries/hooks.js.map +0 -1
  722. package/dist/core/registries/hooks.mjs.map +0 -1
  723. package/dist/core/registries/index.d.ts.map +0 -1
  724. package/dist/core/registries/middlewares.d.ts.map +0 -1
  725. package/dist/core/registries/middlewares.js.map +0 -1
  726. package/dist/core/registries/middlewares.mjs.map +0 -1
  727. package/dist/core/registries/modules.d.ts.map +0 -1
  728. package/dist/core/registries/modules.js.map +0 -1
  729. package/dist/core/registries/modules.mjs.map +0 -1
  730. package/dist/core/registries/plugins.d.ts.map +0 -1
  731. package/dist/core/registries/plugins.js.map +0 -1
  732. package/dist/core/registries/plugins.mjs.map +0 -1
  733. package/dist/core/registries/policies.d.ts.map +0 -1
  734. package/dist/core/registries/policies.js.map +0 -1
  735. package/dist/core/registries/policies.mjs.map +0 -1
  736. package/dist/core/registries/sanitizers.d.ts.map +0 -1
  737. package/dist/core/registries/sanitizers.js.map +0 -1
  738. package/dist/core/registries/sanitizers.mjs.map +0 -1
  739. package/dist/core/registries/services.d.ts.map +0 -1
  740. package/dist/core/registries/services.js.map +0 -1
  741. package/dist/core/registries/services.mjs.map +0 -1
  742. package/dist/core/registries/validators.d.ts.map +0 -1
  743. package/dist/core/registries/validators.js.map +0 -1
  744. package/dist/core/registries/validators.mjs.map +0 -1
  745. package/dist/core/utils.d.ts.map +0 -1
  746. package/dist/core/utils.js.map +0 -1
  747. package/dist/core/utils.mjs.map +0 -1
  748. package/dist/core-api/service/get-fetch-params.d.ts +0 -7
  749. package/dist/core-api/service/get-fetch-params.d.ts.map +0 -1
  750. package/dist/core-api/service/get-fetch-params.js +0 -14
  751. package/dist/core-api/service/get-fetch-params.js.map +0 -1
  752. package/dist/core-api/service/get-fetch-params.mjs +0 -14
  753. package/dist/core-api/service/get-fetch-params.mjs.map +0 -1
  754. package/dist/load/filepath-to-prop-path.d.ts +0 -6
  755. package/dist/load/filepath-to-prop-path.d.ts.map +0 -1
  756. package/dist/load/filepath-to-prop-path.js.map +0 -1
  757. package/dist/load/filepath-to-prop-path.mjs.map +0 -1
  758. package/dist/load/glob.d.ts +0 -7
  759. package/dist/load/glob.d.ts.map +0 -1
  760. package/dist/load/glob.js +0 -15
  761. package/dist/load/glob.js.map +0 -1
  762. package/dist/load/glob.mjs +0 -14
  763. package/dist/load/glob.mjs.map +0 -1
  764. package/dist/load/index.d.ts +0 -3
  765. package/dist/load/index.d.ts.map +0 -1
  766. package/dist/load/load-files.d.ts.map +0 -1
  767. package/dist/load/load-files.js.map +0 -1
  768. package/dist/load/load-files.mjs.map +0 -1
  769. package/dist/load/package-path.d.ts +0 -6
  770. package/dist/load/package-path.d.ts.map +0 -1
  771. package/dist/middlewares/public/assets/images/group_people_1.png +0 -0
  772. package/dist/middlewares/public/assets/images/group_people_2.png +0 -0
  773. package/dist/middlewares/public/assets/images/group_people_3.png +0 -0
  774. package/dist/middlewares/public/assets/images/logo_login.png +0 -0
  775. package/dist/middlewares/public/index.d.ts.map +0 -1
  776. package/dist/middlewares/public/index.html +0 -66
  777. package/dist/middlewares/public/index.js +0 -91
  778. package/dist/middlewares/public/index.js.map +0 -1
  779. package/dist/middlewares/public/index.mjs +0 -85
  780. package/dist/middlewares/public/index.mjs.map +0 -1
  781. package/dist/middlewares/public/serve-static.d.ts +0 -4
  782. package/dist/middlewares/public/serve-static.d.ts.map +0 -1
  783. package/dist/middlewares/public/serve-static.js +0 -24
  784. package/dist/middlewares/public/serve-static.js.map +0 -1
  785. package/dist/middlewares/public/serve-static.mjs +0 -21
  786. package/dist/middlewares/public/serve-static.mjs.map +0 -1
  787. package/dist/services/document-service/document-repository.d.ts +0 -21
  788. package/dist/services/document-service/document-repository.d.ts.map +0 -1
  789. package/dist/services/document-service/document-repository.js +0 -132
  790. package/dist/services/document-service/document-repository.js.map +0 -1
  791. package/dist/services/document-service/document-repository.mjs +0 -132
  792. package/dist/services/document-service/document-repository.mjs.map +0 -1
  793. package/dist/services/document-service/middlewares/defaults/draft-and-publish.d.ts +0 -26
  794. package/dist/services/document-service/middlewares/defaults/draft-and-publish.d.ts.map +0 -1
  795. package/dist/services/document-service/middlewares/defaults/draft-and-publish.js +0 -58
  796. package/dist/services/document-service/middlewares/defaults/draft-and-publish.js.map +0 -1
  797. package/dist/services/document-service/middlewares/defaults/draft-and-publish.mjs +0 -58
  798. package/dist/services/document-service/middlewares/defaults/draft-and-publish.mjs.map +0 -1
  799. package/dist/services/document-service/middlewares/defaults/index.d.ts +0 -3
  800. package/dist/services/document-service/middlewares/defaults/index.d.ts.map +0 -1
  801. package/dist/services/document-service/middlewares/defaults/index.js +0 -82
  802. package/dist/services/document-service/middlewares/defaults/index.js.map +0 -1
  803. package/dist/services/document-service/middlewares/defaults/index.mjs +0 -82
  804. package/dist/services/document-service/middlewares/defaults/index.mjs.map +0 -1
  805. package/dist/services/document-service/middlewares/defaults/locales.d.ts +0 -18
  806. package/dist/services/document-service/middlewares/defaults/locales.d.ts.map +0 -1
  807. package/dist/services/document-service/middlewares/defaults/locales.js +0 -40
  808. package/dist/services/document-service/middlewares/defaults/locales.js.map +0 -1
  809. package/dist/services/document-service/middlewares/defaults/locales.mjs +0 -40
  810. package/dist/services/document-service/middlewares/defaults/locales.mjs.map +0 -1
  811. package/dist/services/document-service/middlewares/index.js +0 -59
  812. package/dist/services/document-service/middlewares/index.js.map +0 -1
  813. package/dist/services/document-service/middlewares/index.mjs +0 -59
  814. package/dist/services/document-service/middlewares/index.mjs.map +0 -1
  815. package/dist/services/utils/upload-files.d.ts +0 -8
  816. package/dist/services/utils/upload-files.d.ts.map +0 -1
  817. package/dist/services/utils/upload-files.js +0 -64
  818. package/dist/services/utils/upload-files.js.map +0 -1
  819. package/dist/services/utils/upload-files.mjs +0 -63
  820. package/dist/services/utils/upload-files.mjs.map +0 -1
  821. package/dist/utils/addSlash.d.ts +0 -3
  822. package/dist/utils/addSlash.d.ts.map +0 -1
  823. package/dist/utils/ee.js +0 -4
  824. package/dist/utils/ee.js.map +0 -1
  825. package/dist/utils/ee.mjs +0 -5
  826. package/dist/utils/ee.mjs.map +0 -1
  827. /package/dist/{core/app-configuration → configuration}/config-loader.d.ts +0 -0
  828. /package/dist/{core/domain → domain}/content-type/validator.d.ts +0 -0
  829. /package/dist/{core/domain → domain}/module/index.d.ts +0 -0
  830. /package/dist/{core/domain → domain}/module/validation.d.ts +0 -0
  831. /package/dist/{core/domain → domain}/module/validation.js +0 -0
  832. /package/dist/{core/domain → domain}/module/validation.mjs +0 -0
  833. /package/dist/{core/loaders → loaders}/admin.d.ts +0 -0
  834. /package/dist/{core/loaders → loaders}/apis.d.ts +0 -0
  835. /package/dist/{core/loaders → loaders}/components.d.ts +0 -0
  836. /package/dist/{core/loaders → loaders}/index.d.ts +0 -0
  837. /package/dist/{core/loaders → loaders}/index.js +0 -0
  838. /package/dist/{core/loaders → loaders}/index.mjs +0 -0
  839. /package/dist/{core/loaders → loaders}/middlewares.d.ts +0 -0
  840. /package/dist/{core/loaders → loaders}/plugins/get-enabled-plugins.d.ts +0 -0
  841. /package/dist/{core/loaders → loaders}/plugins/get-user-plugins-config.d.ts +0 -0
  842. /package/dist/{core/loaders → loaders}/plugins/index.d.ts +0 -0
  843. /package/dist/{core/loaders → loaders}/policies.d.ts +0 -0
  844. /package/dist/{core/loaders → loaders}/policies.js +0 -0
  845. /package/dist/{core/loaders → loaders}/policies.mjs +0 -0
  846. /package/dist/{core/loaders → loaders}/sanitizers.d.ts +0 -0
  847. /package/dist/{core/loaders → loaders}/sanitizers.js +0 -0
  848. /package/dist/{core/loaders → loaders}/sanitizers.mjs +0 -0
  849. /package/dist/{core/loaders → loaders}/src-index.d.ts +0 -0
  850. /package/dist/{core/loaders → loaders}/src-index.js +0 -0
  851. /package/dist/{core/loaders → loaders}/src-index.mjs +0 -0
  852. /package/dist/{core/loaders → loaders}/validators.d.ts +0 -0
  853. /package/dist/{core/loaders → loaders}/validators.js +0 -0
  854. /package/dist/{core/loaders → loaders}/validators.mjs +0 -0
  855. /package/dist/{core/registries → registries}/apis.d.ts +0 -0
  856. /package/dist/{core/registries → registries}/apis.js +0 -0
  857. /package/dist/{core/registries → registries}/apis.mjs +0 -0
  858. /package/dist/{core/registries → registries}/components.d.ts +0 -0
  859. /package/dist/{core/registries → registries}/components.js +0 -0
  860. /package/dist/{core/registries → registries}/components.mjs +0 -0
  861. /package/dist/{core/registries → registries}/content-types.d.ts +0 -0
  862. /package/dist/{core/registries → registries}/controllers.d.ts +0 -0
  863. /package/dist/{core/registries → registries}/custom-fields.d.ts +0 -0
  864. /package/dist/{core/registries → registries}/custom-fields.js +0 -0
  865. /package/dist/{core/registries → registries}/custom-fields.mjs +0 -0
  866. /package/dist/{core/registries → registries}/hooks.d.ts +0 -0
  867. /package/dist/{core/registries → registries}/middlewares.d.ts +0 -0
  868. /package/dist/{core/registries → registries}/modules.d.ts +0 -0
  869. /package/dist/{core/registries → registries}/modules.js +0 -0
  870. /package/dist/{core/registries → registries}/modules.mjs +0 -0
  871. /package/dist/{core/registries → registries}/plugins.d.ts +0 -0
  872. /package/dist/{core/registries → registries}/plugins.js +0 -0
  873. /package/dist/{core/registries → registries}/plugins.mjs +0 -0
  874. /package/dist/{core/registries → registries}/policies.d.ts +0 -0
  875. /package/dist/{core/registries → registries}/sanitizers.d.ts +0 -0
  876. /package/dist/{core/registries → registries}/sanitizers.js +0 -0
  877. /package/dist/{core/registries → registries}/sanitizers.mjs +0 -0
  878. /package/dist/{core/registries → registries}/services.d.ts +0 -0
  879. /package/dist/{core/registries → registries}/validators.d.ts +0 -0
  880. /package/dist/{core/registries → registries}/validators.js +0 -0
  881. /package/dist/{core/registries → registries}/validators.mjs +0 -0
@@ -1 +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"}
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;AAYrD,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;AA2DpG,OAAO,EAAE,gBAAgB,EAAE,CAAC"}
@@ -5,6 +5,7 @@ const strapiUtils = require("@strapi/utils");
5
5
  const transform = require("./transform.js");
6
6
  const singleType = require("./single-type.js");
7
7
  const collectionType = require("./collection-type.js");
8
+ const requestContext = require("../../services/request-context.js");
8
9
  const isSingleType = (contentType) => strapiUtils.contentTypes.isSingleType(contentType);
9
10
  const getAuthFromKoaContext = (ctx) => _.prop("state.auth", ctx) ?? {};
10
11
  function createController({
@@ -12,7 +13,11 @@ function createController({
12
13
  }) {
13
14
  const proto = {
14
15
  transformResponse(data, meta) {
15
- return transform.transformResponse(data, meta, { contentType });
16
+ const ctx = requestContext.get();
17
+ return transform.transformResponse(data, meta, {
18
+ contentType,
19
+ useJsonAPIFormat: ctx?.headers?.["strapi-response-format"] === "v4"
20
+ });
16
21
  },
17
22
  async sanitizeOutput(data, ctx) {
18
23
  const auth = getAuthFromKoaContext(ctx);
@@ -37,9 +42,9 @@ function createController({
37
42
  };
38
43
  let ctrl;
39
44
  if (isSingleType(contentType)) {
40
- ctrl = singleType({ contentType });
45
+ ctrl = singleType.createSingleTypeController({ contentType });
41
46
  } else {
42
- ctrl = collectionType({ contentType });
47
+ ctrl = collectionType.createCollectionTypeController({ contentType });
43
48
  }
44
49
  return Object.assign(Object.create(proto), ctrl);
45
50
  }
@@ -1 +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;;"}
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';\nimport requestCtx from '../../services/request-context';\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 // TODO: replace with Base class + SingleType and CollectionType classes\n\n const proto: CoreApi.Controller.Base = {\n transformResponse(data, meta) {\n const ctx = requestCtx.get();\n return transformResponse(data, meta, {\n contentType,\n useJsonAPIFormat: ctx?.headers?.['strapi-response-format'] === 'v4',\n });\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","requestCtx","transformResponse","sanitize","validate","createSingleTypeController","createCollectionTypeController"],"mappings":";;;;;;;;AAUA,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;AAGD,QAAM,QAAiC;AAAA,IACrC,kBAAkB,MAAM,MAAM;AACtB,YAAA,MAAMC,eAAW;AAChB,aAAAC,UAAA,kBAAkB,MAAM,MAAM;AAAA,QACnC;AAAA,QACA,kBAAkB,KAAK,UAAU,wBAAwB,MAAM;AAAA,MAAA,CAChE;AAAA,IACH;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,WAAA,2BAA2B,EAAE,YAAA,CAAa;AAAA,EAAA,OAC5C;AACE,WAAAC,eAAA,+BAA+B,EAAE,YAAA,CAAa;AAAA,EACvD;AAEA,SAAO,OAAO,OAAO,OAAO,OAAO,KAAK,GAAG,IAAI;AACjD;;"}
@@ -1,8 +1,9 @@
1
1
  import { prop } from "lodash/fp";
2
2
  import { contentTypes, sanitize, validate } from "@strapi/utils";
3
3
  import { transformResponse } from "./transform.mjs";
4
- import createSingleTypeController from "./single-type.mjs";
5
- import createCollectionTypeController from "./collection-type.mjs";
4
+ import { createSingleTypeController } from "./single-type.mjs";
5
+ import { createCollectionTypeController } from "./collection-type.mjs";
6
+ import requestCtx from "../../services/request-context.mjs";
6
7
  const isSingleType = (contentType) => contentTypes.isSingleType(contentType);
7
8
  const getAuthFromKoaContext = (ctx) => prop("state.auth", ctx) ?? {};
8
9
  function createController({
@@ -10,7 +11,11 @@ function createController({
10
11
  }) {
11
12
  const proto = {
12
13
  transformResponse(data, meta) {
13
- return transformResponse(data, meta, { contentType });
14
+ const ctx = requestCtx.get();
15
+ return transformResponse(data, meta, {
16
+ contentType,
17
+ useJsonAPIFormat: ctx?.headers?.["strapi-response-format"] === "v4"
18
+ });
14
19
  },
15
20
  async sanitizeOutput(data, ctx) {
16
21
  const auth = getAuthFromKoaContext(ctx);
@@ -1 +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;"}
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';\nimport requestCtx from '../../services/request-context';\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 // TODO: replace with Base class + SingleType and CollectionType classes\n\n const proto: CoreApi.Controller.Base = {\n transformResponse(data, meta) {\n const ctx = requestCtx.get();\n return transformResponse(data, meta, {\n contentType,\n useJsonAPIFormat: ctx?.headers?.['strapi-response-format'] === 'v4',\n });\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":";;;;;;AAUA,MAAM,eAAe,CAAC,gBACpBA,aAAiB,aAAa,WAAW;AAE3C,MAAM,wBAAwB,CAAC,QAAqB,KAAK,cAAc,GAAG,KAAK;AAK/E,SAAS,iBAAiB;AAAA,EACxB;AACF,GAEG;AAGD,QAAM,QAAiC;AAAA,IACrC,kBAAkB,MAAM,MAAM;AACtB,YAAA,MAAM,WAAW;AAChB,aAAA,kBAAkB,MAAM,MAAM;AAAA,QACnC;AAAA,QACA,kBAAkB,KAAK,UAAU,wBAAwB,MAAM;AAAA,MAAA,CAChE;AAAA,IACH;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;"}
@@ -6,5 +6,5 @@ interface Options {
6
6
  * Returns a single type controller to handle default core-api actions
7
7
  */
8
8
  declare const createSingleTypeController: ({ contentType, }: Options) => Utils.PartialWithThis<CoreApi.Controller.SingleType>;
9
- export default createSingleTypeController;
9
+ export { createSingleTypeController };
10
10
  //# sourceMappingURL=single-type.d.ts.map
@@ -1 +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"}
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;AAEpE,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,CAkD/D,CAAC;AAEF,OAAO,EAAE,0BAA0B,EAAE,CAAC"}
@@ -1,7 +1,7 @@
1
1
  "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
2
3
  const _ = require("lodash/fp");
3
4
  const strapiUtils = require("@strapi/utils");
4
- const transform = require("./transform.js");
5
5
  const createSingleTypeController = ({
6
6
  contentType
7
7
  }) => {
@@ -20,31 +20,26 @@ const createSingleTypeController = ({
20
20
  },
21
21
  /**
22
22
  * create or update single type content.
23
- *
24
- * @return {Object}
25
23
  */
26
24
  async update(ctx) {
27
- const { query } = ctx.request;
28
- const body = transform.parseBody(ctx);
25
+ const { query, body = {} } = ctx.request;
29
26
  if (!_.isObject(body.data)) {
30
27
  throw new strapiUtils.errors.ValidationError('Missing "data" payload in the request body');
31
28
  }
32
29
  const sanitizedInputData = await this.sanitizeInput(body.data, ctx);
33
30
  const entity = await strapi.service(uid).createOrUpdate({
34
31
  ...query,
35
- data: sanitizedInputData,
36
- files: "files" in body ? body.files : void 0
32
+ data: sanitizedInputData
37
33
  });
38
34
  const sanitizedEntity = await this.sanitizeOutput(entity, ctx);
39
35
  return this.transformResponse(sanitizedEntity);
40
36
  },
41
37
  async delete(ctx) {
42
38
  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);
39
+ await strapi.service(uid).delete(query);
40
+ ctx.status = 204;
46
41
  }
47
42
  };
48
43
  };
49
- module.exports = createSingleTypeController;
44
+ exports.createSingleTypeController = createSingleTypeController;
50
45
  //# sourceMappingURL=single-type.js.map
@@ -1 +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;;"}
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\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 // TODO: transform into a class\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 async update(ctx) {\n const { query, body = {} as any } = ctx.request;\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 });\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 await strapi.service(uid).delete(query);\n\n ctx.status = 204;\n },\n };\n};\n\nexport { createSingleTypeController };\n"],"names":["isObject","errors"],"mappings":";;;;AAWA,MAAM,6BAA6B,CAAC;AAAA,EAClC;AACF,MAAqE;AACnE,QAAM,MAAM,YAAY;AAGjB,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,IAKA,MAAM,OAAO,KAAK;AAChB,YAAM,EAAE,OAAO,OAAO,CAAC,EAAA,IAAa,IAAI;AAExC,UAAI,CAACA,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,MAAA,CACP;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,OAAO,QAAQ,GAAG,EAAE,OAAO,KAAK;AAEtC,UAAI,SAAS;AAAA,IACf;AAAA,EAAA;AAEJ;;"}
@@ -1,6 +1,5 @@
1
1
  import { isObject } from "lodash/fp";
2
2
  import { errors } from "@strapi/utils";
3
- import { parseBody } from "./transform.mjs";
4
3
  const createSingleTypeController = ({
5
4
  contentType
6
5
  }) => {
@@ -19,33 +18,28 @@ const createSingleTypeController = ({
19
18
  },
20
19
  /**
21
20
  * create or update single type content.
22
- *
23
- * @return {Object}
24
21
  */
25
22
  async update(ctx) {
26
- const { query } = ctx.request;
27
- const body = parseBody(ctx);
23
+ const { query, body = {} } = ctx.request;
28
24
  if (!isObject(body.data)) {
29
25
  throw new errors.ValidationError('Missing "data" payload in the request body');
30
26
  }
31
27
  const sanitizedInputData = await this.sanitizeInput(body.data, ctx);
32
28
  const entity = await strapi.service(uid).createOrUpdate({
33
29
  ...query,
34
- data: sanitizedInputData,
35
- files: "files" in body ? body.files : void 0
30
+ data: sanitizedInputData
36
31
  });
37
32
  const sanitizedEntity = await this.sanitizeOutput(entity, ctx);
38
33
  return this.transformResponse(sanitizedEntity);
39
34
  },
40
35
  async delete(ctx) {
41
36
  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);
37
+ await strapi.service(uid).delete(query);
38
+ ctx.status = 204;
45
39
  }
46
40
  };
47
41
  };
48
42
  export {
49
- createSingleTypeController as default
43
+ createSingleTypeController
50
44
  };
51
45
  //# sourceMappingURL=single-type.mjs.map
@@ -1 +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;"}
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\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 // TODO: transform into a class\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 async update(ctx) {\n const { query, body = {} as any } = ctx.request;\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 });\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 await strapi.service(uid).delete(query);\n\n ctx.status = 204;\n },\n };\n};\n\nexport { createSingleTypeController };\n"],"names":[],"mappings":";;AAWA,MAAM,6BAA6B,CAAC;AAAA,EAClC;AACF,MAAqE;AACnE,QAAM,MAAM,YAAY;AAGjB,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,IAKA,MAAM,OAAO,KAAK;AAChB,YAAM,EAAE,OAAO,OAAO,CAAC,EAAA,IAAa,IAAI;AAExC,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,MAAA,CACP;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,OAAO,QAAQ,GAAG,EAAE,OAAO,KAAK;AAEtC,UAAI,SAAS;AAAA,IACf;AAAA,EAAA;AAEJ;"}
@@ -1,22 +1,14 @@
1
- /// <reference types="formidable" />
2
- import type Koa from 'koa';
3
1
  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?: {
2
+ interface TransformOptions {
16
3
  contentType?: Schema.ContentType | Schema.Component;
17
- }) => {
18
- data: TransformedEntry | TransformedEntry[] | null;
4
+ /**
5
+ * @deprecated this option is deprecated and will be removed in the next major version
6
+ */
7
+ useJsonAPIFormat?: boolean;
8
+ }
9
+ declare const transformResponse: (resource: any, meta?: unknown, opts?: TransformOptions) => {
10
+ data: any;
19
11
  meta: unknown;
20
12
  } | null | undefined;
21
- export { parseBody, transformResponse };
13
+ export { transformResponse };
22
14
  //# sourceMappingURL=transform.d.ts.map
@@ -1 +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"}
1
+ {"version":3,"file":"transform.d.ts","sourceRoot":"","sources":["../../../src/core-api/controller/transform.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAU,MAAM,EAAO,MAAM,eAAe,CAAC;AA2BzD,UAAU,gBAAgB;IACxB,WAAW,CAAC,EAAE,MAAM,CAAC,WAAW,GAAG,MAAM,CAAC,SAAS,CAAC;IACpD;;OAEG;IACH,gBAAgB,CAAC,EAAE,OAAO,CAAC;CAC5B;AAED,QAAA,MAAM,iBAAiB,aACX,GAAG,SACP,OAAO,SACP,gBAAgB;;;oBAgBvB,CAAC;AAqFF,OAAO,EAAE,iBAAiB,EAAE,CAAC"}
@@ -1,26 +1,23 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
3
  const _ = require("lodash/fp");
4
- const strapiUtils = require("@strapi/utils");
5
4
  function isEntry(property) {
6
5
  return property === null || _.isPlainObject(property) || Array.isArray(property);
7
6
  }
8
7
  function isDZEntries(property) {
9
8
  return Array.isArray(property);
10
9
  }
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 = {}) => {
10
+ const transformResponse = (resource, meta = {}, opts = {
11
+ useJsonAPIFormat: false
12
+ }) => {
19
13
  if (_.isNil(resource)) {
20
14
  return resource;
21
15
  }
16
+ if (!_.isPlainObject(resource) && !Array.isArray(resource)) {
17
+ throw new Error("Entry must be an object or an arrayy of objects");
18
+ }
22
19
  return {
23
- data: transformEntry(resource, opts?.contentType),
20
+ data: opts.useJsonAPIFormat ? transformEntry(resource, opts?.contentType) : resource,
24
21
  meta
25
22
  };
26
23
  };
@@ -45,7 +42,7 @@ function transformEntry(entry, type) {
45
42
  if (!_.isPlainObject(entry)) {
46
43
  throw new Error("Entry must be an object");
47
44
  }
48
- const { id, ...properties } = entry;
45
+ const { id, documentId, ...properties } = entry;
49
46
  const attributeValues = {};
50
47
  for (const key of Object.keys(properties)) {
51
48
  const property = properties[key];
@@ -74,11 +71,9 @@ function transformEntry(entry, type) {
74
71
  }
75
72
  return {
76
73
  id,
74
+ documentId,
77
75
  attributes: attributeValues
78
- // NOTE: not necessary for now
79
- // meta: {},
80
76
  };
81
77
  }
82
- exports.parseBody = parseBody;
83
78
  exports.transformResponse = transformResponse;
84
79
  //# sourceMappingURL=transform.js.map
@@ -1 +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;;;"}
1
+ {"version":3,"file":"transform.js","sources":["../../../src/core-api/controller/transform.ts"],"sourcesContent":["import { isNil, isPlainObject } from 'lodash/fp';\nimport type { Common, Schema, UID } from '@strapi/types';\n\ntype TransformedEntry = {\n id: string;\n documentId?: string | null;\n attributes: Record<string, unknown>;\n};\n\ntype TransformedComponent = {\n id: string;\n [key: string]: unknown;\n};\n\ntype Entry = {\n id: string;\n documentId: string | null;\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\ninterface TransformOptions {\n contentType?: Schema.ContentType | Schema.Component;\n /**\n * @deprecated this option is deprecated and will be removed in the next major version\n */\n useJsonAPIFormat?: boolean;\n}\n\nconst transformResponse = (\n resource: any,\n meta: unknown = {},\n opts: TransformOptions = {\n useJsonAPIFormat: false,\n }\n) => {\n if (isNil(resource)) {\n return resource;\n }\n\n if (!isPlainObject(resource) && !Array.isArray(resource)) {\n throw new Error('Entry must be an object or an arrayy of objects');\n }\n\n return {\n data: opts.useJsonAPIFormat ? transformEntry(resource, opts?.contentType) : resource,\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, documentId, ...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 documentId,\n attributes: attributeValues,\n };\n}\n\nexport { transformResponse };\n"],"names":["isPlainObject","isNil"],"mappings":";;;AAoBA,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;AAUA,MAAM,oBAAoB,CACxB,UACA,OAAgB,CAAA,GAChB,OAAyB;AAAA,EACvB,kBAAkB;AACpB,MACG;AACC,MAAAC,EAAAA,MAAM,QAAQ,GAAG;AACZ,WAAA;AAAA,EACT;AAEI,MAAA,CAACD,gBAAc,QAAQ,KAAK,CAAC,MAAM,QAAQ,QAAQ,GAAG;AAClD,UAAA,IAAI,MAAM,iDAAiD;AAAA,EACnE;AAEO,SAAA;AAAA,IACL,MAAM,KAAK,mBAAmB,eAAe,UAAU,MAAM,WAAW,IAAI;AAAA,IAC5E;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,MAAAC,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,CAACD,EAAAA,cAAc,KAAK,GAAG;AACnB,UAAA,IAAI,MAAM,yBAAyB;AAAA,EAC3C;AAEA,QAAM,EAAE,IAAI,YAAY,GAAG,eAAe;AAE1C,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,UAAAC,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;AAAA,IACA,YAAY;AAAA,EAAA;AAEhB;;"}
@@ -1,24 +1,21 @@
1
1
  import { isNil, isPlainObject } from "lodash/fp";
2
- import { parseMultipartData } from "@strapi/utils";
3
2
  function isEntry(property) {
4
3
  return property === null || isPlainObject(property) || Array.isArray(property);
5
4
  }
6
5
  function isDZEntries(property) {
7
6
  return Array.isArray(property);
8
7
  }
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 = {}) => {
8
+ const transformResponse = (resource, meta = {}, opts = {
9
+ useJsonAPIFormat: false
10
+ }) => {
17
11
  if (isNil(resource)) {
18
12
  return resource;
19
13
  }
14
+ if (!isPlainObject(resource) && !Array.isArray(resource)) {
15
+ throw new Error("Entry must be an object or an arrayy of objects");
16
+ }
20
17
  return {
21
- data: transformEntry(resource, opts?.contentType),
18
+ data: opts.useJsonAPIFormat ? transformEntry(resource, opts?.contentType) : resource,
22
19
  meta
23
20
  };
24
21
  };
@@ -43,7 +40,7 @@ function transformEntry(entry, type) {
43
40
  if (!isPlainObject(entry)) {
44
41
  throw new Error("Entry must be an object");
45
42
  }
46
- const { id, ...properties } = entry;
43
+ const { id, documentId, ...properties } = entry;
47
44
  const attributeValues = {};
48
45
  for (const key of Object.keys(properties)) {
49
46
  const property = properties[key];
@@ -72,13 +69,11 @@ function transformEntry(entry, type) {
72
69
  }
73
70
  return {
74
71
  id,
72
+ documentId,
75
73
  attributes: attributeValues
76
- // NOTE: not necessary for now
77
- // meta: {},
78
74
  };
79
75
  }
80
76
  export {
81
- parseBody,
82
77
  transformResponse
83
78
  };
84
79
  //# sourceMappingURL=transform.mjs.map
@@ -1 +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;"}
1
+ {"version":3,"file":"transform.mjs","sources":["../../../src/core-api/controller/transform.ts"],"sourcesContent":["import { isNil, isPlainObject } from 'lodash/fp';\nimport type { Common, Schema, UID } from '@strapi/types';\n\ntype TransformedEntry = {\n id: string;\n documentId?: string | null;\n attributes: Record<string, unknown>;\n};\n\ntype TransformedComponent = {\n id: string;\n [key: string]: unknown;\n};\n\ntype Entry = {\n id: string;\n documentId: string | null;\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\ninterface TransformOptions {\n contentType?: Schema.ContentType | Schema.Component;\n /**\n * @deprecated this option is deprecated and will be removed in the next major version\n */\n useJsonAPIFormat?: boolean;\n}\n\nconst transformResponse = (\n resource: any,\n meta: unknown = {},\n opts: TransformOptions = {\n useJsonAPIFormat: false,\n }\n) => {\n if (isNil(resource)) {\n return resource;\n }\n\n if (!isPlainObject(resource) && !Array.isArray(resource)) {\n throw new Error('Entry must be an object or an arrayy of objects');\n }\n\n return {\n data: opts.useJsonAPIFormat ? transformEntry(resource, opts?.contentType) : resource,\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, documentId, ...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 documentId,\n attributes: attributeValues,\n };\n}\n\nexport { transformResponse };\n"],"names":[],"mappings":";AAoBA,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;AAUA,MAAM,oBAAoB,CACxB,UACA,OAAgB,CAAA,GAChB,OAAyB;AAAA,EACvB,kBAAkB;AACpB,MACG;AACC,MAAA,MAAM,QAAQ,GAAG;AACZ,WAAA;AAAA,EACT;AAEI,MAAA,CAAC,cAAc,QAAQ,KAAK,CAAC,MAAM,QAAQ,QAAQ,GAAG;AAClD,UAAA,IAAI,MAAM,iDAAiD;AAAA,EACnE;AAEO,SAAA;AAAA,IACL,MAAM,KAAK,mBAAmB,eAAe,UAAU,MAAM,WAAW,IAAI;AAAA,IAC5E;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,YAAY,GAAG,eAAe;AAE1C,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;AAAA,IACA,YAAY;AAAA,EAAA;AAEhB;"}
@@ -1,10 +1,33 @@
1
- import type { CoreApi, Schema } from '@strapi/types';
1
+ import type { CoreApi, Schema, Documents } from '@strapi/types';
2
+ import { CoreService } from './core-service';
3
+ export declare class CollectionTypeService extends CoreService implements CoreApi.Service.CollectionType {
4
+ private contentType;
5
+ constructor(contentType: Schema.CollectionType);
6
+ find(params?: {}): Promise<{
7
+ results: Documents.AnyDocument[];
8
+ pagination: {
9
+ page: number;
10
+ pageSize: number;
11
+ } | {
12
+ start: number;
13
+ limit: number;
14
+ };
15
+ }>;
16
+ findOne(documentId: Documents.ID, params?: {}): import("@strapi/types/dist/modules/documents/result/document-enigne").FindOne<import("@strapi/types/dist/types/core/common/uid").ContentType, any>;
17
+ create(params?: {
18
+ data: {};
19
+ }): Promise<Documents.AnyDocument>;
20
+ update(docId: Documents.ID, params?: {
21
+ data: {};
22
+ }): import("@strapi/types/dist/modules/documents/result/document-enigne").Update<import("@strapi/types/dist/types/core/common/uid").ContentType, any>;
23
+ delete(docId: Documents.ID, params?: {}): Promise<{
24
+ deletedEntries: number;
25
+ }>;
26
+ }
2
27
  /**
3
28
  *
4
29
  * Returns a collection type service to handle default core-api actions
5
30
  */
6
- declare const createCollectionTypeService: ({ contentType, }: {
7
- contentType: Schema.CollectionType;
8
- }) => CoreApi.Service.CollectionType;
9
- export default createCollectionTypeService;
31
+ declare const createCollectionTypeService: (contentType: Schema.CollectionType) => CoreApi.Service.CollectionType;
32
+ export { createCollectionTypeService };
10
33
  //# sourceMappingURL=collection-type.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"collection-type.d.ts","sourceRoot":"","sources":["../../../src/core-api/service/collection-type.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,EAAU,MAAM,eAAe,CAAC;AAkB7D;;;GAGG;AACH,QAAA,MAAM,2BAA2B;iBAGlB,OAAO,cAAc;MAChC,QAAQ,OAAO,CAAC,cAyDnB,CAAC;AAEF,eAAe,2BAA2B,CAAC"}
1
+ {"version":3,"file":"collection-type.d.ts","sourceRoot":"","sources":["../../../src/core-api/service/collection-type.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAIhE,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAE7C,qBAAa,qBAAsB,SAAQ,WAAY,YAAW,OAAO,CAAC,OAAO,CAAC,cAAc;IAC9F,OAAO,CAAC,WAAW,CAAwB;gBAE/B,WAAW,EAAE,MAAM,CAAC,cAAc;IAMxC,IAAI,CAAC,MAAM,KAAK;;;;;;;;;;IA+BtB,OAAO,CAAC,UAAU,EAAE,SAAS,CAAC,EAAE,EAAE,MAAM,KAAK;IAMvC,MAAM,CAAC,MAAM;;KAAe;IAMlC,MAAM,CAAC,KAAK,EAAE,SAAS,CAAC,EAAE,EAAE,MAAM;;KAAe;IAM3C,MAAM,CAAC,KAAK,EAAE,SAAS,CAAC,EAAE,EAAE,MAAM,KAAK;;;CAK9C;AAED;;;GAGG;AAEH,QAAA,MAAM,2BAA2B,gBAClB,OAAO,cAAc,KACjC,QAAQ,OAAO,CAAC,cAElB,CAAC;AAEF,OAAO,EAAE,2BAA2B,EAAE,CAAC"}
@@ -1,58 +1,56 @@
1
1
  "use strict";
2
- const _ = require("lodash/fp");
3
- const strapiUtils = require("@strapi/utils");
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
4
3
  const pagination = require("./pagination.js");
5
- const getFetchParams = require("./get-fetch-params.js");
6
- const {
7
- constants: { PUBLISHED_AT_ATTRIBUTE }
8
- } = strapiUtils.contentTypes;
9
- const setPublishedAt = (data) => {
10
- data[PUBLISHED_AT_ATTRIBUTE] = _.propOr(/* @__PURE__ */ new Date(), PUBLISHED_AT_ATTRIBUTE, data);
11
- };
12
- const createCollectionTypeService = ({
13
- contentType
14
- }) => {
15
- const { uid } = contentType;
16
- return {
17
- getFetchParams: getFetchParams.getFetchParams,
18
- async find(params = {}) {
19
- const fetchParams = this.getFetchParams(params);
20
- const paginationInfo = pagination.getPaginationInfo(fetchParams);
21
- const results = await strapi.entityService?.findMany(uid, {
22
- ...fetchParams,
23
- ...pagination.convertPagedToStartLimit(paginationInfo)
24
- });
25
- if (pagination.shouldCount(fetchParams)) {
26
- const count = await strapi.entityService?.count(uid, { ...fetchParams, ...paginationInfo });
27
- if (typeof count !== "number") {
28
- throw new Error("Count should be a number");
29
- }
30
- return {
31
- results,
32
- pagination: pagination.transformPaginationResponse(paginationInfo, count)
33
- };
4
+ const coreService = require("./core-service.js");
5
+ class CollectionTypeService extends coreService.CoreService {
6
+ contentType;
7
+ constructor(contentType) {
8
+ super();
9
+ this.contentType = contentType;
10
+ }
11
+ async find(params = {}) {
12
+ const { uid } = this.contentType;
13
+ const fetchParams = this.getFetchParams(params);
14
+ const paginationInfo = pagination.getPaginationInfo(fetchParams);
15
+ const results = await strapi.documents(uid).findMany({
16
+ ...fetchParams,
17
+ ...paginationInfo
18
+ });
19
+ if (pagination.shouldCount(fetchParams)) {
20
+ const count = await strapi.documents(uid).count({ ...fetchParams, ...paginationInfo });
21
+ if (typeof count !== "number") {
22
+ throw new Error("Count should be a number");
34
23
  }
35
24
  return {
36
25
  results,
37
- pagination: paginationInfo
26
+ pagination: pagination.transformPaginationResponse(paginationInfo, count)
38
27
  };
39
- },
40
- findOne(entityId, params = {}) {
41
- return strapi.entityService?.findOne(uid, entityId, this.getFetchParams(params));
42
- },
43
- create(params = { data: {} }) {
44
- const { data } = params;
45
- setPublishedAt(data);
46
- return strapi.entityService?.create(uid, { ...params, data });
47
- },
48
- update(entityId, params = { data: {} }) {
49
- const { data } = params;
50
- return strapi.entityService?.update(uid, entityId, { ...params, data });
51
- },
52
- delete(entityId, params = {}) {
53
- return strapi.entityService?.delete(uid, entityId, params);
54
28
  }
55
- };
29
+ return {
30
+ results,
31
+ pagination: paginationInfo
32
+ };
33
+ }
34
+ findOne(documentId, params = {}) {
35
+ const { uid } = this.contentType;
36
+ return strapi.documents(uid).findOne(documentId, this.getFetchParams(params));
37
+ }
38
+ async create(params = { data: {} }) {
39
+ const { uid } = this.contentType;
40
+ return strapi.documents(uid).create(this.getFetchParams(params));
41
+ }
42
+ update(docId, params = { data: {} }) {
43
+ const { uid } = this.contentType;
44
+ return strapi.documents(uid).update(docId, this.getFetchParams(params));
45
+ }
46
+ async delete(docId, params = {}) {
47
+ const { uid } = this.contentType;
48
+ return strapi.documents(uid).delete(docId, this.getFetchParams(params));
49
+ }
50
+ }
51
+ const createCollectionTypeService = (contentType) => {
52
+ return new CollectionTypeService(contentType);
56
53
  };
57
- module.exports = createCollectionTypeService;
54
+ exports.CollectionTypeService = CollectionTypeService;
55
+ exports.createCollectionTypeService = createCollectionTypeService;
58
56
  //# sourceMappingURL=collection-type.js.map