@strapi/core 0.0.0-experimental.6dbac0c205b0f8495781db5706c18cac1a62e62b → 0.0.0-experimental.80cf2c74a2003f3c0602abc81888dd9f36dc68a3

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

Potentially problematic release.


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

Files changed (1058) hide show
  1. package/dist/Strapi.d.ts +40 -35
  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/container.d.ts +2 -2
  25. package/dist/container.d.ts.map +1 -1
  26. package/dist/container.js.map +1 -1
  27. package/dist/container.mjs.map +1 -1
  28. package/dist/core-api/controller/collection-type.d.ts +4 -4
  29. package/dist/core-api/controller/collection-type.d.ts.map +1 -1
  30. package/dist/core-api/controller/collection-type.js +9 -20
  31. package/dist/core-api/controller/collection-type.js.map +1 -1
  32. package/dist/core-api/controller/collection-type.mjs +8 -20
  33. package/dist/core-api/controller/collection-type.mjs.map +1 -1
  34. package/dist/core-api/controller/index.d.ts +3 -3
  35. package/dist/core-api/controller/index.d.ts.map +1 -1
  36. package/dist/core-api/controller/index.js +8 -3
  37. package/dist/core-api/controller/index.js.map +1 -1
  38. package/dist/core-api/controller/index.mjs +8 -3
  39. package/dist/core-api/controller/index.mjs.map +1 -1
  40. package/dist/core-api/controller/single-type.d.ts +4 -4
  41. package/dist/core-api/controller/single-type.d.ts.map +1 -1
  42. package/dist/core-api/controller/single-type.js +6 -11
  43. package/dist/core-api/controller/single-type.js.map +1 -1
  44. package/dist/core-api/controller/single-type.mjs +5 -11
  45. package/dist/core-api/controller/single-type.mjs.map +1 -1
  46. package/dist/core-api/controller/transform.d.ts +10 -18
  47. package/dist/core-api/controller/transform.d.ts.map +1 -1
  48. package/dist/core-api/controller/transform.js +10 -18
  49. package/dist/core-api/controller/transform.js.map +1 -1
  50. package/dist/core-api/controller/transform.mjs +10 -18
  51. package/dist/core-api/controller/transform.mjs.map +1 -1
  52. package/dist/core-api/service/collection-type.d.ts +28 -5
  53. package/dist/core-api/service/collection-type.d.ts.map +1 -1
  54. package/dist/core-api/service/collection-type.js +47 -49
  55. package/dist/core-api/service/collection-type.js.map +1 -1
  56. package/dist/core-api/service/collection-type.mjs +47 -50
  57. package/dist/core-api/service/collection-type.mjs.map +1 -1
  58. package/dist/core-api/service/core-service.d.ts +4 -0
  59. package/dist/core-api/service/core-service.d.ts.map +1 -0
  60. package/dist/core-api/service/core-service.js +12 -0
  61. package/dist/core-api/service/core-service.js.map +1 -0
  62. package/dist/core-api/service/core-service.mjs +12 -0
  63. package/dist/core-api/service/core-service.mjs.map +1 -0
  64. package/dist/core-api/service/index.d.ts +3 -3
  65. package/dist/core-api/service/index.d.ts.map +1 -1
  66. package/dist/core-api/service/index.js +2 -2
  67. package/dist/core-api/service/index.js.map +1 -1
  68. package/dist/core-api/service/index.mjs +4 -4
  69. package/dist/core-api/service/index.mjs.map +1 -1
  70. package/dist/core-api/service/pagination.d.ts +1 -5
  71. package/dist/core-api/service/pagination.d.ts.map +1 -1
  72. package/dist/core-api/service/pagination.js +0 -11
  73. package/dist/core-api/service/pagination.js.map +1 -1
  74. package/dist/core-api/service/pagination.mjs +0 -11
  75. package/dist/core-api/service/pagination.mjs.map +1 -1
  76. package/dist/core-api/service/single-type.d.ts +14 -8
  77. package/dist/core-api/service/single-type.d.ts.map +1 -1
  78. package/dist/core-api/service/single-type.js +35 -50
  79. package/dist/core-api/service/single-type.js.map +1 -1
  80. package/dist/core-api/service/single-type.mjs +34 -50
  81. package/dist/core-api/service/single-type.mjs.map +1 -1
  82. package/dist/{core/domain → domain}/content-type/index.d.ts +3 -2
  83. package/dist/domain/content-type/index.d.ts.map +1 -0
  84. package/dist/{core/domain → domain}/content-type/index.js +23 -34
  85. package/dist/domain/content-type/index.js.map +1 -0
  86. package/dist/{core/domain → domain}/content-type/index.mjs +24 -35
  87. package/dist/domain/content-type/index.mjs.map +1 -0
  88. package/dist/domain/content-type/validator.d.ts.map +1 -0
  89. package/dist/{core/domain → domain}/content-type/validator.js +1 -1
  90. package/dist/domain/content-type/validator.js.map +1 -0
  91. package/dist/{core/domain → domain}/content-type/validator.mjs +2 -2
  92. package/dist/domain/content-type/validator.mjs.map +1 -0
  93. package/dist/domain/module/index.d.ts +40 -0
  94. package/dist/domain/module/index.d.ts.map +1 -0
  95. package/dist/{core/domain → domain}/module/index.js +31 -31
  96. package/dist/domain/module/index.js.map +1 -0
  97. package/dist/{core/domain → domain}/module/index.mjs +5 -5
  98. package/dist/domain/module/index.mjs.map +1 -0
  99. package/dist/domain/module/validation.d.ts.map +1 -0
  100. package/dist/domain/module/validation.js.map +1 -0
  101. package/dist/domain/module/validation.mjs.map +1 -0
  102. package/dist/ee/index.d.ts +2 -2
  103. package/dist/ee/index.d.ts.map +1 -1
  104. package/dist/ee/index.js +2 -2
  105. package/dist/ee/index.js.map +1 -1
  106. package/dist/ee/index.mjs +2 -2
  107. package/dist/ee/index.mjs.map +1 -1
  108. package/dist/ee/license.d.ts +2 -2
  109. package/dist/ee/license.d.ts.map +1 -1
  110. package/dist/ee/license.js +2 -1
  111. package/dist/ee/license.js.map +1 -1
  112. package/dist/ee/license.mjs +2 -1
  113. package/dist/ee/license.mjs.map +1 -1
  114. package/dist/factories.d.ts +11 -10
  115. package/dist/factories.d.ts.map +1 -1
  116. package/dist/factories.js +22 -13
  117. package/dist/factories.js.map +1 -1
  118. package/dist/factories.mjs +23 -14
  119. package/dist/factories.mjs.map +1 -1
  120. package/dist/index.d.ts +3 -2
  121. package/dist/index.d.ts.map +1 -1
  122. package/dist/index.js +3 -1
  123. package/dist/index.js.map +1 -1
  124. package/dist/index.mjs +3 -1
  125. package/dist/index.mjs.map +1 -1
  126. package/dist/loaders/admin.d.ts +3 -0
  127. package/dist/loaders/admin.d.ts.map +1 -0
  128. package/dist/{core/loaders → loaders}/admin.js +12 -1
  129. package/dist/loaders/admin.js.map +1 -0
  130. package/dist/{core/loaders → loaders}/admin.mjs +12 -1
  131. package/dist/loaders/admin.mjs.map +1 -0
  132. package/dist/loaders/apis.d.ts +3 -0
  133. package/dist/loaders/apis.d.ts.map +1 -0
  134. package/dist/{core/loaders → loaders}/apis.js +20 -13
  135. package/dist/loaders/apis.js.map +1 -0
  136. package/dist/{core/loaders → loaders}/apis.mjs +19 -12
  137. package/dist/loaders/apis.mjs.map +1 -0
  138. package/dist/loaders/components.d.ts +3 -0
  139. package/dist/loaders/components.d.ts.map +1 -0
  140. package/dist/{core/loaders → loaders}/components.js +2 -2
  141. package/dist/loaders/components.js.map +1 -0
  142. package/dist/{core/loaders → loaders}/components.mjs +1 -1
  143. package/dist/loaders/components.mjs.map +1 -0
  144. package/dist/loaders/index.d.ts +3 -0
  145. package/dist/loaders/index.d.ts.map +1 -0
  146. package/dist/loaders/index.js.map +1 -0
  147. package/dist/loaders/index.mjs.map +1 -0
  148. package/dist/loaders/middlewares.d.ts +3 -0
  149. package/dist/loaders/middlewares.d.ts.map +1 -0
  150. package/dist/{core/loaders → loaders}/middlewares.js +1 -1
  151. package/dist/loaders/middlewares.js.map +1 -0
  152. package/dist/{core/loaders → loaders}/middlewares.mjs +1 -1
  153. package/dist/loaders/middlewares.mjs.map +1 -0
  154. package/dist/loaders/plugins/get-enabled-plugins.d.ts +5 -0
  155. package/dist/loaders/plugins/get-enabled-plugins.d.ts.map +1 -0
  156. package/dist/{core/loaders → loaders}/plugins/get-enabled-plugins.js +4 -2
  157. package/dist/loaders/plugins/get-enabled-plugins.js.map +1 -0
  158. package/dist/{core/loaders → loaders}/plugins/get-enabled-plugins.mjs +5 -3
  159. package/dist/loaders/plugins/get-enabled-plugins.mjs.map +1 -0
  160. package/dist/loaders/plugins/get-user-plugins-config.d.ts.map +1 -0
  161. package/dist/{core/loaders → loaders}/plugins/get-user-plugins-config.js +3 -3
  162. package/dist/loaders/plugins/get-user-plugins-config.js.map +1 -0
  163. package/dist/{core/loaders → loaders}/plugins/get-user-plugins-config.mjs +3 -3
  164. package/dist/loaders/plugins/get-user-plugins-config.mjs.map +1 -0
  165. package/dist/loaders/plugins/index.d.ts +3 -0
  166. package/dist/loaders/plugins/index.d.ts.map +1 -0
  167. package/dist/{core/loaders → loaders}/plugins/index.js +18 -5
  168. package/dist/loaders/plugins/index.js.map +1 -0
  169. package/dist/{core/loaders → loaders}/plugins/index.mjs +16 -3
  170. package/dist/loaders/plugins/index.mjs.map +1 -0
  171. package/dist/loaders/policies.d.ts +3 -0
  172. package/dist/loaders/policies.d.ts.map +1 -0
  173. package/dist/loaders/policies.js.map +1 -0
  174. package/dist/loaders/policies.mjs.map +1 -0
  175. package/dist/loaders/sanitizers.d.ts +4 -0
  176. package/dist/loaders/sanitizers.d.ts.map +1 -0
  177. package/dist/loaders/sanitizers.js.map +1 -0
  178. package/dist/loaders/sanitizers.mjs.map +1 -0
  179. package/dist/loaders/src-index.d.ts +4 -0
  180. package/dist/loaders/src-index.d.ts.map +1 -0
  181. package/dist/loaders/src-index.js.map +1 -0
  182. package/dist/loaders/src-index.mjs.map +1 -0
  183. package/dist/loaders/validators.d.ts +4 -0
  184. package/dist/loaders/validators.d.ts.map +1 -0
  185. package/dist/loaders/validators.js.map +1 -0
  186. package/dist/loaders/validators.mjs.map +1 -0
  187. package/dist/middlewares/body.d.ts +2 -2
  188. package/dist/middlewares/body.d.ts.map +1 -1
  189. package/dist/middlewares/body.js.map +1 -1
  190. package/dist/middlewares/body.mjs.map +1 -1
  191. package/dist/middlewares/compression.d.ts +2 -2
  192. package/dist/middlewares/compression.d.ts.map +1 -1
  193. package/dist/middlewares/compression.js.map +1 -1
  194. package/dist/middlewares/compression.mjs.map +1 -1
  195. package/dist/middlewares/cors.d.ts +2 -2
  196. package/dist/middlewares/cors.d.ts.map +1 -1
  197. package/dist/middlewares/cors.js.map +1 -1
  198. package/dist/middlewares/cors.mjs.map +1 -1
  199. package/dist/middlewares/errors.d.ts +2 -2
  200. package/dist/middlewares/errors.d.ts.map +1 -1
  201. package/dist/middlewares/errors.js.map +1 -1
  202. package/dist/middlewares/errors.mjs.map +1 -1
  203. package/dist/middlewares/favicon.d.ts +3 -2
  204. package/dist/middlewares/favicon.d.ts.map +1 -1
  205. package/dist/middlewares/favicon.js.map +1 -1
  206. package/dist/middlewares/favicon.mjs.map +1 -1
  207. package/dist/middlewares/index.d.ts +2 -2
  208. package/dist/middlewares/index.d.ts.map +1 -1
  209. package/dist/middlewares/index.js +2 -2
  210. package/dist/middlewares/index.js.map +1 -1
  211. package/dist/middlewares/index.mjs +1 -1
  212. package/dist/middlewares/index.mjs.map +1 -1
  213. package/dist/middlewares/ip.d.ts +2 -2
  214. package/dist/middlewares/ip.d.ts.map +1 -1
  215. package/dist/middlewares/ip.js.map +1 -1
  216. package/dist/middlewares/ip.mjs.map +1 -1
  217. package/dist/middlewares/logger.d.ts +2 -2
  218. package/dist/middlewares/logger.d.ts.map +1 -1
  219. package/dist/middlewares/logger.js.map +1 -1
  220. package/dist/middlewares/logger.mjs.map +1 -1
  221. package/dist/middlewares/powered-by.d.ts +2 -2
  222. package/dist/middlewares/powered-by.d.ts.map +1 -1
  223. package/dist/middlewares/powered-by.js.map +1 -1
  224. package/dist/middlewares/powered-by.mjs.map +1 -1
  225. package/dist/middlewares/public.d.ts +3 -0
  226. package/dist/middlewares/public.d.ts.map +1 -0
  227. package/dist/middlewares/public.js +34 -0
  228. package/dist/middlewares/public.js.map +1 -0
  229. package/dist/middlewares/public.mjs +32 -0
  230. package/dist/middlewares/public.mjs.map +1 -0
  231. package/dist/middlewares/query.d.ts +2 -2
  232. package/dist/middlewares/query.d.ts.map +1 -1
  233. package/dist/middlewares/query.js.map +1 -1
  234. package/dist/middlewares/query.mjs.map +1 -1
  235. package/dist/middlewares/response-time.d.ts +2 -2
  236. package/dist/middlewares/response-time.d.ts.map +1 -1
  237. package/dist/middlewares/response-time.js.map +1 -1
  238. package/dist/middlewares/response-time.mjs.map +1 -1
  239. package/dist/middlewares/responses.d.ts +3 -3
  240. package/dist/middlewares/responses.d.ts.map +1 -1
  241. package/dist/middlewares/responses.js.map +1 -1
  242. package/dist/middlewares/responses.mjs.map +1 -1
  243. package/dist/middlewares/security.d.ts +2 -2
  244. package/dist/middlewares/security.d.ts.map +1 -1
  245. package/dist/middlewares/security.js +24 -3
  246. package/dist/middlewares/security.js.map +1 -1
  247. package/dist/middlewares/security.mjs +24 -3
  248. package/dist/middlewares/security.mjs.map +1 -1
  249. package/dist/middlewares/session.d.ts +2 -2
  250. package/dist/middlewares/session.d.ts.map +1 -1
  251. package/dist/middlewares/session.js.map +1 -1
  252. package/dist/middlewares/session.mjs.map +1 -1
  253. package/dist/migrations/draft-publish.d.ts +17 -0
  254. package/dist/migrations/draft-publish.d.ts.map +1 -0
  255. package/dist/migrations/draft-publish.js +59 -0
  256. package/dist/migrations/draft-publish.js.map +1 -0
  257. package/dist/migrations/draft-publish.mjs +59 -0
  258. package/dist/migrations/draft-publish.mjs.map +1 -0
  259. package/dist/{core/registries → registries}/apis.d.ts +2 -2
  260. package/dist/registries/apis.d.ts.map +1 -0
  261. package/dist/registries/apis.js.map +1 -0
  262. package/dist/registries/apis.mjs.map +1 -0
  263. package/dist/{core/registries → registries}/components.d.ts +6 -6
  264. package/dist/registries/components.d.ts.map +1 -0
  265. package/dist/registries/components.js.map +1 -0
  266. package/dist/registries/components.mjs.map +1 -0
  267. package/dist/registries/config.d.ts +4 -0
  268. package/dist/registries/config.d.ts.map +1 -0
  269. package/dist/registries/config.js +43 -0
  270. package/dist/registries/config.js.map +1 -0
  271. package/dist/registries/config.mjs +44 -0
  272. package/dist/registries/config.mjs.map +1 -0
  273. package/dist/{core/registries → registries}/content-types.d.ts +5 -5
  274. package/dist/registries/content-types.d.ts.map +1 -0
  275. package/dist/{core/registries → registries}/content-types.js +6 -7
  276. package/dist/registries/content-types.js.map +1 -0
  277. package/dist/{core/registries → registries}/content-types.mjs +2 -3
  278. package/dist/registries/content-types.mjs.map +1 -0
  279. package/dist/registries/controllers.d.ts +35 -0
  280. package/dist/registries/controllers.d.ts.map +1 -0
  281. package/dist/{core/registries → registries}/controllers.js +5 -5
  282. package/dist/registries/controllers.js.map +1 -0
  283. package/dist/{core/registries → registries}/controllers.mjs +1 -1
  284. package/dist/registries/controllers.mjs.map +1 -0
  285. package/dist/registries/custom-fields.d.ts +8 -0
  286. package/dist/registries/custom-fields.d.ts.map +1 -0
  287. package/dist/registries/custom-fields.js.map +1 -0
  288. package/dist/registries/custom-fields.mjs.map +1 -0
  289. package/dist/registries/hooks.d.ts.map +1 -0
  290. package/dist/{core/registries → registries}/hooks.js +5 -5
  291. package/dist/registries/hooks.js.map +1 -0
  292. package/dist/{core/registries → registries}/hooks.mjs +1 -1
  293. package/dist/registries/hooks.mjs.map +1 -0
  294. package/dist/{core/registries → registries}/index.d.ts +1 -0
  295. package/dist/registries/index.d.ts.map +1 -0
  296. package/dist/{core/registries → registries}/middlewares.d.ts +6 -6
  297. package/dist/registries/middlewares.d.ts.map +1 -0
  298. package/dist/{core/registries → registries}/middlewares.js +5 -5
  299. package/dist/registries/middlewares.js.map +1 -0
  300. package/dist/{core/registries → registries}/middlewares.mjs +1 -1
  301. package/dist/registries/middlewares.mjs.map +1 -0
  302. package/dist/registries/models.d.ts +6 -0
  303. package/dist/registries/models.d.ts.map +1 -0
  304. package/dist/registries/models.js +16 -0
  305. package/dist/registries/models.js.map +1 -0
  306. package/dist/registries/models.mjs +16 -0
  307. package/dist/registries/models.mjs.map +1 -0
  308. package/dist/{core/registries → registries}/modules.d.ts +2 -2
  309. package/dist/registries/modules.d.ts.map +1 -0
  310. package/dist/registries/modules.js.map +1 -0
  311. package/dist/registries/modules.mjs.map +1 -0
  312. package/dist/{core/utils.d.ts → registries/namespace.d.ts} +1 -1
  313. package/dist/registries/namespace.d.ts.map +1 -0
  314. package/dist/{core/utils.js → registries/namespace.js} +1 -1
  315. package/dist/registries/namespace.js.map +1 -0
  316. package/dist/{core/utils.mjs → registries/namespace.mjs} +1 -1
  317. package/dist/registries/namespace.mjs.map +1 -0
  318. package/dist/registries/plugins.d.ts +9 -0
  319. package/dist/registries/plugins.d.ts.map +1 -0
  320. package/dist/registries/plugins.js.map +1 -0
  321. package/dist/registries/plugins.mjs.map +1 -0
  322. package/dist/{core/registries → registries}/policies.d.ts +6 -6
  323. package/dist/registries/policies.d.ts.map +1 -0
  324. package/dist/{core/registries → registries}/policies.js +5 -5
  325. package/dist/registries/policies.js.map +1 -0
  326. package/dist/{core/registries → registries}/policies.mjs +1 -1
  327. package/dist/registries/policies.mjs.map +1 -0
  328. package/dist/registries/sanitizers.d.ts.map +1 -0
  329. package/dist/registries/sanitizers.js.map +1 -0
  330. package/dist/registries/sanitizers.mjs.map +1 -0
  331. package/dist/{core/registries → registries}/services.d.ts +8 -8
  332. package/dist/registries/services.d.ts.map +1 -0
  333. package/dist/{core/registries → registries}/services.js +5 -5
  334. package/dist/registries/services.js.map +1 -0
  335. package/dist/{core/registries → registries}/services.mjs +1 -1
  336. package/dist/registries/services.mjs.map +1 -0
  337. package/dist/registries/validators.d.ts.map +1 -0
  338. package/dist/registries/validators.js.map +1 -0
  339. package/dist/registries/validators.mjs.map +1 -0
  340. package/dist/services/auth/index.d.ts +4 -4
  341. package/dist/services/auth/index.d.ts.map +1 -1
  342. package/dist/services/auth/index.js.map +1 -1
  343. package/dist/services/auth/index.mjs.map +1 -1
  344. package/dist/services/content-api/index.d.ts +3 -3
  345. package/dist/services/content-api/index.d.ts.map +1 -1
  346. package/dist/services/content-api/index.js.map +1 -1
  347. package/dist/services/content-api/index.mjs.map +1 -1
  348. package/dist/services/content-api/permissions/index.d.ts +3 -3
  349. package/dist/services/content-api/permissions/index.d.ts.map +1 -1
  350. package/dist/services/content-api/permissions/index.js.map +1 -1
  351. package/dist/services/content-api/permissions/index.mjs.map +1 -1
  352. package/dist/services/core-store.d.ts +2 -22
  353. package/dist/services/core-store.d.ts.map +1 -1
  354. package/dist/services/core-store.js +5 -1
  355. package/dist/services/core-store.js.map +1 -1
  356. package/dist/services/core-store.mjs +5 -1
  357. package/dist/services/core-store.mjs.map +1 -1
  358. package/dist/services/cron.d.ts +2 -2
  359. package/dist/services/cron.d.ts.map +1 -1
  360. package/dist/services/cron.js.map +1 -1
  361. package/dist/services/cron.mjs.map +1 -1
  362. package/dist/services/custom-fields.d.ts +2 -2
  363. package/dist/services/custom-fields.d.ts.map +1 -1
  364. package/dist/services/custom-fields.js.map +1 -1
  365. package/dist/services/custom-fields.mjs.map +1 -1
  366. package/dist/services/document-service/common.d.ts +4 -0
  367. package/dist/services/document-service/common.d.ts.map +1 -0
  368. package/dist/services/document-service/common.js +7 -0
  369. package/dist/services/document-service/common.js.map +1 -0
  370. package/dist/services/document-service/common.mjs +7 -0
  371. package/dist/services/document-service/common.mjs.map +1 -0
  372. package/dist/services/document-service/document-engine.d.ts +2 -0
  373. package/dist/services/document-service/document-engine.d.ts.map +1 -0
  374. package/dist/services/document-service/draft-and-publish.d.ts +10 -0
  375. package/dist/services/document-service/draft-and-publish.d.ts.map +1 -0
  376. package/dist/services/document-service/draft-and-publish.js +69 -0
  377. package/dist/services/document-service/draft-and-publish.js.map +1 -0
  378. package/dist/services/document-service/draft-and-publish.mjs +69 -0
  379. package/dist/services/document-service/draft-and-publish.mjs.map +1 -0
  380. package/dist/services/document-service/index.d.ts +18 -7
  381. package/dist/services/document-service/index.d.ts.map +1 -1
  382. package/dist/services/document-service/index.js +20 -190
  383. package/dist/services/document-service/index.js.map +1 -1
  384. package/dist/services/document-service/index.mjs +19 -190
  385. package/dist/services/document-service/index.mjs.map +1 -1
  386. package/dist/services/document-service/internationalization.d.ts +8 -0
  387. package/dist/services/document-service/internationalization.d.ts.map +1 -0
  388. package/dist/services/document-service/internationalization.js +54 -0
  389. package/dist/services/document-service/internationalization.js.map +1 -0
  390. package/dist/services/document-service/internationalization.mjs +54 -0
  391. package/dist/services/document-service/internationalization.mjs.map +1 -0
  392. package/dist/services/document-service/middlewares/errors.d.ts +6 -0
  393. package/dist/services/document-service/middlewares/errors.d.ts.map +1 -0
  394. package/dist/services/document-service/middlewares/errors.js +25 -0
  395. package/dist/services/document-service/middlewares/errors.js.map +1 -0
  396. package/dist/services/document-service/middlewares/errors.mjs +25 -0
  397. package/dist/services/document-service/middlewares/errors.mjs.map +1 -0
  398. package/dist/services/document-service/middlewares/index.d.ts +2 -10
  399. package/dist/services/document-service/middlewares/index.d.ts.map +1 -1
  400. package/dist/services/document-service/middlewares/middleware-manager.d.ts +7 -0
  401. package/dist/services/document-service/middlewares/middleware-manager.d.ts.map +1 -0
  402. package/dist/services/document-service/middlewares/middleware-manager.js +46 -0
  403. package/dist/services/document-service/middlewares/middleware-manager.js.map +1 -0
  404. package/dist/services/document-service/middlewares/middleware-manager.mjs +46 -0
  405. package/dist/services/document-service/middlewares/middleware-manager.mjs.map +1 -0
  406. package/dist/services/document-service/repository.d.ts +3 -0
  407. package/dist/services/document-service/repository.d.ts.map +1 -0
  408. package/dist/services/document-service/repository.js +297 -0
  409. package/dist/services/document-service/repository.js.map +1 -0
  410. package/dist/services/document-service/repository.mjs +297 -0
  411. package/dist/services/document-service/repository.mjs.map +1 -0
  412. package/dist/services/document-service/transform/data.d.ts +5 -0
  413. package/dist/services/document-service/transform/data.d.ts.map +1 -0
  414. package/dist/services/document-service/transform/data.js +13 -0
  415. package/dist/services/document-service/transform/data.js.map +1 -0
  416. package/dist/services/document-service/transform/data.mjs +13 -0
  417. package/dist/services/document-service/transform/data.mjs.map +1 -0
  418. package/dist/services/document-service/transform/fields.d.ts +5 -0
  419. package/dist/services/document-service/transform/fields.d.ts.map +1 -0
  420. package/dist/services/document-service/transform/fields.js +24 -0
  421. package/dist/services/document-service/transform/fields.js.map +1 -0
  422. package/dist/services/document-service/transform/fields.mjs +24 -0
  423. package/dist/services/document-service/transform/fields.mjs.map +1 -0
  424. package/dist/services/document-service/transform/id-map.d.ts +23 -0
  425. package/dist/services/document-service/transform/id-map.d.ts.map +1 -0
  426. package/dist/services/document-service/transform/id-map.js +78 -0
  427. package/dist/services/document-service/transform/id-map.js.map +1 -0
  428. package/dist/services/document-service/transform/id-map.mjs +78 -0
  429. package/dist/services/document-service/transform/id-map.mjs.map +1 -0
  430. package/dist/services/document-service/transform/id-transform.d.ts +5 -0
  431. package/dist/services/document-service/transform/id-transform.d.ts.map +1 -0
  432. package/dist/services/document-service/transform/id-transform.js +33 -0
  433. package/dist/services/document-service/transform/id-transform.js.map +1 -0
  434. package/dist/services/document-service/transform/id-transform.mjs +33 -0
  435. package/dist/services/document-service/transform/id-transform.mjs.map +1 -0
  436. package/dist/services/document-service/transform/populate.d.ts +6 -0
  437. package/dist/services/document-service/transform/populate.d.ts.map +1 -0
  438. package/dist/services/document-service/transform/populate.js +21 -0
  439. package/dist/services/document-service/transform/populate.js.map +1 -0
  440. package/dist/services/document-service/transform/populate.mjs +21 -0
  441. package/dist/services/document-service/transform/populate.mjs.map +1 -0
  442. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +13 -0
  443. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -0
  444. package/dist/services/document-service/transform/relations/extract/data-ids.js +90 -0
  445. package/dist/services/document-service/transform/relations/extract/data-ids.js.map +1 -0
  446. package/dist/services/document-service/transform/relations/extract/data-ids.mjs +90 -0
  447. package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +1 -0
  448. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts +10 -0
  449. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts.map +1 -0
  450. package/dist/services/document-service/transform/relations/transform/data-ids.js +141 -0
  451. package/dist/services/document-service/transform/relations/transform/data-ids.js.map +1 -0
  452. package/dist/services/document-service/transform/relations/transform/data-ids.mjs +141 -0
  453. package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +1 -0
  454. package/dist/services/document-service/transform/relations/transform/output-ids.d.ts +2 -0
  455. package/dist/services/document-service/transform/relations/transform/output-ids.d.ts.map +1 -0
  456. package/dist/services/document-service/transform/relations/utils/data.d.ts +4 -0
  457. package/dist/services/document-service/transform/relations/utils/data.d.ts.map +1 -0
  458. package/dist/services/document-service/transform/relations/utils/data.js +12 -0
  459. package/dist/services/document-service/transform/relations/utils/data.js.map +1 -0
  460. package/dist/services/document-service/transform/relations/utils/data.mjs +12 -0
  461. package/dist/services/document-service/transform/relations/utils/data.mjs.map +1 -0
  462. package/dist/services/document-service/transform/relations/utils/dp.d.ts +10 -0
  463. package/dist/services/document-service/transform/relations/utils/dp.d.ts.map +1 -0
  464. package/dist/services/document-service/transform/relations/utils/dp.js +30 -0
  465. package/dist/services/document-service/transform/relations/utils/dp.js.map +1 -0
  466. package/dist/services/document-service/transform/relations/utils/dp.mjs +30 -0
  467. package/dist/services/document-service/transform/relations/utils/dp.mjs.map +1 -0
  468. package/dist/services/document-service/transform/relations/utils/i18n.d.ts +10 -0
  469. package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -0
  470. package/dist/services/document-service/transform/relations/utils/i18n.js +31 -0
  471. package/dist/services/document-service/transform/relations/utils/i18n.js.map +1 -0
  472. package/dist/services/document-service/transform/relations/utils/i18n.mjs +31 -0
  473. package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +1 -0
  474. package/dist/services/document-service/transform/relations/utils/types.d.ts +15 -0
  475. package/dist/services/document-service/transform/relations/utils/types.d.ts.map +1 -0
  476. package/dist/services/document-service/transform/types.d.ts +13 -0
  477. package/dist/services/document-service/transform/types.d.ts.map +1 -0
  478. package/dist/services/document-service/utils/populate.d.ts +10 -0
  479. package/dist/services/document-service/utils/populate.d.ts.map +1 -0
  480. package/dist/services/document-service/utils/populate.js +41 -0
  481. package/dist/services/document-service/utils/populate.js.map +1 -0
  482. package/dist/services/document-service/utils/populate.mjs +41 -0
  483. package/dist/services/document-service/utils/populate.mjs.map +1 -0
  484. package/dist/services/entity-service/attributes/index.d.ts +4 -4
  485. package/dist/services/entity-service/attributes/index.d.ts.map +1 -1
  486. package/dist/services/entity-service/attributes/index.js.map +1 -1
  487. package/dist/services/entity-service/attributes/index.mjs.map +1 -1
  488. package/dist/services/entity-service/attributes/transforms.d.ts +3 -3
  489. package/dist/services/entity-service/attributes/transforms.d.ts.map +1 -1
  490. package/dist/services/entity-service/attributes/transforms.js.map +1 -1
  491. package/dist/services/entity-service/attributes/transforms.mjs.map +1 -1
  492. package/dist/services/entity-service/components.d.ts +88 -16
  493. package/dist/services/entity-service/components.d.ts.map +1 -1
  494. package/dist/services/entity-service/components.js +13 -99
  495. package/dist/services/entity-service/components.js.map +1 -1
  496. package/dist/services/entity-service/components.mjs +14 -100
  497. package/dist/services/entity-service/components.mjs.map +1 -1
  498. package/dist/services/entity-service/index.d.ts +4 -6
  499. package/dist/services/entity-service/index.d.ts.map +1 -1
  500. package/dist/services/entity-service/index.js +34 -199
  501. package/dist/services/entity-service/index.js.map +1 -1
  502. package/dist/services/entity-service/index.mjs +27 -192
  503. package/dist/services/entity-service/index.mjs.map +1 -1
  504. package/dist/services/entity-service/params.d.ts +5 -5
  505. package/dist/services/entity-service/params.d.ts.map +1 -1
  506. package/dist/services/entity-service/params.js +1 -1
  507. package/dist/services/entity-service/params.js.map +1 -1
  508. package/dist/services/entity-service/params.mjs +1 -1
  509. package/dist/services/entity-service/params.mjs.map +1 -1
  510. package/dist/services/entity-validator/blocks-validator.d.ts.map +1 -1
  511. package/dist/services/entity-validator/blocks-validator.js +22 -2
  512. package/dist/services/entity-validator/blocks-validator.js.map +1 -1
  513. package/dist/services/entity-validator/blocks-validator.mjs +22 -2
  514. package/dist/services/entity-validator/blocks-validator.mjs.map +1 -1
  515. package/dist/services/entity-validator/index.d.ts +2 -2
  516. package/dist/services/entity-validator/index.d.ts.map +1 -1
  517. package/dist/services/entity-validator/index.js +12 -4
  518. package/dist/services/entity-validator/index.js.map +1 -1
  519. package/dist/services/entity-validator/index.mjs +12 -4
  520. package/dist/services/entity-validator/index.mjs.map +1 -1
  521. package/dist/services/entity-validator/validators.d.ts +19 -18
  522. package/dist/services/entity-validator/validators.d.ts.map +1 -1
  523. package/dist/services/entity-validator/validators.js +25 -16
  524. package/dist/services/entity-validator/validators.js.map +1 -1
  525. package/dist/services/entity-validator/validators.mjs +25 -16
  526. package/dist/services/entity-validator/validators.mjs.map +1 -1
  527. package/dist/services/features.d.ts +10 -0
  528. package/dist/services/features.d.ts.map +1 -0
  529. package/dist/services/features.js +17 -0
  530. package/dist/services/features.js.map +1 -0
  531. package/dist/services/features.mjs +17 -0
  532. package/dist/services/features.mjs.map +1 -0
  533. package/dist/services/fs.d.ts +2 -2
  534. package/dist/services/fs.d.ts.map +1 -1
  535. package/dist/services/fs.js.map +1 -1
  536. package/dist/services/fs.mjs.map +1 -1
  537. package/dist/services/metrics/admin-user-hash.d.ts +2 -2
  538. package/dist/services/metrics/admin-user-hash.d.ts.map +1 -1
  539. package/dist/services/metrics/admin-user-hash.js.map +1 -1
  540. package/dist/services/metrics/admin-user-hash.mjs.map +1 -1
  541. package/dist/services/metrics/index.d.ts +2 -2
  542. package/dist/services/metrics/index.d.ts.map +1 -1
  543. package/dist/services/metrics/index.js.map +1 -1
  544. package/dist/services/metrics/index.mjs.map +1 -1
  545. package/dist/services/metrics/middleware.d.ts +2 -2
  546. package/dist/services/metrics/middleware.d.ts.map +1 -1
  547. package/dist/services/metrics/middleware.js.map +1 -1
  548. package/dist/services/metrics/middleware.mjs.map +1 -1
  549. package/dist/services/metrics/sender.d.ts +3 -3
  550. package/dist/services/metrics/sender.d.ts.map +1 -1
  551. package/dist/services/metrics/sender.js.map +1 -1
  552. package/dist/services/metrics/sender.mjs.map +1 -1
  553. package/dist/services/server/admin-api.d.ts +3 -3
  554. package/dist/services/server/admin-api.d.ts.map +1 -1
  555. package/dist/services/server/admin-api.js.map +1 -1
  556. package/dist/services/server/admin-api.mjs.map +1 -1
  557. package/dist/services/server/api.d.ts +3 -3
  558. package/dist/services/server/api.d.ts.map +1 -1
  559. package/dist/services/server/api.js.map +1 -1
  560. package/dist/services/server/api.mjs.map +1 -1
  561. package/dist/services/server/compose-endpoint.d.ts +2 -2
  562. package/dist/services/server/compose-endpoint.d.ts.map +1 -1
  563. package/dist/services/server/compose-endpoint.js +3 -0
  564. package/dist/services/server/compose-endpoint.js.map +1 -1
  565. package/dist/services/server/compose-endpoint.mjs +3 -0
  566. package/dist/services/server/compose-endpoint.mjs.map +1 -1
  567. package/dist/services/server/content-api.d.ts +3 -3
  568. package/dist/services/server/content-api.d.ts.map +1 -1
  569. package/dist/services/server/content-api.js.map +1 -1
  570. package/dist/services/server/content-api.mjs.map +1 -1
  571. package/dist/services/server/http-server.d.ts +2 -2
  572. package/dist/services/server/http-server.d.ts.map +1 -1
  573. package/dist/services/server/http-server.js.map +1 -1
  574. package/dist/services/server/http-server.mjs.map +1 -1
  575. package/dist/services/server/index.d.ts +2 -2
  576. package/dist/services/server/index.d.ts.map +1 -1
  577. package/dist/services/server/index.js +1 -2
  578. package/dist/services/server/index.js.map +1 -1
  579. package/dist/services/server/index.mjs +1 -2
  580. package/dist/services/server/index.mjs.map +1 -1
  581. package/dist/services/server/middleware.d.ts +4 -8
  582. package/dist/services/server/middleware.d.ts.map +1 -1
  583. package/dist/services/server/middleware.js.map +1 -1
  584. package/dist/services/server/middleware.mjs.map +1 -1
  585. package/dist/services/server/policy.d.ts +2 -2
  586. package/dist/services/server/policy.d.ts.map +1 -1
  587. package/dist/services/server/policy.js.map +1 -1
  588. package/dist/services/server/policy.mjs.map +1 -1
  589. package/dist/services/server/register-middlewares.d.ts +2 -2
  590. package/dist/services/server/register-middlewares.d.ts.map +1 -1
  591. package/dist/services/server/register-middlewares.js +1 -1
  592. package/dist/services/server/register-middlewares.js.map +1 -1
  593. package/dist/services/server/register-middlewares.mjs +1 -1
  594. package/dist/services/server/register-middlewares.mjs.map +1 -1
  595. package/dist/services/server/register-routes.d.ts +2 -2
  596. package/dist/services/server/register-routes.d.ts.map +1 -1
  597. package/dist/services/server/register-routes.js.map +1 -1
  598. package/dist/services/server/register-routes.mjs.map +1 -1
  599. package/dist/services/server/routing.d.ts +4 -4
  600. package/dist/services/server/routing.d.ts.map +1 -1
  601. package/dist/services/server/routing.js.map +1 -1
  602. package/dist/services/server/routing.mjs.map +1 -1
  603. package/dist/services/utils/dynamic-zones.d.ts.map +1 -1
  604. package/dist/services/utils/dynamic-zones.js +2 -1
  605. package/dist/services/utils/dynamic-zones.js.map +1 -1
  606. package/dist/services/utils/dynamic-zones.mjs +2 -1
  607. package/dist/services/utils/dynamic-zones.mjs.map +1 -1
  608. package/dist/services/webhook-runner.d.ts +10 -1
  609. package/dist/services/webhook-runner.d.ts.map +1 -1
  610. package/dist/services/webhook-runner.js.map +1 -1
  611. package/dist/services/webhook-runner.mjs.map +1 -1
  612. package/dist/services/webhook-store.d.ts +2 -22
  613. package/dist/services/webhook-store.d.ts.map +1 -1
  614. package/dist/services/webhook-store.js +7 -3
  615. package/dist/services/webhook-store.js.map +1 -1
  616. package/dist/services/webhook-store.mjs +7 -3
  617. package/dist/services/webhook-store.mjs.map +1 -1
  618. package/dist/utils/convert-custom-field-type.d.ts +2 -3
  619. package/dist/utils/convert-custom-field-type.d.ts.map +1 -1
  620. package/dist/utils/convert-custom-field-type.js +2 -1
  621. package/dist/utils/convert-custom-field-type.js.map +1 -1
  622. package/dist/utils/convert-custom-field-type.mjs +1 -1
  623. package/dist/utils/convert-custom-field-type.mjs.map +1 -1
  624. package/dist/utils/ee.d.ts +1 -2
  625. package/dist/utils/ee.d.ts.map +1 -1
  626. package/dist/utils/fetch.d.ts +3 -2
  627. package/dist/utils/fetch.d.ts.map +1 -1
  628. package/dist/utils/fetch.js +2 -2
  629. package/dist/utils/fetch.js.map +1 -1
  630. package/dist/utils/fetch.mjs +2 -2
  631. package/dist/utils/fetch.mjs.map +1 -1
  632. package/dist/utils/filepath-to-prop-path.d.ts +5 -0
  633. package/dist/utils/filepath-to-prop-path.d.ts.map +1 -0
  634. package/dist/{load → utils}/filepath-to-prop-path.js +3 -2
  635. package/dist/utils/filepath-to-prop-path.js.map +1 -0
  636. package/dist/{load → utils}/filepath-to-prop-path.mjs +2 -2
  637. package/dist/utils/filepath-to-prop-path.mjs.map +1 -0
  638. package/dist/utils/get-dirs.d.ts +4 -5
  639. package/dist/utils/get-dirs.d.ts.map +1 -1
  640. package/dist/utils/get-dirs.js +2 -1
  641. package/dist/utils/get-dirs.js.map +1 -1
  642. package/dist/utils/get-dirs.mjs +1 -1
  643. package/dist/utils/get-dirs.mjs.map +1 -1
  644. package/dist/utils/index.d.ts +11 -4
  645. package/dist/utils/index.d.ts.map +1 -1
  646. package/dist/utils/is-initialized.d.ts +2 -2
  647. package/dist/utils/is-initialized.d.ts.map +1 -1
  648. package/dist/utils/is-initialized.js +5 -4
  649. package/dist/utils/is-initialized.js.map +1 -1
  650. package/dist/utils/is-initialized.mjs +4 -4
  651. package/dist/utils/is-initialized.mjs.map +1 -1
  652. package/dist/utils/load-config-file.d.ts +2 -0
  653. package/dist/utils/load-config-file.d.ts.map +1 -0
  654. package/dist/{core/app-configuration → utils}/load-config-file.js +3 -3
  655. package/dist/utils/load-config-file.js.map +1 -0
  656. package/dist/{core/app-configuration → utils}/load-config-file.mjs +4 -4
  657. package/dist/utils/load-config-file.mjs.map +1 -0
  658. package/dist/{load → utils}/load-files.d.ts +2 -2
  659. package/dist/utils/load-files.d.ts.map +1 -0
  660. package/dist/{load → utils}/load-files.js +7 -6
  661. package/dist/utils/load-files.js.map +1 -0
  662. package/dist/{load → utils}/load-files.mjs +7 -7
  663. package/dist/utils/load-files.mjs.map +1 -0
  664. package/dist/utils/open-browser.d.ts +2 -3
  665. package/dist/utils/open-browser.d.ts.map +1 -1
  666. package/dist/utils/open-browser.js +5 -5
  667. package/dist/utils/open-browser.js.map +1 -1
  668. package/dist/utils/open-browser.mjs +4 -5
  669. package/dist/utils/open-browser.mjs.map +1 -1
  670. package/dist/utils/signals.d.ts +2 -2
  671. package/dist/utils/signals.d.ts.map +1 -1
  672. package/dist/utils/signals.js.map +1 -1
  673. package/dist/utils/signals.mjs.map +1 -1
  674. package/dist/utils/startup-logger.d.ts +2 -3
  675. package/dist/utils/startup-logger.d.ts.map +1 -1
  676. package/dist/utils/startup-logger.js +19 -13
  677. package/dist/utils/startup-logger.js.map +1 -1
  678. package/dist/utils/startup-logger.mjs +18 -13
  679. package/dist/utils/startup-logger.mjs.map +1 -1
  680. package/dist/utils/transform-content-types-to-models.d.ts +129 -3
  681. package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
  682. package/dist/utils/transform-content-types-to-models.js +248 -15
  683. package/dist/utils/transform-content-types-to-models.js.map +1 -1
  684. package/dist/utils/transform-content-types-to-models.mjs +245 -15
  685. package/dist/utils/transform-content-types-to-models.mjs.map +1 -1
  686. package/dist/utils/update-notifier/index.d.ts +2 -3
  687. package/dist/utils/update-notifier/index.d.ts.map +1 -1
  688. package/dist/utils/update-notifier/index.js +8 -2
  689. package/dist/utils/update-notifier/index.js.map +1 -1
  690. package/dist/utils/update-notifier/index.mjs +7 -2
  691. package/dist/utils/update-notifier/index.mjs.map +1 -1
  692. package/package.json +18 -26
  693. package/bin/strapi.js +0 -2
  694. package/dist/admin.d.ts +0 -5
  695. package/dist/admin.d.ts.map +0 -1
  696. package/dist/cli.d.ts +0 -2
  697. package/dist/cli.d.ts.map +0 -1
  698. package/dist/commands/actions/admin/create-user/action.d.ts +0 -12
  699. package/dist/commands/actions/admin/create-user/action.d.ts.map +0 -1
  700. package/dist/commands/actions/admin/create-user/command.d.ts +0 -7
  701. package/dist/commands/actions/admin/create-user/command.d.ts.map +0 -1
  702. package/dist/commands/actions/admin/reset-user-password/action.d.ts +0 -10
  703. package/dist/commands/actions/admin/reset-user-password/action.d.ts.map +0 -1
  704. package/dist/commands/actions/admin/reset-user-password/command.d.ts +0 -7
  705. package/dist/commands/actions/admin/reset-user-password/command.d.ts.map +0 -1
  706. package/dist/commands/actions/components/list/action.d.ts +0 -3
  707. package/dist/commands/actions/components/list/action.d.ts.map +0 -1
  708. package/dist/commands/actions/components/list/command.d.ts +0 -7
  709. package/dist/commands/actions/components/list/command.d.ts.map +0 -1
  710. package/dist/commands/actions/configuration/dump/action.d.ts +0 -11
  711. package/dist/commands/actions/configuration/dump/action.d.ts.map +0 -1
  712. package/dist/commands/actions/configuration/dump/command.d.ts +0 -7
  713. package/dist/commands/actions/configuration/dump/command.d.ts.map +0 -1
  714. package/dist/commands/actions/configuration/restore/action.d.ts +0 -11
  715. package/dist/commands/actions/configuration/restore/action.d.ts.map +0 -1
  716. package/dist/commands/actions/configuration/restore/command.d.ts +0 -7
  717. package/dist/commands/actions/configuration/restore/command.d.ts.map +0 -1
  718. package/dist/commands/actions/console/action.d.ts +0 -6
  719. package/dist/commands/actions/console/action.d.ts.map +0 -1
  720. package/dist/commands/actions/console/command.d.ts +0 -7
  721. package/dist/commands/actions/console/command.d.ts.map +0 -1
  722. package/dist/commands/actions/content-types/list/action.d.ts +0 -3
  723. package/dist/commands/actions/content-types/list/action.d.ts.map +0 -1
  724. package/dist/commands/actions/content-types/list/command.d.ts +0 -7
  725. package/dist/commands/actions/content-types/list/command.d.ts.map +0 -1
  726. package/dist/commands/actions/controllers/list/action.d.ts +0 -3
  727. package/dist/commands/actions/controllers/list/action.d.ts.map +0 -1
  728. package/dist/commands/actions/controllers/list/command.d.ts +0 -7
  729. package/dist/commands/actions/controllers/list/command.d.ts.map +0 -1
  730. package/dist/commands/actions/generate/command.d.ts +0 -7
  731. package/dist/commands/actions/generate/command.d.ts.map +0 -1
  732. package/dist/commands/actions/hooks/list/action.d.ts +0 -3
  733. package/dist/commands/actions/hooks/list/action.d.ts.map +0 -1
  734. package/dist/commands/actions/hooks/list/command.d.ts +0 -7
  735. package/dist/commands/actions/hooks/list/command.d.ts.map +0 -1
  736. package/dist/commands/actions/install/action.d.ts +0 -3
  737. package/dist/commands/actions/install/action.d.ts.map +0 -1
  738. package/dist/commands/actions/install/command.d.ts +0 -7
  739. package/dist/commands/actions/install/command.d.ts.map +0 -1
  740. package/dist/commands/actions/middlewares/list/action.d.ts +0 -3
  741. package/dist/commands/actions/middlewares/list/action.d.ts.map +0 -1
  742. package/dist/commands/actions/middlewares/list/command.d.ts +0 -7
  743. package/dist/commands/actions/middlewares/list/command.d.ts.map +0 -1
  744. package/dist/commands/actions/new/action.d.ts +0 -8
  745. package/dist/commands/actions/new/action.d.ts.map +0 -1
  746. package/dist/commands/actions/new/command.d.ts +0 -7
  747. package/dist/commands/actions/new/command.d.ts.map +0 -1
  748. package/dist/commands/actions/plugin/build-command/action.d.ts +0 -7
  749. package/dist/commands/actions/plugin/build-command/action.d.ts.map +0 -1
  750. package/dist/commands/actions/plugin/build-command/command.d.ts +0 -7
  751. package/dist/commands/actions/plugin/build-command/command.d.ts.map +0 -1
  752. package/dist/commands/actions/plugin/watch/action.d.ts +0 -7
  753. package/dist/commands/actions/plugin/watch/action.d.ts.map +0 -1
  754. package/dist/commands/actions/plugin/watch/command.d.ts +0 -7
  755. package/dist/commands/actions/plugin/watch/command.d.ts.map +0 -1
  756. package/dist/commands/actions/policies/list/action.d.ts +0 -3
  757. package/dist/commands/actions/policies/list/action.d.ts.map +0 -1
  758. package/dist/commands/actions/policies/list/command.d.ts +0 -7
  759. package/dist/commands/actions/policies/list/command.d.ts.map +0 -1
  760. package/dist/commands/actions/report/action.d.ts +0 -8
  761. package/dist/commands/actions/report/action.d.ts.map +0 -1
  762. package/dist/commands/actions/report/command.d.ts +0 -7
  763. package/dist/commands/actions/report/command.d.ts.map +0 -1
  764. package/dist/commands/actions/routes/list/action.d.ts +0 -3
  765. package/dist/commands/actions/routes/list/action.d.ts.map +0 -1
  766. package/dist/commands/actions/routes/list/command.d.ts +0 -7
  767. package/dist/commands/actions/routes/list/command.d.ts.map +0 -1
  768. package/dist/commands/actions/services/list/action.d.ts +0 -3
  769. package/dist/commands/actions/services/list/action.d.ts.map +0 -1
  770. package/dist/commands/actions/services/list/command.d.ts +0 -7
  771. package/dist/commands/actions/services/list/command.d.ts.map +0 -1
  772. package/dist/commands/actions/start/action.d.ts +0 -6
  773. package/dist/commands/actions/start/action.d.ts.map +0 -1
  774. package/dist/commands/actions/start/command.d.ts +0 -7
  775. package/dist/commands/actions/start/command.d.ts.map +0 -1
  776. package/dist/commands/actions/telemetry/disable/action.d.ts +0 -2
  777. package/dist/commands/actions/telemetry/disable/action.d.ts.map +0 -1
  778. package/dist/commands/actions/telemetry/disable/command.d.ts +0 -7
  779. package/dist/commands/actions/telemetry/disable/command.d.ts.map +0 -1
  780. package/dist/commands/actions/telemetry/enable/action.d.ts +0 -3
  781. package/dist/commands/actions/telemetry/enable/action.d.ts.map +0 -1
  782. package/dist/commands/actions/telemetry/enable/command.d.ts +0 -7
  783. package/dist/commands/actions/telemetry/enable/command.d.ts.map +0 -1
  784. package/dist/commands/actions/templates/generate/action.d.ts +0 -2
  785. package/dist/commands/actions/templates/generate/action.d.ts.map +0 -1
  786. package/dist/commands/actions/templates/generate/command.d.ts +0 -7
  787. package/dist/commands/actions/templates/generate/command.d.ts.map +0 -1
  788. package/dist/commands/actions/ts/generate-types/action.d.ts +0 -9
  789. package/dist/commands/actions/ts/generate-types/action.d.ts.map +0 -1
  790. package/dist/commands/actions/ts/generate-types/command.d.ts +0 -7
  791. package/dist/commands/actions/ts/generate-types/command.d.ts.map +0 -1
  792. package/dist/commands/actions/uninstall/action.d.ts +0 -6
  793. package/dist/commands/actions/uninstall/action.d.ts.map +0 -1
  794. package/dist/commands/actions/uninstall/command.d.ts +0 -7
  795. package/dist/commands/actions/uninstall/command.d.ts.map +0 -1
  796. package/dist/commands/actions/version/command.d.ts +0 -7
  797. package/dist/commands/actions/version/command.d.ts.map +0 -1
  798. package/dist/commands/actions/watch-admin/action.d.ts +0 -7
  799. package/dist/commands/actions/watch-admin/action.d.ts.map +0 -1
  800. package/dist/commands/actions/watch-admin/command.d.ts +0 -7
  801. package/dist/commands/actions/watch-admin/command.d.ts.map +0 -1
  802. package/dist/commands/index.d.ts +0 -37
  803. package/dist/commands/index.d.ts.map +0 -1
  804. package/dist/commands/types.d.ts +0 -14
  805. package/dist/commands/types.d.ts.map +0 -1
  806. package/dist/commands/utils/commander.d.ts +0 -36
  807. package/dist/commands/utils/commander.d.ts.map +0 -1
  808. package/dist/commands/utils/helpers.d.ts +0 -49
  809. package/dist/commands/utils/helpers.d.ts.map +0 -1
  810. package/dist/commands/utils/logger.d.ts +0 -19
  811. package/dist/commands/utils/logger.d.ts.map +0 -1
  812. package/dist/commands/utils/pkg.d.ts +0 -119
  813. package/dist/commands/utils/pkg.d.ts.map +0 -1
  814. package/dist/commands/utils/tsconfig.d.ts +0 -19
  815. package/dist/commands/utils/tsconfig.d.ts.map +0 -1
  816. package/dist/core/app-configuration/config-loader.d.ts.map +0 -1
  817. package/dist/core/app-configuration/config-loader.js +0 -19
  818. package/dist/core/app-configuration/config-loader.js.map +0 -1
  819. package/dist/core/app-configuration/config-loader.mjs +0 -17
  820. package/dist/core/app-configuration/config-loader.mjs.map +0 -1
  821. package/dist/core/app-configuration/index.d.ts.map +0 -1
  822. package/dist/core/app-configuration/index.js.map +0 -1
  823. package/dist/core/app-configuration/index.mjs.map +0 -1
  824. package/dist/core/app-configuration/load-config-file.d.ts +0 -2
  825. package/dist/core/app-configuration/load-config-file.d.ts.map +0 -1
  826. package/dist/core/app-configuration/load-config-file.js.map +0 -1
  827. package/dist/core/app-configuration/load-config-file.mjs.map +0 -1
  828. package/dist/core/bootstrap.d.ts +0 -5
  829. package/dist/core/bootstrap.d.ts.map +0 -1
  830. package/dist/core/bootstrap.js +0 -28
  831. package/dist/core/bootstrap.js.map +0 -1
  832. package/dist/core/bootstrap.mjs +0 -27
  833. package/dist/core/bootstrap.mjs.map +0 -1
  834. package/dist/core/domain/content-type/index.d.ts.map +0 -1
  835. package/dist/core/domain/content-type/index.js.map +0 -1
  836. package/dist/core/domain/content-type/index.mjs.map +0 -1
  837. package/dist/core/domain/content-type/validator.d.ts.map +0 -1
  838. package/dist/core/domain/content-type/validator.js.map +0 -1
  839. package/dist/core/domain/content-type/validator.mjs.map +0 -1
  840. package/dist/core/domain/module/index.d.ts +0 -39
  841. package/dist/core/domain/module/index.d.ts.map +0 -1
  842. package/dist/core/domain/module/index.js.map +0 -1
  843. package/dist/core/domain/module/index.mjs.map +0 -1
  844. package/dist/core/domain/module/validation.d.ts.map +0 -1
  845. package/dist/core/domain/module/validation.js.map +0 -1
  846. package/dist/core/domain/module/validation.mjs.map +0 -1
  847. package/dist/core/loaders/admin.d.ts +0 -3
  848. package/dist/core/loaders/admin.d.ts.map +0 -1
  849. package/dist/core/loaders/admin.js.map +0 -1
  850. package/dist/core/loaders/admin.mjs.map +0 -1
  851. package/dist/core/loaders/apis.d.ts +0 -3
  852. package/dist/core/loaders/apis.d.ts.map +0 -1
  853. package/dist/core/loaders/apis.js.map +0 -1
  854. package/dist/core/loaders/apis.mjs.map +0 -1
  855. package/dist/core/loaders/components.d.ts +0 -3
  856. package/dist/core/loaders/components.d.ts.map +0 -1
  857. package/dist/core/loaders/components.js.map +0 -1
  858. package/dist/core/loaders/components.mjs.map +0 -1
  859. package/dist/core/loaders/index.d.ts +0 -3
  860. package/dist/core/loaders/index.d.ts.map +0 -1
  861. package/dist/core/loaders/index.js.map +0 -1
  862. package/dist/core/loaders/index.mjs.map +0 -1
  863. package/dist/core/loaders/middlewares.d.ts +0 -3
  864. package/dist/core/loaders/middlewares.d.ts.map +0 -1
  865. package/dist/core/loaders/middlewares.js.map +0 -1
  866. package/dist/core/loaders/middlewares.mjs.map +0 -1
  867. package/dist/core/loaders/plugins/get-enabled-plugins.d.ts +0 -5
  868. package/dist/core/loaders/plugins/get-enabled-plugins.d.ts.map +0 -1
  869. package/dist/core/loaders/plugins/get-enabled-plugins.js.map +0 -1
  870. package/dist/core/loaders/plugins/get-enabled-plugins.mjs.map +0 -1
  871. package/dist/core/loaders/plugins/get-user-plugins-config.d.ts.map +0 -1
  872. package/dist/core/loaders/plugins/get-user-plugins-config.js.map +0 -1
  873. package/dist/core/loaders/plugins/get-user-plugins-config.mjs.map +0 -1
  874. package/dist/core/loaders/plugins/index.d.ts +0 -3
  875. package/dist/core/loaders/plugins/index.d.ts.map +0 -1
  876. package/dist/core/loaders/plugins/index.js.map +0 -1
  877. package/dist/core/loaders/plugins/index.mjs.map +0 -1
  878. package/dist/core/loaders/policies.d.ts +0 -3
  879. package/dist/core/loaders/policies.d.ts.map +0 -1
  880. package/dist/core/loaders/policies.js.map +0 -1
  881. package/dist/core/loaders/policies.mjs.map +0 -1
  882. package/dist/core/loaders/sanitizers.d.ts +0 -4
  883. package/dist/core/loaders/sanitizers.d.ts.map +0 -1
  884. package/dist/core/loaders/sanitizers.js.map +0 -1
  885. package/dist/core/loaders/sanitizers.mjs.map +0 -1
  886. package/dist/core/loaders/src-index.d.ts +0 -4
  887. package/dist/core/loaders/src-index.d.ts.map +0 -1
  888. package/dist/core/loaders/src-index.js.map +0 -1
  889. package/dist/core/loaders/src-index.mjs.map +0 -1
  890. package/dist/core/loaders/validators.d.ts +0 -4
  891. package/dist/core/loaders/validators.d.ts.map +0 -1
  892. package/dist/core/loaders/validators.js.map +0 -1
  893. package/dist/core/loaders/validators.mjs.map +0 -1
  894. package/dist/core/registries/apis.d.ts.map +0 -1
  895. package/dist/core/registries/apis.js.map +0 -1
  896. package/dist/core/registries/apis.mjs.map +0 -1
  897. package/dist/core/registries/components.d.ts.map +0 -1
  898. package/dist/core/registries/components.js.map +0 -1
  899. package/dist/core/registries/components.mjs.map +0 -1
  900. package/dist/core/registries/config.d.ts +0 -4
  901. package/dist/core/registries/config.d.ts.map +0 -1
  902. package/dist/core/registries/config.js +0 -23
  903. package/dist/core/registries/config.js.map +0 -1
  904. package/dist/core/registries/config.mjs +0 -22
  905. package/dist/core/registries/config.mjs.map +0 -1
  906. package/dist/core/registries/content-types.d.ts.map +0 -1
  907. package/dist/core/registries/content-types.js.map +0 -1
  908. package/dist/core/registries/content-types.mjs.map +0 -1
  909. package/dist/core/registries/controllers.d.ts +0 -35
  910. package/dist/core/registries/controllers.d.ts.map +0 -1
  911. package/dist/core/registries/controllers.js.map +0 -1
  912. package/dist/core/registries/controllers.mjs.map +0 -1
  913. package/dist/core/registries/custom-fields.d.ts +0 -8
  914. package/dist/core/registries/custom-fields.d.ts.map +0 -1
  915. package/dist/core/registries/custom-fields.js.map +0 -1
  916. package/dist/core/registries/custom-fields.mjs.map +0 -1
  917. package/dist/core/registries/hooks.d.ts.map +0 -1
  918. package/dist/core/registries/hooks.js.map +0 -1
  919. package/dist/core/registries/hooks.mjs.map +0 -1
  920. package/dist/core/registries/index.d.ts.map +0 -1
  921. package/dist/core/registries/middlewares.d.ts.map +0 -1
  922. package/dist/core/registries/middlewares.js.map +0 -1
  923. package/dist/core/registries/middlewares.mjs.map +0 -1
  924. package/dist/core/registries/modules.d.ts.map +0 -1
  925. package/dist/core/registries/modules.js.map +0 -1
  926. package/dist/core/registries/modules.mjs.map +0 -1
  927. package/dist/core/registries/plugins.d.ts +0 -9
  928. package/dist/core/registries/plugins.d.ts.map +0 -1
  929. package/dist/core/registries/plugins.js.map +0 -1
  930. package/dist/core/registries/plugins.mjs.map +0 -1
  931. package/dist/core/registries/policies.d.ts.map +0 -1
  932. package/dist/core/registries/policies.js.map +0 -1
  933. package/dist/core/registries/policies.mjs.map +0 -1
  934. package/dist/core/registries/sanitizers.d.ts.map +0 -1
  935. package/dist/core/registries/sanitizers.js.map +0 -1
  936. package/dist/core/registries/sanitizers.mjs.map +0 -1
  937. package/dist/core/registries/services.d.ts.map +0 -1
  938. package/dist/core/registries/services.js.map +0 -1
  939. package/dist/core/registries/services.mjs.map +0 -1
  940. package/dist/core/registries/validators.d.ts.map +0 -1
  941. package/dist/core/registries/validators.js.map +0 -1
  942. package/dist/core/registries/validators.mjs.map +0 -1
  943. package/dist/core/utils.d.ts.map +0 -1
  944. package/dist/core/utils.js.map +0 -1
  945. package/dist/core/utils.mjs.map +0 -1
  946. package/dist/core-api/service/get-fetch-params.d.ts +0 -7
  947. package/dist/core-api/service/get-fetch-params.d.ts.map +0 -1
  948. package/dist/core-api/service/get-fetch-params.js +0 -14
  949. package/dist/core-api/service/get-fetch-params.js.map +0 -1
  950. package/dist/core-api/service/get-fetch-params.mjs +0 -14
  951. package/dist/core-api/service/get-fetch-params.mjs.map +0 -1
  952. package/dist/load/filepath-to-prop-path.d.ts +0 -6
  953. package/dist/load/filepath-to-prop-path.d.ts.map +0 -1
  954. package/dist/load/filepath-to-prop-path.js.map +0 -1
  955. package/dist/load/filepath-to-prop-path.mjs.map +0 -1
  956. package/dist/load/glob.d.ts +0 -7
  957. package/dist/load/glob.d.ts.map +0 -1
  958. package/dist/load/glob.js +0 -15
  959. package/dist/load/glob.js.map +0 -1
  960. package/dist/load/glob.mjs +0 -14
  961. package/dist/load/glob.mjs.map +0 -1
  962. package/dist/load/index.d.ts +0 -3
  963. package/dist/load/index.d.ts.map +0 -1
  964. package/dist/load/load-files.d.ts.map +0 -1
  965. package/dist/load/load-files.js.map +0 -1
  966. package/dist/load/load-files.mjs.map +0 -1
  967. package/dist/load/package-path.d.ts +0 -6
  968. package/dist/load/package-path.d.ts.map +0 -1
  969. package/dist/middlewares/public/assets/images/group_people_1.png +0 -0
  970. package/dist/middlewares/public/assets/images/group_people_2.png +0 -0
  971. package/dist/middlewares/public/assets/images/group_people_3.png +0 -0
  972. package/dist/middlewares/public/assets/images/logo_login.png +0 -0
  973. package/dist/middlewares/public/index.d.ts +0 -3
  974. package/dist/middlewares/public/index.d.ts.map +0 -1
  975. package/dist/middlewares/public/index.html +0 -66
  976. package/dist/middlewares/public/index.js +0 -91
  977. package/dist/middlewares/public/index.js.map +0 -1
  978. package/dist/middlewares/public/index.mjs +0 -85
  979. package/dist/middlewares/public/index.mjs.map +0 -1
  980. package/dist/middlewares/public/serve-static.d.ts +0 -4
  981. package/dist/middlewares/public/serve-static.d.ts.map +0 -1
  982. package/dist/middlewares/public/serve-static.js +0 -24
  983. package/dist/middlewares/public/serve-static.js.map +0 -1
  984. package/dist/middlewares/public/serve-static.mjs +0 -21
  985. package/dist/middlewares/public/serve-static.mjs.map +0 -1
  986. package/dist/services/document-service/document-repository.d.ts +0 -21
  987. package/dist/services/document-service/document-repository.d.ts.map +0 -1
  988. package/dist/services/document-service/document-repository.js +0 -132
  989. package/dist/services/document-service/document-repository.js.map +0 -1
  990. package/dist/services/document-service/document-repository.mjs +0 -132
  991. package/dist/services/document-service/document-repository.mjs.map +0 -1
  992. package/dist/services/document-service/middlewares/defaults/draft-and-publish.d.ts +0 -26
  993. package/dist/services/document-service/middlewares/defaults/draft-and-publish.d.ts.map +0 -1
  994. package/dist/services/document-service/middlewares/defaults/draft-and-publish.js +0 -58
  995. package/dist/services/document-service/middlewares/defaults/draft-and-publish.js.map +0 -1
  996. package/dist/services/document-service/middlewares/defaults/draft-and-publish.mjs +0 -58
  997. package/dist/services/document-service/middlewares/defaults/draft-and-publish.mjs.map +0 -1
  998. package/dist/services/document-service/middlewares/defaults/index.d.ts +0 -3
  999. package/dist/services/document-service/middlewares/defaults/index.d.ts.map +0 -1
  1000. package/dist/services/document-service/middlewares/defaults/index.js +0 -82
  1001. package/dist/services/document-service/middlewares/defaults/index.js.map +0 -1
  1002. package/dist/services/document-service/middlewares/defaults/index.mjs +0 -82
  1003. package/dist/services/document-service/middlewares/defaults/index.mjs.map +0 -1
  1004. package/dist/services/document-service/middlewares/defaults/locales.d.ts +0 -18
  1005. package/dist/services/document-service/middlewares/defaults/locales.d.ts.map +0 -1
  1006. package/dist/services/document-service/middlewares/defaults/locales.js +0 -40
  1007. package/dist/services/document-service/middlewares/defaults/locales.js.map +0 -1
  1008. package/dist/services/document-service/middlewares/defaults/locales.mjs +0 -40
  1009. package/dist/services/document-service/middlewares/defaults/locales.mjs.map +0 -1
  1010. package/dist/services/document-service/middlewares/index.js +0 -59
  1011. package/dist/services/document-service/middlewares/index.js.map +0 -1
  1012. package/dist/services/document-service/middlewares/index.mjs +0 -59
  1013. package/dist/services/document-service/middlewares/index.mjs.map +0 -1
  1014. package/dist/services/utils/upload-files.d.ts +0 -8
  1015. package/dist/services/utils/upload-files.d.ts.map +0 -1
  1016. package/dist/services/utils/upload-files.js +0 -64
  1017. package/dist/services/utils/upload-files.js.map +0 -1
  1018. package/dist/services/utils/upload-files.mjs +0 -63
  1019. package/dist/services/utils/upload-files.mjs.map +0 -1
  1020. package/dist/utils/addSlash.d.ts +0 -3
  1021. package/dist/utils/addSlash.d.ts.map +0 -1
  1022. package/dist/utils/ee.js +0 -4
  1023. package/dist/utils/ee.js.map +0 -1
  1024. package/dist/utils/ee.mjs +0 -5
  1025. package/dist/utils/ee.mjs.map +0 -1
  1026. /package/dist/{core/app-configuration → configuration}/config-loader.d.ts +0 -0
  1027. /package/dist/{core/domain → domain}/content-type/validator.d.ts +0 -0
  1028. /package/dist/{core/domain → domain}/module/validation.d.ts +0 -0
  1029. /package/dist/{core/domain → domain}/module/validation.js +0 -0
  1030. /package/dist/{core/domain → domain}/module/validation.mjs +0 -0
  1031. /package/dist/{core/loaders → loaders}/index.js +0 -0
  1032. /package/dist/{core/loaders → loaders}/index.mjs +0 -0
  1033. /package/dist/{core/loaders → loaders}/plugins/get-user-plugins-config.d.ts +0 -0
  1034. /package/dist/{core/loaders → loaders}/policies.js +0 -0
  1035. /package/dist/{core/loaders → loaders}/policies.mjs +0 -0
  1036. /package/dist/{core/loaders → loaders}/sanitizers.js +0 -0
  1037. /package/dist/{core/loaders → loaders}/sanitizers.mjs +0 -0
  1038. /package/dist/{core/loaders → loaders}/src-index.js +0 -0
  1039. /package/dist/{core/loaders → loaders}/src-index.mjs +0 -0
  1040. /package/dist/{core/loaders → loaders}/validators.js +0 -0
  1041. /package/dist/{core/loaders → loaders}/validators.mjs +0 -0
  1042. /package/dist/{core/registries → registries}/apis.js +0 -0
  1043. /package/dist/{core/registries → registries}/apis.mjs +0 -0
  1044. /package/dist/{core/registries → registries}/components.js +0 -0
  1045. /package/dist/{core/registries → registries}/components.mjs +0 -0
  1046. /package/dist/{core/registries → registries}/custom-fields.js +0 -0
  1047. /package/dist/{core/registries → registries}/custom-fields.mjs +0 -0
  1048. /package/dist/{core/registries → registries}/hooks.d.ts +0 -0
  1049. /package/dist/{core/registries → registries}/modules.js +0 -0
  1050. /package/dist/{core/registries → registries}/modules.mjs +0 -0
  1051. /package/dist/{core/registries → registries}/plugins.js +0 -0
  1052. /package/dist/{core/registries → registries}/plugins.mjs +0 -0
  1053. /package/dist/{core/registries → registries}/sanitizers.d.ts +0 -0
  1054. /package/dist/{core/registries → registries}/sanitizers.js +0 -0
  1055. /package/dist/{core/registries → registries}/sanitizers.mjs +0 -0
  1056. /package/dist/{core/registries → registries}/validators.d.ts +0 -0
  1057. /package/dist/{core/registries → registries}/validators.js +0 -0
  1058. /package/dist/{core/registries → registries}/validators.mjs +0 -0
