@strapi/core 0.0.0-experimental.6dbac0c205b0f8495781db5706c18cac1a62e62b → 0.0.0-experimental.76447298a89499e415c97916c03f4f90c25ff336

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 (1249) hide show
  1. package/dist/Strapi.d.ts +50 -56
  2. package/dist/Strapi.d.ts.map +1 -1
  3. package/dist/Strapi.js +165 -214
  4. package/dist/Strapi.js.map +1 -1
  5. package/dist/Strapi.mjs +159 -208
  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 +106 -0
  9. package/dist/configuration/config-loader.js.map +1 -0
  10. package/dist/configuration/config-loader.mjs +104 -0
  11. package/dist/configuration/config-loader.mjs.map +1 -0
  12. package/dist/configuration/get-dirs.d.ts +10 -0
  13. package/dist/configuration/get-dirs.d.ts.map +1 -0
  14. package/dist/configuration/get-dirs.js +31 -0
  15. package/dist/configuration/get-dirs.js.map +1 -0
  16. package/dist/configuration/get-dirs.mjs +31 -0
  17. package/dist/configuration/get-dirs.mjs.map +1 -0
  18. package/dist/configuration/index.d.ts +48 -0
  19. package/dist/configuration/index.d.ts.map +1 -0
  20. package/dist/configuration/index.js +80 -0
  21. package/dist/configuration/index.js.map +1 -0
  22. package/dist/configuration/index.mjs +75 -0
  23. package/dist/configuration/index.mjs.map +1 -0
  24. package/dist/configuration/urls.d.ts +8 -0
  25. package/dist/configuration/urls.d.ts.map +1 -0
  26. package/dist/configuration/urls.js +68 -0
  27. package/dist/configuration/urls.js.map +1 -0
  28. package/dist/configuration/urls.mjs +66 -0
  29. package/dist/configuration/urls.mjs.map +1 -0
  30. package/dist/container.d.ts +2 -2
  31. package/dist/container.d.ts.map +1 -1
  32. package/dist/container.js.map +1 -1
  33. package/dist/container.mjs.map +1 -1
  34. package/dist/core-api/controller/collection-type.d.ts +4 -4
  35. package/dist/core-api/controller/collection-type.d.ts.map +1 -1
  36. package/dist/core-api/controller/collection-type.js +10 -20
  37. package/dist/core-api/controller/collection-type.js.map +1 -1
  38. package/dist/core-api/controller/collection-type.mjs +9 -20
  39. package/dist/core-api/controller/collection-type.mjs.map +1 -1
  40. package/dist/core-api/controller/index.d.ts +3 -3
  41. package/dist/core-api/controller/index.d.ts.map +1 -1
  42. package/dist/core-api/controller/index.js +13 -8
  43. package/dist/core-api/controller/index.js.map +1 -1
  44. package/dist/core-api/controller/index.mjs +14 -9
  45. package/dist/core-api/controller/index.mjs.map +1 -1
  46. package/dist/core-api/controller/single-type.d.ts +4 -4
  47. package/dist/core-api/controller/single-type.d.ts.map +1 -1
  48. package/dist/core-api/controller/single-type.js +6 -11
  49. package/dist/core-api/controller/single-type.js.map +1 -1
  50. package/dist/core-api/controller/single-type.mjs +5 -11
  51. package/dist/core-api/controller/single-type.mjs.map +1 -1
  52. package/dist/core-api/controller/transform.d.ts +10 -18
  53. package/dist/core-api/controller/transform.d.ts.map +1 -1
  54. package/dist/core-api/controller/transform.js +10 -18
  55. package/dist/core-api/controller/transform.js.map +1 -1
  56. package/dist/core-api/controller/transform.mjs +10 -18
  57. package/dist/core-api/controller/transform.mjs.map +1 -1
  58. package/dist/core-api/routes/index.d.ts.map +1 -1
  59. package/dist/core-api/service/collection-type.d.ts +28 -5
  60. package/dist/core-api/service/collection-type.d.ts.map +1 -1
  61. package/dist/core-api/service/collection-type.js +56 -49
  62. package/dist/core-api/service/collection-type.js.map +1 -1
  63. package/dist/core-api/service/collection-type.mjs +56 -50
  64. package/dist/core-api/service/collection-type.mjs.map +1 -1
  65. package/dist/core-api/service/core-service.d.ts +4 -0
  66. package/dist/core-api/service/core-service.d.ts.map +1 -0
  67. package/dist/core-api/service/core-service.js +12 -0
  68. package/dist/core-api/service/core-service.js.map +1 -0
  69. package/dist/core-api/service/core-service.mjs +12 -0
  70. package/dist/core-api/service/core-service.mjs.map +1 -0
  71. package/dist/core-api/service/index.d.ts +3 -3
  72. package/dist/core-api/service/index.d.ts.map +1 -1
  73. package/dist/core-api/service/index.js +2 -2
  74. package/dist/core-api/service/index.js.map +1 -1
  75. package/dist/core-api/service/index.mjs +4 -4
  76. package/dist/core-api/service/index.mjs.map +1 -1
  77. package/dist/core-api/service/pagination.d.ts +1 -5
  78. package/dist/core-api/service/pagination.d.ts.map +1 -1
  79. package/dist/core-api/service/pagination.js +0 -11
  80. package/dist/core-api/service/pagination.js.map +1 -1
  81. package/dist/core-api/service/pagination.mjs +0 -11
  82. package/dist/core-api/service/pagination.mjs.map +1 -1
  83. package/dist/core-api/service/single-type.d.ts +14 -8
  84. package/dist/core-api/service/single-type.d.ts.map +1 -1
  85. package/dist/core-api/service/single-type.js +41 -50
  86. package/dist/core-api/service/single-type.js.map +1 -1
  87. package/dist/core-api/service/single-type.mjs +40 -50
  88. package/dist/core-api/service/single-type.mjs.map +1 -1
  89. package/dist/domain/content-type/index.d.ts +10 -0
  90. package/dist/domain/content-type/index.d.ts.map +1 -0
  91. package/dist/domain/content-type/index.js +111 -0
  92. package/dist/domain/content-type/index.js.map +1 -0
  93. package/dist/domain/content-type/index.mjs +109 -0
  94. package/dist/domain/content-type/index.mjs.map +1 -0
  95. package/dist/domain/content-type/validator.d.ts.map +1 -0
  96. package/dist/domain/content-type/validator.js +77 -0
  97. package/dist/domain/content-type/validator.js.map +1 -0
  98. package/dist/domain/content-type/validator.mjs +75 -0
  99. package/dist/domain/content-type/validator.mjs.map +1 -0
  100. package/dist/domain/module/index.d.ts +40 -0
  101. package/dist/domain/module/index.d.ts.map +1 -0
  102. package/dist/domain/module/index.js +107 -0
  103. package/dist/domain/module/index.js.map +1 -0
  104. package/dist/domain/module/index.mjs +105 -0
  105. package/dist/domain/module/index.mjs.map +1 -0
  106. package/dist/domain/module/validation.d.ts.map +1 -0
  107. package/dist/domain/module/validation.js.map +1 -0
  108. package/dist/domain/module/validation.mjs.map +1 -0
  109. package/dist/ee/index.d.ts +4 -2
  110. package/dist/ee/index.d.ts.map +1 -1
  111. package/dist/ee/index.js +2 -2
  112. package/dist/ee/index.js.map +1 -1
  113. package/dist/ee/index.mjs +2 -2
  114. package/dist/ee/index.mjs.map +1 -1
  115. package/dist/ee/license.d.ts +2 -2
  116. package/dist/ee/license.d.ts.map +1 -1
  117. package/dist/ee/license.js +3 -1
  118. package/dist/ee/license.js.map +1 -1
  119. package/dist/ee/license.mjs +3 -1
  120. package/dist/ee/license.mjs.map +1 -1
  121. package/dist/factories.d.ts +11 -10
  122. package/dist/factories.d.ts.map +1 -1
  123. package/dist/factories.js +22 -13
  124. package/dist/factories.js.map +1 -1
  125. package/dist/factories.mjs +23 -14
  126. package/dist/factories.mjs.map +1 -1
  127. package/dist/index.d.ts +5 -2
  128. package/dist/index.d.ts.map +1 -1
  129. package/dist/index.js +27 -1
  130. package/dist/index.js.map +1 -1
  131. package/dist/index.mjs +28 -2
  132. package/dist/index.mjs.map +1 -1
  133. package/dist/loaders/admin.d.ts +3 -0
  134. package/dist/loaders/admin.d.ts.map +1 -0
  135. package/dist/loaders/admin.js +26 -0
  136. package/dist/loaders/admin.js.map +1 -0
  137. package/dist/loaders/admin.mjs +25 -0
  138. package/dist/loaders/admin.mjs.map +1 -0
  139. package/dist/loaders/apis.d.ts +3 -0
  140. package/dist/loaders/apis.d.ts.map +1 -0
  141. package/dist/loaders/apis.js +137 -0
  142. package/dist/loaders/apis.js.map +1 -0
  143. package/dist/loaders/apis.mjs +135 -0
  144. package/dist/loaders/apis.mjs.map +1 -0
  145. package/dist/loaders/components.d.ts +3 -0
  146. package/dist/loaders/components.d.ts.map +1 -0
  147. package/dist/loaders/components.js +38 -0
  148. package/dist/loaders/components.js.map +1 -0
  149. package/dist/loaders/components.mjs +37 -0
  150. package/dist/loaders/components.mjs.map +1 -0
  151. package/dist/loaders/index.d.ts +3 -0
  152. package/dist/loaders/index.d.ts.map +1 -0
  153. package/dist/loaders/index.js +24 -0
  154. package/dist/loaders/index.js.map +1 -0
  155. package/dist/loaders/index.mjs +24 -0
  156. package/dist/loaders/index.mjs.map +1 -0
  157. package/dist/loaders/middlewares.d.ts +3 -0
  158. package/dist/loaders/middlewares.d.ts.map +1 -0
  159. package/dist/loaders/middlewares.js +31 -0
  160. package/dist/loaders/middlewares.js.map +1 -0
  161. package/dist/loaders/middlewares.mjs +30 -0
  162. package/dist/loaders/middlewares.mjs.map +1 -0
  163. package/dist/loaders/plugins/get-enabled-plugins.d.ts +5 -0
  164. package/dist/loaders/plugins/get-enabled-plugins.d.ts.map +1 -0
  165. package/dist/loaders/plugins/get-enabled-plugins.js +113 -0
  166. package/dist/loaders/plugins/get-enabled-plugins.js.map +1 -0
  167. package/dist/loaders/plugins/get-enabled-plugins.mjs +111 -0
  168. package/dist/loaders/plugins/get-enabled-plugins.mjs.map +1 -0
  169. package/dist/loaders/plugins/get-user-plugins-config.d.ts.map +1 -0
  170. package/dist/loaders/plugins/get-user-plugins-config.js +27 -0
  171. package/dist/loaders/plugins/get-user-plugins-config.js.map +1 -0
  172. package/dist/loaders/plugins/get-user-plugins-config.mjs +25 -0
  173. package/dist/loaders/plugins/get-user-plugins-config.mjs.map +1 -0
  174. package/dist/loaders/plugins/index.d.ts +3 -0
  175. package/dist/loaders/plugins/index.d.ts.map +1 -0
  176. package/dist/loaders/plugins/index.js +118 -0
  177. package/dist/loaders/plugins/index.js.map +1 -0
  178. package/dist/loaders/plugins/index.mjs +117 -0
  179. package/dist/loaders/plugins/index.mjs.map +1 -0
  180. package/dist/loaders/policies.d.ts +3 -0
  181. package/dist/loaders/policies.d.ts.map +1 -0
  182. package/dist/loaders/policies.js.map +1 -0
  183. package/dist/loaders/policies.mjs.map +1 -0
  184. package/dist/loaders/sanitizers.d.ts +4 -0
  185. package/dist/loaders/sanitizers.d.ts.map +1 -0
  186. package/dist/loaders/sanitizers.js.map +1 -0
  187. package/dist/loaders/sanitizers.mjs.map +1 -0
  188. package/dist/loaders/src-index.d.ts +4 -0
  189. package/dist/loaders/src-index.d.ts.map +1 -0
  190. package/dist/loaders/src-index.js.map +1 -0
  191. package/dist/loaders/src-index.mjs.map +1 -0
  192. package/dist/loaders/validators.d.ts +4 -0
  193. package/dist/loaders/validators.d.ts.map +1 -0
  194. package/dist/loaders/validators.js.map +1 -0
  195. package/dist/loaders/validators.mjs.map +1 -0
  196. package/dist/middlewares/body.d.ts +4 -4
  197. package/dist/middlewares/body.d.ts.map +1 -1
  198. package/dist/middlewares/body.js +4 -4
  199. package/dist/middlewares/body.js.map +1 -1
  200. package/dist/middlewares/body.mjs +4 -4
  201. package/dist/middlewares/body.mjs.map +1 -1
  202. package/dist/middlewares/compression.d.ts +2 -2
  203. package/dist/middlewares/compression.d.ts.map +1 -1
  204. package/dist/middlewares/compression.js.map +1 -1
  205. package/dist/middlewares/compression.mjs.map +1 -1
  206. package/dist/middlewares/cors.d.ts +2 -2
  207. package/dist/middlewares/cors.d.ts.map +1 -1
  208. package/dist/middlewares/cors.js.map +1 -1
  209. package/dist/middlewares/cors.mjs.map +1 -1
  210. package/dist/middlewares/errors.d.ts +2 -2
  211. package/dist/middlewares/errors.d.ts.map +1 -1
  212. package/dist/middlewares/errors.js.map +1 -1
  213. package/dist/middlewares/errors.mjs.map +1 -1
  214. package/dist/middlewares/favicon.d.ts +3 -2
  215. package/dist/middlewares/favicon.d.ts.map +1 -1
  216. package/dist/middlewares/favicon.js.map +1 -1
  217. package/dist/middlewares/favicon.mjs.map +1 -1
  218. package/dist/middlewares/index.d.ts +2 -2
  219. package/dist/middlewares/index.d.ts.map +1 -1
  220. package/dist/middlewares/index.js +2 -2
  221. package/dist/middlewares/index.js.map +1 -1
  222. package/dist/middlewares/index.mjs +1 -1
  223. package/dist/middlewares/index.mjs.map +1 -1
  224. package/dist/middlewares/ip.d.ts +2 -2
  225. package/dist/middlewares/ip.d.ts.map +1 -1
  226. package/dist/middlewares/ip.js.map +1 -1
  227. package/dist/middlewares/ip.mjs.map +1 -1
  228. package/dist/middlewares/logger.d.ts +2 -2
  229. package/dist/middlewares/logger.d.ts.map +1 -1
  230. package/dist/middlewares/logger.js.map +1 -1
  231. package/dist/middlewares/logger.mjs.map +1 -1
  232. package/dist/middlewares/powered-by.d.ts +2 -2
  233. package/dist/middlewares/powered-by.d.ts.map +1 -1
  234. package/dist/middlewares/powered-by.js.map +1 -1
  235. package/dist/middlewares/powered-by.mjs.map +1 -1
  236. package/dist/middlewares/public.d.ts +3 -0
  237. package/dist/middlewares/public.d.ts.map +1 -0
  238. package/dist/middlewares/public.js +34 -0
  239. package/dist/middlewares/public.js.map +1 -0
  240. package/dist/middlewares/public.mjs +32 -0
  241. package/dist/middlewares/public.mjs.map +1 -0
  242. package/dist/middlewares/query.d.ts +2 -2
  243. package/dist/middlewares/query.d.ts.map +1 -1
  244. package/dist/middlewares/query.js.map +1 -1
  245. package/dist/middlewares/query.mjs.map +1 -1
  246. package/dist/middlewares/response-time.d.ts +2 -2
  247. package/dist/middlewares/response-time.d.ts.map +1 -1
  248. package/dist/middlewares/response-time.js.map +1 -1
  249. package/dist/middlewares/response-time.mjs.map +1 -1
  250. package/dist/middlewares/responses.d.ts +3 -3
  251. package/dist/middlewares/responses.d.ts.map +1 -1
  252. package/dist/middlewares/responses.js.map +1 -1
  253. package/dist/middlewares/responses.mjs.map +1 -1
  254. package/dist/middlewares/security.d.ts +2 -2
  255. package/dist/middlewares/security.d.ts.map +1 -1
  256. package/dist/middlewares/security.js +24 -3
  257. package/dist/middlewares/security.js.map +1 -1
  258. package/dist/middlewares/security.mjs +24 -3
  259. package/dist/middlewares/security.mjs.map +1 -1
  260. package/dist/middlewares/session.d.ts +2 -2
  261. package/dist/middlewares/session.d.ts.map +1 -1
  262. package/dist/middlewares/session.js.map +1 -1
  263. package/dist/middlewares/session.mjs.map +1 -1
  264. package/dist/migrations/database/5.0.0-discard-drafts.d.ts +12 -0
  265. package/dist/migrations/database/5.0.0-discard-drafts.d.ts.map +1 -0
  266. package/dist/migrations/database/5.0.0-discard-drafts.js +49 -0
  267. package/dist/migrations/database/5.0.0-discard-drafts.js.map +1 -0
  268. package/dist/migrations/database/5.0.0-discard-drafts.mjs +49 -0
  269. package/dist/migrations/database/5.0.0-discard-drafts.mjs.map +1 -0
  270. package/dist/migrations/draft-publish.d.ts +17 -0
  271. package/dist/migrations/draft-publish.d.ts.map +1 -0
  272. package/dist/migrations/draft-publish.js +59 -0
  273. package/dist/migrations/draft-publish.js.map +1 -0
  274. package/dist/migrations/draft-publish.mjs +59 -0
  275. package/dist/migrations/draft-publish.mjs.map +1 -0
  276. package/dist/providers/admin.d.ts +3 -0
  277. package/dist/providers/admin.d.ts.map +1 -0
  278. package/dist/providers/admin.js +20 -0
  279. package/dist/providers/admin.js.map +1 -0
  280. package/dist/providers/admin.mjs +21 -0
  281. package/dist/providers/admin.mjs.map +1 -0
  282. package/dist/providers/coreStore.d.ts +3 -0
  283. package/dist/providers/coreStore.d.ts.map +1 -0
  284. package/dist/providers/coreStore.js +11 -0
  285. package/dist/providers/coreStore.js.map +1 -0
  286. package/dist/providers/coreStore.mjs +12 -0
  287. package/dist/providers/coreStore.mjs.map +1 -0
  288. package/dist/providers/cron.d.ts +3 -0
  289. package/dist/providers/cron.d.ts.map +1 -0
  290. package/dist/providers/cron.js +20 -0
  291. package/dist/providers/cron.js.map +1 -0
  292. package/dist/providers/cron.mjs +21 -0
  293. package/dist/providers/cron.mjs.map +1 -0
  294. package/dist/providers/index.d.ts +3 -0
  295. package/dist/providers/index.d.ts.map +1 -0
  296. package/dist/providers/index.js +11 -0
  297. package/dist/providers/index.js.map +1 -0
  298. package/dist/providers/index.mjs +11 -0
  299. package/dist/providers/index.mjs.map +1 -0
  300. package/dist/providers/provider.d.ts +9 -0
  301. package/dist/providers/provider.d.ts.map +1 -0
  302. package/dist/providers/provider.js +5 -0
  303. package/dist/providers/provider.js.map +1 -0
  304. package/dist/providers/provider.mjs +5 -0
  305. package/dist/providers/provider.mjs.map +1 -0
  306. package/dist/providers/registries.d.ts +3 -0
  307. package/dist/providers/registries.d.ts.map +1 -0
  308. package/dist/providers/registries.js +35 -0
  309. package/dist/providers/registries.js.map +1 -0
  310. package/dist/providers/registries.mjs +36 -0
  311. package/dist/providers/registries.mjs.map +1 -0
  312. package/dist/providers/telemetry.d.ts +3 -0
  313. package/dist/providers/telemetry.d.ts.map +1 -0
  314. package/dist/providers/telemetry.js +19 -0
  315. package/dist/providers/telemetry.js.map +1 -0
  316. package/dist/providers/telemetry.mjs +20 -0
  317. package/dist/providers/telemetry.mjs.map +1 -0
  318. package/dist/providers/webhooks.d.ts +3 -0
  319. package/dist/providers/webhooks.d.ts.map +1 -0
  320. package/dist/providers/webhooks.js +30 -0
  321. package/dist/providers/webhooks.js.map +1 -0
  322. package/dist/providers/webhooks.mjs +31 -0
  323. package/dist/providers/webhooks.mjs.map +1 -0
  324. package/dist/registries/apis.d.ts +8 -0
  325. package/dist/registries/apis.d.ts.map +1 -0
  326. package/dist/registries/apis.js.map +1 -0
  327. package/dist/registries/apis.mjs.map +1 -0
  328. package/dist/registries/components.d.ts +25 -0
  329. package/dist/registries/components.d.ts.map +1 -0
  330. package/dist/registries/components.js.map +1 -0
  331. package/dist/registries/components.mjs.map +1 -0
  332. package/dist/registries/content-types.d.ts +33 -0
  333. package/dist/registries/content-types.d.ts.map +1 -0
  334. package/dist/registries/content-types.js +70 -0
  335. package/dist/registries/content-types.js.map +1 -0
  336. package/dist/registries/content-types.mjs +71 -0
  337. package/dist/registries/content-types.mjs.map +1 -0
  338. package/dist/registries/controllers.d.ts +35 -0
  339. package/dist/registries/controllers.d.ts.map +1 -0
  340. package/dist/registries/controllers.js +80 -0
  341. package/dist/registries/controllers.js.map +1 -0
  342. package/dist/registries/controllers.mjs +81 -0
  343. package/dist/registries/controllers.mjs.map +1 -0
  344. package/dist/registries/custom-fields.d.ts +8 -0
  345. package/dist/registries/custom-fields.d.ts.map +1 -0
  346. package/dist/registries/custom-fields.js.map +1 -0
  347. package/dist/registries/custom-fields.mjs.map +1 -0
  348. package/dist/registries/hooks.d.ts.map +1 -0
  349. package/dist/registries/hooks.js +58 -0
  350. package/dist/registries/hooks.js.map +1 -0
  351. package/dist/registries/hooks.mjs +59 -0
  352. package/dist/registries/hooks.mjs.map +1 -0
  353. package/dist/registries/index.d.ts +15 -0
  354. package/dist/registries/index.d.ts.map +1 -0
  355. package/dist/registries/middlewares.d.ts +31 -0
  356. package/dist/registries/middlewares.d.ts.map +1 -0
  357. package/dist/registries/middlewares.js +60 -0
  358. package/dist/registries/middlewares.js.map +1 -0
  359. package/dist/registries/middlewares.mjs +61 -0
  360. package/dist/registries/middlewares.mjs.map +1 -0
  361. package/dist/registries/models.d.ts +6 -0
  362. package/dist/registries/models.d.ts.map +1 -0
  363. package/dist/registries/models.js +16 -0
  364. package/dist/registries/models.js.map +1 -0
  365. package/dist/registries/models.mjs +16 -0
  366. package/dist/registries/models.mjs.map +1 -0
  367. package/dist/registries/modules.d.ts +15 -0
  368. package/dist/registries/modules.d.ts.map +1 -0
  369. package/dist/registries/modules.js.map +1 -0
  370. package/dist/registries/modules.mjs.map +1 -0
  371. package/dist/registries/namespace.d.ts +5 -0
  372. package/dist/registries/namespace.d.ts.map +1 -0
  373. package/dist/registries/namespace.js +27 -0
  374. package/dist/registries/namespace.js.map +1 -0
  375. package/dist/registries/namespace.mjs +27 -0
  376. package/dist/registries/namespace.mjs.map +1 -0
  377. package/dist/registries/plugins.d.ts +9 -0
  378. package/dist/registries/plugins.d.ts.map +1 -0
  379. package/dist/registries/plugins.js.map +1 -0
  380. package/dist/registries/plugins.mjs.map +1 -0
  381. package/dist/registries/policies.d.ts +46 -0
  382. package/dist/registries/policies.d.ts.map +1 -0
  383. package/dist/registries/policies.js +108 -0
  384. package/dist/registries/policies.js.map +1 -0
  385. package/dist/registries/policies.mjs +109 -0
  386. package/dist/registries/policies.mjs.map +1 -0
  387. package/dist/registries/sanitizers.d.ts.map +1 -0
  388. package/dist/registries/sanitizers.js.map +1 -0
  389. package/dist/registries/sanitizers.mjs.map +1 -0
  390. package/dist/registries/services.d.ts +35 -0
  391. package/dist/registries/services.d.ts.map +1 -0
  392. package/dist/registries/services.js +80 -0
  393. package/dist/registries/services.js.map +1 -0
  394. package/dist/registries/services.mjs +81 -0
  395. package/dist/registries/services.mjs.map +1 -0
  396. package/dist/registries/validators.d.ts.map +1 -0
  397. package/dist/registries/validators.js.map +1 -0
  398. package/dist/registries/validators.mjs.map +1 -0
  399. package/dist/services/auth/index.d.ts +4 -4
  400. package/dist/services/auth/index.d.ts.map +1 -1
  401. package/dist/services/auth/index.js.map +1 -1
  402. package/dist/services/auth/index.mjs.map +1 -1
  403. package/dist/services/config.d.ts +3 -0
  404. package/dist/services/config.d.ts.map +1 -0
  405. package/dist/services/config.js +47 -0
  406. package/dist/services/config.js.map +1 -0
  407. package/dist/services/config.mjs +47 -0
  408. package/dist/services/config.mjs.map +1 -0
  409. package/dist/services/content-api/index.d.ts +21 -3
  410. package/dist/services/content-api/index.d.ts.map +1 -1
  411. package/dist/services/content-api/index.js +28 -2
  412. package/dist/services/content-api/index.js.map +1 -1
  413. package/dist/services/content-api/index.mjs +28 -2
  414. package/dist/services/content-api/index.mjs.map +1 -1
  415. package/dist/services/content-api/permissions/index.d.ts +3 -3
  416. package/dist/services/content-api/permissions/index.d.ts.map +1 -1
  417. package/dist/services/content-api/permissions/index.js +1 -1
  418. package/dist/services/content-api/permissions/index.js.map +1 -1
  419. package/dist/services/content-api/permissions/index.mjs +1 -1
  420. package/dist/services/content-api/permissions/index.mjs.map +1 -1
  421. package/dist/services/core-store.d.ts +2 -22
  422. package/dist/services/core-store.d.ts.map +1 -1
  423. package/dist/services/core-store.js +5 -1
  424. package/dist/services/core-store.js.map +1 -1
  425. package/dist/services/core-store.mjs +5 -1
  426. package/dist/services/core-store.mjs.map +1 -1
  427. package/dist/services/cron.d.ts +2 -2
  428. package/dist/services/cron.d.ts.map +1 -1
  429. package/dist/services/cron.js.map +1 -1
  430. package/dist/services/cron.mjs.map +1 -1
  431. package/dist/services/custom-fields.d.ts +2 -2
  432. package/dist/services/custom-fields.d.ts.map +1 -1
  433. package/dist/services/custom-fields.js.map +1 -1
  434. package/dist/services/custom-fields.mjs.map +1 -1
  435. package/dist/services/document-service/attributes/index.d.ts +6 -0
  436. package/dist/services/document-service/attributes/index.d.ts.map +1 -0
  437. package/dist/services/document-service/attributes/index.js +22 -0
  438. package/dist/services/document-service/attributes/index.js.map +1 -0
  439. package/dist/services/document-service/attributes/index.mjs +22 -0
  440. package/dist/services/document-service/attributes/index.mjs.map +1 -0
  441. package/dist/services/document-service/attributes/transforms.d.ts +10 -0
  442. package/dist/services/document-service/attributes/transforms.d.ts.map +1 -0
  443. package/dist/services/document-service/attributes/transforms.js.map +1 -0
  444. package/dist/services/document-service/attributes/transforms.mjs.map +1 -0
  445. package/dist/services/document-service/common.d.ts +4 -0
  446. package/dist/services/document-service/common.d.ts.map +1 -0
  447. package/dist/services/document-service/common.js +7 -0
  448. package/dist/services/document-service/common.js.map +1 -0
  449. package/dist/services/document-service/common.mjs +7 -0
  450. package/dist/services/document-service/common.mjs.map +1 -0
  451. package/dist/services/document-service/components.d.ts +25 -1
  452. package/dist/services/document-service/components.d.ts.map +1 -1
  453. package/dist/services/document-service/components.js +288 -0
  454. package/dist/services/document-service/components.js.map +1 -0
  455. package/dist/services/document-service/components.mjs +286 -0
  456. package/dist/services/document-service/components.mjs.map +1 -0
  457. package/dist/services/document-service/draft-and-publish.d.ts +10 -0
  458. package/dist/services/document-service/draft-and-publish.d.ts.map +1 -0
  459. package/dist/services/document-service/draft-and-publish.js +69 -0
  460. package/dist/services/document-service/draft-and-publish.js.map +1 -0
  461. package/dist/services/document-service/draft-and-publish.mjs +69 -0
  462. package/dist/services/document-service/draft-and-publish.mjs.map +1 -0
  463. package/dist/services/document-service/entries.d.ts +10 -0
  464. package/dist/services/document-service/entries.d.ts.map +1 -0
  465. package/dist/services/document-service/entries.js +95 -0
  466. package/dist/services/document-service/entries.js.map +1 -0
  467. package/dist/services/document-service/entries.mjs +95 -0
  468. package/dist/services/document-service/entries.mjs.map +1 -0
  469. package/dist/services/document-service/index.d.ts +16 -7
  470. package/dist/services/document-service/index.d.ts.map +1 -1
  471. package/dist/services/document-service/index.js +28 -187
  472. package/dist/services/document-service/index.js.map +1 -1
  473. package/dist/services/document-service/index.mjs +27 -187
  474. package/dist/services/document-service/index.mjs.map +1 -1
  475. package/dist/services/document-service/internationalization.d.ts +8 -0
  476. package/dist/services/document-service/internationalization.d.ts.map +1 -0
  477. package/dist/services/document-service/internationalization.js +54 -0
  478. package/dist/services/document-service/internationalization.js.map +1 -0
  479. package/dist/services/document-service/internationalization.mjs +54 -0
  480. package/dist/services/document-service/internationalization.mjs.map +1 -0
  481. package/dist/services/document-service/middlewares/errors.d.ts +6 -0
  482. package/dist/services/document-service/middlewares/errors.d.ts.map +1 -0
  483. package/dist/services/document-service/middlewares/errors.js +25 -0
  484. package/dist/services/document-service/middlewares/errors.js.map +1 -0
  485. package/dist/services/document-service/middlewares/errors.mjs +25 -0
  486. package/dist/services/document-service/middlewares/errors.mjs.map +1 -0
  487. package/dist/services/document-service/middlewares/index.d.ts +2 -10
  488. package/dist/services/document-service/middlewares/index.d.ts.map +1 -1
  489. package/dist/services/document-service/middlewares/middleware-manager.d.ts +10 -0
  490. package/dist/services/document-service/middlewares/middleware-manager.d.ts.map +1 -0
  491. package/dist/services/document-service/middlewares/middleware-manager.js +49 -0
  492. package/dist/services/document-service/middlewares/middleware-manager.js.map +1 -0
  493. package/dist/services/document-service/middlewares/middleware-manager.mjs +49 -0
  494. package/dist/services/document-service/middlewares/middleware-manager.mjs.map +1 -0
  495. package/dist/services/document-service/params.d.ts +3 -1
  496. package/dist/services/document-service/params.d.ts.map +1 -1
  497. package/dist/services/document-service/params.js +8 -0
  498. package/dist/services/document-service/params.js.map +1 -0
  499. package/dist/services/document-service/params.mjs +8 -0
  500. package/dist/services/document-service/params.mjs.map +1 -0
  501. package/dist/services/document-service/repository.d.ts +3 -0
  502. package/dist/services/document-service/repository.d.ts.map +1 -0
  503. package/dist/services/document-service/repository.js +250 -0
  504. package/dist/services/document-service/repository.js.map +1 -0
  505. package/dist/services/document-service/repository.mjs +250 -0
  506. package/dist/services/document-service/repository.mjs.map +1 -0
  507. package/dist/services/document-service/transform/data.d.ts +5 -0
  508. package/dist/services/document-service/transform/data.d.ts.map +1 -0
  509. package/dist/services/document-service/transform/data.js +15 -0
  510. package/dist/services/document-service/transform/data.js.map +1 -0
  511. package/dist/services/document-service/transform/data.mjs +15 -0
  512. package/dist/services/document-service/transform/data.mjs.map +1 -0
  513. package/dist/services/document-service/transform/fields.d.ts +5 -0
  514. package/dist/services/document-service/transform/fields.d.ts.map +1 -0
  515. package/dist/services/document-service/transform/fields.js +24 -0
  516. package/dist/services/document-service/transform/fields.js.map +1 -0
  517. package/dist/services/document-service/transform/fields.mjs +24 -0
  518. package/dist/services/document-service/transform/fields.mjs.map +1 -0
  519. package/dist/services/document-service/transform/id-map.d.ts +23 -0
  520. package/dist/services/document-service/transform/id-map.d.ts.map +1 -0
  521. package/dist/services/document-service/transform/id-map.js +78 -0
  522. package/dist/services/document-service/transform/id-map.js.map +1 -0
  523. package/dist/services/document-service/transform/id-map.mjs +78 -0
  524. package/dist/services/document-service/transform/id-map.mjs.map +1 -0
  525. package/dist/services/document-service/transform/id-transform.d.ts +5 -0
  526. package/dist/services/document-service/transform/id-transform.d.ts.map +1 -0
  527. package/dist/services/document-service/transform/id-transform.js +33 -0
  528. package/dist/services/document-service/transform/id-transform.js.map +1 -0
  529. package/dist/services/document-service/transform/id-transform.mjs +33 -0
  530. package/dist/services/document-service/transform/id-transform.mjs.map +1 -0
  531. package/dist/services/document-service/transform/populate.d.ts +6 -0
  532. package/dist/services/document-service/transform/populate.d.ts.map +1 -0
  533. package/dist/services/document-service/transform/populate.js +21 -0
  534. package/dist/services/document-service/transform/populate.js.map +1 -0
  535. package/dist/services/document-service/transform/populate.mjs +21 -0
  536. package/dist/services/document-service/transform/populate.mjs.map +1 -0
  537. package/dist/services/document-service/transform/query.d.ts +5 -0
  538. package/dist/services/document-service/transform/query.d.ts.map +1 -0
  539. package/dist/services/document-service/transform/query.js +9 -0
  540. package/dist/services/document-service/transform/query.js.map +1 -0
  541. package/dist/services/document-service/transform/query.mjs +9 -0
  542. package/dist/services/document-service/transform/query.mjs.map +1 -0
  543. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +14 -0
  544. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -0
  545. package/dist/services/document-service/transform/relations/extract/data-ids.js +54 -0
  546. package/dist/services/document-service/transform/relations/extract/data-ids.js.map +1 -0
  547. package/dist/services/document-service/transform/relations/extract/data-ids.mjs +54 -0
  548. package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +1 -0
  549. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts +14 -0
  550. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts.map +1 -0
  551. package/dist/services/document-service/transform/relations/transform/data-ids.js +73 -0
  552. package/dist/services/document-service/transform/relations/transform/data-ids.js.map +1 -0
  553. package/dist/services/document-service/transform/relations/transform/data-ids.mjs +73 -0
  554. package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +1 -0
  555. package/dist/services/document-service/transform/relations/transform/default-locale.d.ts +9 -0
  556. package/dist/services/document-service/transform/relations/transform/default-locale.d.ts.map +1 -0
  557. package/dist/services/document-service/transform/relations/transform/default-locale.js +32 -0
  558. package/dist/services/document-service/transform/relations/transform/default-locale.js.map +1 -0
  559. package/dist/services/document-service/transform/relations/transform/default-locale.mjs +32 -0
  560. package/dist/services/document-service/transform/relations/transform/default-locale.mjs.map +1 -0
  561. package/dist/services/document-service/transform/relations/utils/data.d.ts +4 -0
  562. package/dist/services/document-service/transform/relations/utils/data.d.ts.map +1 -0
  563. package/dist/services/document-service/transform/relations/utils/dp.d.ts +10 -0
  564. package/dist/services/document-service/transform/relations/utils/dp.d.ts.map +1 -0
  565. package/dist/services/document-service/transform/relations/utils/dp.js +30 -0
  566. package/dist/services/document-service/transform/relations/utils/dp.js.map +1 -0
  567. package/dist/services/document-service/transform/relations/utils/dp.mjs +30 -0
  568. package/dist/services/document-service/transform/relations/utils/dp.mjs.map +1 -0
  569. package/dist/services/document-service/transform/relations/utils/i18n.d.ts +10 -0
  570. package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -0
  571. package/dist/services/document-service/transform/relations/utils/i18n.js +25 -0
  572. package/dist/services/document-service/transform/relations/utils/i18n.js.map +1 -0
  573. package/dist/services/document-service/transform/relations/utils/i18n.mjs +25 -0
  574. package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +1 -0
  575. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts +6 -0
  576. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts.map +1 -0
  577. package/dist/services/document-service/transform/relations/utils/map-relation.js +87 -0
  578. package/dist/services/document-service/transform/relations/utils/map-relation.js.map +1 -0
  579. package/dist/services/document-service/transform/relations/utils/map-relation.mjs +87 -0
  580. package/dist/services/document-service/transform/relations/utils/map-relation.mjs.map +1 -0
  581. package/dist/services/document-service/transform/relations/utils/types.d.ts +21 -0
  582. package/dist/services/document-service/transform/relations/utils/types.d.ts.map +1 -0
  583. package/dist/services/document-service/transform/types.d.ts +13 -0
  584. package/dist/services/document-service/transform/types.d.ts.map +1 -0
  585. package/dist/services/document-service/utils/populate.d.ts +10 -0
  586. package/dist/services/document-service/utils/populate.d.ts.map +1 -0
  587. package/dist/services/document-service/utils/populate.js +41 -0
  588. package/dist/services/document-service/utils/populate.js.map +1 -0
  589. package/dist/services/document-service/utils/populate.mjs +41 -0
  590. package/dist/services/document-service/utils/populate.mjs.map +1 -0
  591. package/dist/services/entity-service/index.d.ts +4 -6
  592. package/dist/services/entity-service/index.d.ts.map +1 -1
  593. package/dist/services/entity-service/index.js +44 -203
  594. package/dist/services/entity-service/index.js.map +1 -1
  595. package/dist/services/entity-service/index.mjs +38 -197
  596. package/dist/services/entity-service/index.mjs.map +1 -1
  597. package/dist/services/entity-validator/blocks-validator.d.ts.map +1 -1
  598. package/dist/services/entity-validator/blocks-validator.js +22 -2
  599. package/dist/services/entity-validator/blocks-validator.js.map +1 -1
  600. package/dist/services/entity-validator/blocks-validator.mjs +22 -2
  601. package/dist/services/entity-validator/blocks-validator.mjs.map +1 -1
  602. package/dist/services/entity-validator/index.d.ts +2 -2
  603. package/dist/services/entity-validator/index.d.ts.map +1 -1
  604. package/dist/services/entity-validator/index.js +105 -91
  605. package/dist/services/entity-validator/index.js.map +1 -1
  606. package/dist/services/entity-validator/index.mjs +105 -91
  607. package/dist/services/entity-validator/index.mjs.map +1 -1
  608. package/dist/services/entity-validator/validators.d.ts +19 -18
  609. package/dist/services/entity-validator/validators.d.ts.map +1 -1
  610. package/dist/services/entity-validator/validators.js +25 -16
  611. package/dist/services/entity-validator/validators.js.map +1 -1
  612. package/dist/services/entity-validator/validators.mjs +25 -16
  613. package/dist/services/entity-validator/validators.mjs.map +1 -1
  614. package/dist/services/features.d.ts +10 -0
  615. package/dist/services/features.d.ts.map +1 -0
  616. package/dist/services/features.js +17 -0
  617. package/dist/services/features.js.map +1 -0
  618. package/dist/services/features.mjs +17 -0
  619. package/dist/services/features.mjs.map +1 -0
  620. package/dist/services/fs.d.ts +2 -2
  621. package/dist/services/fs.d.ts.map +1 -1
  622. package/dist/services/fs.js.map +1 -1
  623. package/dist/services/fs.mjs.map +1 -1
  624. package/dist/services/metrics/admin-user-hash.d.ts +2 -2
  625. package/dist/services/metrics/admin-user-hash.d.ts.map +1 -1
  626. package/dist/services/metrics/admin-user-hash.js.map +1 -1
  627. package/dist/services/metrics/admin-user-hash.mjs.map +1 -1
  628. package/dist/services/metrics/index.d.ts +2 -2
  629. package/dist/services/metrics/index.d.ts.map +1 -1
  630. package/dist/services/metrics/index.js.map +1 -1
  631. package/dist/services/metrics/index.mjs.map +1 -1
  632. package/dist/services/metrics/middleware.d.ts +2 -2
  633. package/dist/services/metrics/middleware.d.ts.map +1 -1
  634. package/dist/services/metrics/middleware.js.map +1 -1
  635. package/dist/services/metrics/middleware.mjs.map +1 -1
  636. package/dist/services/metrics/rate-limiter.d.ts.map +1 -1
  637. package/dist/services/metrics/rate-limiter.js.map +1 -1
  638. package/dist/services/metrics/rate-limiter.mjs.map +1 -1
  639. package/dist/services/metrics/sender.d.ts +3 -3
  640. package/dist/services/metrics/sender.d.ts.map +1 -1
  641. package/dist/services/metrics/sender.js.map +1 -1
  642. package/dist/services/metrics/sender.mjs.map +1 -1
  643. package/dist/services/query-params.d.ts +7 -0
  644. package/dist/services/query-params.d.ts.map +1 -0
  645. package/dist/services/query-params.js +12 -0
  646. package/dist/services/query-params.js.map +1 -0
  647. package/dist/services/query-params.mjs +13 -0
  648. package/dist/services/query-params.mjs.map +1 -0
  649. package/dist/services/reloader.d.ts +7 -0
  650. package/dist/services/reloader.d.ts.map +1 -0
  651. package/dist/services/reloader.js +36 -0
  652. package/dist/services/reloader.js.map +1 -0
  653. package/dist/services/reloader.mjs +36 -0
  654. package/dist/services/reloader.mjs.map +1 -0
  655. package/dist/services/server/admin-api.d.ts +3 -3
  656. package/dist/services/server/admin-api.d.ts.map +1 -1
  657. package/dist/services/server/admin-api.js.map +1 -1
  658. package/dist/services/server/admin-api.mjs.map +1 -1
  659. package/dist/services/server/api.d.ts +3 -3
  660. package/dist/services/server/api.d.ts.map +1 -1
  661. package/dist/services/server/api.js.map +1 -1
  662. package/dist/services/server/api.mjs.map +1 -1
  663. package/dist/services/server/compose-endpoint.d.ts +2 -2
  664. package/dist/services/server/compose-endpoint.d.ts.map +1 -1
  665. package/dist/services/server/compose-endpoint.js +4 -2
  666. package/dist/services/server/compose-endpoint.js.map +1 -1
  667. package/dist/services/server/compose-endpoint.mjs +5 -3
  668. package/dist/services/server/compose-endpoint.mjs.map +1 -1
  669. package/dist/services/server/content-api.d.ts +3 -3
  670. package/dist/services/server/content-api.d.ts.map +1 -1
  671. package/dist/services/server/content-api.js.map +1 -1
  672. package/dist/services/server/content-api.mjs.map +1 -1
  673. package/dist/services/server/http-server.d.ts +2 -2
  674. package/dist/services/server/http-server.d.ts.map +1 -1
  675. package/dist/services/server/http-server.js.map +1 -1
  676. package/dist/services/server/http-server.mjs.map +1 -1
  677. package/dist/services/server/index.d.ts +2 -2
  678. package/dist/services/server/index.d.ts.map +1 -1
  679. package/dist/services/server/index.js +1 -2
  680. package/dist/services/server/index.js.map +1 -1
  681. package/dist/services/server/index.mjs +1 -2
  682. package/dist/services/server/index.mjs.map +1 -1
  683. package/dist/services/server/koa.d.ts.map +1 -1
  684. package/dist/services/server/middleware.d.ts +4 -8
  685. package/dist/services/server/middleware.d.ts.map +1 -1
  686. package/dist/services/server/middleware.js.map +1 -1
  687. package/dist/services/server/middleware.mjs.map +1 -1
  688. package/dist/services/server/policy.d.ts +3 -3
  689. package/dist/services/server/policy.d.ts.map +1 -1
  690. package/dist/services/server/policy.js +4 -4
  691. package/dist/services/server/policy.js.map +1 -1
  692. package/dist/services/server/policy.mjs +4 -4
  693. package/dist/services/server/policy.mjs.map +1 -1
  694. package/dist/services/server/register-middlewares.d.ts +2 -2
  695. package/dist/services/server/register-middlewares.d.ts.map +1 -1
  696. package/dist/services/server/register-middlewares.js +1 -1
  697. package/dist/services/server/register-middlewares.js.map +1 -1
  698. package/dist/services/server/register-middlewares.mjs +1 -1
  699. package/dist/services/server/register-middlewares.mjs.map +1 -1
  700. package/dist/services/server/register-routes.d.ts +2 -2
  701. package/dist/services/server/register-routes.d.ts.map +1 -1
  702. package/dist/services/server/register-routes.js +3 -3
  703. package/dist/services/server/register-routes.js.map +1 -1
  704. package/dist/services/server/register-routes.mjs +3 -3
  705. package/dist/services/server/register-routes.mjs.map +1 -1
  706. package/dist/services/server/routing.d.ts +5 -5
  707. package/dist/services/server/routing.d.ts.map +1 -1
  708. package/dist/services/server/routing.js.map +1 -1
  709. package/dist/services/server/routing.mjs.map +1 -1
  710. package/dist/services/utils/dynamic-zones.d.ts.map +1 -1
  711. package/dist/services/utils/dynamic-zones.js +2 -1
  712. package/dist/services/utils/dynamic-zones.js.map +1 -1
  713. package/dist/services/utils/dynamic-zones.mjs +2 -1
  714. package/dist/services/utils/dynamic-zones.mjs.map +1 -1
  715. package/dist/services/webhook-runner.d.ts +10 -1
  716. package/dist/services/webhook-runner.d.ts.map +1 -1
  717. package/dist/services/webhook-runner.js.map +1 -1
  718. package/dist/services/webhook-runner.mjs.map +1 -1
  719. package/dist/services/webhook-store.d.ts +2 -22
  720. package/dist/services/webhook-store.d.ts.map +1 -1
  721. package/dist/services/webhook-store.js +11 -8
  722. package/dist/services/webhook-store.js.map +1 -1
  723. package/dist/services/webhook-store.mjs +11 -8
  724. package/dist/services/webhook-store.mjs.map +1 -1
  725. package/dist/utils/convert-custom-field-type.d.ts +2 -3
  726. package/dist/utils/convert-custom-field-type.d.ts.map +1 -1
  727. package/dist/utils/convert-custom-field-type.js +2 -1
  728. package/dist/utils/convert-custom-field-type.js.map +1 -1
  729. package/dist/utils/convert-custom-field-type.mjs +1 -1
  730. package/dist/utils/convert-custom-field-type.mjs.map +1 -1
  731. package/dist/utils/ee.d.ts +1 -2
  732. package/dist/utils/ee.d.ts.map +1 -1
  733. package/dist/utils/fetch.d.ts +3 -2
  734. package/dist/utils/fetch.d.ts.map +1 -1
  735. package/dist/utils/fetch.js +2 -2
  736. package/dist/utils/fetch.js.map +1 -1
  737. package/dist/utils/fetch.mjs +2 -2
  738. package/dist/utils/fetch.mjs.map +1 -1
  739. package/dist/utils/filepath-to-prop-path.d.ts +5 -0
  740. package/dist/utils/filepath-to-prop-path.d.ts.map +1 -0
  741. package/dist/utils/filepath-to-prop-path.js +12 -0
  742. package/dist/utils/filepath-to-prop-path.js.map +1 -0
  743. package/dist/utils/filepath-to-prop-path.mjs +10 -0
  744. package/dist/utils/filepath-to-prop-path.mjs.map +1 -0
  745. package/dist/utils/index.d.ts +12 -4
  746. package/dist/utils/index.d.ts.map +1 -1
  747. package/dist/utils/is-initialized.d.ts +2 -2
  748. package/dist/utils/is-initialized.d.ts.map +1 -1
  749. package/dist/utils/is-initialized.js +5 -4
  750. package/dist/utils/is-initialized.js.map +1 -1
  751. package/dist/utils/is-initialized.mjs +4 -4
  752. package/dist/utils/is-initialized.mjs.map +1 -1
  753. package/dist/utils/load-config-file.d.ts +2 -0
  754. package/dist/utils/load-config-file.d.ts.map +1 -0
  755. package/dist/utils/load-config-file.js +45 -0
  756. package/dist/utils/load-config-file.js.map +1 -0
  757. package/dist/utils/load-config-file.mjs +42 -0
  758. package/dist/utils/load-config-file.mjs.map +1 -0
  759. package/dist/utils/load-files.d.ts +11 -0
  760. package/dist/utils/load-files.d.ts.map +1 -0
  761. package/dist/utils/load-files.js +39 -0
  762. package/dist/utils/load-files.js.map +1 -0
  763. package/dist/utils/load-files.mjs +35 -0
  764. package/dist/utils/load-files.mjs.map +1 -0
  765. package/dist/utils/open-browser.d.ts +2 -3
  766. package/dist/utils/open-browser.d.ts.map +1 -1
  767. package/dist/utils/open-browser.js +5 -5
  768. package/dist/utils/open-browser.js.map +1 -1
  769. package/dist/utils/open-browser.mjs +4 -5
  770. package/dist/utils/open-browser.mjs.map +1 -1
  771. package/dist/utils/resolve-working-dirs.d.ts +19 -0
  772. package/dist/utils/resolve-working-dirs.d.ts.map +1 -0
  773. package/dist/utils/resolve-working-dirs.js +13 -0
  774. package/dist/utils/resolve-working-dirs.js.map +1 -0
  775. package/dist/utils/resolve-working-dirs.mjs +11 -0
  776. package/dist/utils/resolve-working-dirs.mjs.map +1 -0
  777. package/dist/utils/signals.d.ts +2 -2
  778. package/dist/utils/signals.d.ts.map +1 -1
  779. package/dist/utils/signals.js.map +1 -1
  780. package/dist/utils/signals.mjs.map +1 -1
  781. package/dist/utils/startup-logger.d.ts +2 -3
  782. package/dist/utils/startup-logger.d.ts.map +1 -1
  783. package/dist/utils/startup-logger.js +19 -13
  784. package/dist/utils/startup-logger.js.map +1 -1
  785. package/dist/utils/startup-logger.mjs +18 -13
  786. package/dist/utils/startup-logger.mjs.map +1 -1
  787. package/dist/utils/transform-content-types-to-models.d.ts +129 -3
  788. package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
  789. package/dist/utils/transform-content-types-to-models.js +240 -15
  790. package/dist/utils/transform-content-types-to-models.js.map +1 -1
  791. package/dist/utils/transform-content-types-to-models.mjs +237 -15
  792. package/dist/utils/transform-content-types-to-models.mjs.map +1 -1
  793. package/dist/utils/update-notifier/index.d.ts +2 -8
  794. package/dist/utils/update-notifier/index.d.ts.map +1 -1
  795. package/dist/utils/update-notifier/index.js +13 -10
  796. package/dist/utils/update-notifier/index.js.map +1 -1
  797. package/dist/utils/update-notifier/index.mjs +12 -10
  798. package/dist/utils/update-notifier/index.mjs.map +1 -1
  799. package/package.json +26 -34
  800. package/bin/strapi.js +0 -2
  801. package/dist/admin.d.ts +0 -5
  802. package/dist/admin.d.ts.map +0 -1
  803. package/dist/cli.d.ts +0 -2
  804. package/dist/cli.d.ts.map +0 -1
  805. package/dist/commands/actions/admin/create-user/action.d.ts +0 -12
  806. package/dist/commands/actions/admin/create-user/action.d.ts.map +0 -1
  807. package/dist/commands/actions/admin/create-user/command.d.ts +0 -7
  808. package/dist/commands/actions/admin/create-user/command.d.ts.map +0 -1
  809. package/dist/commands/actions/admin/reset-user-password/action.d.ts +0 -10
  810. package/dist/commands/actions/admin/reset-user-password/action.d.ts.map +0 -1
  811. package/dist/commands/actions/admin/reset-user-password/command.d.ts +0 -7
  812. package/dist/commands/actions/admin/reset-user-password/command.d.ts.map +0 -1
  813. package/dist/commands/actions/components/list/action.d.ts +0 -3
  814. package/dist/commands/actions/components/list/action.d.ts.map +0 -1
  815. package/dist/commands/actions/components/list/command.d.ts +0 -7
  816. package/dist/commands/actions/components/list/command.d.ts.map +0 -1
  817. package/dist/commands/actions/configuration/dump/action.d.ts +0 -11
  818. package/dist/commands/actions/configuration/dump/action.d.ts.map +0 -1
  819. package/dist/commands/actions/configuration/dump/command.d.ts +0 -7
  820. package/dist/commands/actions/configuration/dump/command.d.ts.map +0 -1
  821. package/dist/commands/actions/configuration/restore/action.d.ts +0 -11
  822. package/dist/commands/actions/configuration/restore/action.d.ts.map +0 -1
  823. package/dist/commands/actions/configuration/restore/command.d.ts +0 -7
  824. package/dist/commands/actions/configuration/restore/command.d.ts.map +0 -1
  825. package/dist/commands/actions/console/action.d.ts +0 -6
  826. package/dist/commands/actions/console/action.d.ts.map +0 -1
  827. package/dist/commands/actions/console/command.d.ts +0 -7
  828. package/dist/commands/actions/console/command.d.ts.map +0 -1
  829. package/dist/commands/actions/content-types/list/action.d.ts +0 -3
  830. package/dist/commands/actions/content-types/list/action.d.ts.map +0 -1
  831. package/dist/commands/actions/content-types/list/command.d.ts +0 -7
  832. package/dist/commands/actions/content-types/list/command.d.ts.map +0 -1
  833. package/dist/commands/actions/controllers/list/action.d.ts +0 -3
  834. package/dist/commands/actions/controllers/list/action.d.ts.map +0 -1
  835. package/dist/commands/actions/controllers/list/command.d.ts +0 -7
  836. package/dist/commands/actions/controllers/list/command.d.ts.map +0 -1
  837. package/dist/commands/actions/generate/command.d.ts +0 -7
  838. package/dist/commands/actions/generate/command.d.ts.map +0 -1
  839. package/dist/commands/actions/hooks/list/action.d.ts +0 -3
  840. package/dist/commands/actions/hooks/list/action.d.ts.map +0 -1
  841. package/dist/commands/actions/hooks/list/command.d.ts +0 -7
  842. package/dist/commands/actions/hooks/list/command.d.ts.map +0 -1
  843. package/dist/commands/actions/install/action.d.ts +0 -3
  844. package/dist/commands/actions/install/action.d.ts.map +0 -1
  845. package/dist/commands/actions/install/command.d.ts +0 -7
  846. package/dist/commands/actions/install/command.d.ts.map +0 -1
  847. package/dist/commands/actions/middlewares/list/action.d.ts +0 -3
  848. package/dist/commands/actions/middlewares/list/action.d.ts.map +0 -1
  849. package/dist/commands/actions/middlewares/list/command.d.ts +0 -7
  850. package/dist/commands/actions/middlewares/list/command.d.ts.map +0 -1
  851. package/dist/commands/actions/new/action.d.ts +0 -8
  852. package/dist/commands/actions/new/action.d.ts.map +0 -1
  853. package/dist/commands/actions/new/command.d.ts +0 -7
  854. package/dist/commands/actions/new/command.d.ts.map +0 -1
  855. package/dist/commands/actions/plugin/build-command/action.d.ts +0 -7
  856. package/dist/commands/actions/plugin/build-command/action.d.ts.map +0 -1
  857. package/dist/commands/actions/plugin/build-command/command.d.ts +0 -7
  858. package/dist/commands/actions/plugin/build-command/command.d.ts.map +0 -1
  859. package/dist/commands/actions/plugin/watch/action.d.ts +0 -7
  860. package/dist/commands/actions/plugin/watch/action.d.ts.map +0 -1
  861. package/dist/commands/actions/plugin/watch/command.d.ts +0 -7
  862. package/dist/commands/actions/plugin/watch/command.d.ts.map +0 -1
  863. package/dist/commands/actions/policies/list/action.d.ts +0 -3
  864. package/dist/commands/actions/policies/list/action.d.ts.map +0 -1
  865. package/dist/commands/actions/policies/list/command.d.ts +0 -7
  866. package/dist/commands/actions/policies/list/command.d.ts.map +0 -1
  867. package/dist/commands/actions/report/action.d.ts +0 -8
  868. package/dist/commands/actions/report/action.d.ts.map +0 -1
  869. package/dist/commands/actions/report/command.d.ts +0 -7
  870. package/dist/commands/actions/report/command.d.ts.map +0 -1
  871. package/dist/commands/actions/routes/list/action.d.ts +0 -3
  872. package/dist/commands/actions/routes/list/action.d.ts.map +0 -1
  873. package/dist/commands/actions/routes/list/command.d.ts +0 -7
  874. package/dist/commands/actions/routes/list/command.d.ts.map +0 -1
  875. package/dist/commands/actions/services/list/action.d.ts +0 -3
  876. package/dist/commands/actions/services/list/action.d.ts.map +0 -1
  877. package/dist/commands/actions/services/list/command.d.ts +0 -7
  878. package/dist/commands/actions/services/list/command.d.ts.map +0 -1
  879. package/dist/commands/actions/start/action.d.ts +0 -6
  880. package/dist/commands/actions/start/action.d.ts.map +0 -1
  881. package/dist/commands/actions/start/command.d.ts +0 -7
  882. package/dist/commands/actions/start/command.d.ts.map +0 -1
  883. package/dist/commands/actions/telemetry/disable/action.d.ts +0 -2
  884. package/dist/commands/actions/telemetry/disable/action.d.ts.map +0 -1
  885. package/dist/commands/actions/telemetry/disable/command.d.ts +0 -7
  886. package/dist/commands/actions/telemetry/disable/command.d.ts.map +0 -1
  887. package/dist/commands/actions/telemetry/enable/action.d.ts +0 -3
  888. package/dist/commands/actions/telemetry/enable/action.d.ts.map +0 -1
  889. package/dist/commands/actions/telemetry/enable/command.d.ts +0 -7
  890. package/dist/commands/actions/telemetry/enable/command.d.ts.map +0 -1
  891. package/dist/commands/actions/templates/generate/action.d.ts +0 -2
  892. package/dist/commands/actions/templates/generate/action.d.ts.map +0 -1
  893. package/dist/commands/actions/templates/generate/command.d.ts +0 -7
  894. package/dist/commands/actions/templates/generate/command.d.ts.map +0 -1
  895. package/dist/commands/actions/ts/generate-types/action.d.ts +0 -9
  896. package/dist/commands/actions/ts/generate-types/action.d.ts.map +0 -1
  897. package/dist/commands/actions/ts/generate-types/command.d.ts +0 -7
  898. package/dist/commands/actions/ts/generate-types/command.d.ts.map +0 -1
  899. package/dist/commands/actions/uninstall/action.d.ts +0 -6
  900. package/dist/commands/actions/uninstall/action.d.ts.map +0 -1
  901. package/dist/commands/actions/uninstall/command.d.ts +0 -7
  902. package/dist/commands/actions/uninstall/command.d.ts.map +0 -1
  903. package/dist/commands/actions/version/command.d.ts +0 -7
  904. package/dist/commands/actions/version/command.d.ts.map +0 -1
  905. package/dist/commands/actions/watch-admin/action.d.ts +0 -7
  906. package/dist/commands/actions/watch-admin/action.d.ts.map +0 -1
  907. package/dist/commands/actions/watch-admin/command.d.ts +0 -7
  908. package/dist/commands/actions/watch-admin/command.d.ts.map +0 -1
  909. package/dist/commands/index.d.ts +0 -37
  910. package/dist/commands/index.d.ts.map +0 -1
  911. package/dist/commands/types.d.ts +0 -14
  912. package/dist/commands/types.d.ts.map +0 -1
  913. package/dist/commands/utils/commander.d.ts +0 -36
  914. package/dist/commands/utils/commander.d.ts.map +0 -1
  915. package/dist/commands/utils/helpers.d.ts +0 -49
  916. package/dist/commands/utils/helpers.d.ts.map +0 -1
  917. package/dist/commands/utils/logger.d.ts +0 -19
  918. package/dist/commands/utils/logger.d.ts.map +0 -1
  919. package/dist/commands/utils/pkg.d.ts +0 -119
  920. package/dist/commands/utils/pkg.d.ts.map +0 -1
  921. package/dist/commands/utils/tsconfig.d.ts +0 -19
  922. package/dist/commands/utils/tsconfig.d.ts.map +0 -1
  923. package/dist/core/app-configuration/config-loader.d.ts.map +0 -1
  924. package/dist/core/app-configuration/config-loader.js +0 -19
  925. package/dist/core/app-configuration/config-loader.js.map +0 -1
  926. package/dist/core/app-configuration/config-loader.mjs +0 -17
  927. package/dist/core/app-configuration/config-loader.mjs.map +0 -1
  928. package/dist/core/app-configuration/index.d.ts +0 -36
  929. package/dist/core/app-configuration/index.d.ts.map +0 -1
  930. package/dist/core/app-configuration/index.js +0 -55
  931. package/dist/core/app-configuration/index.js.map +0 -1
  932. package/dist/core/app-configuration/index.mjs +0 -51
  933. package/dist/core/app-configuration/index.mjs.map +0 -1
  934. package/dist/core/app-configuration/load-config-file.d.ts +0 -2
  935. package/dist/core/app-configuration/load-config-file.d.ts.map +0 -1
  936. package/dist/core/app-configuration/load-config-file.js +0 -45
  937. package/dist/core/app-configuration/load-config-file.js.map +0 -1
  938. package/dist/core/app-configuration/load-config-file.mjs +0 -42
  939. package/dist/core/app-configuration/load-config-file.mjs.map +0 -1
  940. package/dist/core/bootstrap.d.ts +0 -5
  941. package/dist/core/bootstrap.d.ts.map +0 -1
  942. package/dist/core/bootstrap.js +0 -28
  943. package/dist/core/bootstrap.js.map +0 -1
  944. package/dist/core/bootstrap.mjs +0 -27
  945. package/dist/core/bootstrap.mjs.map +0 -1
  946. package/dist/core/domain/content-type/index.d.ts +0 -9
  947. package/dist/core/domain/content-type/index.d.ts.map +0 -1
  948. package/dist/core/domain/content-type/index.js +0 -122
  949. package/dist/core/domain/content-type/index.js.map +0 -1
  950. package/dist/core/domain/content-type/index.mjs +0 -120
  951. package/dist/core/domain/content-type/index.mjs.map +0 -1
  952. package/dist/core/domain/content-type/validator.d.ts.map +0 -1
  953. package/dist/core/domain/content-type/validator.js +0 -77
  954. package/dist/core/domain/content-type/validator.js.map +0 -1
  955. package/dist/core/domain/content-type/validator.mjs +0 -75
  956. package/dist/core/domain/content-type/validator.mjs.map +0 -1
  957. package/dist/core/domain/module/index.d.ts +0 -39
  958. package/dist/core/domain/module/index.d.ts.map +0 -1
  959. package/dist/core/domain/module/index.js +0 -107
  960. package/dist/core/domain/module/index.js.map +0 -1
  961. package/dist/core/domain/module/index.mjs +0 -105
  962. package/dist/core/domain/module/index.mjs.map +0 -1
  963. package/dist/core/domain/module/validation.d.ts.map +0 -1
  964. package/dist/core/domain/module/validation.js.map +0 -1
  965. package/dist/core/domain/module/validation.mjs.map +0 -1
  966. package/dist/core/loaders/admin.d.ts +0 -3
  967. package/dist/core/loaders/admin.d.ts.map +0 -1
  968. package/dist/core/loaders/admin.js +0 -16
  969. package/dist/core/loaders/admin.js.map +0 -1
  970. package/dist/core/loaders/admin.mjs +0 -15
  971. package/dist/core/loaders/admin.mjs.map +0 -1
  972. package/dist/core/loaders/apis.d.ts +0 -3
  973. package/dist/core/loaders/apis.d.ts.map +0 -1
  974. package/dist/core/loaders/apis.js +0 -130
  975. package/dist/core/loaders/apis.js.map +0 -1
  976. package/dist/core/loaders/apis.mjs +0 -128
  977. package/dist/core/loaders/apis.mjs.map +0 -1
  978. package/dist/core/loaders/components.d.ts +0 -3
  979. package/dist/core/loaders/components.d.ts.map +0 -1
  980. package/dist/core/loaders/components.js +0 -38
  981. package/dist/core/loaders/components.js.map +0 -1
  982. package/dist/core/loaders/components.mjs +0 -37
  983. package/dist/core/loaders/components.mjs.map +0 -1
  984. package/dist/core/loaders/index.d.ts +0 -3
  985. package/dist/core/loaders/index.d.ts.map +0 -1
  986. package/dist/core/loaders/index.js +0 -26
  987. package/dist/core/loaders/index.js.map +0 -1
  988. package/dist/core/loaders/index.mjs +0 -26
  989. package/dist/core/loaders/index.mjs.map +0 -1
  990. package/dist/core/loaders/middlewares.d.ts +0 -3
  991. package/dist/core/loaders/middlewares.d.ts.map +0 -1
  992. package/dist/core/loaders/middlewares.js +0 -31
  993. package/dist/core/loaders/middlewares.js.map +0 -1
  994. package/dist/core/loaders/middlewares.mjs +0 -30
  995. package/dist/core/loaders/middlewares.mjs.map +0 -1
  996. package/dist/core/loaders/plugins/get-enabled-plugins.d.ts +0 -5
  997. package/dist/core/loaders/plugins/get-enabled-plugins.d.ts.map +0 -1
  998. package/dist/core/loaders/plugins/get-enabled-plugins.js +0 -110
  999. package/dist/core/loaders/plugins/get-enabled-plugins.js.map +0 -1
  1000. package/dist/core/loaders/plugins/get-enabled-plugins.mjs +0 -108
  1001. package/dist/core/loaders/plugins/get-enabled-plugins.mjs.map +0 -1
  1002. package/dist/core/loaders/plugins/get-user-plugins-config.d.ts.map +0 -1
  1003. package/dist/core/loaders/plugins/get-user-plugins-config.js +0 -27
  1004. package/dist/core/loaders/plugins/get-user-plugins-config.js.map +0 -1
  1005. package/dist/core/loaders/plugins/get-user-plugins-config.mjs +0 -25
  1006. package/dist/core/loaders/plugins/get-user-plugins-config.mjs.map +0 -1
  1007. package/dist/core/loaders/plugins/index.d.ts +0 -3
  1008. package/dist/core/loaders/plugins/index.d.ts.map +0 -1
  1009. package/dist/core/loaders/plugins/index.js +0 -105
  1010. package/dist/core/loaders/plugins/index.js.map +0 -1
  1011. package/dist/core/loaders/plugins/index.mjs +0 -104
  1012. package/dist/core/loaders/plugins/index.mjs.map +0 -1
  1013. package/dist/core/loaders/policies.d.ts +0 -3
  1014. package/dist/core/loaders/policies.d.ts.map +0 -1
  1015. package/dist/core/loaders/policies.js.map +0 -1
  1016. package/dist/core/loaders/policies.mjs.map +0 -1
  1017. package/dist/core/loaders/sanitizers.d.ts +0 -4
  1018. package/dist/core/loaders/sanitizers.d.ts.map +0 -1
  1019. package/dist/core/loaders/sanitizers.js.map +0 -1
  1020. package/dist/core/loaders/sanitizers.mjs.map +0 -1
  1021. package/dist/core/loaders/src-index.d.ts +0 -4
  1022. package/dist/core/loaders/src-index.d.ts.map +0 -1
  1023. package/dist/core/loaders/src-index.js.map +0 -1
  1024. package/dist/core/loaders/src-index.mjs.map +0 -1
  1025. package/dist/core/loaders/validators.d.ts +0 -4
  1026. package/dist/core/loaders/validators.d.ts.map +0 -1
  1027. package/dist/core/loaders/validators.js.map +0 -1
  1028. package/dist/core/loaders/validators.mjs.map +0 -1
  1029. package/dist/core/registries/apis.d.ts +0 -8
  1030. package/dist/core/registries/apis.d.ts.map +0 -1
  1031. package/dist/core/registries/apis.js.map +0 -1
  1032. package/dist/core/registries/apis.mjs.map +0 -1
  1033. package/dist/core/registries/components.d.ts +0 -25
  1034. package/dist/core/registries/components.d.ts.map +0 -1
  1035. package/dist/core/registries/components.js.map +0 -1
  1036. package/dist/core/registries/components.mjs.map +0 -1
  1037. package/dist/core/registries/config.d.ts +0 -4
  1038. package/dist/core/registries/config.d.ts.map +0 -1
  1039. package/dist/core/registries/config.js +0 -23
  1040. package/dist/core/registries/config.js.map +0 -1
  1041. package/dist/core/registries/config.mjs +0 -22
  1042. package/dist/core/registries/config.mjs.map +0 -1
  1043. package/dist/core/registries/content-types.d.ts +0 -33
  1044. package/dist/core/registries/content-types.d.ts.map +0 -1
  1045. package/dist/core/registries/content-types.js +0 -71
  1046. package/dist/core/registries/content-types.js.map +0 -1
  1047. package/dist/core/registries/content-types.mjs +0 -72
  1048. package/dist/core/registries/content-types.mjs.map +0 -1
  1049. package/dist/core/registries/controllers.d.ts +0 -35
  1050. package/dist/core/registries/controllers.d.ts.map +0 -1
  1051. package/dist/core/registries/controllers.js +0 -80
  1052. package/dist/core/registries/controllers.js.map +0 -1
  1053. package/dist/core/registries/controllers.mjs +0 -81
  1054. package/dist/core/registries/controllers.mjs.map +0 -1
  1055. package/dist/core/registries/custom-fields.d.ts +0 -8
  1056. package/dist/core/registries/custom-fields.d.ts.map +0 -1
  1057. package/dist/core/registries/custom-fields.js.map +0 -1
  1058. package/dist/core/registries/custom-fields.mjs.map +0 -1
  1059. package/dist/core/registries/hooks.d.ts.map +0 -1
  1060. package/dist/core/registries/hooks.js +0 -58
  1061. package/dist/core/registries/hooks.js.map +0 -1
  1062. package/dist/core/registries/hooks.mjs +0 -59
  1063. package/dist/core/registries/hooks.mjs.map +0 -1
  1064. package/dist/core/registries/index.d.ts +0 -15
  1065. package/dist/core/registries/index.d.ts.map +0 -1
  1066. package/dist/core/registries/middlewares.d.ts +0 -31
  1067. package/dist/core/registries/middlewares.d.ts.map +0 -1
  1068. package/dist/core/registries/middlewares.js +0 -60
  1069. package/dist/core/registries/middlewares.js.map +0 -1
  1070. package/dist/core/registries/middlewares.mjs +0 -61
  1071. package/dist/core/registries/middlewares.mjs.map +0 -1
  1072. package/dist/core/registries/modules.d.ts +0 -15
  1073. package/dist/core/registries/modules.d.ts.map +0 -1
  1074. package/dist/core/registries/modules.js.map +0 -1
  1075. package/dist/core/registries/modules.mjs.map +0 -1
  1076. package/dist/core/registries/plugins.d.ts +0 -9
  1077. package/dist/core/registries/plugins.d.ts.map +0 -1
  1078. package/dist/core/registries/plugins.js.map +0 -1
  1079. package/dist/core/registries/plugins.mjs.map +0 -1
  1080. package/dist/core/registries/policies.d.ts +0 -34
  1081. package/dist/core/registries/policies.d.ts.map +0 -1
  1082. package/dist/core/registries/policies.js +0 -62
  1083. package/dist/core/registries/policies.js.map +0 -1
  1084. package/dist/core/registries/policies.mjs +0 -63
  1085. package/dist/core/registries/policies.mjs.map +0 -1
  1086. package/dist/core/registries/sanitizers.d.ts.map +0 -1
  1087. package/dist/core/registries/sanitizers.js.map +0 -1
  1088. package/dist/core/registries/sanitizers.mjs.map +0 -1
  1089. package/dist/core/registries/services.d.ts +0 -35
  1090. package/dist/core/registries/services.d.ts.map +0 -1
  1091. package/dist/core/registries/services.js +0 -80
  1092. package/dist/core/registries/services.js.map +0 -1
  1093. package/dist/core/registries/services.mjs +0 -81
  1094. package/dist/core/registries/services.mjs.map +0 -1
  1095. package/dist/core/registries/validators.d.ts.map +0 -1
  1096. package/dist/core/registries/validators.js.map +0 -1
  1097. package/dist/core/registries/validators.mjs.map +0 -1
  1098. package/dist/core/utils.d.ts +0 -5
  1099. package/dist/core/utils.d.ts.map +0 -1
  1100. package/dist/core/utils.js +0 -27
  1101. package/dist/core/utils.js.map +0 -1
  1102. package/dist/core/utils.mjs +0 -27
  1103. package/dist/core/utils.mjs.map +0 -1
  1104. package/dist/core-api/service/get-fetch-params.d.ts +0 -7
  1105. package/dist/core-api/service/get-fetch-params.d.ts.map +0 -1
  1106. package/dist/core-api/service/get-fetch-params.js +0 -14
  1107. package/dist/core-api/service/get-fetch-params.js.map +0 -1
  1108. package/dist/core-api/service/get-fetch-params.mjs +0 -14
  1109. package/dist/core-api/service/get-fetch-params.mjs.map +0 -1
  1110. package/dist/load/filepath-to-prop-path.d.ts +0 -6
  1111. package/dist/load/filepath-to-prop-path.d.ts.map +0 -1
  1112. package/dist/load/filepath-to-prop-path.js +0 -11
  1113. package/dist/load/filepath-to-prop-path.js.map +0 -1
  1114. package/dist/load/filepath-to-prop-path.mjs +0 -10
  1115. package/dist/load/filepath-to-prop-path.mjs.map +0 -1
  1116. package/dist/load/glob.d.ts +0 -7
  1117. package/dist/load/glob.d.ts.map +0 -1
  1118. package/dist/load/glob.js +0 -15
  1119. package/dist/load/glob.js.map +0 -1
  1120. package/dist/load/glob.mjs +0 -14
  1121. package/dist/load/glob.mjs.map +0 -1
  1122. package/dist/load/index.d.ts +0 -3
  1123. package/dist/load/index.d.ts.map +0 -1
  1124. package/dist/load/load-files.d.ts +0 -11
  1125. package/dist/load/load-files.d.ts.map +0 -1
  1126. package/dist/load/load-files.js +0 -38
  1127. package/dist/load/load-files.js.map +0 -1
  1128. package/dist/load/load-files.mjs +0 -35
  1129. package/dist/load/load-files.mjs.map +0 -1
  1130. package/dist/load/package-path.d.ts +0 -6
  1131. package/dist/load/package-path.d.ts.map +0 -1
  1132. package/dist/middlewares/public/assets/images/group_people_1.png +0 -0
  1133. package/dist/middlewares/public/assets/images/group_people_2.png +0 -0
  1134. package/dist/middlewares/public/assets/images/group_people_3.png +0 -0
  1135. package/dist/middlewares/public/assets/images/logo_login.png +0 -0
  1136. package/dist/middlewares/public/index.d.ts +0 -3
  1137. package/dist/middlewares/public/index.d.ts.map +0 -1
  1138. package/dist/middlewares/public/index.html +0 -66
  1139. package/dist/middlewares/public/index.js +0 -91
  1140. package/dist/middlewares/public/index.js.map +0 -1
  1141. package/dist/middlewares/public/index.mjs +0 -85
  1142. package/dist/middlewares/public/index.mjs.map +0 -1
  1143. package/dist/middlewares/public/serve-static.d.ts +0 -4
  1144. package/dist/middlewares/public/serve-static.d.ts.map +0 -1
  1145. package/dist/middlewares/public/serve-static.js +0 -24
  1146. package/dist/middlewares/public/serve-static.js.map +0 -1
  1147. package/dist/middlewares/public/serve-static.mjs +0 -21
  1148. package/dist/middlewares/public/serve-static.mjs.map +0 -1
  1149. package/dist/services/document-service/document-repository.d.ts +0 -21
  1150. package/dist/services/document-service/document-repository.d.ts.map +0 -1
  1151. package/dist/services/document-service/document-repository.js +0 -132
  1152. package/dist/services/document-service/document-repository.js.map +0 -1
  1153. package/dist/services/document-service/document-repository.mjs +0 -132
  1154. package/dist/services/document-service/document-repository.mjs.map +0 -1
  1155. package/dist/services/document-service/middlewares/defaults/draft-and-publish.d.ts +0 -26
  1156. package/dist/services/document-service/middlewares/defaults/draft-and-publish.d.ts.map +0 -1
  1157. package/dist/services/document-service/middlewares/defaults/draft-and-publish.js +0 -58
  1158. package/dist/services/document-service/middlewares/defaults/draft-and-publish.js.map +0 -1
  1159. package/dist/services/document-service/middlewares/defaults/draft-and-publish.mjs +0 -58
  1160. package/dist/services/document-service/middlewares/defaults/draft-and-publish.mjs.map +0 -1
  1161. package/dist/services/document-service/middlewares/defaults/index.d.ts +0 -3
  1162. package/dist/services/document-service/middlewares/defaults/index.d.ts.map +0 -1
  1163. package/dist/services/document-service/middlewares/defaults/index.js +0 -82
  1164. package/dist/services/document-service/middlewares/defaults/index.js.map +0 -1
  1165. package/dist/services/document-service/middlewares/defaults/index.mjs +0 -82
  1166. package/dist/services/document-service/middlewares/defaults/index.mjs.map +0 -1
  1167. package/dist/services/document-service/middlewares/defaults/locales.d.ts +0 -18
  1168. package/dist/services/document-service/middlewares/defaults/locales.d.ts.map +0 -1
  1169. package/dist/services/document-service/middlewares/defaults/locales.js +0 -40
  1170. package/dist/services/document-service/middlewares/defaults/locales.js.map +0 -1
  1171. package/dist/services/document-service/middlewares/defaults/locales.mjs +0 -40
  1172. package/dist/services/document-service/middlewares/defaults/locales.mjs.map +0 -1
  1173. package/dist/services/document-service/middlewares/index.js +0 -59
  1174. package/dist/services/document-service/middlewares/index.js.map +0 -1
  1175. package/dist/services/document-service/middlewares/index.mjs +0 -59
  1176. package/dist/services/document-service/middlewares/index.mjs.map +0 -1
  1177. package/dist/services/entity-service/attributes/index.d.ts +0 -6
  1178. package/dist/services/entity-service/attributes/index.d.ts.map +0 -1
  1179. package/dist/services/entity-service/attributes/index.js +0 -22
  1180. package/dist/services/entity-service/attributes/index.js.map +0 -1
  1181. package/dist/services/entity-service/attributes/index.mjs +0 -22
  1182. package/dist/services/entity-service/attributes/index.mjs.map +0 -1
  1183. package/dist/services/entity-service/attributes/transforms.d.ts +0 -10
  1184. package/dist/services/entity-service/attributes/transforms.d.ts.map +0 -1
  1185. package/dist/services/entity-service/attributes/transforms.js.map +0 -1
  1186. package/dist/services/entity-service/attributes/transforms.mjs.map +0 -1
  1187. package/dist/services/entity-service/components.d.ts +0 -23
  1188. package/dist/services/entity-service/components.d.ts.map +0 -1
  1189. package/dist/services/entity-service/components.js +0 -384
  1190. package/dist/services/entity-service/components.js.map +0 -1
  1191. package/dist/services/entity-service/components.mjs +0 -382
  1192. package/dist/services/entity-service/components.mjs.map +0 -1
  1193. package/dist/services/entity-service/params.d.ts +0 -8
  1194. package/dist/services/entity-service/params.d.ts.map +0 -1
  1195. package/dist/services/entity-service/params.js +0 -8
  1196. package/dist/services/entity-service/params.js.map +0 -1
  1197. package/dist/services/entity-service/params.mjs +0 -8
  1198. package/dist/services/entity-service/params.mjs.map +0 -1
  1199. package/dist/services/utils/upload-files.d.ts +0 -8
  1200. package/dist/services/utils/upload-files.d.ts.map +0 -1
  1201. package/dist/services/utils/upload-files.js +0 -64
  1202. package/dist/services/utils/upload-files.js.map +0 -1
  1203. package/dist/services/utils/upload-files.mjs +0 -63
  1204. package/dist/services/utils/upload-files.mjs.map +0 -1
  1205. package/dist/utils/addSlash.d.ts +0 -3
  1206. package/dist/utils/addSlash.d.ts.map +0 -1
  1207. package/dist/utils/ee.js +0 -4
  1208. package/dist/utils/ee.js.map +0 -1
  1209. package/dist/utils/ee.mjs +0 -5
  1210. package/dist/utils/ee.mjs.map +0 -1
  1211. package/dist/utils/get-dirs.d.ts +0 -10
  1212. package/dist/utils/get-dirs.d.ts.map +0 -1
  1213. package/dist/utils/get-dirs.js +0 -29
  1214. package/dist/utils/get-dirs.js.map +0 -1
  1215. package/dist/utils/get-dirs.mjs +0 -30
  1216. package/dist/utils/get-dirs.mjs.map +0 -1
  1217. /package/dist/{core/app-configuration → configuration}/config-loader.d.ts +0 -0
  1218. /package/dist/{core/domain → domain}/content-type/validator.d.ts +0 -0
  1219. /package/dist/{core/domain → domain}/module/validation.d.ts +0 -0
  1220. /package/dist/{core/domain → domain}/module/validation.js +0 -0
  1221. /package/dist/{core/domain → domain}/module/validation.mjs +0 -0
  1222. /package/dist/{core/loaders → loaders}/plugins/get-user-plugins-config.d.ts +0 -0
  1223. /package/dist/{core/loaders → loaders}/policies.js +0 -0
  1224. /package/dist/{core/loaders → loaders}/policies.mjs +0 -0
  1225. /package/dist/{core/loaders → loaders}/sanitizers.js +0 -0
  1226. /package/dist/{core/loaders → loaders}/sanitizers.mjs +0 -0
  1227. /package/dist/{core/loaders → loaders}/src-index.js +0 -0
  1228. /package/dist/{core/loaders → loaders}/src-index.mjs +0 -0
  1229. /package/dist/{core/loaders → loaders}/validators.js +0 -0
  1230. /package/dist/{core/loaders → loaders}/validators.mjs +0 -0
  1231. /package/dist/{core/registries → registries}/apis.js +0 -0
  1232. /package/dist/{core/registries → registries}/apis.mjs +0 -0
  1233. /package/dist/{core/registries → registries}/components.js +0 -0
  1234. /package/dist/{core/registries → registries}/components.mjs +0 -0
  1235. /package/dist/{core/registries → registries}/custom-fields.js +0 -0
  1236. /package/dist/{core/registries → registries}/custom-fields.mjs +0 -0
  1237. /package/dist/{core/registries → registries}/hooks.d.ts +0 -0
  1238. /package/dist/{core/registries → registries}/modules.js +0 -0
  1239. /package/dist/{core/registries → registries}/modules.mjs +0 -0
  1240. /package/dist/{core/registries → registries}/plugins.js +0 -0
  1241. /package/dist/{core/registries → registries}/plugins.mjs +0 -0
  1242. /package/dist/{core/registries → registries}/sanitizers.d.ts +0 -0
  1243. /package/dist/{core/registries → registries}/sanitizers.js +0 -0
  1244. /package/dist/{core/registries → registries}/sanitizers.mjs +0 -0
  1245. /package/dist/{core/registries → registries}/validators.d.ts +0 -0
  1246. /package/dist/{core/registries → registries}/validators.js +0 -0
  1247. /package/dist/{core/registries → registries}/validators.mjs +0 -0
  1248. /package/dist/services/{entity-service → document-service}/attributes/transforms.js +0 -0
  1249. /package/dist/services/{entity-service → document-service}/attributes/transforms.mjs +0 -0