@@ -1 +1 @@
1
- {"version":3,"file":"pagination.mjs","sources":["../../../src/core-api/service/pagination.ts"],"sourcesContent":["import { has, toNumber, isUndefined } from 'lodash/fp';\nimport { errors } from '@strapi/utils';\n\ninterface BasePaginationParams {\n withCount?: boolean | 't' | '1' | 'true' | 'f' | '0' | 'false' | 0 | 1;\n}\n\ntype PagedPagination = BasePaginationParams & {\n page?: number;\n pageSize?: number;\n};\n\ntype OffsetPagination = BasePaginationParams & {\n start?: number;\n limit?: number;\n};\n\nexport type PaginationParams = PagedPagination | OffsetPagination;\n\ntype PaginationInfo =\n | {\n page: number;\n pageSize: number;\n }\n | {\n start: number;\n limit: number;\n };\n\n/**\n * Default limit values from config\n */\nconst getLimitConfigDefaults = () => ({\n defaultLimit: toNumber(strapi.config.get('api.rest.defaultLimit', 25)),\n maxLimit: toNumber(strapi.config.get('api.rest.maxLimit')) || null,\n});\n\n/**\n * Should maxLimit be used as the limit or not\n */\nconst shouldApplyMaxLimit = (\n limit: number,\n maxLimit: number | null,\n { isPagedPagination = false } = {}\n) => (!isPagedPagination && limit === -1) || (maxLimit !== null && limit > maxLimit);\n\nconst shouldCount = (params: { pagination?: PaginationParams }) => {\n if (has('pagination.withCount', params)) {\n const withCount = params.pagination?.withCount;\n\n if (typeof withCount === 'boolean') {\n return withCount;\n }\n\n if (typeof withCount === 'undefined') {\n return false;\n }\n\n if (['true', 't', '1', 1].includes(withCount)) {\n return true;\n }\n\n if (['false', 'f', '0', 0].includes(withCount)) {\n return false;\n }\n\n throw new errors.ValidationError(\n 'Invalid withCount parameter. Expected \"t\",\"1\",\"true\",\"false\",\"0\",\"f\"'\n );\n }\n\n return Boolean(strapi.config.get('api.rest.withCount', true));\n};\n\nconst isOffsetPagination = (pagination?: PaginationParams): pagination is OffsetPagination =>\n has('start', pagination) || has('limit', pagination);\nconst isPagedPagination = (pagination?: PaginationParams): pagination is PagedPagination =>\n has('page', pagination) || has('pageSize', pagination);\n\nconst getPaginationInfo = (params: { pagination?: PaginationParams }): PaginationInfo => {\n const { defaultLimit, maxLimit } = getLimitConfigDefaults();\n\n const { pagination } = params;\n\n const isPaged = isPagedPagination(pagination);\n const isOffset = isOffsetPagination(pagination);\n\n if (isOffset && isPaged) {\n throw new errors.ValidationError(\n 'Invalid pagination parameters. Expected either start/limit or page/pageSize'\n );\n }\n\n if (!isOffset && !isPaged) {\n return {\n page: 1,\n pageSize: defaultLimit,\n };\n }\n\n if (isPagedPagination(pagination)) {\n const pageSize = isUndefined(pagination.pageSize)\n ? defaultLimit\n : Math.max(1, toNumber(pagination.pageSize));\n\n return {\n page: Math.max(1, toNumber(pagination.page || 1)),\n pageSize:\n typeof maxLimit === 'number' &&\n shouldApplyMaxLimit(pageSize, maxLimit, { isPagedPagination: true })\n ? maxLimit\n : Math.max(1, pageSize),\n };\n }\n\n const limit = isUndefined(pagination.limit) ? defaultLimit : toNumber(pagination.limit);\n\n return {\n start: Math.max(0, toNumber(pagination.start || 0)),\n limit: shouldApplyMaxLimit(limit, maxLimit) ? maxLimit || -1 : Math.max(1, limit),\n };\n};\n\nconst convertPagedToStartLimit = (paginationInfo: PaginationInfo) => {\n if ('page' in paginationInfo) {\n const { page, pageSize } = paginationInfo;\n return {\n start: (page - 1) * pageSize,\n limit: pageSize,\n };\n }\n\n return paginationInfo;\n};\n\nconst transformPaginationResponse = (paginationInfo: PaginationInfo, count: number) => {\n if ('page' in paginationInfo) {\n return {\n ...paginationInfo,\n pageCount: Math.ceil(count / paginationInfo.pageSize),\n total: count,\n };\n }\n\n return {\n ...paginationInfo,\n total: count,\n };\n};\n\nexport { getPaginationInfo, convertPagedToStartLimit, transformPaginationResponse, shouldCount };\n"],"names":["isPagedPagination"],"mappings":";;AAgCA,MAAM,yBAAyB,OAAO;AAAA,EACpC,cAAc,SAAS,OAAO,OAAO,IAAI,yBAAyB,EAAE,CAAC;AAAA,EACrE,UAAU,SAAS,OAAO,OAAO,IAAI,mBAAmB,CAAC,KAAK;AAChE;AAKA,MAAM,sBAAsB,CAC1B,OACA,UACA,EAAE,mBAAAA,qBAAoB,UAAU,CAAA,MAC5B,CAACA,sBAAqB,UAAU,MAAQ,aAAa,QAAQ,QAAQ;AAErE,MAAA,cAAc,CAAC,WAA8C;AAC7D,MAAA,IAAI,wBAAwB,MAAM,GAAG;AACjC,UAAA,YAAY,OAAO,YAAY;AAEjC,QAAA,OAAO,cAAc,WAAW;AAC3B,aAAA;AAAA,IACT;AAEI,QAAA,OAAO,cAAc,aAAa;AAC7B,aAAA;AAAA,IACT;AAEI,QAAA,CAAC,QAAQ,KAAK,KAAK,CAAC,EAAE,SAAS,SAAS,GAAG;AACtC,aAAA;AAAA,IACT;AAEI,QAAA,CAAC,SAAS,KAAK,KAAK,CAAC,EAAE,SAAS,SAAS,GAAG;AACvC,aAAA;AAAA,IACT;AAEA,UAAM,IAAI,OAAO;AAAA,MACf;AAAA,IAAA;AAAA,EAEJ;AAEA,SAAO,QAAQ,OAAO,OAAO,IAAI,sBAAsB,IAAI,CAAC;AAC9D;AAEA,MAAM,qBAAqB,CAAC,eAC1B,IAAI,SAAS,UAAU,KAAK,IAAI,SAAS,UAAU;AACrD,MAAM,oBAAoB,CAAC,eACzB,IAAI,QAAQ,UAAU,KAAK,IAAI,YAAY,UAAU;AAEjD,MAAA,oBAAoB,CAAC,WAA8D;AACvF,QAAM,EAAE,cAAc,SAAS,IAAI,uBAAuB;AAEpD,QAAA,EAAE,WAAe,IAAA;AAEjB,QAAA,UAAU,kBAAkB,UAAU;AACtC,QAAA,WAAW,mBAAmB,UAAU;AAE9C,MAAI,YAAY,SAAS;AACvB,UAAM,IAAI,OAAO;AAAA,MACf;AAAA,IAAA;AAAA,EAEJ;AAEI,MAAA,CAAC,YAAY,CAAC,SAAS;AAClB,WAAA;AAAA,MACL,MAAM;AAAA,MACN,UAAU;AAAA,IAAA;AAAA,EAEd;AAEI,MAAA,kBAAkB,UAAU,GAAG;AACjC,UAAM,WAAW,YAAY,WAAW,QAAQ,IAC5C,eACA,KAAK,IAAI,GAAG,SAAS,WAAW,QAAQ,CAAC;AAEtC,WAAA;AAAA,MACL,MAAM,KAAK,IAAI,GAAG,SAAS,WAAW,QAAQ,CAAC,CAAC;AAAA,MAChD,UACE,OAAO,aAAa,YACpB,oBAAoB,UAAU,UAAU,EAAE,mBAAmB,KAAA,CAAM,IAC/D,WACA,KAAK,IAAI,GAAG,QAAQ;AAAA,IAAA;AAAA,EAE9B;AAEM,QAAA,QAAQ,YAAY,WAAW,KAAK,IAAI,eAAe,SAAS,WAAW,KAAK;AAE/E,SAAA;AAAA,IACL,OAAO,KAAK,IAAI,GAAG,SAAS,WAAW,SAAS,CAAC,CAAC;AAAA,IAClD,OAAO,oBAAoB,OAAO,QAAQ,IAAI,YAAY,KAAK,KAAK,IAAI,GAAG,KAAK;AAAA,EAAA;AAEpF;AAEM,MAAA,2BAA2B,CAAC,mBAAmC;AACnE,MAAI,UAAU,gBAAgB;AACtB,UAAA,EAAE,MAAM,SAAa,IAAA;AACpB,WAAA;AAAA,MACL,QAAQ,OAAO,KAAK;AAAA,MACpB,OAAO;AAAA,IAAA;AAAA,EAEX;AAEO,SAAA;AACT;AAEM,MAAA,8BAA8B,CAAC,gBAAgC,UAAkB;AACrF,MAAI,UAAU,gBAAgB;AACrB,WAAA;AAAA,MACL,GAAG;AAAA,MACH,WAAW,KAAK,KAAK,QAAQ,eAAe,QAAQ;AAAA,MACpD,OAAO;AAAA,IAAA;AAAA,EAEX;AAEO,SAAA;AAAA,IACL,GAAG;AAAA,IACH,OAAO;AAAA,EAAA;AAEX;"}
1
+ {"version":3,"file":"pagination.mjs","sources":["../../../src/core-api/service/pagination.ts"],"sourcesContent":["import { has, toNumber, isUndefined } from 'lodash/fp';\nimport { errors } from '@strapi/utils';\n\ninterface BasePaginationParams {\n withCount?: boolean | 't' | '1' | 'true' | 'f' | '0' | 'false' | 0 | 1;\n}\n\ntype PagedPagination = BasePaginationParams & {\n page?: number;\n pageSize?: number;\n};\n\ntype OffsetPagination = BasePaginationParams & {\n start?: number;\n limit?: number;\n};\n\nexport type PaginationParams = PagedPagination | OffsetPagination;\n\ntype PaginationInfo =\n | {\n page: number;\n pageSize: number;\n }\n | {\n start: number;\n limit: number;\n };\n\n/**\n * Default limit values from config\n */\nconst getLimitConfigDefaults = () => ({\n defaultLimit: toNumber(strapi.config.get('api.rest.defaultLimit', 25)),\n maxLimit: toNumber(strapi.config.get('api.rest.maxLimit')) || null,\n});\n\n/**\n * Should maxLimit be used as the limit or not\n */\nconst shouldApplyMaxLimit = (\n limit: number,\n maxLimit: number | null,\n { isPagedPagination = false } = {}\n) => (!isPagedPagination && limit === -1) || (maxLimit !== null && limit > maxLimit);\n\nconst shouldCount = (params: { pagination?: PaginationParams }) => {\n if (has('pagination.withCount', params)) {\n const withCount = params.pagination?.withCount;\n\n if (typeof withCount === 'boolean') {\n return withCount;\n }\n\n if (typeof withCount === 'undefined') {\n return false;\n }\n\n if (['true', 't', '1', 1].includes(withCount)) {\n return true;\n }\n\n if (['false', 'f', '0', 0].includes(withCount)) {\n return false;\n }\n\n throw new errors.ValidationError(\n 'Invalid withCount parameter. Expected \"t\",\"1\",\"true\",\"false\",\"0\",\"f\"'\n );\n }\n\n return Boolean(strapi.config.get('api.rest.withCount', true));\n};\n\nconst isOffsetPagination = (pagination?: PaginationParams): pagination is OffsetPagination =>\n has('start', pagination) || has('limit', pagination);\n\nconst isPagedPagination = (pagination?: PaginationParams): pagination is PagedPagination =>\n has('page', pagination) || has('pageSize', pagination);\n\nconst getPaginationInfo = (params: { pagination?: PaginationParams }): PaginationInfo => {\n const { defaultLimit, maxLimit } = getLimitConfigDefaults();\n\n const { pagination } = params;\n\n const isPaged = isPagedPagination(pagination);\n const isOffset = isOffsetPagination(pagination);\n\n if (isOffset && isPaged) {\n throw new errors.ValidationError(\n 'Invalid pagination parameters. Expected either start/limit or page/pageSize'\n );\n }\n\n if (!isOffset && !isPaged) {\n return {\n page: 1,\n pageSize: defaultLimit,\n };\n }\n\n if (isPagedPagination(pagination)) {\n const pageSize = isUndefined(pagination.pageSize)\n ? defaultLimit\n : Math.max(1, toNumber(pagination.pageSize));\n\n return {\n page: Math.max(1, toNumber(pagination.page || 1)),\n pageSize:\n typeof maxLimit === 'number' &&\n shouldApplyMaxLimit(pageSize, maxLimit, { isPagedPagination: true })\n ? maxLimit\n : Math.max(1, pageSize),\n };\n }\n\n const limit = isUndefined(pagination.limit) ? defaultLimit : toNumber(pagination.limit);\n\n return {\n start: Math.max(0, toNumber(pagination.start || 0)),\n limit: shouldApplyMaxLimit(limit, maxLimit) ? maxLimit || -1 : Math.max(1, limit),\n };\n};\n\nconst transformPaginationResponse = (paginationInfo: PaginationInfo, count: number) => {\n if ('page' in paginationInfo) {\n return {\n ...paginationInfo,\n pageCount: Math.ceil(count / paginationInfo.pageSize),\n total: count,\n };\n }\n\n return {\n ...paginationInfo,\n total: count,\n };\n};\n\nexport { getPaginationInfo, transformPaginationResponse, shouldCount };\n"],"names":["isPagedPagination"],"mappings":";;AAgCA,MAAM,yBAAyB,OAAO;AAAA,EACpC,cAAc,SAAS,OAAO,OAAO,IAAI,yBAAyB,EAAE,CAAC;AAAA,EACrE,UAAU,SAAS,OAAO,OAAO,IAAI,mBAAmB,CAAC,KAAK;AAChE;AAKA,MAAM,sBAAsB,CAC1B,OACA,UACA,EAAE,mBAAAA,qBAAoB,UAAU,CAAA,MAC5B,CAACA,sBAAqB,UAAU,MAAQ,aAAa,QAAQ,QAAQ;AAErE,MAAA,cAAc,CAAC,WAA8C;AAC7D,MAAA,IAAI,wBAAwB,MAAM,GAAG;AACjC,UAAA,YAAY,OAAO,YAAY;AAEjC,QAAA,OAAO,cAAc,WAAW;AAC3B,aAAA;AAAA,IACT;AAEI,QAAA,OAAO,cAAc,aAAa;AAC7B,aAAA;AAAA,IACT;AAEI,QAAA,CAAC,QAAQ,KAAK,KAAK,CAAC,EAAE,SAAS,SAAS,GAAG;AACtC,aAAA;AAAA,IACT;AAEI,QAAA,CAAC,SAAS,KAAK,KAAK,CAAC,EAAE,SAAS,SAAS,GAAG;AACvC,aAAA;AAAA,IACT;AAEA,UAAM,IAAI,OAAO;AAAA,MACf;AAAA,IAAA;AAAA,EAEJ;AAEA,SAAO,QAAQ,OAAO,OAAO,IAAI,sBAAsB,IAAI,CAAC;AAC9D;AAEA,MAAM,qBAAqB,CAAC,eAC1B,IAAI,SAAS,UAAU,KAAK,IAAI,SAAS,UAAU;AAErD,MAAM,oBAAoB,CAAC,eACzB,IAAI,QAAQ,UAAU,KAAK,IAAI,YAAY,UAAU;AAEjD,MAAA,oBAAoB,CAAC,WAA8D;AACvF,QAAM,EAAE,cAAc,SAAS,IAAI,uBAAuB;AAEpD,QAAA,EAAE,WAAe,IAAA;AAEjB,QAAA,UAAU,kBAAkB,UAAU;AACtC,QAAA,WAAW,mBAAmB,UAAU;AAE9C,MAAI,YAAY,SAAS;AACvB,UAAM,IAAI,OAAO;AAAA,MACf;AAAA,IAAA;AAAA,EAEJ;AAEI,MAAA,CAAC,YAAY,CAAC,SAAS;AAClB,WAAA;AAAA,MACL,MAAM;AAAA,MACN,UAAU;AAAA,IAAA;AAAA,EAEd;AAEI,MAAA,kBAAkB,UAAU,GAAG;AACjC,UAAM,WAAW,YAAY,WAAW,QAAQ,IAC5C,eACA,KAAK,IAAI,GAAG,SAAS,WAAW,QAAQ,CAAC;AAEtC,WAAA;AAAA,MACL,MAAM,KAAK,IAAI,GAAG,SAAS,WAAW,QAAQ,CAAC,CAAC;AAAA,MAChD,UACE,OAAO,aAAa,YACpB,oBAAoB,UAAU,UAAU,EAAE,mBAAmB,KAAA,CAAM,IAC/D,WACA,KAAK,IAAI,GAAG,QAAQ;AAAA,IAAA;AAAA,EAE9B;AAEM,QAAA,QAAQ,YAAY,WAAW,KAAK,IAAI,eAAe,SAAS,WAAW,KAAK;AAE/E,SAAA;AAAA,IACL,OAAO,KAAK,IAAI,GAAG,SAAS,WAAW,SAAS,CAAC,CAAC;AAAA,IAClD,OAAO,oBAAoB,OAAO,QAAQ,IAAI,YAAY,KAAK,KAAK,IAAI,GAAG,KAAK;AAAA,EAAA;AAEpF;AAEM,MAAA,8BAA8B,CAAC,gBAAgC,UAAkB;AACrF,MAAI,UAAU,gBAAgB;AACrB,WAAA;AAAA,MACL,GAAG;AAAA,MACH,WAAW,KAAK,KAAK,QAAQ,eAAe,QAAQ;AAAA,MACpD,OAAO;AAAA,IAAA;AAAA,EAEX;AAEO,SAAA;AAAA,IACL,GAAG;AAAA,IACH,OAAO;AAAA,EAAA;AAEX;"}
@@ -1,9 +1,15 @@
1
- import type { CoreApi, Schema } from '@strapi/types';
2
- /**
3
- * Returns a single type service to handle default core-api actions
4
- */
5
- declare const createSingleTypeService: ({ contentType, }: {
6
- contentType: Schema.SingleType;
7
- }) => CoreApi.Service.SingleType;
8
- export default createSingleTypeService;
1
+ import type { Struct, Core } from '@strapi/types';
2
+ import { CoreService } from './core-service';
3
+ export declare class SingleTypeService extends CoreService implements Core.CoreAPI.Service.SingleType {
4
+ private contentType;
5
+ constructor(contentType: Struct.SingleTypeSchema);
6
+ getDocumentId(): Promise<string>;
7
+ find(params?: {}): Promise<import("@strapi/types/dist/modules/documents").AnyDocument | null>;
8
+ createOrUpdate(params?: {}): Promise<import("@strapi/types/dist/modules/documents").AnyDocument | null>;
9
+ delete(params?: {}): Promise<{
10
+ deletedEntries: number;
11
+ }>;
12
+ }
13
+ declare const createSingleTypeService: (contentType: Struct.SingleTypeSchema) => Core.CoreAPI.Service.SingleType;
14
+ export { createSingleTypeService };
9
15
  //# sourceMappingURL=single-type.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"single-type.d.ts","sourceRoot":"","sources":["../../../src/core-api/service/single-type.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,EAAU,MAAM,eAAe,CAAC;AAY7D;;GAEG;AACH,QAAA,MAAM,uBAAuB;iBAGd,OAAO,UAAU;MAC5B,QAAQ,OAAO,CAAC,UAkDnB,CAAC;AAEF,eAAe,uBAAuB,CAAC"}
1
+ {"version":3,"file":"single-type.d.ts","sourceRoot":"","sources":["../../../src/core-api/service/single-type.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAClD,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAE7C,qBAAa,iBAAkB,SAAQ,WAAY,YAAW,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,UAAU;IAC3F,OAAO,CAAC,WAAW,CAA0B;gBAEjC,WAAW,EAAE,MAAM,CAAC,gBAAgB;IAM1C,aAAa;IASb,IAAI,CAAC,MAAM,KAAK;IAMhB,cAAc,CAAC,MAAM,KAAK;IAY1B,MAAM,CAAC,MAAM,KAAK;;;CAQzB;AAED,QAAA,MAAM,uBAAuB,gBACd,OAAO,gBAAgB,KACnC,KAAK,OAAO,CAAC,OAAO,CAAC,UAEvB,CAAC;AAEF,OAAO,EAAE,uBAAuB,EAAE,CAAC"}
@@ -1,54 +1,39 @@
1
1
  "use strict";
2
- const _ = require("lodash/fp");
3
- const strapiUtils = require("@strapi/utils");
4
- const getFetchParams = require("./get-fetch-params.js");
5
- const {
6
- constants: { PUBLISHED_AT_ATTRIBUTE }
7
- } = strapiUtils.contentTypes;
8
- const setPublishedAt = (data) => {
9
- data[PUBLISHED_AT_ATTRIBUTE] = _.propOr(/* @__PURE__ */ new Date(), PUBLISHED_AT_ATTRIBUTE, data);
10
- };
11
- const createSingleTypeService = ({
12
- contentType
13
- }) => {
14
- const { uid } = contentType;
15
- return {
16
- getFetchParams: getFetchParams.getFetchParams,
17
- /**
18
- * Returns singleType content
19
- */
20
- find(params = {}) {
21
- return strapi.entityService?.findMany(uid, this.getFetchParams(params)) ?? null;
22
- },
23
- /**
24
- * Creates or updates a singleType content
25
- *
26
- * @return {Promise}
27
- */
28
- async createOrUpdate({ data, ...params } = { data: {} }) {
29
- const entity = await this.find({ ...params, publicationState: "preview" });
30
- if (!entity) {
31
- const count = await strapi.query(uid).count();
32
- if (count >= 1) {
33
- throw new strapiUtils.errors.ValidationError("singleType.alreadyExists");
34
- }
35
- setPublishedAt(data);
36
- return strapi.entityService?.create(uid, { ...params, data });
37
- }
38
- return strapi.entityService?.update(uid, entity.id, { ...params, data });
39
- },
40
- /**
41
- * Deletes the singleType content
42
- *
43
- * @return {Promise}
44
- */
45
- async delete(params = {}) {
46
- const entity = await this.find(params);
47
- if (!entity)
48
- return;
49
- return strapi.entityService?.delete(uid, entity.id);
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const coreService = require("./core-service.js");
4
+ class SingleTypeService extends coreService.CoreService {
5
+ contentType;
6
+ constructor(contentType) {
7
+ super();
8
+ this.contentType = contentType;
9
+ }
10
+ async getDocumentId() {
11
+ const { uid } = this.contentType;
12
+ return strapi.db.query(uid).findOne().then((document) => document?.documentId);
13
+ }
14
+ async find(params = {}) {
15
+ const { uid } = this.contentType;
16
+ return strapi.documents(uid).findFirst(this.getFetchParams(params));
17
+ }
18
+ async createOrUpdate(params = {}) {
19
+ const { uid } = this.contentType;
20
+ const documentId = await this.getDocumentId();
21
+ if (documentId) {
22
+ return strapi.documents(uid).update(documentId, this.getFetchParams(params));
50
23
  }
51
- };
24
+ return strapi.documents(uid).create(this.getFetchParams(params));
25
+ }
26
+ async delete(params = {}) {
27
+ const { uid } = this.contentType;
28
+ const documentId = await this.getDocumentId();
29
+ if (!documentId)
30
+ return { deletedEntries: 0 };
31
+ return strapi.documents(uid).delete(documentId, this.getFetchParams(params));
32
+ }
33
+ }
34
+ const createSingleTypeService = (contentType) => {
35
+ return new SingleTypeService(contentType);
52
36
  };
53
- module.exports = createSingleTypeService;
37
+ exports.SingleTypeService = SingleTypeService;
38
+ exports.createSingleTypeService = createSingleTypeService;
54
39
  //# sourceMappingURL=single-type.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"single-type.js","sources":["../../../src/core-api/service/single-type.ts"],"sourcesContent":["import { propOr } from 'lodash/fp';\nimport type { CoreApi, Schema, Common } from '@strapi/types';\nimport { errors, contentTypes as contentTypeUtils } from '@strapi/utils';\nimport { getFetchParams } from './get-fetch-params';\n\nconst {\n constants: { PUBLISHED_AT_ATTRIBUTE },\n} = contentTypeUtils;\n\nconst setPublishedAt = (data: Record<string, unknown>) => {\n data[PUBLISHED_AT_ATTRIBUTE] = propOr(new Date(), PUBLISHED_AT_ATTRIBUTE, data);\n};\n\n/**\n * Returns a single type service to handle default core-api actions\n */\nconst createSingleTypeService = ({\n contentType,\n}: {\n contentType: Schema.SingleType;\n}): CoreApi.Service.SingleType => {\n const { uid } = contentType;\n\n return <any>{\n getFetchParams,\n /**\n * Returns singleType content\n */\n find(params = {}) {\n return (\n strapi.entityService?.findMany(uid as Common.UID.SingleType, this.getFetchParams(params)) ??\n null\n );\n },\n\n /**\n * Creates or updates a singleType content\n *\n * @return {Promise}\n */\n async createOrUpdate({ data, ...params } = { data: {} }) {\n const entity = await this.find({ ...params, publicationState: 'preview' });\n\n if (!entity) {\n const count = await strapi.query(uid).count();\n if (count >= 1) {\n throw new errors.ValidationError('singleType.alreadyExists');\n }\n\n setPublishedAt(data);\n\n return strapi.entityService?.create(uid, { ...params, data });\n }\n\n return strapi.entityService?.update(uid, entity.id, { ...params, data });\n },\n\n /**\n * Deletes the singleType content\n *\n * @return {Promise}\n */\n async delete(params = {}) {\n const entity = await this.find(params);\n\n if (!entity) return;\n\n return strapi.entityService?.delete(uid, entity.id);\n },\n };\n};\n\nexport default createSingleTypeService;\n"],"names":["contentTypeUtils","propOr","getFetchParams","errors"],"mappings":";;;;AAKA,MAAM;AAAA,EACJ,WAAW,EAAE,uBAAuB;AACtC,IAAIA;AAEJ,MAAM,iBAAiB,CAAC,SAAkC;AACxD,OAAK,sBAAsB,IAAIC,EAAA,2BAAW,QAAQ,wBAAwB,IAAI;AAChF;AAKA,MAAM,0BAA0B,CAAC;AAAA,EAC/B;AACF,MAEkC;AAC1B,QAAA,EAAE,IAAQ,IAAA;AAEJ,SAAA;AAAA,IAAA,gBACVC,eAAA;AAAA;AAAA;AAAA;AAAA,IAIA,KAAK,SAAS,IAAI;AAEd,aAAA,OAAO,eAAe,SAAS,KAA8B,KAAK,eAAe,MAAM,CAAC,KACxF;AAAA,IAEJ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOA,MAAM,eAAe,EAAE,MAAM,GAAG,OAAO,IAAI,EAAE,MAAM,CAAA,KAAM;AACjD,YAAA,SAAS,MAAM,KAAK,KAAK,EAAE,GAAG,QAAQ,kBAAkB,UAAA,CAAW;AAEzE,UAAI,CAAC,QAAQ;AACX,cAAM,QAAQ,MAAM,OAAO,MAAM,GAAG,EAAE;AACtC,YAAI,SAAS,GAAG;AACR,gBAAA,IAAIC,YAAO,OAAA,gBAAgB,0BAA0B;AAAA,QAC7D;AAEA,uBAAe,IAAI;AAEZ,eAAA,OAAO,eAAe,OAAO,KAAK,EAAE,GAAG,QAAQ,MAAM;AAAA,MAC9D;AAEO,aAAA,OAAO,eAAe,OAAO,KAAK,OAAO,IAAI,EAAE,GAAG,QAAQ,KAAA,CAAM;AAAA,IACzE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOA,MAAM,OAAO,SAAS,IAAI;AACxB,YAAM,SAAS,MAAM,KAAK,KAAK,MAAM;AAErC,UAAI,CAAC;AAAQ;AAEb,aAAO,OAAO,eAAe,OAAO,KAAK,OAAO,EAAE;AAAA,IACpD;AAAA,EAAA;AAEJ;;"}
1
+ {"version":3,"file":"single-type.js","sources":["../../../src/core-api/service/single-type.ts"],"sourcesContent":["import type { Struct, Core } from '@strapi/types';\nimport { CoreService } from './core-service';\n\nexport class SingleTypeService extends CoreService implements Core.CoreAPI.Service.SingleType {\n private contentType: Struct.SingleTypeSchema;\n\n constructor(contentType: Struct.SingleTypeSchema) {\n super();\n\n this.contentType = contentType;\n }\n\n async getDocumentId() {\n const { uid } = this.contentType;\n\n return strapi.db\n .query(uid)\n .findOne()\n .then((document) => document?.documentId as string);\n }\n\n async find(params = {}) {\n const { uid } = this.contentType;\n\n return strapi.documents(uid).findFirst(this.getFetchParams(params));\n }\n\n async createOrUpdate(params = {}) {\n const { uid } = this.contentType;\n\n const documentId = await this.getDocumentId();\n\n if (documentId) {\n return strapi.documents(uid).update(documentId, this.getFetchParams(params));\n }\n\n return strapi.documents(uid).create(this.getFetchParams(params));\n }\n\n async delete(params = {}) {\n const { uid } = this.contentType;\n\n const documentId = await this.getDocumentId();\n if (!documentId) return { deletedEntries: 0 };\n\n return strapi.documents(uid).delete(documentId, this.getFetchParams(params));\n }\n}\n\nconst createSingleTypeService = (\n contentType: Struct.SingleTypeSchema\n): Core.CoreAPI.Service.SingleType => {\n return new SingleTypeService(contentType);\n};\n\nexport { createSingleTypeService };\n"],"names":["CoreService"],"mappings":";;;AAGO,MAAM,0BAA0BA,YAAAA,YAAuD;AAAA,EACpF;AAAA,EAER,YAAY,aAAsC;AAC1C;AAEN,SAAK,cAAc;AAAA,EACrB;AAAA,EAEA,MAAM,gBAAgB;AACd,UAAA,EAAE,IAAI,IAAI,KAAK;AAEd,WAAA,OAAO,GACX,MAAM,GAAG,EACT,UACA,KAAK,CAAC,aAAa,UAAU,UAAoB;AAAA,EACtD;AAAA,EAEA,MAAM,KAAK,SAAS,IAAI;AAChB,UAAA,EAAE,IAAI,IAAI,KAAK;AAEd,WAAA,OAAO,UAAU,GAAG,EAAE,UAAU,KAAK,eAAe,MAAM,CAAC;AAAA,EACpE;AAAA,EAEA,MAAM,eAAe,SAAS,IAAI;AAC1B,UAAA,EAAE,IAAI,IAAI,KAAK;AAEf,UAAA,aAAa,MAAM,KAAK;AAE9B,QAAI,YAAY;AACP,aAAA,OAAO,UAAU,GAAG,EAAE,OAAO,YAAY,KAAK,eAAe,MAAM,CAAC;AAAA,IAC7E;AAEO,WAAA,OAAO,UAAU,GAAG,EAAE,OAAO,KAAK,eAAe,MAAM,CAAC;AAAA,EACjE;AAAA,EAEA,MAAM,OAAO,SAAS,IAAI;AAClB,UAAA,EAAE,IAAI,IAAI,KAAK;AAEf,UAAA,aAAa,MAAM,KAAK;AAC9B,QAAI,CAAC;AAAmB,aAAA,EAAE,gBAAgB;AAEnC,WAAA,OAAO,UAAU,GAAG,EAAE,OAAO,YAAY,KAAK,eAAe,MAAM,CAAC;AAAA,EAC7E;AACF;AAEM,MAAA,0BAA0B,CAC9B,gBACoC;AAC7B,SAAA,IAAI,kBAAkB,WAAW;AAC1C;;;"}
@@ -1,55 +1,39 @@
1
- import { propOr } from "lodash/fp";
2
- import { errors, contentTypes } from "@strapi/utils";
3
- import { getFetchParams } from "./get-fetch-params.mjs";
4
- const {
5
- constants: { PUBLISHED_AT_ATTRIBUTE }
6
- } = contentTypes;
7
- const setPublishedAt = (data) => {
8
- data[PUBLISHED_AT_ATTRIBUTE] = propOr(/* @__PURE__ */ new Date(), PUBLISHED_AT_ATTRIBUTE, data);
9
- };
10
- const createSingleTypeService = ({
11
- contentType
12
- }) => {
13
- const { uid } = contentType;
14
- return {
15
- getFetchParams,
16
- /**
17
- * Returns singleType content
18
- */
19
- find(params = {}) {
20
- return strapi.entityService?.findMany(uid, this.getFetchParams(params)) ?? null;
21
- },
22
- /**
23
- * Creates or updates a singleType content
24
- *
25
- * @return {Promise}
26
- */
27
- async createOrUpdate({ data, ...params } = { data: {} }) {
28
- const entity = await this.find({ ...params, publicationState: "preview" });
29
- if (!entity) {
30
- const count = await strapi.query(uid).count();
31
- if (count >= 1) {
32
- throw new errors.ValidationError("singleType.alreadyExists");
33
- }
34
- setPublishedAt(data);
35
- return strapi.entityService?.create(uid, { ...params, data });
36
- }
37
- return strapi.entityService?.update(uid, entity.id, { ...params, data });
38
- },
39
- /**
40
- * Deletes the singleType content
41
- *
42
- * @return {Promise}
43
- */
44
- async delete(params = {}) {
45
- const entity = await this.find(params);
46
- if (!entity)
47
- return;
48
- return strapi.entityService?.delete(uid, entity.id);
1
+ import { CoreService } from "./core-service.mjs";
2
+ class SingleTypeService extends CoreService {
3
+ contentType;
4
+ constructor(contentType) {
5
+ super();
6
+ this.contentType = contentType;
7
+ }
8
+ async getDocumentId() {
9
+ const { uid } = this.contentType;
10
+ return strapi.db.query(uid).findOne().then((document) => document?.documentId);
11
+ }
12
+ async find(params = {}) {
13
+ const { uid } = this.contentType;
14
+ return strapi.documents(uid).findFirst(this.getFetchParams(params));
15
+ }
16
+ async createOrUpdate(params = {}) {
17
+ const { uid } = this.contentType;
18
+ const documentId = await this.getDocumentId();
19
+ if (documentId) {
20
+ return strapi.documents(uid).update(documentId, this.getFetchParams(params));
49
21
  }
50
- };
22
+ return strapi.documents(uid).create(this.getFetchParams(params));
23
+ }
24
+ async delete(params = {}) {
25
+ const { uid } = this.contentType;
26
+ const documentId = await this.getDocumentId();
27
+ if (!documentId)
28
+ return { deletedEntries: 0 };
29
+ return strapi.documents(uid).delete(documentId, this.getFetchParams(params));
30
+ }
31
+ }
32
+ const createSingleTypeService = (contentType) => {
33
+ return new SingleTypeService(contentType);
51
34
  };
52
35
  export {
53
- createSingleTypeService as default
36
+ SingleTypeService,
37
+ createSingleTypeService
54
38
  };
55
39
  //# sourceMappingURL=single-type.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"single-type.mjs","sources":["../../../src/core-api/service/single-type.ts"],"sourcesContent":["import { propOr } from 'lodash/fp';\nimport type { CoreApi, Schema, Common } from '@strapi/types';\nimport { errors, contentTypes as contentTypeUtils } from '@strapi/utils';\nimport { getFetchParams } from './get-fetch-params';\n\nconst {\n constants: { PUBLISHED_AT_ATTRIBUTE },\n} = contentTypeUtils;\n\nconst setPublishedAt = (data: Record<string, unknown>) => {\n data[PUBLISHED_AT_ATTRIBUTE] = propOr(new Date(), PUBLISHED_AT_ATTRIBUTE, data);\n};\n\n/**\n * Returns a single type service to handle default core-api actions\n */\nconst createSingleTypeService = ({\n contentType,\n}: {\n contentType: Schema.SingleType;\n}): CoreApi.Service.SingleType => {\n const { uid } = contentType;\n\n return <any>{\n getFetchParams,\n /**\n * Returns singleType content\n */\n find(params = {}) {\n return (\n strapi.entityService?.findMany(uid as Common.UID.SingleType, this.getFetchParams(params)) ??\n null\n );\n },\n\n /**\n * Creates or updates a singleType content\n *\n * @return {Promise}\n */\n async createOrUpdate({ data, ...params } = { data: {} }) {\n const entity = await this.find({ ...params, publicationState: 'preview' });\n\n if (!entity) {\n const count = await strapi.query(uid).count();\n if (count >= 1) {\n throw new errors.ValidationError('singleType.alreadyExists');\n }\n\n setPublishedAt(data);\n\n return strapi.entityService?.create(uid, { ...params, data });\n }\n\n return strapi.entityService?.update(uid, entity.id, { ...params, data });\n },\n\n /**\n * Deletes the singleType content\n *\n * @return {Promise}\n */\n async delete(params = {}) {\n const entity = await this.find(params);\n\n if (!entity) return;\n\n return strapi.entityService?.delete(uid, entity.id);\n },\n };\n};\n\nexport default createSingleTypeService;\n"],"names":["contentTypeUtils"],"mappings":";;;AAKA,MAAM;AAAA,EACJ,WAAW,EAAE,uBAAuB;AACtC,IAAIA;AAEJ,MAAM,iBAAiB,CAAC,SAAkC;AACxD,OAAK,sBAAsB,IAAI,2BAAW,QAAQ,wBAAwB,IAAI;AAChF;AAKA,MAAM,0BAA0B,CAAC;AAAA,EAC/B;AACF,MAEkC;AAC1B,QAAA,EAAE,IAAQ,IAAA;AAEJ,SAAA;AAAA,IACV;AAAA;AAAA;AAAA;AAAA,IAIA,KAAK,SAAS,IAAI;AAEd,aAAA,OAAO,eAAe,SAAS,KAA8B,KAAK,eAAe,MAAM,CAAC,KACxF;AAAA,IAEJ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOA,MAAM,eAAe,EAAE,MAAM,GAAG,OAAO,IAAI,EAAE,MAAM,CAAA,KAAM;AACjD,YAAA,SAAS,MAAM,KAAK,KAAK,EAAE,GAAG,QAAQ,kBAAkB,UAAA,CAAW;AAEzE,UAAI,CAAC,QAAQ;AACX,cAAM,QAAQ,MAAM,OAAO,MAAM,GAAG,EAAE;AACtC,YAAI,SAAS,GAAG;AACR,gBAAA,IAAI,OAAO,gBAAgB,0BAA0B;AAAA,QAC7D;AAEA,uBAAe,IAAI;AAEZ,eAAA,OAAO,eAAe,OAAO,KAAK,EAAE,GAAG,QAAQ,MAAM;AAAA,MAC9D;AAEO,aAAA,OAAO,eAAe,OAAO,KAAK,OAAO,IAAI,EAAE,GAAG,QAAQ,KAAA,CAAM;AAAA,IACzE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOA,MAAM,OAAO,SAAS,IAAI;AACxB,YAAM,SAAS,MAAM,KAAK,KAAK,MAAM;AAErC,UAAI,CAAC;AAAQ;AAEb,aAAO,OAAO,eAAe,OAAO,KAAK,OAAO,EAAE;AAAA,IACpD;AAAA,EAAA;AAEJ;"}
1
+ {"version":3,"file":"single-type.mjs","sources":["../../../src/core-api/service/single-type.ts"],"sourcesContent":["import type { Struct, Core } from '@strapi/types';\nimport { CoreService } from './core-service';\n\nexport class SingleTypeService extends CoreService implements Core.CoreAPI.Service.SingleType {\n private contentType: Struct.SingleTypeSchema;\n\n constructor(contentType: Struct.SingleTypeSchema) {\n super();\n\n this.contentType = contentType;\n }\n\n async getDocumentId() {\n const { uid } = this.contentType;\n\n return strapi.db\n .query(uid)\n .findOne()\n .then((document) => document?.documentId as string);\n }\n\n async find(params = {}) {\n const { uid } = this.contentType;\n\n return strapi.documents(uid).findFirst(this.getFetchParams(params));\n }\n\n async createOrUpdate(params = {}) {\n const { uid } = this.contentType;\n\n const documentId = await this.getDocumentId();\n\n if (documentId) {\n return strapi.documents(uid).update(documentId, this.getFetchParams(params));\n }\n\n return strapi.documents(uid).create(this.getFetchParams(params));\n }\n\n async delete(params = {}) {\n const { uid } = this.contentType;\n\n const documentId = await this.getDocumentId();\n if (!documentId) return { deletedEntries: 0 };\n\n return strapi.documents(uid).delete(documentId, this.getFetchParams(params));\n }\n}\n\nconst createSingleTypeService = (\n contentType: Struct.SingleTypeSchema\n): Core.CoreAPI.Service.SingleType => {\n return new SingleTypeService(contentType);\n};\n\nexport { createSingleTypeService };\n"],"names":[],"mappings":";AAGO,MAAM,0BAA0B,YAAuD;AAAA,EACpF;AAAA,EAER,YAAY,aAAsC;AAC1C;AAEN,SAAK,cAAc;AAAA,EACrB;AAAA,EAEA,MAAM,gBAAgB;AACd,UAAA,EAAE,IAAI,IAAI,KAAK;AAEd,WAAA,OAAO,GACX,MAAM,GAAG,EACT,UACA,KAAK,CAAC,aAAa,UAAU,UAAoB;AAAA,EACtD;AAAA,EAEA,MAAM,KAAK,SAAS,IAAI;AAChB,UAAA,EAAE,IAAI,IAAI,KAAK;AAEd,WAAA,OAAO,UAAU,GAAG,EAAE,UAAU,KAAK,eAAe,MAAM,CAAC;AAAA,EACpE;AAAA,EAEA,MAAM,eAAe,SAAS,IAAI;AAC1B,UAAA,EAAE,IAAI,IAAI,KAAK;AAEf,UAAA,aAAa,MAAM,KAAK;AAE9B,QAAI,YAAY;AACP,aAAA,OAAO,UAAU,GAAG,EAAE,OAAO,YAAY,KAAK,eAAe,MAAM,CAAC;AAAA,IAC7E;AAEO,WAAA,OAAO,UAAU,GAAG,EAAE,OAAO,KAAK,eAAe,MAAM,CAAC;AAAA,EACjE;AAAA,EAEA,MAAM,OAAO,SAAS,IAAI;AAClB,UAAA,EAAE,IAAI,IAAI,KAAK;AAEf,UAAA,aAAa,MAAM,KAAK;AAC9B,QAAI,CAAC;AAAmB,aAAA,EAAE,gBAAgB;AAEnC,WAAA,OAAO,UAAU,GAAG,EAAE,OAAO,YAAY,KAAK,eAAe,MAAM,CAAC;AAAA,EAC7E;AACF;AAEM,MAAA,0BAA0B,CAC9B,gBACoC;AAC7B,SAAA,IAAI,kBAAkB,WAAW;AAC1C;"}
@@ -4,6 +4,7 @@ export type ContentTypeDefinition = {
4
4
  actions: Record<string, unknown>;
5
5
  lifecycles: Record<string, unknown>;
6
6
  };
7
- declare const createContentType: (uid: string, definition: ContentTypeDefinition) => Schema.ContentType;
8
- export { createContentType };
7
+ declare const createContentType: (uid: string, definition: ContentTypeDefinition) => import("@strapi/types/dist/struct").ContentTypeSchema;
8
+ declare const getGlobalId: (schema: Schema.ContentType, prefix?: string) => string;
9
+ export { createContentType, getGlobalId };
9
10
  //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/domain/content-type/index.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAG5C,MAAM,MAAM,qBAAqB,GAAG;IAClC,MAAM,EAAE,MAAM,CAAC,WAAW,CAAC;IAC3B,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACjC,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACrC,CAAC;AAUF,QAAA,MAAM,iBAAiB,QAAS,MAAM,cAAc,qBAAqB,0DAiCxE,CAAC;AAyDF,QAAA,MAAM,WAAW,WAAY,OAAO,WAAW,WAAW,MAAM,WAK/D,CAAC;AAmBF,OAAO,EAAE,iBAAiB,EAAE,WAAW,EAAE,CAAC"}
@@ -25,39 +25,20 @@ ${e.errors}`);
25
25
  }
26
26
  const { schema, actions, lifecycles } = _.cloneDeep(definition);
27
27
  Object.assign(schema, {
28
+ uid,
29
+ modelType: "contentType",
28
30
  kind: schema.kind || "collectionType",
29
31
  __schema__: pickSchema(definition.schema),
30
- modelType: "contentType",
31
32
  modelName: definition.schema.info.singularName,
32
- connection: "default"
33
+ actions,
34
+ lifecycles
33
35
  });
34
- if (uid.startsWith("api::")) {
35
- Object.assign(schema, {
36
- uid,
37
- apiName: uid.split("::")[1].split(".")[0],
38
- collectionName: schema.collectionName || schema.info.singularName,
39
- globalId: getGlobalId(schema, schema.info.singularName)
40
- });
41
- } else if (uid.startsWith("plugin::")) {
42
- const pluginName = uid.split("::")[1].split(".")[0];
43
- Object.assign(schema, {
44
- uid,
45
- plugin: pluginName,
46
- // TODO: to be set in load-plugins.js
47
- collectionName: schema.collectionName || `${pluginName}_${schema.info.singularName}`.toLowerCase(),
48
- globalId: getGlobalId(schema, schema.info.singularName, pluginName)
49
- });
50
- } else if (uid.startsWith("admin::")) {
51
- Object.assign(schema, {
52
- uid,
53
- plugin: "admin",
54
- globalId: getGlobalId(schema, schema.info.singularName, "admin")
55
- });
56
- } else {
57
- throw new Error(
58
- `Incorrect Content Type UID "${uid}". The UID should start with api::, plugin:: or admin::.`
59
- );
60
- }
36
+ addTimestamps(schema);
37
+ addDraftAndPublish(schema);
38
+ addCreatorFields(schema);
39
+ return schema;
40
+ };
41
+ const addTimestamps = (schema) => {
61
42
  Object.assign(schema.attributes, {
62
43
  [CREATED_AT_ATTRIBUTE]: {
63
44
  type: "datetime"
@@ -67,6 +48,11 @@ ${e.errors}`);
67
48
  type: "datetime"
68
49
  }
69
50
  });
51
+ };
52
+ const addDraftAndPublish = (schema) => {
53
+ if (!___default.default.has(schema, "options.draftAndPublish")) {
54
+ ___default.default.set(schema, "options.draftAndPublish", false);
55
+ }
70
56
  schema.attributes[PUBLISHED_AT_ATTRIBUTE] = {
71
57
  type: "datetime",
72
58
  configurable: false,
@@ -76,6 +62,8 @@ ${e.errors}`);
76
62
  return /* @__PURE__ */ new Date();
77
63
  }
78
64
  };
65
+ };
66
+ const addCreatorFields = (schema) => {
79
67
  const isPrivate = !___default.default.get(schema, "options.populateCreatorFields", false);
80
68
  schema.attributes[CREATED_BY_ATTRIBUTE] = {
81
69
  type: "relation",
@@ -97,12 +85,11 @@ ${e.errors}`);
97
85
  useJoinTable: false,
98
86
  private: isPrivate
99
87
  };