@@ -0,0 +1,75 @@
1
+ import _ from "lodash";
2
+ import { yup, strings } from "@strapi/utils";
3
+ const LIFECYCLES = [
4
+ "beforeCreate",
5
+ "afterCreate",
6
+ "beforeFindOne",
7
+ "afterFindOne",
8
+ "beforeFindMany",
9
+ "afterFindMany",
10
+ "beforeCount",
11
+ "afterCount",
12
+ "beforeCreateMany",
13
+ "afterCreateMany",
14
+ "beforeUpdate",
15
+ "afterUpdate",
16
+ "beforeUpdateMany",
17
+ "afterUpdateMany",
18
+ "beforeDelete",
19
+ "afterDelete",
20
+ "beforeDeleteMany",
21
+ "afterDeleteMany"
22
+ ];
23
+ const GRAPHQL_ENUM_REGEX = /^[_A-Za-z][_0-9A-Za-z]*$/;
24
+ const lifecyclesShape = _.mapValues(_.keyBy(LIFECYCLES), () => yup.mixed().nullable().isFunction());
25
+ const contentTypeSchemaValidator = yup.object().shape({
26
+ schema: yup.object().shape({
27
+ info: yup.object().shape({
28
+ displayName: yup.string().required(),
29
+ singularName: yup.string().isKebabCase().required(),
30
+ pluralName: yup.string().isKebabCase().required()
31
+ }).required(),
32
+ attributes: yup.object().test({
33
+ name: "valuesCollide",
34
+ message: "Some values collide when normalized",
35
+ test(attributes) {
36
+ for (const attrName of Object.keys(attributes)) {
37
+ const attr = attributes[attrName];
38
+ if (attr.type === "enumeration") {
39
+ const regressedValues = attr.enum.map(strings.toRegressedEnumValue);
40
+ if (!regressedValues.every((value) => GRAPHQL_ENUM_REGEX.test(value))) {
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
+ return this.createError({ message });
43
+ }
44
+ if (regressedValues.some((value) => value === "")) {
45
+ return this.createError({
46
+ message: `At least one value of the enumeration '${attrName}' appears to be empty. Only alphanumerical characters are taken into account.`
47
+ });
48
+ }
49
+ const duplicates = _.uniq(
50
+ regressedValues.filter(
51
+ (value, index, values) => values.indexOf(value) !== index
52
+ )
53
+ );
54
+ if (duplicates.length) {
55
+ const message = `Some enumeration values of the field '${attrName}' collide when normalized: ${duplicates.join(
56
+ ", "
57
+ )}. Please modify your enumeration.`;
58
+ return this.createError({ message });
59
+ }
60
+ }
61
+ }
62
+ return true;
63
+ }
64
+ })
65
+ }),
66
+ actions: yup.object().onlyContainsFunctions(),
67
+ lifecycles: yup.object().shape(lifecyclesShape).noUnknown()
68
+ });
69
+ const validateContentTypeDefinition = (data) => {
70
+ return contentTypeSchemaValidator.validateSync(data, { strict: true, abortEarly: false });
71
+ };
72
+ export {
73
+ validateContentTypeDefinition
74
+ };
75
+ //# sourceMappingURL=validator.mjs.map
@@ -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;"}
@@ -0,0 +1,40 @@
1
+ import { type PropertyPath } from 'lodash';
2
+ import type { Core, UID, Struct } from '@strapi/types';
3
+ export interface RawModule {
4
+ config?: Record<string, unknown>;
5
+ routes?: Core.Module['routes'];
6
+ controllers?: Core.Module['controllers'];
7
+ services?: Core.Module['services'];
8
+ contentTypes?: Core.Module['contentTypes'];
9
+ policies?: Core.Module['policies'];
10
+ middlewares?: Core.Module['middlewares'];
11
+ bootstrap?: (params: {
12
+ strapi: Core.Strapi;
13
+ }) => Promise<void>;
14
+ register?: (params: {
15
+ strapi: Core.Strapi;
16
+ }) => Promise<void>;
17
+ destroy?: (params: {
18
+ strapi: Core.Strapi;
19
+ }) => Promise<void>;
20
+ }
21
+ export interface Module {
22
+ bootstrap: () => Promise<void>;
23
+ register: () => Promise<void>;
24
+ destroy: () => Promise<void>;
25
+ load: () => void;
26
+ routes: Core.Module['routes'];
27
+ config<T = unknown>(key: PropertyPath, defaultVal?: T): T;
28
+ contentType: (ctName: UID.ContentType) => Struct.ContentTypeSchema;
29
+ contentTypes: Record<string, Struct.ContentTypeSchema>;
30
+ service: (serviceName: UID.Service) => Core.Service;
31
+ services: Record<string, Core.Service>;
32
+ policy: (policyName: UID.Policy) => Core.Policy;
33
+ policies: Record<string, Core.Policy>;
34
+ middleware: (middlewareName: UID.Middleware) => Core.Middleware;
35
+ middlewares: Record<string, Core.Middleware>;
36
+ controller: (controllerName: UID.Controller) => Core.Controller;
37
+ controllers: Record<string, Core.Controller>;
38
+ }
39
+ export declare const createModule: (namespace: string, rawModule: RawModule, strapi: Core.Strapi) => Module;
40
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/domain/module/index.ts"],"names":[],"mappings":"AAAA,OAAU,EAAE,KAAK,YAAY,EAAW,MAAM,QAAQ,CAAC;AAEvD,OAAO,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAWvD,MAAM,WAAW,SAAS;IACxB,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACjC,MAAM,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;IAC/B,WAAW,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;IACzC,QAAQ,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;IACnC,YAAY,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC;IAC3C,QAAQ,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;IACnC,WAAW,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;IACzC,SAAS,CAAC,EAAE,CAAC,MAAM,EAAE;QAAE,MAAM,EAAE,IAAI,CAAC,MAAM,CAAA;KAAE,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAC/D,QAAQ,CAAC,EAAE,CAAC,MAAM,EAAE;QAAE,MAAM,EAAE,IAAI,CAAC,MAAM,CAAA;KAAE,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAC9D,OAAO,CAAC,EAAE,CAAC,MAAM,EAAE;QAAE,MAAM,EAAE,IAAI,CAAC,MAAM,CAAA;KAAE,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;CAC9D;AAED,MAAM,WAAW,MAAM;IACrB,SAAS,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IAC/B,QAAQ,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IAC9B,OAAO,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IAC7B,IAAI,EAAE,MAAM,IAAI,CAAC;IACjB,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;IAC9B,MAAM,CAAC,CAAC,GAAG,OAAO,EAAE,GAAG,EAAE,YAAY,EAAE,UAAU,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;IAC1D,WAAW,EAAE,CAAC,MAAM,EAAE,GAAG,CAAC,WAAW,KAAK,MAAM,CAAC,iBAAiB,CAAC;IACnE,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,iBAAiB,CAAC,CAAC;IACvD,OAAO,EAAE,CAAC,WAAW,EAAE,GAAG,CAAC,OAAO,KAAK,IAAI,CAAC,OAAO,CAAC;IACpD,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;IACvC,MAAM,EAAE,CAAC,UAAU,EAAE,GAAG,CAAC,MAAM,KAAK,IAAI,CAAC,MAAM,CAAC;IAChD,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;IACtC,UAAU,EAAE,CAAC,cAAc,EAAE,GAAG,CAAC,UAAU,KAAK,IAAI,CAAC,UAAU,CAAC;IAChE,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;IAC7C,UAAU,EAAE,CAAC,cAAc,EAAE,GAAG,CAAC,UAAU,KAAK,IAAI,CAAC,UAAU,CAAC;IAChE,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;CAC9C;AAiBD,eAAO,MAAM,YAAY,cACZ,MAAM,aACN,SAAS,UACZ,KAAK,MAAM,KAClB,MAqFF,CAAC"}
@@ -0,0 +1,107 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const _ = require("lodash");
4
+ const strapiUtils = require("@strapi/utils");
5
+ const namespace = require("../../registries/namespace.js");
6
+ const validation = require("./validation.js");
7
+ const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
8
+ const ___default = /* @__PURE__ */ _interopDefault(_);
9
+ const removeNamespacedKeys = (map, namespace$1) => {
10
+ return ___default.default.mapKeys(map, (value, key) => namespace.removeNamespace(key, namespace$1));
11
+ };
12
+ const defaultModule = {
13
+ config: {},
14
+ routes: [],
15
+ controllers: {},
16
+ services: {},
17
+ contentTypes: {},
18
+ policies: {},
19
+ middlewares: {}
20
+ };
21
+ const createModule = (namespace2, rawModule, strapi) => {
22
+ ___default.default.defaults(rawModule, defaultModule);
23
+ try {
24
+ validation.validateModule(rawModule);
25
+ } catch (e) {
26
+ if (e instanceof strapiUtils.yup.ValidationError) {
27
+ throw new Error(`strapi-server.js is invalid for '${namespace2}'.
28
+ ${e.errors.join("\n")}`);
29
+ }
30
+ }
31
+ const called = {};
32
+ return {
33
+ async bootstrap() {
34
+ if (called.bootstrap) {
35
+ throw new Error(`Bootstrap for ${namespace2} has already been called`);
36
+ }
37
+ called.bootstrap = true;
38
+ await (rawModule.bootstrap && rawModule.bootstrap({ strapi }));
39
+ },
40
+ async register() {
41
+ if (called.register) {
42
+ throw new Error(`Register for ${namespace2} has already been called`);
43
+ }
44
+ called.register = true;
45
+ await (rawModule.register && rawModule.register({ strapi }));
46
+ },
47
+ async destroy() {
48
+ if (called.destroy) {
49
+ throw new Error(`Destroy for ${namespace2} has already been called`);
50
+ }
51
+ called.destroy = true;
52
+ await (rawModule.destroy && rawModule.destroy({ strapi }));
53
+ },
54
+ load() {
55
+ strapi.get("content-types").add(namespace2, rawModule.contentTypes);
56
+ strapi.get("services").add(namespace2, rawModule.services);
57
+ strapi.get("policies").add(namespace2, rawModule.policies);
58
+ strapi.get("middlewares").add(namespace2, rawModule.middlewares);
59
+ strapi.get("controllers").add(namespace2, rawModule.controllers);
60
+ strapi.get("config").set(namespace2, rawModule.config);
61
+ },
62
+ get routes() {
63
+ return rawModule.routes ?? {};
64
+ },
65
+ config(path, defaultValue) {
66
+ const pathArray = _.flatten([namespace2, path]);
67
+ return strapi.get("config").get(pathArray, defaultValue);
68
+ },
69
+ contentType(ctName) {
70
+ return strapi.get("content-types").get(`${namespace2}.${ctName}`);
71
+ },
72
+ get contentTypes() {
73
+ const contentTypes = strapi.get("content-types").getAll(namespace2);
74
+ return removeNamespacedKeys(contentTypes, namespace2);
75
+ },
76
+ service(serviceName) {
77
+ return strapi.get("services").get(`${namespace2}.${serviceName}`);
78
+ },
79
+ get services() {
80
+ const services = strapi.get("services").getAll(namespace2);
81
+ return removeNamespacedKeys(services, namespace2);
82
+ },
83
+ policy(policyName) {
84
+ return strapi.get("policies").get(`${namespace2}.${policyName}`);
85
+ },
86
+ get policies() {
87
+ const policies = strapi.get("policies").getAll(namespace2);
88
+ return removeNamespacedKeys(policies, namespace2);
89
+ },
90
+ middleware(middlewareName) {
91
+ return strapi.get("middlewares").get(`${namespace2}.${middlewareName}`);
92
+ },
93
+ get middlewares() {
94
+ const middlewares = strapi.get("middlewares").getAll(namespace2);
95
+ return removeNamespacedKeys(middlewares, namespace2);
96
+ },
97
+ controller(controllerName) {
98
+ return strapi.get("controllers").get(`${namespace2}.${controllerName}`);
99
+ },
100
+ get controllers() {
101
+ const controllers = strapi.get("controllers").getAll(namespace2);
102
+ return removeNamespacedKeys(controllers, namespace2);
103
+ }
104
+ };
105
+ };
106
+ exports.createModule = createModule;
107
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../../../src/domain/module/index.ts"],"sourcesContent":["import _, { type PropertyPath, flatten } from 'lodash';\nimport { yup } from '@strapi/utils';\nimport type { Core, UID, Struct } from '@strapi/types';\n\nimport { removeNamespace } from '../../registries/namespace';\nimport { validateModule } from './validation';\n\ninterface LifecyclesState {\n bootstrap?: boolean;\n register?: boolean;\n destroy?: boolean;\n}\n\nexport interface RawModule {\n config?: Record<string, unknown>;\n routes?: Core.Module['routes'];\n controllers?: Core.Module['controllers'];\n services?: Core.Module['services'];\n contentTypes?: Core.Module['contentTypes'];\n policies?: Core.Module['policies'];\n middlewares?: Core.Module['middlewares'];\n bootstrap?: (params: { strapi: Core.Strapi }) => Promise<void>;\n register?: (params: { strapi: Core.Strapi }) => Promise<void>;\n destroy?: (params: { strapi: Core.Strapi }) => Promise<void>;\n}\n\nexport interface Module {\n bootstrap: () => Promise<void>;\n register: () => Promise<void>;\n destroy: () => Promise<void>;\n load: () => void;\n routes: Core.Module['routes'];\n config<T = unknown>(key: PropertyPath, defaultVal?: T): T; // TODO: this mirrors ConfigProvider.get, we should use it directly\n contentType: (ctName: UID.ContentType) => Struct.ContentTypeSchema;\n contentTypes: Record<string, Struct.ContentTypeSchema>;\n service: (serviceName: UID.Service) => Core.Service;\n services: Record<string, Core.Service>;\n policy: (policyName: UID.Policy) => Core.Policy;\n policies: Record<string, Core.Policy>;\n middleware: (middlewareName: UID.Middleware) => Core.Middleware;\n middlewares: Record<string, Core.Middleware>;\n controller: (controllerName: UID.Controller) => Core.Controller;\n controllers: Record<string, Core.Controller>;\n}\n\n// Removes the namespace from a map with keys prefixed with a namespace\nconst removeNamespacedKeys = <T extends Record<string, unknown>>(map: T, namespace: string) => {\n return _.mapKeys(map, (value, key) => removeNamespace(key, namespace));\n};\n\nconst defaultModule = {\n config: {},\n routes: [],\n controllers: {},\n services: {},\n contentTypes: {},\n policies: {},\n middlewares: {},\n};\n\nexport const createModule = (\n namespace: string,\n rawModule: RawModule,\n strapi: Core.Strapi\n): Module => {\n _.defaults(rawModule, defaultModule);\n\n try {\n validateModule(rawModule);\n } catch (e) {\n if (e instanceof yup.ValidationError) {\n throw new Error(`strapi-server.js is invalid for '${namespace}'.\\n${e.errors.join('\\n')}`);\n }\n }\n\n const called: LifecyclesState = {};\n return {\n async bootstrap() {\n if (called.bootstrap) {\n throw new Error(`Bootstrap for ${namespace} has already been called`);\n }\n called.bootstrap = true;\n await (rawModule.bootstrap && rawModule.bootstrap({ strapi }));\n },\n async register() {\n if (called.register) {\n throw new Error(`Register for ${namespace} has already been called`);\n }\n called.register = true;\n await (rawModule.register && rawModule.register({ strapi }));\n },\n async destroy() {\n if (called.destroy) {\n throw new Error(`Destroy for ${namespace} has already been called`);\n }\n called.destroy = true;\n await (rawModule.destroy && rawModule.destroy({ strapi }));\n },\n load() {\n strapi.get('content-types').add(namespace, rawModule.contentTypes);\n strapi.get('services').add(namespace, rawModule.services);\n strapi.get('policies').add(namespace, rawModule.policies);\n strapi.get('middlewares').add(namespace, rawModule.middlewares);\n strapi.get('controllers').add(namespace, rawModule.controllers);\n strapi.get('config').set(namespace, rawModule.config);\n },\n get routes() {\n return rawModule.routes ?? {};\n },\n config(path: PropertyPath, defaultValue: unknown) {\n const pathArray = flatten([namespace, path]);\n return strapi.get('config').get(pathArray, defaultValue);\n },\n contentType(ctName: UID.ContentType) {\n return strapi.get('content-types').get(`${namespace}.${ctName}`);\n },\n get contentTypes() {\n const contentTypes = strapi.get('content-types').getAll(namespace);\n return removeNamespacedKeys(contentTypes, namespace);\n },\n service(serviceName: UID.Service) {\n return strapi.get('services').get(`${namespace}.${serviceName}`);\n },\n get services() {\n const services = strapi.get('services').getAll(namespace);\n return removeNamespacedKeys(services, namespace);\n },\n policy(policyName: UID.Policy) {\n return strapi.get('policies').get(`${namespace}.${policyName}`);\n },\n get policies() {\n const policies = strapi.get('policies').getAll(namespace);\n return removeNamespacedKeys(policies, namespace);\n },\n middleware(middlewareName: UID.Middleware) {\n return strapi.get('middlewares').get(`${namespace}.${middlewareName}`);\n },\n get middlewares() {\n const middlewares = strapi.get('middlewares').getAll(namespace);\n return removeNamespacedKeys(middlewares, namespace);\n },\n controller(controllerName: UID.Controller) {\n return strapi.get('controllers').get(`${namespace}.${controllerName}`);\n },\n get controllers() {\n const controllers = strapi.get('controllers').getAll(namespace);\n return removeNamespacedKeys(controllers, namespace);\n },\n };\n};\n"],"names":["namespace","_","removeNamespace","validateModule","yup","flatten"],"mappings":"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"}
@@ -0,0 +1,105 @@
1
+ import _, { flatten } from "lodash";
2
+ import { yup } from "@strapi/utils";
3
+ import { removeNamespace } from "../../registries/namespace.mjs";
4
+ import { validateModule } from "./validation.mjs";
5
+ const removeNamespacedKeys = (map, namespace) => {
6
+ return _.mapKeys(map, (value, key) => removeNamespace(key, namespace));
7
+ };
8
+ const defaultModule = {
9
+ config: {},
10
+ routes: [],
11
+ controllers: {},
12
+ services: {},
13
+ contentTypes: {},
14
+ policies: {},
15
+ middlewares: {}
16
+ };
17
+ const createModule = (namespace, rawModule, strapi) => {
18
+ _.defaults(rawModule, defaultModule);
19
+ try {
20
+ validateModule(rawModule);
21
+ } catch (e) {
22
+ if (e instanceof yup.ValidationError) {
23
+ throw new Error(`strapi-server.js is invalid for '${namespace}'.
24
+ ${e.errors.join("\n")}`);
25
+ }
26
+ }
27
+ const called = {};
28
+ return {
29
+ async bootstrap() {
30
+ if (called.bootstrap) {
31
+ throw new Error(`Bootstrap for ${namespace} has already been called`);
32
+ }
33
+ called.bootstrap = true;
34
+ await (rawModule.bootstrap && rawModule.bootstrap({ strapi }));
35
+ },
36
+ async register() {
37
+ if (called.register) {
38
+ throw new Error(`Register for ${namespace} has already been called`);
39
+ }
40
+ called.register = true;
41
+ await (rawModule.register && rawModule.register({ strapi }));
42
+ },
43
+ async destroy() {
44
+ if (called.destroy) {
45
+ throw new Error(`Destroy for ${namespace} has already been called`);
46
+ }
47
+ called.destroy = true;
48
+ await (rawModule.destroy && rawModule.destroy({ strapi }));
49
+ },
50
+ load() {
51
+ strapi.get("content-types").add(namespace, rawModule.contentTypes);
52
+ strapi.get("services").add(namespace, rawModule.services);
53
+ strapi.get("policies").add(namespace, rawModule.policies);
54
+ strapi.get("middlewares").add(namespace, rawModule.middlewares);
55
+ strapi.get("controllers").add(namespace, rawModule.controllers);
56
+ strapi.get("config").set(namespace, rawModule.config);
57
+ },
58
+ get routes() {
59
+ return rawModule.routes ?? {};
60
+ },
61
+ config(path, defaultValue) {
62
+ const pathArray = flatten([namespace, path]);
63
+ return strapi.get("config").get(pathArray, defaultValue);
64
+ },
65
+ contentType(ctName) {
66
+ return strapi.get("content-types").get(`${namespace}.${ctName}`);
67
+ },
68
+ get contentTypes() {
69
+ const contentTypes = strapi.get("content-types").getAll(namespace);
70
+ return removeNamespacedKeys(contentTypes, namespace);
71
+ },
72
+ service(serviceName) {
73
+ return strapi.get("services").get(`${namespace}.${serviceName}`);
74
+ },
75
+ get services() {
76
+ const services = strapi.get("services").getAll(namespace);
77
+ return removeNamespacedKeys(services, namespace);
78
+ },
79
+ policy(policyName) {
80
+ return strapi.get("policies").get(`${namespace}.${policyName}`);
81
+ },
82
+ get policies() {
83
+ const policies = strapi.get("policies").getAll(namespace);
84
+ return removeNamespacedKeys(policies, namespace);
85
+ },
86
+ middleware(middlewareName) {
87
+ return strapi.get("middlewares").get(`${namespace}.${middlewareName}`);
88
+ },
89
+ get middlewares() {
90
+ const middlewares = strapi.get("middlewares").getAll(namespace);
91
+ return removeNamespacedKeys(middlewares, namespace);
92
+ },
93
+ controller(controllerName) {
94
+ return strapi.get("controllers").get(`${namespace}.${controllerName}`);
95
+ },
96
+ get controllers() {
97
+ const controllers = strapi.get("controllers").getAll(namespace);
98
+ return removeNamespacedKeys(controllers, namespace);
99
+ }
100
+ };
101
+ };
102
+ export {
103
+ createModule
104
+ };
105
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.mjs","sources":["../../../src/domain/module/index.ts"],"sourcesContent":["import _, { type PropertyPath, flatten } from 'lodash';\nimport { yup } from '@strapi/utils';\nimport type { Core, UID, Struct } from '@strapi/types';\n\nimport { removeNamespace } from '../../registries/namespace';\nimport { validateModule } from './validation';\n\ninterface LifecyclesState {\n bootstrap?: boolean;\n register?: boolean;\n destroy?: boolean;\n}\n\nexport interface RawModule {\n config?: Record<string, unknown>;\n routes?: Core.Module['routes'];\n controllers?: Core.Module['controllers'];\n services?: Core.Module['services'];\n contentTypes?: Core.Module['contentTypes'];\n policies?: Core.Module['policies'];\n middlewares?: Core.Module['middlewares'];\n bootstrap?: (params: { strapi: Core.Strapi }) => Promise<void>;\n register?: (params: { strapi: Core.Strapi }) => Promise<void>;\n destroy?: (params: { strapi: Core.Strapi }) => Promise<void>;\n}\n\nexport interface Module {\n bootstrap: () => Promise<void>;\n register: () => Promise<void>;\n destroy: () => Promise<void>;\n load: () => void;\n routes: Core.Module['routes'];\n config<T = unknown>(key: PropertyPath, defaultVal?: T): T; // TODO: this mirrors ConfigProvider.get, we should use it directly\n contentType: (ctName: UID.ContentType) => Struct.ContentTypeSchema;\n contentTypes: Record<string, Struct.ContentTypeSchema>;\n service: (serviceName: UID.Service) => Core.Service;\n services: Record<string, Core.Service>;\n policy: (policyName: UID.Policy) => Core.Policy;\n policies: Record<string, Core.Policy>;\n middleware: (middlewareName: UID.Middleware) => Core.Middleware;\n middlewares: Record<string, Core.Middleware>;\n controller: (controllerName: UID.Controller) => Core.Controller;\n controllers: Record<string, Core.Controller>;\n}\n\n// Removes the namespace from a map with keys prefixed with a namespace\nconst removeNamespacedKeys = <T extends Record<string, unknown>>(map: T, namespace: string) => {\n return _.mapKeys(map, (value, key) => removeNamespace(key, namespace));\n};\n\nconst defaultModule = {\n config: {},\n routes: [],\n controllers: {},\n services: {},\n contentTypes: {},\n policies: {},\n middlewares: {},\n};\n\nexport const createModule = (\n namespace: string,\n rawModule: RawModule,\n strapi: Core.Strapi\n): Module => {\n _.defaults(rawModule, defaultModule);\n\n try {\n validateModule(rawModule);\n } catch (e) {\n if (e instanceof yup.ValidationError) {\n throw new Error(`strapi-server.js is invalid for '${namespace}'.\\n${e.errors.join('\\n')}`);\n }\n }\n\n const called: LifecyclesState = {};\n return {\n async bootstrap() {\n if (called.bootstrap) {\n throw new Error(`Bootstrap for ${namespace} has already been called`);\n }\n called.bootstrap = true;\n await (rawModule.bootstrap && rawModule.bootstrap({ strapi }));\n },\n async register() {\n if (called.register) {\n throw new Error(`Register for ${namespace} has already been called`);\n }\n called.register = true;\n await (rawModule.register && rawModule.register({ strapi }));\n },\n async destroy() {\n if (called.destroy) {\n throw new Error(`Destroy for ${namespace} has already been called`);\n }\n called.destroy = true;\n await (rawModule.destroy && rawModule.destroy({ strapi }));\n },\n load() {\n strapi.get('content-types').add(namespace, rawModule.contentTypes);\n strapi.get('services').add(namespace, rawModule.services);\n strapi.get('policies').add(namespace, rawModule.policies);\n strapi.get('middlewares').add(namespace, rawModule.middlewares);\n strapi.get('controllers').add(namespace, rawModule.controllers);\n strapi.get('config').set(namespace, rawModule.config);\n },\n get routes() {\n return rawModule.routes ?? {};\n },\n config(path: PropertyPath, defaultValue: unknown) {\n const pathArray = flatten([namespace, path]);\n return strapi.get('config').get(pathArray, defaultValue);\n },\n contentType(ctName: UID.ContentType) {\n return strapi.get('content-types').get(`${namespace}.${ctName}`);\n },\n get contentTypes() {\n const contentTypes = strapi.get('content-types').getAll(namespace);\n return removeNamespacedKeys(contentTypes, namespace);\n },\n service(serviceName: UID.Service) {\n return strapi.get('services').get(`${namespace}.${serviceName}`);\n },\n get services() {\n const services = strapi.get('services').getAll(namespace);\n return removeNamespacedKeys(services, namespace);\n },\n policy(policyName: UID.Policy) {\n return strapi.get('policies').get(`${namespace}.${policyName}`);\n },\n get policies() {\n const policies = strapi.get('policies').getAll(namespace);\n return removeNamespacedKeys(policies, namespace);\n },\n middleware(middlewareName: UID.Middleware) {\n return strapi.get('middlewares').get(`${namespace}.${middlewareName}`);\n },\n get middlewares() {\n const middlewares = strapi.get('middlewares').getAll(namespace);\n return removeNamespacedKeys(middlewares, namespace);\n },\n controller(controllerName: UID.Controller) {\n return strapi.get('controllers').get(`${namespace}.${controllerName}`);\n },\n get controllers() {\n const controllers = strapi.get('controllers').getAll(namespace);\n return removeNamespacedKeys(controllers, namespace);\n },\n };\n};\n"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validation.d.ts","sourceRoot":"","sources":["../../../src/domain/module/validation.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,eAAe,CAAC;AAuBpC,QAAA,MAAM,cAAc,SAAU,OAAO;;;;;;;;;;;GAEpC,CAAC;AAEF,OAAO,EAAE,cAAc,EAAE,CAAC"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validation.js","sources":["../../../src/domain/module/validation.ts"],"sourcesContent":["import { yup } from '@strapi/utils';\n\nconst strapiServerSchema = yup\n .object()\n .shape({\n bootstrap: yup.mixed().isFunction(),\n destroy: yup.mixed().isFunction(),\n register: yup.mixed().isFunction(),\n config: yup.object(),\n routes: yup.lazy((value) => {\n if (Array.isArray(value)) {\n return yup.array();\n }\n return yup.object();\n }),\n controllers: yup.object(),\n services: yup.object(),\n policies: yup.object(),\n middlewares: yup.object(),\n contentTypes: yup.object(),\n })\n .noUnknown();\n\nconst validateModule = (data: unknown) => {\n return strapiServerSchema.validateSync(data, { strict: true, abortEarly: false });\n};\n\nexport { validateModule };\n"],"names":["yup"],"mappings":";;;AAEA,MAAM,qBAAqBA,YAAA,IACxB,OAAO,EACP,MAAM;AAAA,EACL,WAAWA,YAAA,IAAI,MAAM,EAAE,WAAW;AAAA,EAClC,SAASA,YAAA,IAAI,MAAM,EAAE,WAAW;AAAA,EAChC,UAAUA,YAAA,IAAI,MAAM,EAAE,WAAW;AAAA,EACjC,QAAQA,gBAAI,OAAO;AAAA,EACnB,QAAQA,YAAA,IAAI,KAAK,CAAC,UAAU;AACtB,QAAA,MAAM,QAAQ,KAAK,GAAG;AACxB,aAAOA,YAAAA,IAAI;IACb;AACA,WAAOA,YAAAA,IAAI;EAAO,CACnB;AAAA,EACD,aAAaA,gBAAI,OAAO;AAAA,EACxB,UAAUA,gBAAI,OAAO;AAAA,EACrB,UAAUA,gBAAI,OAAO;AAAA,EACrB,aAAaA,gBAAI,OAAO;AAAA,EACxB,cAAcA,gBAAI,OAAO;AAC3B,CAAC,EACA,UAAU;AAEP,MAAA,iBAAiB,CAAC,SAAkB;AACjC,SAAA,mBAAmB,aAAa,MAAM,EAAE,QAAQ,MAAM,YAAY,OAAO;AAClF;;"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validation.mjs","sources":["../../../src/domain/module/validation.ts"],"sourcesContent":["import { yup } from '@strapi/utils';\n\nconst strapiServerSchema = yup\n .object()\n .shape({\n bootstrap: yup.mixed().isFunction(),\n destroy: yup.mixed().isFunction(),\n register: yup.mixed().isFunction(),\n config: yup.object(),\n routes: yup.lazy((value) => {\n if (Array.isArray(value)) {\n return yup.array();\n }\n return yup.object();\n }),\n controllers: yup.object(),\n services: yup.object(),\n policies: yup.object(),\n middlewares: yup.object(),\n contentTypes: yup.object(),\n })\n .noUnknown();\n\nconst validateModule = (data: unknown) => {\n return strapiServerSchema.validateSync(data, { strict: true, abortEarly: false });\n};\n\nexport { validateModule };\n"],"names":[],"mappings":";AAEA,MAAM,qBAAqB,IACxB,OAAO,EACP,MAAM;AAAA,EACL,WAAW,IAAI,MAAM,EAAE,WAAW;AAAA,EAClC,SAAS,IAAI,MAAM,EAAE,WAAW;AAAA,EAChC,UAAU,IAAI,MAAM,EAAE,WAAW;AAAA,EACjC,QAAQ,IAAI,OAAO;AAAA,EACnB,QAAQ,IAAI,KAAK,CAAC,UAAU;AACtB,QAAA,MAAM,QAAQ,KAAK,GAAG;AACxB,aAAO,IAAI;IACb;AACA,WAAO,IAAI;EAAO,CACnB;AAAA,EACD,aAAa,IAAI,OAAO;AAAA,EACxB,UAAU,IAAI,OAAO;AAAA,EACrB,UAAU,IAAI,OAAO;AAAA,EACrB,aAAa,IAAI,OAAO;AAAA,EACxB,cAAc,IAAI,OAAO;AAC3B,CAAC,EACA,UAAU;AAEP,MAAA,iBAAiB,CAAC,SAAkB;AACjC,SAAA,mBAAmB,aAAa,MAAM,EAAE,QAAQ,MAAM,YAAY,OAAO;AAClF;"}
@@ -1,16 +1,18 @@
1
- import type { Strapi } from '@strapi/types';
1
+ import type { Core } from '@strapi/types';
2
2
  declare const _default: Readonly<{
3
3
  init: (licenseDir: string, logger?: import("winston").Logger | undefined) => void;
4
4
  checkLicense: ({ strapi }: {
5
- strapi: Strapi;
5
+ strapi: Core.Strapi;
6
6
  }) => Promise<void>;
7
7
  readonly isEE: boolean;
8
8
  readonly seats: number | undefined;
9
9
  features: Readonly<{
10
10
  list: () => {
11
+ [key: string]: any;
11
12
  name: string;
12
13
  }[];
13
14
  get: (featureName: string) => {
15
+ [key: string]: any;
14
16
  name: string;
15
17
  } | undefined;
16
18
  isEnabled: (featureName: string) => boolean;
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/ee/index.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;;;;;;;;;;;;;;;iCAgPf,MAAM;;;AAfnC,wBAiBG"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/ee/index.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;;;;;;;;;;;;;;;;;iCAgPb,MAAM;;;AAfnC,wBAiBG"}
package/dist/ee/index.js CHANGED
@@ -134,7 +134,7 @@ const list = () => {
134
134
  ) || [];
135
135
  };
136
136
  const get = (featureName) => list().find((feature) => feature.name === featureName);
137
- const EE = Object.freeze({
137
+ const index = Object.freeze({
138
138
  init,
139
139
  checkLicense,
140
140
  get isEE() {
@@ -149,5 +149,5 @@ const EE = Object.freeze({
149
149
  isEnabled: (featureName) => get(featureName) !== void 0
150
150
  })
151
151
  });
152
- module.exports = EE;
152
+ module.exports = index;
153
153
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../src/ee/index.ts"],"sourcesContent":["import { pick, isEqual } from 'lodash/fp';\nimport type { Logger } from '@strapi/logger';\nimport type { Strapi } from '@strapi/types';\n\nimport { readLicense, verifyLicense, fetchLicense, LicenseCheckError } from './license';\nimport { shiftCronExpression } from '../utils/cron';\n\nconst ONE_MINUTE = 1000 * 60;\n\ninterface EE {\n enabled: boolean;\n licenseInfo: {\n licenseKey?: string;\n features?: Array<{ name: string } | string>;\n expireAt?: string;\n seats?: number;\n type?: string;\n };\n logger?: Logger;\n}\n\nconst ee: EE = {\n enabled: false,\n licenseInfo: {},\n};\n\nconst disable = (message: string) => {\n // Prevent emitting ee.disable if it was already disabled\n const shouldEmitEvent = ee.enabled !== false;\n\n ee.logger?.warn(`${message} Switching to CE.`);\n // Only keep the license key for potential re-enabling during a later check\n ee.licenseInfo = pick('licenseKey', ee.licenseInfo);\n\n ee.enabled = false;\n\n if (shouldEmitEvent) {\n // Notify EE features that they should be disabled\n strapi.eventHub.emit('ee.disable');\n }\n};\n\nconst enable = () => {\n // Prevent emitting ee.enable if it was already enabled\n const shouldEmitEvent = ee.enabled !== true;\n\n ee.enabled = true;\n\n if (shouldEmitEvent) {\n // Notify EE features that they should be disabled\n strapi.eventHub.emit('ee.enable');\n }\n};\n\nlet initialized = false;\n\n/**\n * Optimistically enable EE if the format of the license is valid, only run once.\n */\nconst init = (licenseDir: string, logger?: Logger) => {\n if (initialized) {\n return;\n }\n\n initialized = true;\n ee.logger = logger;\n\n if (process.env.STRAPI_DISABLE_EE?.toLowerCase() === 'true') {\n return;\n }\n\n try {\n const license = process.env.STRAPI_LICENSE || readLicense(licenseDir);\n\n if (license) {\n ee.licenseInfo = verifyLicense(license);\n enable();\n }\n } catch (error) {\n if (error instanceof Error) {\n disable(error.message);\n } else {\n disable('Invalid license.');\n }\n }\n};\n\n/**\n * Contact the license registry to update the license to its latest state.\n *\n * Store the result in database to avoid unecessary requests, and will fallback to that in case of a network failure.\n */\nconst onlineUpdate = async ({ strapi }: { strapi: Strapi }) => {\n const { get, commit, rollback } = (await strapi.db?.transaction()) as any;\n const transaction = get();\n\n try {\n const storedInfo = await strapi.db\n ?.queryBuilder('strapi::core-store')\n .where({ key: 'ee_information' })\n .select('value')\n .first()\n .transacting(transaction)\n .forUpdate()\n .execute()\n .then((result: any) => (result ? JSON.parse(result.value) : result));\n\n const shouldContactRegistry = (storedInfo?.lastCheckAt ?? 0) < Date.now() - ONE_MINUTE;\n const result: {\n license?: string | null;\n error?: string;\n lastCheckAt?: number;\n } = { lastCheckAt: Date.now() };\n\n const fallback = (error: Error) => {\n if (error instanceof LicenseCheckError && error.shouldFallback && storedInfo?.license) {\n ee.logger?.warn(\n `${error.message} The last stored one will be used as a potential fallback.`\n );\n return storedInfo.license;\n }\n\n result.error = error.message;\n disable(error.message);\n };\n\n if (!ee?.licenseInfo?.licenseKey) {\n throw new Error('Missing license key.');\n }\n\n const license = shouldContactRegistry\n ? await fetchLicense({ strapi }, ee.licenseInfo.licenseKey, strapi.config.get('uuid')).catch(\n fallback\n )\n : storedInfo.license;\n\n if (license) {\n try {\n // Verify license and check if its info changed\n const newLicenseInfo = verifyLicense(license);\n const licenseInfoChanged =\n !isEqual(newLicenseInfo.features, ee.licenseInfo.features) ||\n newLicenseInfo.seats !== ee.licenseInfo.seats ||\n newLicenseInfo.type !== ee.licenseInfo.type;\n\n // Store the new license info\n ee.licenseInfo = newLicenseInfo;\n const wasEnabled = ee.enabled;\n validateInfo();\n\n // Notify EE features\n if (licenseInfoChanged && wasEnabled) {\n strapi.eventHub.emit('ee.update');\n }\n } catch (error) {\n if (error instanceof Error) {\n disable(error.message);\n } else {\n disable('Invalid license.');\n }\n }\n } else if (!shouldContactRegistry) {\n disable(storedInfo.error);\n }\n\n if (shouldContactRegistry) {\n result.license = license ?? null;\n const query = strapi.db!.queryBuilder('strapi::core-store').transacting(transaction);\n\n if (!storedInfo) {\n query.insert({ key: 'ee_information', value: JSON.stringify(result) });\n } else {\n query.update({ value: JSON.stringify(result) }).where({ key: 'ee_information' });\n }\n\n await query.execute();\n }\n\n await commit();\n } catch (error) {\n // Example of errors: SQLite does not support FOR UPDATE\n await rollback();\n }\n};\n\nconst validateInfo = () => {\n if (typeof ee.licenseInfo.expireAt === 'undefined') {\n throw new Error('Missing license key.');\n }\n\n const expirationTime = new Date(ee.licenseInfo.expireAt).getTime();\n\n if (expirationTime < new Date().getTime()) {\n return disable('License expired.');\n }\n\n enable();\n};\n\nconst checkLicense = async ({ strapi }: { strapi: Strapi }) => {\n const shouldStayOffline =\n ee.licenseInfo.type === 'gold' &&\n // This env variable support is temporarily used to ease the migration between online vs offline\n process.env.STRAPI_DISABLE_LICENSE_PING?.toLowerCase() === 'true';\n\n if (!shouldStayOffline) {\n await onlineUpdate({ strapi });\n strapi.cron.add({ [shiftCronExpression('0 0 */12 * * *')]: onlineUpdate });\n } else {\n if (!ee.licenseInfo.expireAt) {\n return disable('Your license does not have offline support.');\n }\n\n validateInfo();\n }\n};\n\nconst list = () => {\n return (\n ee.licenseInfo.features?.map((feature) =>\n typeof feature === 'object' ? feature : { name: feature }\n ) || []\n );\n};\n\nconst get = (featureName: string) => list().find((feature) => feature.name === featureName);\n\nexport default Object.freeze({\n init,\n checkLicense,\n\n get isEE() {\n return ee.enabled;\n },\n\n get seats() {\n return ee.licenseInfo.seats;\n },\n\n features: Object.freeze({\n list,\n get,\n isEnabled: (featureName: string) => get(featureName) !== undefined,\n }),\n});\n"],"names":["pick","license","readLicense","verifyLicense","strapi","get","result","LicenseCheckError","fetchLicense","isEqual","shiftCronExpression"],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sources":["../../src/ee/index.ts"],"sourcesContent":["import { pick, isEqual } from 'lodash/fp';\nimport type { Logger } from '@strapi/logger';\nimport type { Core } from '@strapi/types';\n\nimport { readLicense, verifyLicense, fetchLicense, LicenseCheckError } from './license';\nimport { shiftCronExpression } from '../utils/cron';\n\nconst ONE_MINUTE = 1000 * 60;\n\ninterface EE {\n enabled: boolean;\n licenseInfo: {\n licenseKey?: string;\n features?: Array<{ name: string; [key: string]: any } | string>;\n expireAt?: string;\n seats?: number;\n type?: string;\n };\n logger?: Logger;\n}\n\nconst ee: EE = {\n enabled: false,\n licenseInfo: {},\n};\n\nconst disable = (message: string) => {\n // Prevent emitting ee.disable if it was already disabled\n const shouldEmitEvent = ee.enabled !== false;\n\n ee.logger?.warn(`${message} Switching to CE.`);\n // Only keep the license key for potential re-enabling during a later check\n ee.licenseInfo = pick('licenseKey', ee.licenseInfo);\n\n ee.enabled = false;\n\n if (shouldEmitEvent) {\n // Notify EE features that they should be disabled\n strapi.eventHub.emit('ee.disable');\n }\n};\n\nconst enable = () => {\n // Prevent emitting ee.enable if it was already enabled\n const shouldEmitEvent = ee.enabled !== true;\n\n ee.enabled = true;\n\n if (shouldEmitEvent) {\n // Notify EE features that they should be disabled\n strapi.eventHub.emit('ee.enable');\n }\n};\n\nlet initialized = false;\n\n/**\n * Optimistically enable EE if the format of the license is valid, only run once.\n */\nconst init = (licenseDir: string, logger?: Logger) => {\n if (initialized) {\n return;\n }\n\n initialized = true;\n ee.logger = logger;\n\n if (process.env.STRAPI_DISABLE_EE?.toLowerCase() === 'true') {\n return;\n }\n\n try {\n const license = process.env.STRAPI_LICENSE || readLicense(licenseDir);\n\n if (license) {\n ee.licenseInfo = verifyLicense(license);\n enable();\n }\n } catch (error) {\n if (error instanceof Error) {\n disable(error.message);\n } else {\n disable('Invalid license.');\n }\n }\n};\n\n/**\n * Contact the license registry to update the license to its latest state.\n *\n * Store the result in database to avoid unecessary requests, and will fallback to that in case of a network failure.\n */\nconst onlineUpdate = async ({ strapi }: { strapi: Core.Strapi }) => {\n const { get, commit, rollback } = (await strapi.db?.transaction()) as any;\n const transaction = get();\n\n try {\n const storedInfo = await strapi.db\n ?.queryBuilder('strapi::core-store')\n .where({ key: 'ee_information' })\n .select('value')\n .first()\n .transacting(transaction)\n .forUpdate()\n .execute()\n .then((result: any) => (result ? JSON.parse(result.value) : result));\n\n const shouldContactRegistry = (storedInfo?.lastCheckAt ?? 0) < Date.now() - ONE_MINUTE;\n const result: {\n license?: string | null;\n error?: string;\n lastCheckAt?: number;\n } = { lastCheckAt: Date.now() };\n\n const fallback = (error: Error) => {\n if (error instanceof LicenseCheckError && error.shouldFallback && storedInfo?.license) {\n ee.logger?.warn(\n `${error.message} The last stored one will be used as a potential fallback.`\n );\n return storedInfo.license;\n }\n\n result.error = error.message;\n disable(error.message);\n };\n\n if (!ee?.licenseInfo?.licenseKey) {\n throw new Error('Missing license key.');\n }\n\n const license = shouldContactRegistry\n ? await fetchLicense({ strapi }, ee.licenseInfo.licenseKey, strapi.config.get('uuid')).catch(\n fallback\n )\n : storedInfo.license;\n\n if (license) {\n try {\n // Verify license and check if its info changed\n const newLicenseInfo = verifyLicense(license);\n const licenseInfoChanged =\n !isEqual(newLicenseInfo.features, ee.licenseInfo.features) ||\n newLicenseInfo.seats !== ee.licenseInfo.seats ||\n newLicenseInfo.type !== ee.licenseInfo.type;\n\n // Store the new license info\n ee.licenseInfo = newLicenseInfo;\n const wasEnabled = ee.enabled;\n validateInfo();\n\n // Notify EE features\n if (licenseInfoChanged && wasEnabled) {\n strapi.eventHub.emit('ee.update');\n }\n } catch (error) {\n if (error instanceof Error) {\n disable(error.message);\n } else {\n disable('Invalid license.');\n }\n }\n } else if (!shouldContactRegistry) {\n disable(storedInfo.error);\n }\n\n if (shouldContactRegistry) {\n result.license = license ?? null;\n const query = strapi.db.queryBuilder('strapi::core-store').transacting(transaction);\n\n if (!storedInfo) {\n query.insert({ key: 'ee_information', value: JSON.stringify(result) });\n } else {\n query.update({ value: JSON.stringify(result) }).where({ key: 'ee_information' });\n }\n\n await query.execute();\n }\n\n await commit();\n } catch (error) {\n // Example of errors: SQLite does not support FOR UPDATE\n await rollback();\n }\n};\n\nconst validateInfo = () => {\n if (typeof ee.licenseInfo.expireAt === 'undefined') {\n throw new Error('Missing license key.');\n }\n\n const expirationTime = new Date(ee.licenseInfo.expireAt).getTime();\n\n if (expirationTime < new Date().getTime()) {\n return disable('License expired.');\n }\n\n enable();\n};\n\nconst checkLicense = async ({ strapi }: { strapi: Core.Strapi }) => {\n const shouldStayOffline =\n ee.licenseInfo.type === 'gold' &&\n // This env variable support is temporarily used to ease the migration between online vs offline\n process.env.STRAPI_DISABLE_LICENSE_PING?.toLowerCase() === 'true';\n\n if (!shouldStayOffline) {\n await onlineUpdate({ strapi });\n strapi.cron.add({ [shiftCronExpression('0 0 */12 * * *')]: onlineUpdate });\n } else {\n if (!ee.licenseInfo.expireAt) {\n return disable('Your license does not have offline support.');\n }\n\n validateInfo();\n }\n};\n\nconst list = () => {\n return (\n ee.licenseInfo.features?.map((feature) =>\n typeof feature === 'object' ? feature : { name: feature }\n ) || []\n );\n};\n\nconst get = (featureName: string) => list().find((feature) => feature.name === featureName);\n\nexport default Object.freeze({\n init,\n checkLicense,\n\n get isEE() {\n return ee.enabled;\n },\n\n get seats() {\n return ee.licenseInfo.seats;\n },\n\n features: Object.freeze({\n list,\n get,\n isEnabled: (featureName: string) => get(featureName) !== undefined,\n }),\n});\n"],"names":["pick","license","readLicense","verifyLicense","strapi","get","result","LicenseCheckError","fetchLicense","isEqual","shiftCronExpression"],"mappings":"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"}
package/dist/ee/index.mjs CHANGED
@@ -133,7 +133,7 @@ const list = () => {
133
133
  ) || [];
134
134
  };
135
135
  const get = (featureName) => list().find((feature) => feature.name === featureName);
136
- const EE = Object.freeze({
136
+ const index = Object.freeze({
137
137
  init,
138
138
  checkLicense,
139
139
  get isEE() {
@@ -149,6 +149,6 @@ const EE = Object.freeze({
149
149
  })
150
150
  });
151
151
  export {
152
- EE as default
152
+ index as default
153
153
  };
154
154
  //# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","sources":["../../src/ee/index.ts"],"sourcesContent":["import { pick, isEqual } from 'lodash/fp';\nimport type { Logger } from '@strapi/logger';\nimport type { Strapi } from '@strapi/types';\n\nimport { readLicense, verifyLicense, fetchLicense, LicenseCheckError } from './license';\nimport { shiftCronExpression } from '../utils/cron';\n\nconst ONE_MINUTE = 1000 * 60;\n\ninterface EE {\n enabled: boolean;\n licenseInfo: {\n licenseKey?: string;\n features?: Array<{ name: string } | string>;\n expireAt?: string;\n seats?: number;\n type?: string;\n };\n logger?: Logger;\n}\n\nconst ee: EE = {\n enabled: false,\n licenseInfo: {},\n};\n\nconst disable = (message: string) => {\n // Prevent emitting ee.disable if it was already disabled\n const shouldEmitEvent = ee.enabled !== false;\n\n ee.logger?.warn(`${message} Switching to CE.`);\n // Only keep the license key for potential re-enabling during a later check\n ee.licenseInfo = pick('licenseKey', ee.licenseInfo);\n\n ee.enabled = false;\n\n if (shouldEmitEvent) {\n // Notify EE features that they should be disabled\n strapi.eventHub.emit('ee.disable');\n }\n};\n\nconst enable = () => {\n // Prevent emitting ee.enable if it was already enabled\n const shouldEmitEvent = ee.enabled !== true;\n\n ee.enabled = true;\n\n if (shouldEmitEvent) {\n // Notify EE features that they should be disabled\n strapi.eventHub.emit('ee.enable');\n }\n};\n\nlet initialized = false;\n\n/**\n * Optimistically enable EE if the format of the license is valid, only run once.\n */\nconst init = (licenseDir: string, logger?: Logger) => {\n if (initialized) {\n return;\n }\n\n initialized = true;\n ee.logger = logger;\n\n if (process.env.STRAPI_DISABLE_EE?.toLowerCase() === 'true') {\n return;\n }\n\n try {\n const license = process.env.STRAPI_LICENSE || readLicense(licenseDir);\n\n if (license) {\n ee.licenseInfo = verifyLicense(license);\n enable();\n }\n } catch (error) {\n if (error instanceof Error) {\n disable(error.message);\n } else {\n disable('Invalid license.');\n }\n }\n};\n\n/**\n * Contact the license registry to update the license to its latest state.\n *\n * Store the result in database to avoid unecessary requests, and will fallback to that in case of a network failure.\n */\nconst onlineUpdate = async ({ strapi }: { strapi: Strapi }) => {\n const { get, commit, rollback } = (await strapi.db?.transaction()) as any;\n const transaction = get();\n\n try {\n const storedInfo = await strapi.db\n ?.queryBuilder('strapi::core-store')\n .where({ key: 'ee_information' })\n .select('value')\n .first()\n .transacting(transaction)\n .forUpdate()\n .execute()\n .then((result: any) => (result ? JSON.parse(result.value) : result));\n\n const shouldContactRegistry = (storedInfo?.lastCheckAt ?? 0) < Date.now() - ONE_MINUTE;\n const result: {\n license?: string | null;\n error?: string;\n lastCheckAt?: number;\n } = { lastCheckAt: Date.now() };\n\n const fallback = (error: Error) => {\n if (error instanceof LicenseCheckError && error.shouldFallback && storedInfo?.license) {\n ee.logger?.warn(\n `${error.message} The last stored one will be used as a potential fallback.`\n );\n return storedInfo.license;\n }\n\n result.error = error.message;\n disable(error.message);\n };\n\n if (!ee?.licenseInfo?.licenseKey) {\n throw new Error('Missing license key.');\n }\n\n const license = shouldContactRegistry\n ? await fetchLicense({ strapi }, ee.licenseInfo.licenseKey, strapi.config.get('uuid')).catch(\n fallback\n )\n : storedInfo.license;\n\n if (license) {\n try {\n // Verify license and check if its info changed\n const newLicenseInfo = verifyLicense(license);\n const licenseInfoChanged =\n !isEqual(newLicenseInfo.features, ee.licenseInfo.features) ||\n newLicenseInfo.seats !== ee.licenseInfo.seats ||\n newLicenseInfo.type !== ee.licenseInfo.type;\n\n // Store the new license info\n ee.licenseInfo = newLicenseInfo;\n const wasEnabled = ee.enabled;\n validateInfo();\n\n // Notify EE features\n if (licenseInfoChanged && wasEnabled) {\n strapi.eventHub.emit('ee.update');\n }\n } catch (error) {\n if (error instanceof Error) {\n disable(error.message);\n } else {\n disable('Invalid license.');\n }\n }\n } else if (!shouldContactRegistry) {\n disable(storedInfo.error);\n }\n\n if (shouldContactRegistry) {\n result.license = license ?? null;\n const query = strapi.db!.queryBuilder('strapi::core-store').transacting(transaction);\n\n if (!storedInfo) {\n query.insert({ key: 'ee_information', value: JSON.stringify(result) });\n } else {\n query.update({ value: JSON.stringify(result) }).where({ key: 'ee_information' });\n }\n\n await query.execute();\n }\n\n await commit();\n } catch (error) {\n // Example of errors: SQLite does not support FOR UPDATE\n await rollback();\n }\n};\n\nconst validateInfo = () => {\n if (typeof ee.licenseInfo.expireAt === 'undefined') {\n throw new Error('Missing license key.');\n }\n\n const expirationTime = new Date(ee.licenseInfo.expireAt).getTime();\n\n if (expirationTime < new Date().getTime()) {\n return disable('License expired.');\n }\n\n enable();\n};\n\nconst checkLicense = async ({ strapi }: { strapi: Strapi }) => {\n const shouldStayOffline =\n ee.licenseInfo.type === 'gold' &&\n // This env variable support is temporarily used to ease the migration between online vs offline\n process.env.STRAPI_DISABLE_LICENSE_PING?.toLowerCase() === 'true';\n\n if (!shouldStayOffline) {\n await onlineUpdate({ strapi });\n strapi.cron.add({ [shiftCronExpression('0 0 */12 * * *')]: onlineUpdate });\n } else {\n if (!ee.licenseInfo.expireAt) {\n return disable('Your license does not have offline support.');\n }\n\n validateInfo();\n }\n};\n\nconst list = () => {\n return (\n ee.licenseInfo.features?.map((feature) =>\n typeof feature === 'object' ? feature : { name: feature }\n ) || []\n );\n};\n\nconst get = (featureName: string) => list().find((feature) => feature.name === featureName);\n\nexport default Object.freeze({\n init,\n checkLicense,\n\n get isEE() {\n return ee.enabled;\n },\n\n get seats() {\n return ee.licenseInfo.seats;\n },\n\n features: Object.freeze({\n list,\n get,\n isEnabled: (featureName: string) => get(featureName) !== undefined,\n }),\n});\n"],"names":["strapi","get","result"],"mappings":"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"}
1
+ {"version":3,"file":"index.mjs","sources":["../../src/ee/index.ts"],"sourcesContent":["import { pick, isEqual } from 'lodash/fp';\nimport type { Logger } from '@strapi/logger';\nimport type { Core } from '@strapi/types';\n\nimport { readLicense, verifyLicense, fetchLicense, LicenseCheckError } from './license';\nimport { shiftCronExpression } from '../utils/cron';\n\nconst ONE_MINUTE = 1000 * 60;\n\ninterface EE {\n enabled: boolean;\n licenseInfo: {\n licenseKey?: string;\n features?: Array<{ name: string; [key: string]: any } | string>;\n expireAt?: string;\n seats?: number;\n type?: string;\n };\n logger?: Logger;\n}\n\nconst ee: EE = {\n enabled: false,\n licenseInfo: {},\n};\n\nconst disable = (message: string) => {\n // Prevent emitting ee.disable if it was already disabled\n const shouldEmitEvent = ee.enabled !== false;\n\n ee.logger?.warn(`${message} Switching to CE.`);\n // Only keep the license key for potential re-enabling during a later check\n ee.licenseInfo = pick('licenseKey', ee.licenseInfo);\n\n ee.enabled = false;\n\n if (shouldEmitEvent) {\n // Notify EE features that they should be disabled\n strapi.eventHub.emit('ee.disable');\n }\n};\n\nconst enable = () => {\n // Prevent emitting ee.enable if it was already enabled\n const shouldEmitEvent = ee.enabled !== true;\n\n ee.enabled = true;\n\n if (shouldEmitEvent) {\n // Notify EE features that they should be disabled\n strapi.eventHub.emit('ee.enable');\n }\n};\n\nlet initialized = false;\n\n/**\n * Optimistically enable EE if the format of the license is valid, only run once.\n */\nconst init = (licenseDir: string, logger?: Logger) => {\n if (initialized) {\n return;\n }\n\n initialized = true;\n ee.logger = logger;\n\n if (process.env.STRAPI_DISABLE_EE?.toLowerCase() === 'true') {\n return;\n }\n\n try {\n const license = process.env.STRAPI_LICENSE || readLicense(licenseDir);\n\n if (license) {\n ee.licenseInfo = verifyLicense(license);\n enable();\n }\n } catch (error) {\n if (error instanceof Error) {\n disable(error.message);\n } else {\n disable('Invalid license.');\n }\n }\n};\n\n/**\n * Contact the license registry to update the license to its latest state.\n *\n * Store the result in database to avoid unecessary requests, and will fallback to that in case of a network failure.\n */\nconst onlineUpdate = async ({ strapi }: { strapi: Core.Strapi }) => {\n const { get, commit, rollback } = (await strapi.db?.transaction()) as any;\n const transaction = get();\n\n try {\n const storedInfo = await strapi.db\n ?.queryBuilder('strapi::core-store')\n .where({ key: 'ee_information' })\n .select('value')\n .first()\n .transacting(transaction)\n .forUpdate()\n .execute()\n .then((result: any) => (result ? JSON.parse(result.value) : result));\n\n const shouldContactRegistry = (storedInfo?.lastCheckAt ?? 0) < Date.now() - ONE_MINUTE;\n const result: {\n license?: string | null;\n error?: string;\n lastCheckAt?: number;\n } = { lastCheckAt: Date.now() };\n\n const fallback = (error: Error) => {\n if (error instanceof LicenseCheckError && error.shouldFallback && storedInfo?.license) {\n ee.logger?.warn(\n `${error.message} The last stored one will be used as a potential fallback.`\n );\n return storedInfo.license;\n }\n\n result.error = error.message;\n disable(error.message);\n };\n\n if (!ee?.licenseInfo?.licenseKey) {\n throw new Error('Missing license key.');\n }\n\n const license = shouldContactRegistry\n ? await fetchLicense({ strapi }, ee.licenseInfo.licenseKey, strapi.config.get('uuid')).catch(\n fallback\n )\n : storedInfo.license;\n\n if (license) {\n try {\n // Verify license and check if its info changed\n const newLicenseInfo = verifyLicense(license);\n const licenseInfoChanged =\n !isEqual(newLicenseInfo.features, ee.licenseInfo.features) ||\n newLicenseInfo.seats !== ee.licenseInfo.seats ||\n newLicenseInfo.type !== ee.licenseInfo.type;\n\n // Store the new license info\n ee.licenseInfo = newLicenseInfo;\n const wasEnabled = ee.enabled;\n validateInfo();\n\n // Notify EE features\n if (licenseInfoChanged && wasEnabled) {\n strapi.eventHub.emit('ee.update');\n }\n } catch (error) {\n if (error instanceof Error) {\n disable(error.message);\n } else {\n disable('Invalid license.');\n }\n }\n } else if (!shouldContactRegistry) {\n disable(storedInfo.error);\n }\n\n if (shouldContactRegistry) {\n result.license = license ?? null;\n const query = strapi.db.queryBuilder('strapi::core-store').transacting(transaction);\n\n if (!storedInfo) {\n query.insert({ key: 'ee_information', value: JSON.stringify(result) });\n } else {\n query.update({ value: JSON.stringify(result) }).where({ key: 'ee_information' });\n }\n\n await query.execute();\n }\n\n await commit();\n } catch (error) {\n // Example of errors: SQLite does not support FOR UPDATE\n await rollback();\n }\n};\n\nconst validateInfo = () => {\n if (typeof ee.licenseInfo.expireAt === 'undefined') {\n throw new Error('Missing license key.');\n }\n\n const expirationTime = new Date(ee.licenseInfo.expireAt).getTime();\n\n if (expirationTime < new Date().getTime()) {\n return disable('License expired.');\n }\n\n enable();\n};\n\nconst checkLicense = async ({ strapi }: { strapi: Core.Strapi }) => {\n const shouldStayOffline =\n ee.licenseInfo.type === 'gold' &&\n // This env variable support is temporarily used to ease the migration between online vs offline\n process.env.STRAPI_DISABLE_LICENSE_PING?.toLowerCase() === 'true';\n\n if (!shouldStayOffline) {\n await onlineUpdate({ strapi });\n strapi.cron.add({ [shiftCronExpression('0 0 */12 * * *')]: onlineUpdate });\n } else {\n if (!ee.licenseInfo.expireAt) {\n return disable('Your license does not have offline support.');\n }\n\n validateInfo();\n }\n};\n\nconst list = () => {\n return (\n ee.licenseInfo.features?.map((feature) =>\n typeof feature === 'object' ? feature : { name: feature }\n ) || []\n );\n};\n\nconst get = (featureName: string) => list().find((feature) => feature.name === featureName);\n\nexport default Object.freeze({\n init,\n checkLicense,\n\n get isEE() {\n return ee.enabled;\n },\n\n get seats() {\n return ee.licenseInfo.seats;\n },\n\n features: Object.freeze({\n list,\n get,\n isEnabled: (featureName: string) => get(featureName) !== undefined,\n }),\n});\n"],"names":["strapi","get","result"],"mappings":"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"}
@@ -1,4 +1,4 @@
1
- import type { Strapi } from '@strapi/types';
1
+ import type { Core } from '@strapi/types';
2
2
  interface LicenseInfo {
3
3
  type: 'bronze' | 'silver' | 'gold';
4
4
  expireAt?: string;
@@ -15,7 +15,7 @@ declare class LicenseCheckError extends Error {
15
15
  declare const readLicense: (directory: string) => string | undefined;
16
16
  declare const verifyLicense: (license: string) => LicenseInfo;
17
17
  declare const fetchLicense: ({ strapi }: {
18
- strapi: Strapi;
18
+ strapi: Core.Strapi;
19
19
  }, key: string, projectId: string) => Promise<any>;
20
20
  export { readLicense, verifyLicense, fetchLicense, LicenseCheckError };
21
21
  //# sourceMappingURL=license.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"license.d.ts","sourceRoot":"","sources":["../../src/ee/license.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAI5C,UAAU,WAAW;IACnB,IAAI,EAAE,QAAQ,GAAG,QAAQ,GAAG,MAAM,CAAC;IACnC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,KAAK,CAAC;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;KAAE,CAAC,CAAC;CACvE;AAgBD,cAAM,iBAAkB,SAAQ,KAAK;IACnC,cAAc,UAAS;gBAEX,OAAO,EAAE,MAAM,EAAE,cAAc,UAAQ;CAKpD;AAED,QAAA,MAAM,WAAW,cAAe,MAAM,uBASrC,CAAC;AAEF,QAAA,MAAM,aAAa,YAAa,MAAM,gBA2BrC,CAAC;AAMF,QAAA,MAAM,YAAY;YAAgC,MAAM;QAAS,MAAM,aAAa,MAAM,iBA2BzF,CAAC;AAEF,OAAO,EAAE,WAAW,EAAE,aAAa,EAAE,YAAY,EAAE,iBAAiB,EAAE,CAAC"}
1
+ {"version":3,"file":"license.d.ts","sourceRoot":"","sources":["../../src/ee/license.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAI1C,UAAU,WAAW;IACnB,IAAI,EAAE,QAAQ,GAAG,QAAQ,GAAG,MAAM,CAAC;IACnC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,KAAK,CAAC;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;KAAE,CAAC,CAAC;CACvE;AAkBD,cAAM,iBAAkB,SAAQ,KAAK;IACnC,cAAc,UAAS;gBAEX,OAAO,EAAE,MAAM,EAAE,cAAc,UAAQ;CAKpD;AAED,QAAA,MAAM,WAAW,cAAe,MAAM,uBASrC,CAAC;AAEF,QAAA,MAAM,aAAa,YAAa,MAAM,gBA2BrC,CAAC;AAMF,QAAA,MAAM,YAAY,eACJ;IAAE,MAAM,EAAE,KAAK,MAAM,CAAA;CAAE,OAC9B,MAAM,aACA,MAAM,iBA4BlB,CAAC;AAEF,OAAO,EAAE,WAAW,EAAE,aAAa,EAAE,YAAY,EAAE,iBAAiB,EAAE,CAAC"}
@@ -15,7 +15,9 @@ const DEFAULT_FEATURES = {
15
15
  // Set a null retention duration to allow the user to override it
16
16
  // The default of 90 days is set in the audit logs service
17
17
  { name: "audit-logs", options: { retentionDays: null } },
18
- { name: "review-workflows" }
18
+ { name: "review-workflows" },
19
+ { name: "cms-content-releases" },
20
+ { name: "cms-content-history", options: { retentionDays: 99999 } }
19
21
  ]
20
22
  };
21
23
  const publicKey = fs__default.default.readFileSync(path.resolve(__dirname, "../../resources/key.pub"));