100
- Object.assign(schema, { actions, lifecycles });
101
- return schema;
102
88
  };
103
- const getGlobalId = (model, modelName, prefix) => {
89
+ const getGlobalId = (schema, prefix) => {
90
+ const modelName = schema.info.singularName;
104
91
  const globalId = prefix ? `${prefix}-${modelName}` : modelName;
105
- return model.globalId || ___default.default.upperFirst(___default.default.camelCase(globalId));
92
+ return schema.globalId || ___default.default.upperFirst(___default.default.camelCase(globalId));
106
93
  };
107
94
  const pickSchema = (model) => {
108
95
  const schema = ___default.default.cloneDeep(
@@ -112,11 +99,13 @@ const pickSchema = (model) => {
112
99
  "info",
113
100
  "options",
114
101
  "pluginOptions",
115
- "attributes"
102
+ "attributes",
103
+ "kind"
116
104
  ])
117
105
  );
118
106
  schema.kind = model.kind || "collectionType";
119
107
  return schema;
120
108
  };
121
109
  exports.createContentType = createContentType;
110
+ exports.getGlobalId = getGlobalId;
122
111
  //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../../../src/domain/content-type/index.ts"],"sourcesContent":["import { cloneDeep } from 'lodash/fp';\nimport _ from 'lodash';\nimport { yup, contentTypes as contentTypesUtils } from '@strapi/utils';\nimport type { Schema } from '@strapi/types';\nimport { validateContentTypeDefinition } from './validator';\n\nexport type ContentTypeDefinition = {\n schema: Schema.ContentType;\n actions: Record<string, unknown>;\n lifecycles: Record<string, unknown>;\n};\n\nconst {\n CREATED_AT_ATTRIBUTE,\n UPDATED_AT_ATTRIBUTE,\n PUBLISHED_AT_ATTRIBUTE,\n CREATED_BY_ATTRIBUTE,\n UPDATED_BY_ATTRIBUTE,\n} = contentTypesUtils.constants;\n\nconst createContentType = (uid: string, definition: ContentTypeDefinition) => {\n try {\n validateContentTypeDefinition(definition);\n } catch (e) {\n if (e instanceof yup.ValidationError) {\n throw new Error(`Content Type Definition is invalid for ${uid}'.\\n${e.errors}`);\n }\n\n throw e;\n }\n\n const { schema, actions, lifecycles } = cloneDeep(definition);\n\n // general info\n Object.assign(schema, {\n uid,\n modelType: 'contentType',\n kind: schema.kind || 'collectionType',\n __schema__: pickSchema(definition.schema),\n modelName: definition.schema.info.singularName,\n actions,\n lifecycles,\n });\n\n addTimestamps(schema);\n\n // Published at is added regardless of draft and publish being enabled\n // In case it is not enabled, value will be always published, and it will not contain a draft\n addDraftAndPublish(schema);\n\n addCreatorFields(schema);\n\n return schema;\n};\n\nconst addTimestamps = (schema: Schema.ContentType) => {\n // attributes\n Object.assign(schema.attributes, {\n [CREATED_AT_ATTRIBUTE]: {\n type: 'datetime',\n },\n // TODO: handle on edit set to new date\n [UPDATED_AT_ATTRIBUTE]: {\n type: 'datetime',\n },\n });\n};\n\nconst addDraftAndPublish = (schema: Schema.ContentType) => {\n if (!_.has(schema, 'options.draftAndPublish')) {\n _.set(schema, 'options.draftAndPublish', false); // Disabled by default\n }\n\n schema.attributes[PUBLISHED_AT_ATTRIBUTE] = {\n type: 'datetime',\n configurable: false,\n writable: true,\n visible: false,\n default() {\n return new Date();\n },\n };\n};\n\nconst addCreatorFields = (schema: Schema.ContentType) => {\n const isPrivate = !_.get(schema, 'options.populateCreatorFields', false);\n\n schema.attributes[CREATED_BY_ATTRIBUTE] = {\n type: 'relation',\n relation: 'oneToOne',\n target: 'admin::user',\n configurable: false,\n writable: false,\n visible: false,\n useJoinTable: false,\n private: isPrivate,\n };\n\n schema.attributes[UPDATED_BY_ATTRIBUTE] = {\n type: 'relation',\n relation: 'oneToOne',\n target: 'admin::user',\n configurable: false,\n writable: false,\n visible: false,\n useJoinTable: false,\n private: isPrivate,\n };\n};\n\nconst getGlobalId = (schema: Schema.ContentType, prefix?: string) => {\n const modelName = schema.info.singularName;\n const globalId = prefix ? `${prefix}-${modelName}` : modelName;\n\n return schema.globalId || _.upperFirst(_.camelCase(globalId));\n};\n\nconst pickSchema = (model: Schema.ContentType) => {\n const schema = _.cloneDeep(\n _.pick(model, [\n 'connection',\n 'collectionName',\n 'info',\n 'options',\n 'pluginOptions',\n 'attributes',\n 'kind',\n ])\n );\n\n schema.kind = model.kind || 'collectionType';\n return schema;\n};\n\nexport { createContentType, getGlobalId };\n"],"names":["contentTypesUtils","validateContentTypeDefinition","yup","cloneDeep","_"],"mappings":";;;;;;;;AAYA,MAAM;AAAA,EACJ;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,IAAIA,YAAAA,aAAkB;AAEhB,MAAA,oBAAoB,CAAC,KAAa,eAAsC;AACxE,MAAA;AACFC,cAAA,8BAA8B,UAAU;AAAA,WACjC,GAAG;AACN,QAAA,aAAaC,gBAAI,iBAAiB;AAC9B,YAAA,IAAI,MAAM,0CAA0C,GAAG;AAAA,EAAO,EAAE,MAAM,EAAE;AAAA,IAChF;AAEM,UAAA;AAAA,EACR;AAEA,QAAM,EAAE,QAAQ,SAAS,WAAW,IAAIC,EAAAA,UAAU,UAAU;AAG5D,SAAO,OAAO,QAAQ;AAAA,IACpB;AAAA,IACA,WAAW;AAAA,IACX,MAAM,OAAO,QAAQ;AAAA,IACrB,YAAY,WAAW,WAAW,MAAM;AAAA,IACxC,WAAW,WAAW,OAAO,KAAK;AAAA,IAClC;AAAA,IACA;AAAA,EAAA,CACD;AAED,gBAAc,MAAM;AAIpB,qBAAmB,MAAM;AAEzB,mBAAiB,MAAM;AAEhB,SAAA;AACT;AAEA,MAAM,gBAAgB,CAAC,WAA+B;AAE7C,SAAA,OAAO,OAAO,YAAY;AAAA,IAC/B,CAAC,oBAAoB,GAAG;AAAA,MACtB,MAAM;AAAA,IACR;AAAA;AAAA,IAEA,CAAC,oBAAoB,GAAG;AAAA,MACtB,MAAM;AAAA,IACR;AAAA,EAAA,CACD;AACH;AAEA,MAAM,qBAAqB,CAAC,WAA+B;AACzD,MAAI,CAACC,WAAAA,QAAE,IAAI,QAAQ,yBAAyB,GAAG;AAC3CA,eAAAA,QAAA,IAAI,QAAQ,2BAA2B,KAAK;AAAA,EAChD;AAEO,SAAA,WAAW,sBAAsB,IAAI;AAAA,IAC1C,MAAM;AAAA,IACN,cAAc;AAAA,IACd,UAAU;AAAA,IACV,SAAS;AAAA,IACT,UAAU;AACR,iCAAW,KAAK;AAAA,IAClB;AAAA,EAAA;AAEJ;AAEA,MAAM,mBAAmB,CAAC,WAA+B;AACvD,QAAM,YAAY,CAACA,mBAAE,IAAI,QAAQ,iCAAiC,KAAK;AAEhE,SAAA,WAAW,oBAAoB,IAAI;AAAA,IACxC,MAAM;AAAA,IACN,UAAU;AAAA,IACV,QAAQ;AAAA,IACR,cAAc;AAAA,IACd,UAAU;AAAA,IACV,SAAS;AAAA,IACT,cAAc;AAAA,IACd,SAAS;AAAA,EAAA;AAGJ,SAAA,WAAW,oBAAoB,IAAI;AAAA,IACxC,MAAM;AAAA,IACN,UAAU;AAAA,IACV,QAAQ;AAAA,IACR,cAAc;AAAA,IACd,UAAU;AAAA,IACV,SAAS;AAAA,IACT,cAAc;AAAA,IACd,SAAS;AAAA,EAAA;AAEb;AAEM,MAAA,cAAc,CAAC,QAA4B,WAAoB;AAC7D,QAAA,YAAY,OAAO,KAAK;AAC9B,QAAM,WAAW,SAAS,GAAG,MAAM,IAAI,SAAS,KAAK;AAErD,SAAO,OAAO,YAAYA,mBAAE,WAAWA,WAAAA,QAAE,UAAU,QAAQ,CAAC;AAC9D;AAEA,MAAM,aAAa,CAAC,UAA8B;AAChD,QAAM,SAASA,WAAAA,QAAE;AAAA,IACfA,WAAA,QAAE,KAAK,OAAO;AAAA,MACZ;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,IAAA,CACD;AAAA,EAAA;AAGI,SAAA,OAAO,MAAM,QAAQ;AACrB,SAAA;AACT;;;"}
@@ -21,39 +21,20 @@ ${e.errors}`);
21
21
  }
22
22
  const { schema, actions, lifecycles } = cloneDeep(definition);
23
23
  Object.assign(schema, {
24
+ uid,
25
+ modelType: "contentType",
24
26
  kind: schema.kind || "collectionType",
25
27
  __schema__: pickSchema(definition.schema),
26
- modelType: "contentType",
27
28
  modelName: definition.schema.info.singularName,
28
- connection: "default"
29
+ actions,
30
+ lifecycles
29
31
  });
30
- if (uid.startsWith("api::")) {
31
- Object.assign(schema, {
32
- uid,
33
- apiName: uid.split("::")[1].split(".")[0],
34
- collectionName: schema.collectionName || schema.info.singularName,
35
- globalId: getGlobalId(schema, schema.info.singularName)
36
- });
37
- } else if (uid.startsWith("plugin::")) {
38
- const pluginName = uid.split("::")[1].split(".")[0];
39
- Object.assign(schema, {
40
- uid,
41
- plugin: pluginName,
42
- // TODO: to be set in load-plugins.js
43
- collectionName: schema.collectionName || `${pluginName}_${schema.info.singularName}`.toLowerCase(),
44
- globalId: getGlobalId(schema, schema.info.singularName, pluginName)
45
- });
46
- } else if (uid.startsWith("admin::")) {
47
- Object.assign(schema, {
48
- uid,
49
- plugin: "admin",
50
- globalId: getGlobalId(schema, schema.info.singularName, "admin")
51
- });
52
- } else {
53
- throw new Error(
54
- `Incorrect Content Type UID "${uid}". The UID should start with api::, plugin:: or admin::.`
55
- );
56
- }
32
+ addTimestamps(schema);
33
+ addDraftAndPublish(schema);
34
+ addCreatorFields(schema);
35
+ return schema;
36
+ };
37
+ const addTimestamps = (schema) => {
57
38
  Object.assign(schema.attributes, {
58
39
  [CREATED_AT_ATTRIBUTE]: {
59
40
  type: "datetime"
@@ -63,6 +44,11 @@ ${e.errors}`);
63
44
  type: "datetime"
64
45
  }
65
46
  });
47
+ };
48
+ const addDraftAndPublish = (schema) => {
49
+ if (!_.has(schema, "options.draftAndPublish")) {
50
+ _.set(schema, "options.draftAndPublish", false);
51
+ }
66
52
  schema.attributes[PUBLISHED_AT_ATTRIBUTE] = {
67
53
  type: "datetime",
68
54
  configurable: false,
@@ -72,6 +58,8 @@ ${e.errors}`);
72
58
  return /* @__PURE__ */ new Date();
73
59
  }
74
60
  };
61
+ };
62
+ const addCreatorFields = (schema) => {
75
63
  const isPrivate = !_.get(schema, "options.populateCreatorFields", false);
76
64
  schema.attributes[CREATED_BY_ATTRIBUTE] = {
77
65
  type: "relation",
@@ -93,12 +81,11 @@ ${e.errors}`);
93
81
  useJoinTable: false,
94
82
  private: isPrivate
95
83
  };
96
- Object.assign(schema, { actions, lifecycles });
97
- return schema;
98
84
  };
99
- const getGlobalId = (model, modelName, prefix) => {
85
+ const getGlobalId = (schema, prefix) => {
86
+ const modelName = schema.info.singularName;
100
87
  const globalId = prefix ? `${prefix}-${modelName}` : modelName;
101
- return model.globalId || _.upperFirst(_.camelCase(globalId));
88
+ return schema.globalId || _.upperFirst(_.camelCase(globalId));
102
89
  };
103
90
  const pickSchema = (model) => {
104
91
  const schema = _.cloneDeep(
@@ -108,13 +95,15 @@ const pickSchema = (model) => {
108
95
  "info",
109
96
  "options",
110
97
  "pluginOptions",
111
- "attributes"
98
+ "attributes",
99
+ "kind"
112
100
  ])
113
101
  );
114
102
  schema.kind = model.kind || "collectionType";
115
103
  return schema;
116
104
  };
117
105
  export {
118
- createContentType
106
+ createContentType,
107
+ getGlobalId
119
108
  };
120
109
  //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.mjs","sources":["../../../src/domain/content-type/index.ts"],"sourcesContent":["import { cloneDeep } from 'lodash/fp';\nimport _ from 'lodash';\nimport { yup, contentTypes as contentTypesUtils } from '@strapi/utils';\nimport type { Schema } from '@strapi/types';\nimport { validateContentTypeDefinition } from './validator';\n\nexport type ContentTypeDefinition = {\n schema: Schema.ContentType;\n actions: Record<string, unknown>;\n lifecycles: Record<string, unknown>;\n};\n\nconst {\n CREATED_AT_ATTRIBUTE,\n UPDATED_AT_ATTRIBUTE,\n PUBLISHED_AT_ATTRIBUTE,\n CREATED_BY_ATTRIBUTE,\n UPDATED_BY_ATTRIBUTE,\n} = contentTypesUtils.constants;\n\nconst createContentType = (uid: string, definition: ContentTypeDefinition) => {\n try {\n validateContentTypeDefinition(definition);\n } catch (e) {\n if (e instanceof yup.ValidationError) {\n throw new Error(`Content Type Definition is invalid for ${uid}'.\\n${e.errors}`);\n }\n\n throw e;\n }\n\n const { schema, actions, lifecycles } = cloneDeep(definition);\n\n // general info\n Object.assign(schema, {\n uid,\n modelType: 'contentType',\n kind: schema.kind || 'collectionType',\n __schema__: pickSchema(definition.schema),\n modelName: definition.schema.info.singularName,\n actions,\n lifecycles,\n });\n\n addTimestamps(schema);\n\n // Published at is added regardless of draft and publish being enabled\n // In case it is not enabled, value will be always published, and it will not contain a draft\n addDraftAndPublish(schema);\n\n addCreatorFields(schema);\n\n return schema;\n};\n\nconst addTimestamps = (schema: Schema.ContentType) => {\n // attributes\n Object.assign(schema.attributes, {\n [CREATED_AT_ATTRIBUTE]: {\n type: 'datetime',\n },\n // TODO: handle on edit set to new date\n [UPDATED_AT_ATTRIBUTE]: {\n type: 'datetime',\n },\n });\n};\n\nconst addDraftAndPublish = (schema: Schema.ContentType) => {\n if (!_.has(schema, 'options.draftAndPublish')) {\n _.set(schema, 'options.draftAndPublish', false); // Disabled by default\n }\n\n schema.attributes[PUBLISHED_AT_ATTRIBUTE] = {\n type: 'datetime',\n configurable: false,\n writable: true,\n visible: false,\n default() {\n return new Date();\n },\n };\n};\n\nconst addCreatorFields = (schema: Schema.ContentType) => {\n const isPrivate = !_.get(schema, 'options.populateCreatorFields', false);\n\n schema.attributes[CREATED_BY_ATTRIBUTE] = {\n type: 'relation',\n relation: 'oneToOne',\n target: 'admin::user',\n configurable: false,\n writable: false,\n visible: false,\n useJoinTable: false,\n private: isPrivate,\n };\n\n schema.attributes[UPDATED_BY_ATTRIBUTE] = {\n type: 'relation',\n relation: 'oneToOne',\n target: 'admin::user',\n configurable: false,\n writable: false,\n visible: false,\n useJoinTable: false,\n private: isPrivate,\n };\n};\n\nconst getGlobalId = (schema: Schema.ContentType, prefix?: string) => {\n const modelName = schema.info.singularName;\n const globalId = prefix ? `${prefix}-${modelName}` : modelName;\n\n return schema.globalId || _.upperFirst(_.camelCase(globalId));\n};\n\nconst pickSchema = (model: Schema.ContentType) => {\n const schema = _.cloneDeep(\n _.pick(model, [\n 'connection',\n 'collectionName',\n 'info',\n 'options',\n 'pluginOptions',\n 'attributes',\n 'kind',\n ])\n );\n\n schema.kind = model.kind || 'collectionType';\n return schema;\n};\n\nexport { createContentType, getGlobalId };\n"],"names":["contentTypesUtils"],"mappings":";;;;AAYA,MAAM;AAAA,EACJ;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,IAAIA,aAAkB;AAEhB,MAAA,oBAAoB,CAAC,KAAa,eAAsC;AACxE,MAAA;AACF,kCAA8B,UAAU;AAAA,WACjC,GAAG;AACN,QAAA,aAAa,IAAI,iBAAiB;AAC9B,YAAA,IAAI,MAAM,0CAA0C,GAAG;AAAA,EAAO,EAAE,MAAM,EAAE;AAAA,IAChF;AAEM,UAAA;AAAA,EACR;AAEA,QAAM,EAAE,QAAQ,SAAS,WAAW,IAAI,UAAU,UAAU;AAG5D,SAAO,OAAO,QAAQ;AAAA,IACpB;AAAA,IACA,WAAW;AAAA,IACX,MAAM,OAAO,QAAQ;AAAA,IACrB,YAAY,WAAW,WAAW,MAAM;AAAA,IACxC,WAAW,WAAW,OAAO,KAAK;AAAA,IAClC;AAAA,IACA;AAAA,EAAA,CACD;AAED,gBAAc,MAAM;AAIpB,qBAAmB,MAAM;AAEzB,mBAAiB,MAAM;AAEhB,SAAA;AACT;AAEA,MAAM,gBAAgB,CAAC,WAA+B;AAE7C,SAAA,OAAO,OAAO,YAAY;AAAA,IAC/B,CAAC,oBAAoB,GAAG;AAAA,MACtB,MAAM;AAAA,IACR;AAAA;AAAA,IAEA,CAAC,oBAAoB,GAAG;AAAA,MACtB,MAAM;AAAA,IACR;AAAA,EAAA,CACD;AACH;AAEA,MAAM,qBAAqB,CAAC,WAA+B;AACzD,MAAI,CAAC,EAAE,IAAI,QAAQ,yBAAyB,GAAG;AAC3C,MAAA,IAAI,QAAQ,2BAA2B,KAAK;AAAA,EAChD;AAEO,SAAA,WAAW,sBAAsB,IAAI;AAAA,IAC1C,MAAM;AAAA,IACN,cAAc;AAAA,IACd,UAAU;AAAA,IACV,SAAS;AAAA,IACT,UAAU;AACR,iCAAW,KAAK;AAAA,IAClB;AAAA,EAAA;AAEJ;AAEA,MAAM,mBAAmB,CAAC,WAA+B;AACvD,QAAM,YAAY,CAAC,EAAE,IAAI,QAAQ,iCAAiC,KAAK;AAEhE,SAAA,WAAW,oBAAoB,IAAI;AAAA,IACxC,MAAM;AAAA,IACN,UAAU;AAAA,IACV,QAAQ;AAAA,IACR,cAAc;AAAA,IACd,UAAU;AAAA,IACV,SAAS;AAAA,IACT,cAAc;AAAA,IACd,SAAS;AAAA,EAAA;AAGJ,SAAA,WAAW,oBAAoB,IAAI;AAAA,IACxC,MAAM;AAAA,IACN,UAAU;AAAA,IACV,QAAQ;AAAA,IACR,cAAc;AAAA,IACd,UAAU;AAAA,IACV,SAAS;AAAA,IACT,cAAc;AAAA,IACd,SAAS;AAAA,EAAA;AAEb;AAEM,MAAA,cAAc,CAAC,QAA4B,WAAoB;AAC7D,QAAA,YAAY,OAAO,KAAK;AAC9B,QAAM,WAAW,SAAS,GAAG,MAAM,IAAI,SAAS,KAAK;AAErD,SAAO,OAAO,YAAY,EAAE,WAAW,EAAE,UAAU,QAAQ,CAAC;AAC9D;AAEA,MAAM,aAAa,CAAC,UAA8B;AAChD,QAAM,SAAS,EAAE;AAAA,IACf,EAAE,KAAK,OAAO;AAAA,MACZ;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,IAAA,CACD;AAAA,EAAA;AAGI,SAAA,OAAO,MAAM,QAAQ;AACrB,SAAA;AACT;"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validator.d.ts","sourceRoot":"","sources":["../../../src/domain/content-type/validator.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,GAAG,EAAW,MAAM,eAAe,CAAC;AAkG7C,QAAA,MAAM,6BAA6B,SAAU,OAAO;;;;;;;;;;;;;;;;;;;GAEnD,CAAC;AAEF,OAAO,EAAE,6BAA6B,EAAE,CAAC"}
@@ -40,7 +40,7 @@ const contentTypeSchemaValidator = strapiUtils.yup.object().shape({
40
40
  for (const attrName of Object.keys(attributes)) {
41
41
  const attr = attributes[attrName];
42
42
  if (attr.type === "enumeration") {
43
- const regressedValues = attr.enum.map(strapiUtils.toRegressedEnumValue);
43
+ const regressedValues = attr.enum.map(strapiUtils.strings.toRegressedEnumValue);
44
44
  if (!regressedValues.every((value) => GRAPHQL_ENUM_REGEX.test(value))) {
45
45
  const message = `Invalid enumeration value. Values should have at least one alphabetical character preceding the first occurence of a number. Update your enumeration '${attrName}'.`;
46
46
  return this.createError({ message });
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validator.js","sources":["../../../src/domain/content-type/validator.ts"],"sourcesContent":["import _ from 'lodash';\nimport { yup, strings } from '@strapi/utils';\nimport type { Schema } from '@strapi/types';\n\nconst LIFECYCLES = [\n 'beforeCreate',\n 'afterCreate',\n 'beforeFindOne',\n 'afterFindOne',\n 'beforeFindMany',\n 'afterFindMany',\n 'beforeCount',\n 'afterCount',\n 'beforeCreateMany',\n 'afterCreateMany',\n 'beforeUpdate',\n 'afterUpdate',\n 'beforeUpdateMany',\n 'afterUpdateMany',\n 'beforeDelete',\n 'afterDelete',\n 'beforeDeleteMany',\n 'afterDeleteMany',\n] as const;\n\n/**\n * For enumerations the least common denomiator is GraphQL, where\n * values needs to match the secure name regex:\n * GraphQL Spec https://spec.graphql.org/June2018/#sec-Names\n *\n * Therefore we need to make sure our users only use values, which\n * can be returned by GraphQL, by checking the regressed values\n * agains the GraphQL regex.\n *\n * TODO V5: check if we can avoid this coupling by moving this logic\n * into the GraphQL plugin.\n */\nconst GRAPHQL_ENUM_REGEX = /^[_A-Za-z][_0-9A-Za-z]*$/;\n\nconst lifecyclesShape = _.mapValues(_.keyBy(LIFECYCLES), () => yup.mixed().nullable().isFunction());\n\nconst contentTypeSchemaValidator = yup.object().shape({\n schema: yup.object().shape({\n info: yup\n .object()\n .shape({\n displayName: yup.string().required(),\n singularName: yup.string().isKebabCase().required(),\n pluralName: yup.string().isKebabCase().required(),\n })\n .required(),\n attributes: yup.object().test({\n name: 'valuesCollide',\n message: 'Some values collide when normalized',\n test(attributes: Schema.ContentType['attributes']) {\n for (const attrName of Object.keys(attributes)) {\n const attr = attributes[attrName];\n if (attr.type === 'enumeration') {\n const regressedValues = attr.enum.map(strings.toRegressedEnumValue);\n\n // should match the GraphQL regex\n if (!regressedValues.every((value: string) => GRAPHQL_ENUM_REGEX.test(value))) {\n const message = `Invalid enumeration value. Values should have at least one alphabetical character preceding the first occurence of a number. Update your enumeration '${attrName}'.`;\n\n return this.createError({ message });\n }\n\n // should not contain empty values\n if (regressedValues.some((value: string) => value === '')) {\n return this.createError({\n message: `At least one value of the enumeration '${attrName}' appears to be empty. Only alphanumerical characters are taken into account.`,\n });\n }\n\n // should not collide\n const duplicates = _.uniq(\n regressedValues.filter(\n (value: string, index: number, values: string[]) => values.indexOf(value) !== index\n )\n );\n\n if (duplicates.length) {\n const message = `Some enumeration values of the field '${attrName}' collide when normalized: ${duplicates.join(\n ', '\n )}. Please modify your enumeration.`;\n\n return this.createError({ message });\n }\n }\n }\n\n return true;\n },\n }),\n }),\n actions: yup.object().onlyContainsFunctions(),\n lifecycles: yup.object().shape(lifecyclesShape).noUnknown(),\n});\n\nconst validateContentTypeDefinition = (data: unknown) => {\n return contentTypeSchemaValidator.validateSync(data, { strict: true, abortEarly: false });\n};\n\nexport { validateContentTypeDefinition };\n"],"names":["_","yup","strings"],"mappings":";;;;;;AAIA,MAAM,aAAa;AAAA,EACjB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF;AAcA,MAAM,qBAAqB;AAE3B,MAAM,kBAAkBA,WAAAA,QAAE,UAAUA,WAAA,QAAE,MAAM,UAAU,GAAG,MAAMC,YAAAA,IAAI,MAAM,EAAE,SAAS,EAAE,WAAY,CAAA;AAElG,MAAM,6BAA6BA,YAAA,IAAI,OAAO,EAAE,MAAM;AAAA,EACpD,QAAQA,YAAA,IAAI,OAAO,EAAE,MAAM;AAAA,IACzB,MAAMA,YAAA,IACH,OAAO,EACP,MAAM;AAAA,MACL,aAAaA,YAAA,IAAI,OAAO,EAAE,SAAS;AAAA,MACnC,cAAcA,YAAAA,IAAI,OAAS,EAAA,YAAA,EAAc,SAAS;AAAA,MAClD,YAAYA,YAAAA,IAAI,OAAS,EAAA,YAAA,EAAc,SAAS;AAAA,IACjD,CAAA,EACA,SAAS;AAAA,IACZ,YAAYA,YAAA,IAAI,OAAO,EAAE,KAAK;AAAA,MAC5B,MAAM;AAAA,MACN,SAAS;AAAA,MACT,KAAK,YAA8C;AACjD,mBAAW,YAAY,OAAO,KAAK,UAAU,GAAG;AACxC,gBAAA,OAAO,WAAW,QAAQ;AAC5B,cAAA,KAAK,SAAS,eAAe;AAC/B,kBAAM,kBAAkB,KAAK,KAAK,IAAIC,YAAAA,QAAQ,oBAAoB;AAG9D,gBAAA,CAAC,gBAAgB,MAAM,CAAC,UAAkB,mBAAmB,KAAK,KAAK,CAAC,GAAG;AACvE,oBAAA,UAAU,yJAAyJ,QAAQ;AAEjL,qBAAO,KAAK,YAAY,EAAE,QAAS,CAAA;AAAA,YACrC;AAGA,gBAAI,gBAAgB,KAAK,CAAC,UAAkB,UAAU,EAAE,GAAG;AACzD,qBAAO,KAAK,YAAY;AAAA,gBACtB,SAAS,0CAA0C,QAAQ;AAAA,cAAA,CAC5D;AAAA,YACH;AAGA,kBAAM,aAAaF,WAAAA,QAAE;AAAA,cACnB,gBAAgB;AAAA,gBACd,CAAC,OAAe,OAAe,WAAqB,OAAO,QAAQ,KAAK,MAAM;AAAA,cAChF;AAAA,YAAA;AAGF,gBAAI,WAAW,QAAQ;AACrB,oBAAM,UAAU,yCAAyC,QAAQ,8BAA8B,WAAW;AAAA,gBACxG;AAAA,cACD,CAAA;AAED,qBAAO,KAAK,YAAY,EAAE,QAAS,CAAA;AAAA,YACrC;AAAA,UACF;AAAA,QACF;AAEO,eAAA;AAAA,MACT;AAAA,IAAA,CACD;AAAA,EAAA,CACF;AAAA,EACD,SAASC,YAAA,IAAI,OAAO,EAAE,sBAAsB;AAAA,EAC5C,YAAYA,YAAI,IAAA,OAAA,EAAS,MAAM,eAAe,EAAE,UAAU;AAC5D,CAAC;AAEK,MAAA,gCAAgC,CAAC,SAAkB;AAChD,SAAA,2BAA2B,aAAa,MAAM,EAAE,QAAQ,MAAM,YAAY,OAAO;AAC1F;;"}
@@ -1,5 +1,5 @@
1
1
  import _ from "lodash";
2
- import { yup, toRegressedEnumValue } from "@strapi/utils";
2
+ import { yup, strings } from "@strapi/utils";
3
3
  const LIFECYCLES = [
4
4
  "beforeCreate",
5
5
  "afterCreate",
@@ -36,7 +36,7 @@ const contentTypeSchemaValidator = yup.object().shape({
36
36
  for (const attrName of Object.keys(attributes)) {
37
37
  const attr = attributes[attrName];
38
38
  if (attr.type === "enumeration") {
39
- const regressedValues = attr.enum.map(toRegressedEnumValue);
39
+ const regressedValues = attr.enum.map(strings.toRegressedEnumValue);
40
40
  if (!regressedValues.every((value) => GRAPHQL_ENUM_REGEX.test(value))) {
41
41
  const message = `Invalid enumeration value. Values should have at least one alphabetical character preceding the first occurence of a number. Update your enumeration '${attrName}'.`;
42
42
  return this.createError({ message });
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validator.mjs","sources":["../../../src/domain/content-type/validator.ts"],"sourcesContent":["import _ from 'lodash';\nimport { yup, strings } from '@strapi/utils';\nimport type { Schema } from '@strapi/types';\n\nconst LIFECYCLES = [\n 'beforeCreate',\n 'afterCreate',\n 'beforeFindOne',\n 'afterFindOne',\n 'beforeFindMany',\n 'afterFindMany',\n 'beforeCount',\n 'afterCount',\n 'beforeCreateMany',\n 'afterCreateMany',\n 'beforeUpdate',\n 'afterUpdate',\n 'beforeUpdateMany',\n 'afterUpdateMany',\n 'beforeDelete',\n 'afterDelete',\n 'beforeDeleteMany',\n 'afterDeleteMany',\n] as const;\n\n/**\n * For enumerations the least common denomiator is GraphQL, where\n * values needs to match the secure name regex:\n * GraphQL Spec https://spec.graphql.org/June2018/#sec-Names\n *\n * Therefore we need to make sure our users only use values, which\n * can be returned by GraphQL, by checking the regressed values\n * agains the GraphQL regex.\n *\n * TODO V5: check if we can avoid this coupling by moving this logic\n * into the GraphQL plugin.\n */\nconst GRAPHQL_ENUM_REGEX = /^[_A-Za-z][_0-9A-Za-z]*$/;\n\nconst lifecyclesShape = _.mapValues(_.keyBy(LIFECYCLES), () => yup.mixed().nullable().isFunction());\n\nconst contentTypeSchemaValidator = yup.object().shape({\n schema: yup.object().shape({\n info: yup\n .object()\n .shape({\n displayName: yup.string().required(),\n singularName: yup.string().isKebabCase().required(),\n pluralName: yup.string().isKebabCase().required(),\n })\n .required(),\n attributes: yup.object().test({\n name: 'valuesCollide',\n message: 'Some values collide when normalized',\n test(attributes: Schema.ContentType['attributes']) {\n for (const attrName of Object.keys(attributes)) {\n const attr = attributes[attrName];\n if (attr.type === 'enumeration') {\n const regressedValues = attr.enum.map(strings.toRegressedEnumValue);\n\n // should match the GraphQL regex\n if (!regressedValues.every((value: string) => GRAPHQL_ENUM_REGEX.test(value))) {\n const message = `Invalid enumeration value. Values should have at least one alphabetical character preceding the first occurence of a number. Update your enumeration '${attrName}'.`;\n\n return this.createError({ message });\n }\n\n // should not contain empty values\n if (regressedValues.some((value: string) => value === '')) {\n return this.createError({\n message: `At least one value of the enumeration '${attrName}' appears to be empty. Only alphanumerical characters are taken into account.`,\n });\n }\n\n // should not collide\n const duplicates = _.uniq(\n regressedValues.filter(\n (value: string, index: number, values: string[]) => values.indexOf(value) !== index\n )\n );\n\n if (duplicates.length) {\n const message = `Some enumeration values of the field '${attrName}' collide when normalized: ${duplicates.join(\n ', '\n )}. Please modify your enumeration.`;\n\n return this.createError({ message });\n }\n }\n }\n\n return true;\n },\n }),\n }),\n actions: yup.object().onlyContainsFunctions(),\n lifecycles: yup.object().shape(lifecyclesShape).noUnknown(),\n});\n\nconst validateContentTypeDefinition = (data: unknown) => {\n return contentTypeSchemaValidator.validateSync(data, { strict: true, abortEarly: false });\n};\n\nexport { validateContentTypeDefinition };\n"],"names":[],"mappings":";;AAIA,MAAM,aAAa;AAAA,EACjB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF;AAcA,MAAM,qBAAqB;AAE3B,MAAM,kBAAkB,EAAE,UAAU,EAAE,MAAM,UAAU,GAAG,MAAM,IAAI,MAAM,EAAE,SAAS,EAAE,WAAY,CAAA;AAElG,MAAM,6BAA6B,IAAI,OAAO,EAAE,MAAM;AAAA,EACpD,QAAQ,IAAI,OAAO,EAAE,MAAM;AAAA,IACzB,MAAM,IACH,OAAO,EACP,MAAM;AAAA,MACL,aAAa,IAAI,OAAO,EAAE,SAAS;AAAA,MACnC,cAAc,IAAI,OAAS,EAAA,YAAA,EAAc,SAAS;AAAA,MAClD,YAAY,IAAI,OAAS,EAAA,YAAA,EAAc,SAAS;AAAA,IACjD,CAAA,EACA,SAAS;AAAA,IACZ,YAAY,IAAI,OAAO,EAAE,KAAK;AAAA,MAC5B,MAAM;AAAA,MACN,SAAS;AAAA,MACT,KAAK,YAA8C;AACjD,mBAAW,YAAY,OAAO,KAAK,UAAU,GAAG;AACxC,gBAAA,OAAO,WAAW,QAAQ;AAC5B,cAAA,KAAK,SAAS,eAAe;AAC/B,kBAAM,kBAAkB,KAAK,KAAK,IAAI,QAAQ,oBAAoB;AAG9D,gBAAA,CAAC,gBAAgB,MAAM,CAAC,UAAkB,mBAAmB,KAAK,KAAK,CAAC,GAAG;AACvE,oBAAA,UAAU,yJAAyJ,QAAQ;AAEjL,qBAAO,KAAK,YAAY,EAAE,QAAS,CAAA;AAAA,YACrC;AAGA,gBAAI,gBAAgB,KAAK,CAAC,UAAkB,UAAU,EAAE,GAAG;AACzD,qBAAO,KAAK,YAAY;AAAA,gBACtB,SAAS,0CAA0C,QAAQ;AAAA,cAAA,CAC5D;AAAA,YACH;AAGA,kBAAM,aAAa,EAAE;AAAA,cACnB,gBAAgB;AAAA,gBACd,CAAC,OAAe,OAAe,WAAqB,OAAO,QAAQ,KAAK,MAAM;AAAA,cAChF;AAAA,YAAA;AAGF,gBAAI,WAAW,QAAQ;AACrB,oBAAM,UAAU,yCAAyC,QAAQ,8BAA8B,WAAW;AAAA,gBACxG;AAAA,cACD,CAAA;AAED,qBAAO,KAAK,YAAY,EAAE,QAAS,CAAA;AAAA,YACrC;AAAA,UACF;AAAA,QACF;AAEO,eAAA;AAAA,MACT;AAAA,IAAA,CACD;AAAA,EAAA,CACF;AAAA,EACD,SAAS,IAAI,OAAO,EAAE,sBAAsB;AAAA,EAC5C,YAAY,IAAI,OAAA,EAAS,MAAM,eAAe,EAAE,UAAU;AAC5D,CAAC;AAEK,MAAA,gCAAgC,CAAC,SAAkB;AAChD,SAAA,2BAA2B,aAAa,MAAM,EAAE,QAAQ,MAAM,YAAY,OAAO;AAC1F;"}