@strapi/core 0.0.0-experimental.f49f46a1c17445a39e8af3f63124bcccf73842e6 → 0.0.0-experimental.f56bca7c4d88bc4c61b6de9f65648d857cf242d9

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (701) hide show
  1. package/dist/Strapi.d.ts.map +1 -1
  2. package/dist/Strapi.js +427 -407
  3. package/dist/Strapi.js.map +1 -1
  4. package/dist/Strapi.mjs +426 -405
  5. package/dist/Strapi.mjs.map +1 -1
  6. package/dist/compile.js +23 -14
  7. package/dist/compile.js.map +1 -1
  8. package/dist/compile.mjs +22 -14
  9. package/dist/compile.mjs.map +1 -1
  10. package/dist/configuration/config-loader.js +110 -97
  11. package/dist/configuration/config-loader.js.map +1 -1
  12. package/dist/configuration/config-loader.mjs +109 -96
  13. package/dist/configuration/config-loader.mjs.map +1 -1
  14. package/dist/configuration/get-dirs.js +31 -29
  15. package/dist/configuration/get-dirs.js.map +1 -1
  16. package/dist/configuration/get-dirs.mjs +30 -30
  17. package/dist/configuration/get-dirs.mjs.map +1 -1
  18. package/dist/configuration/index.d.ts.map +1 -1
  19. package/dist/configuration/index.js +84 -73
  20. package/dist/configuration/index.js.map +1 -1
  21. package/dist/configuration/index.mjs +83 -69
  22. package/dist/configuration/index.mjs.map +1 -1
  23. package/dist/configuration/urls.d.ts.map +1 -1
  24. package/dist/configuration/urls.js +74 -61
  25. package/dist/configuration/urls.js.map +1 -1
  26. package/dist/configuration/urls.mjs +73 -62
  27. package/dist/configuration/urls.mjs.map +1 -1
  28. package/dist/container.js +27 -23
  29. package/dist/container.js.map +1 -1
  30. package/dist/container.mjs +26 -24
  31. package/dist/container.mjs.map +1 -1
  32. package/dist/core-api/controller/collection-type.js +77 -76
  33. package/dist/core-api/controller/collection-type.js.map +1 -1
  34. package/dist/core-api/controller/collection-type.mjs +76 -77
  35. package/dist/core-api/controller/collection-type.mjs.map +1 -1
  36. package/dist/core-api/controller/index.js +63 -48
  37. package/dist/core-api/controller/index.js.map +1 -1
  38. package/dist/core-api/controller/index.mjs +62 -49
  39. package/dist/core-api/controller/index.mjs.map +1 -1
  40. package/dist/core-api/controller/single-type.js +41 -40
  41. package/dist/core-api/controller/single-type.js.map +1 -1
  42. package/dist/core-api/controller/single-type.mjs +40 -41
  43. package/dist/core-api/controller/single-type.mjs.map +1 -1
  44. package/dist/core-api/controller/transform.js +72 -63
  45. package/dist/core-api/controller/transform.js.map +1 -1
  46. package/dist/core-api/controller/transform.mjs +71 -64
  47. package/dist/core-api/controller/transform.mjs.map +1 -1
  48. package/dist/core-api/routes/index.js +64 -62
  49. package/dist/core-api/routes/index.js.map +1 -1
  50. package/dist/core-api/routes/index.mjs +62 -62
  51. package/dist/core-api/routes/index.mjs.map +1 -1
  52. package/dist/core-api/service/collection-type.js +73 -60
  53. package/dist/core-api/service/collection-type.js.map +1 -1
  54. package/dist/core-api/service/collection-type.mjs +72 -62
  55. package/dist/core-api/service/collection-type.mjs.map +1 -1
  56. package/dist/core-api/service/core-service.js +9 -8
  57. package/dist/core-api/service/core-service.js.map +1 -1
  58. package/dist/core-api/service/core-service.mjs +8 -9
  59. package/dist/core-api/service/core-service.mjs.map +1 -1
  60. package/dist/core-api/service/index.js +13 -13
  61. package/dist/core-api/service/index.js.map +1 -1
  62. package/dist/core-api/service/index.mjs +12 -14
  63. package/dist/core-api/service/index.mjs.map +1 -1
  64. package/dist/core-api/service/pagination.js +69 -43
  65. package/dist/core-api/service/pagination.js.map +1 -1
  66. package/dist/core-api/service/pagination.mjs +68 -47
  67. package/dist/core-api/service/pagination.mjs.map +1 -1
  68. package/dist/core-api/service/single-type.js +43 -39
  69. package/dist/core-api/service/single-type.js.map +1 -1
  70. package/dist/core-api/service/single-type.mjs +42 -41
  71. package/dist/core-api/service/single-type.mjs.map +1 -1
  72. package/dist/domain/content-type/index.js +95 -100
  73. package/dist/domain/content-type/index.js.map +1 -1
  74. package/dist/domain/content-type/index.mjs +94 -100
  75. package/dist/domain/content-type/index.mjs.map +1 -1
  76. package/dist/domain/content-type/validator.js +84 -69
  77. package/dist/domain/content-type/validator.js.map +1 -1
  78. package/dist/domain/content-type/validator.mjs +83 -68
  79. package/dist/domain/content-type/validator.mjs.map +1 -1
  80. package/dist/domain/module/index.js +109 -100
  81. package/dist/domain/module/index.js.map +1 -1
  82. package/dist/domain/module/index.mjs +108 -99
  83. package/dist/domain/module/index.mjs.map +1 -1
  84. package/dist/domain/module/validation.js +25 -20
  85. package/dist/domain/module/validation.js.map +1 -1
  86. package/dist/domain/module/validation.mjs +24 -21
  87. package/dist/domain/module/validation.mjs.map +1 -1
  88. package/dist/ee/index.d.ts +1 -0
  89. package/dist/ee/index.d.ts.map +1 -1
  90. package/dist/ee/index.js +171 -137
  91. package/dist/ee/index.js.map +1 -1
  92. package/dist/ee/index.mjs +170 -139
  93. package/dist/ee/index.mjs.map +1 -1
  94. package/dist/ee/license.d.ts.map +1 -1
  95. package/dist/ee/license.js +99 -75
  96. package/dist/ee/license.js.map +1 -1
  97. package/dist/ee/license.mjs +98 -76
  98. package/dist/ee/license.mjs.map +1 -1
  99. package/dist/factories.js +72 -67
  100. package/dist/factories.js.map +1 -1
  101. package/dist/factories.mjs +71 -71
  102. package/dist/factories.mjs.map +1 -1
  103. package/dist/index.js +29 -26
  104. package/dist/index.js.map +1 -1
  105. package/dist/index.mjs +29 -29
  106. package/dist/index.mjs.map +1 -1
  107. package/dist/loaders/admin.d.ts.map +1 -1
  108. package/dist/loaders/admin.js +21 -20
  109. package/dist/loaders/admin.js.map +1 -1
  110. package/dist/loaders/admin.mjs +20 -20
  111. package/dist/loaders/admin.mjs.map +1 -1
  112. package/dist/loaders/apis.js +143 -120
  113. package/dist/loaders/apis.js.map +1 -1
  114. package/dist/loaders/apis.mjs +142 -119
  115. package/dist/loaders/apis.mjs.map +1 -1
  116. package/dist/loaders/components.js +33 -34
  117. package/dist/loaders/components.js.map +1 -1
  118. package/dist/loaders/components.mjs +32 -34
  119. package/dist/loaders/components.mjs.map +1 -1
  120. package/dist/loaders/index.js +22 -20
  121. package/dist/loaders/index.js.map +1 -1
  122. package/dist/loaders/index.mjs +21 -21
  123. package/dist/loaders/index.mjs.map +1 -1
  124. package/dist/loaders/middlewares.js +29 -25
  125. package/dist/loaders/middlewares.js.map +1 -1
  126. package/dist/loaders/middlewares.mjs +28 -25
  127. package/dist/loaders/middlewares.mjs.map +1 -1
  128. package/dist/loaders/plugins/get-enabled-plugins.js +126 -131
  129. package/dist/loaders/plugins/get-enabled-plugins.js.map +1 -1
  130. package/dist/loaders/plugins/get-enabled-plugins.mjs +125 -108
  131. package/dist/loaders/plugins/get-enabled-plugins.mjs.map +1 -1
  132. package/dist/loaders/plugins/get-user-plugins-config.js +25 -24
  133. package/dist/loaders/plugins/get-user-plugins-config.js.map +1 -1
  134. package/dist/loaders/plugins/get-user-plugins-config.mjs +24 -23
  135. package/dist/loaders/plugins/get-user-plugins-config.mjs.map +1 -1
  136. package/dist/loaders/plugins/index.js +132 -122
  137. package/dist/loaders/plugins/index.js.map +1 -1
  138. package/dist/loaders/plugins/index.mjs +121 -112
  139. package/dist/loaders/plugins/index.mjs.map +1 -1
  140. package/dist/loaders/policies.js +24 -20
  141. package/dist/loaders/policies.js.map +1 -1
  142. package/dist/loaders/policies.mjs +23 -20
  143. package/dist/loaders/policies.mjs.map +1 -1
  144. package/dist/loaders/sanitizers.js +10 -4
  145. package/dist/loaders/sanitizers.js.map +1 -1
  146. package/dist/loaders/sanitizers.mjs +9 -6
  147. package/dist/loaders/sanitizers.mjs.map +1 -1
  148. package/dist/loaders/src-index.js +35 -27
  149. package/dist/loaders/src-index.js.map +1 -1
  150. package/dist/loaders/src-index.mjs +34 -29
  151. package/dist/loaders/src-index.mjs.map +1 -1
  152. package/dist/loaders/validators.js +9 -4
  153. package/dist/loaders/validators.js.map +1 -1
  154. package/dist/loaders/validators.mjs +8 -6
  155. package/dist/loaders/validators.mjs.map +1 -1
  156. package/dist/middlewares/body.d.ts.map +1 -1
  157. package/dist/middlewares/body.js +58 -54
  158. package/dist/middlewares/body.js.map +1 -1
  159. package/dist/middlewares/body.mjs +57 -51
  160. package/dist/middlewares/body.mjs.map +1 -1
  161. package/dist/middlewares/compression.js +6 -6
  162. package/dist/middlewares/compression.js.map +1 -1
  163. package/dist/middlewares/compression.mjs +5 -5
  164. package/dist/middlewares/compression.mjs.map +1 -1
  165. package/dist/middlewares/cors.js +59 -48
  166. package/dist/middlewares/cors.js.map +1 -1
  167. package/dist/middlewares/cors.mjs +58 -47
  168. package/dist/middlewares/cors.mjs.map +1 -1
  169. package/dist/middlewares/errors.js +32 -30
  170. package/dist/middlewares/errors.js.map +1 -1
  171. package/dist/middlewares/errors.mjs +31 -31
  172. package/dist/middlewares/errors.mjs.map +1 -1
  173. package/dist/middlewares/favicon.js +27 -17
  174. package/dist/middlewares/favicon.js.map +1 -1
  175. package/dist/middlewares/favicon.mjs +26 -16
  176. package/dist/middlewares/favicon.mjs.map +1 -1
  177. package/dist/middlewares/index.js +32 -30
  178. package/dist/middlewares/index.js.map +1 -1
  179. package/dist/middlewares/index.mjs +31 -31
  180. package/dist/middlewares/index.mjs.map +1 -1
  181. package/dist/middlewares/ip.js +6 -6
  182. package/dist/middlewares/ip.js.map +1 -1
  183. package/dist/middlewares/ip.mjs +5 -5
  184. package/dist/middlewares/ip.mjs.map +1 -1
  185. package/dist/middlewares/logger.js +10 -9
  186. package/dist/middlewares/logger.js.map +1 -1
  187. package/dist/middlewares/logger.mjs +9 -10
  188. package/dist/middlewares/logger.mjs.map +1 -1
  189. package/dist/middlewares/powered-by.js +13 -9
  190. package/dist/middlewares/powered-by.js.map +1 -1
  191. package/dist/middlewares/powered-by.mjs +12 -10
  192. package/dist/middlewares/powered-by.mjs.map +1 -1
  193. package/dist/middlewares/public.js +33 -29
  194. package/dist/middlewares/public.js.map +1 -1
  195. package/dist/middlewares/public.mjs +32 -28
  196. package/dist/middlewares/public.mjs.map +1 -1
  197. package/dist/middlewares/query.js +35 -32
  198. package/dist/middlewares/query.js.map +1 -1
  199. package/dist/middlewares/query.mjs +34 -31
  200. package/dist/middlewares/query.mjs.map +1 -1
  201. package/dist/middlewares/response-time.js +10 -9
  202. package/dist/middlewares/response-time.js.map +1 -1
  203. package/dist/middlewares/response-time.mjs +9 -10
  204. package/dist/middlewares/response-time.mjs.map +1 -1
  205. package/dist/middlewares/responses.js +14 -12
  206. package/dist/middlewares/responses.js.map +1 -1
  207. package/dist/middlewares/responses.mjs +13 -13
  208. package/dist/middlewares/responses.mjs.map +1 -1
  209. package/dist/middlewares/security.js +109 -71
  210. package/dist/middlewares/security.js.map +1 -1
  211. package/dist/middlewares/security.mjs +108 -70
  212. package/dist/middlewares/security.mjs.map +1 -1
  213. package/dist/middlewares/session.js +26 -25
  214. package/dist/middlewares/session.js.map +1 -1
  215. package/dist/middlewares/session.mjs +25 -24
  216. package/dist/middlewares/session.mjs.map +1 -1
  217. package/dist/migrations/database/5.0.0-discard-drafts.d.ts +2 -2
  218. package/dist/migrations/database/5.0.0-discard-drafts.d.ts.map +1 -1
  219. package/dist/migrations/database/5.0.0-discard-drafts.js +152 -90
  220. package/dist/migrations/database/5.0.0-discard-drafts.js.map +1 -1
  221. package/dist/migrations/database/5.0.0-discard-drafts.mjs +151 -92
  222. package/dist/migrations/database/5.0.0-discard-drafts.mjs.map +1 -1
  223. package/dist/migrations/draft-publish.d.ts +1 -1
  224. package/dist/migrations/draft-publish.d.ts.map +1 -1
  225. package/dist/migrations/draft-publish.js +61 -34
  226. package/dist/migrations/draft-publish.js.map +1 -1
  227. package/dist/migrations/draft-publish.mjs +60 -36
  228. package/dist/migrations/draft-publish.mjs.map +1 -1
  229. package/dist/migrations/i18n.js +62 -45
  230. package/dist/migrations/i18n.js.map +1 -1
  231. package/dist/migrations/i18n.mjs +61 -47
  232. package/dist/migrations/i18n.mjs.map +1 -1
  233. package/dist/migrations/index.js +24 -10
  234. package/dist/migrations/index.js.map +1 -1
  235. package/dist/migrations/index.mjs +23 -12
  236. package/dist/migrations/index.mjs.map +1 -1
  237. package/dist/package.json.js +182 -0
  238. package/dist/package.json.js.map +1 -0
  239. package/dist/package.json.mjs +159 -0
  240. package/dist/package.json.mjs.map +1 -0
  241. package/dist/providers/admin.js +27 -17
  242. package/dist/providers/admin.js.map +1 -1
  243. package/dist/providers/admin.mjs +26 -19
  244. package/dist/providers/admin.mjs.map +1 -1
  245. package/dist/providers/coreStore.js +13 -8
  246. package/dist/providers/coreStore.js.map +1 -1
  247. package/dist/providers/coreStore.mjs +12 -10
  248. package/dist/providers/coreStore.mjs.map +1 -1
  249. package/dist/providers/cron.js +19 -16
  250. package/dist/providers/cron.js.map +1 -1
  251. package/dist/providers/cron.mjs +18 -18
  252. package/dist/providers/cron.mjs.map +1 -1
  253. package/dist/providers/index.js +18 -9
  254. package/dist/providers/index.js.map +1 -1
  255. package/dist/providers/index.mjs +17 -10
  256. package/dist/providers/index.mjs.map +1 -1
  257. package/dist/providers/provider.js +4 -3
  258. package/dist/providers/provider.js.map +1 -1
  259. package/dist/providers/provider.mjs +3 -4
  260. package/dist/providers/provider.mjs.map +1 -1
  261. package/dist/providers/registries.js +37 -32
  262. package/dist/providers/registries.js.map +1 -1
  263. package/dist/providers/registries.mjs +36 -34
  264. package/dist/providers/registries.mjs.map +1 -1
  265. package/dist/providers/telemetry.js +19 -16
  266. package/dist/providers/telemetry.js.map +1 -1
  267. package/dist/providers/telemetry.mjs +18 -18
  268. package/dist/providers/telemetry.mjs.map +1 -1
  269. package/dist/providers/webhooks.js +28 -26
  270. package/dist/providers/webhooks.js.map +1 -1
  271. package/dist/providers/webhooks.mjs +27 -28
  272. package/dist/providers/webhooks.mjs.map +1 -1
  273. package/dist/registries/apis.js +23 -20
  274. package/dist/registries/apis.js.map +1 -1
  275. package/dist/registries/apis.mjs +22 -22
  276. package/dist/registries/apis.mjs.map +1 -1
  277. package/dist/registries/components.js +35 -37
  278. package/dist/registries/components.js.map +1 -1
  279. package/dist/registries/components.mjs +34 -39
  280. package/dist/registries/components.mjs.map +1 -1
  281. package/dist/registries/content-types.js +54 -59
  282. package/dist/registries/content-types.js.map +1 -1
  283. package/dist/registries/content-types.mjs +53 -61
  284. package/dist/registries/content-types.mjs.map +1 -1
  285. package/dist/registries/controllers.js +70 -71
  286. package/dist/registries/controllers.js.map +1 -1
  287. package/dist/registries/controllers.mjs +69 -73
  288. package/dist/registries/controllers.mjs.map +1 -1
  289. package/dist/registries/custom-fields.js +75 -65
  290. package/dist/registries/custom-fields.js.map +1 -1
  291. package/dist/registries/custom-fields.mjs +74 -67
  292. package/dist/registries/custom-fields.mjs.map +1 -1
  293. package/dist/registries/hooks.js +46 -49
  294. package/dist/registries/hooks.js.map +1 -1
  295. package/dist/registries/hooks.mjs +45 -51
  296. package/dist/registries/hooks.mjs.map +1 -1
  297. package/dist/registries/middlewares.js +49 -51
  298. package/dist/registries/middlewares.js.map +1 -1
  299. package/dist/registries/middlewares.mjs +48 -53
  300. package/dist/registries/middlewares.mjs.map +1 -1
  301. package/dist/registries/models.js +14 -13
  302. package/dist/registries/models.js.map +1 -1
  303. package/dist/registries/models.mjs +13 -14
  304. package/dist/registries/models.mjs.map +1 -1
  305. package/dist/registries/modules.js +39 -36
  306. package/dist/registries/modules.js.map +1 -1
  307. package/dist/registries/modules.mjs +38 -38
  308. package/dist/registries/modules.mjs.map +1 -1
  309. package/dist/registries/namespace.js +21 -20
  310. package/dist/registries/namespace.js.map +1 -1
  311. package/dist/registries/namespace.mjs +20 -23
  312. package/dist/registries/namespace.mjs.map +1 -1
  313. package/dist/registries/plugins.js +23 -20
  314. package/dist/registries/plugins.js.map +1 -1
  315. package/dist/registries/plugins.mjs +22 -22
  316. package/dist/registries/plugins.mjs.map +1 -1
  317. package/dist/registries/policies.js +103 -96
  318. package/dist/registries/policies.js.map +1 -1
  319. package/dist/registries/policies.mjs +102 -98
  320. package/dist/registries/policies.mjs.map +1 -1
  321. package/dist/registries/sanitizers.js +23 -22
  322. package/dist/registries/sanitizers.js.map +1 -1
  323. package/dist/registries/sanitizers.mjs +22 -22
  324. package/dist/registries/sanitizers.mjs.map +1 -1
  325. package/dist/registries/services.js +71 -71
  326. package/dist/registries/services.js.map +1 -1
  327. package/dist/registries/services.mjs +70 -73
  328. package/dist/registries/services.mjs.map +1 -1
  329. package/dist/registries/validators.js +23 -22
  330. package/dist/registries/validators.js.map +1 -1
  331. package/dist/registries/validators.mjs +22 -22
  332. package/dist/registries/validators.mjs.map +1 -1
  333. package/dist/services/auth/index.js +74 -74
  334. package/dist/services/auth/index.js.map +1 -1
  335. package/dist/services/auth/index.mjs +73 -74
  336. package/dist/services/auth/index.mjs.map +1 -1
  337. package/dist/services/config.js +47 -43
  338. package/dist/services/config.js.map +1 -1
  339. package/dist/services/config.mjs +46 -44
  340. package/dist/services/config.mjs.map +1 -1
  341. package/dist/services/content-api/index.js +80 -79
  342. package/dist/services/content-api/index.js.map +1 -1
  343. package/dist/services/content-api/index.mjs +79 -79
  344. package/dist/services/content-api/index.mjs.map +1 -1
  345. package/dist/services/content-api/permissions/engine.js +8 -5
  346. package/dist/services/content-api/permissions/engine.js.map +1 -1
  347. package/dist/services/content-api/permissions/engine.mjs +7 -5
  348. package/dist/services/content-api/permissions/engine.mjs.map +1 -1
  349. package/dist/services/content-api/permissions/index.js +101 -81
  350. package/dist/services/content-api/permissions/index.js.map +1 -1
  351. package/dist/services/content-api/permissions/index.mjs +100 -81
  352. package/dist/services/content-api/permissions/index.mjs.map +1 -1
  353. package/dist/services/content-api/permissions/providers/action.js +17 -14
  354. package/dist/services/content-api/permissions/providers/action.js.map +1 -1
  355. package/dist/services/content-api/permissions/providers/action.mjs +16 -16
  356. package/dist/services/content-api/permissions/providers/action.mjs.map +1 -1
  357. package/dist/services/content-api/permissions/providers/condition.js +17 -14
  358. package/dist/services/content-api/permissions/providers/condition.js.map +1 -1
  359. package/dist/services/content-api/permissions/providers/condition.mjs +16 -16
  360. package/dist/services/content-api/permissions/providers/condition.mjs.map +1 -1
  361. package/dist/services/core-store.js +115 -95
  362. package/dist/services/core-store.js.map +1 -1
  363. package/dist/services/core-store.mjs +114 -97
  364. package/dist/services/core-store.mjs.map +1 -1
  365. package/dist/services/cron.js +74 -65
  366. package/dist/services/cron.js.map +1 -1
  367. package/dist/services/cron.mjs +73 -67
  368. package/dist/services/cron.mjs.map +1 -1
  369. package/dist/services/custom-fields.js +9 -7
  370. package/dist/services/custom-fields.js.map +1 -1
  371. package/dist/services/custom-fields.mjs +8 -9
  372. package/dist/services/custom-fields.mjs.map +1 -1
  373. package/dist/services/document-service/attributes/index.js +23 -18
  374. package/dist/services/document-service/attributes/index.js.map +1 -1
  375. package/dist/services/document-service/attributes/index.mjs +22 -19
  376. package/dist/services/document-service/attributes/index.mjs.map +1 -1
  377. package/dist/services/document-service/attributes/transforms.js +16 -15
  378. package/dist/services/document-service/attributes/transforms.js.map +1 -1
  379. package/dist/services/document-service/attributes/transforms.mjs +15 -15
  380. package/dist/services/document-service/attributes/transforms.mjs.map +1 -1
  381. package/dist/services/document-service/common.js +5 -4
  382. package/dist/services/document-service/common.js.map +1 -1
  383. package/dist/services/document-service/common.mjs +4 -5
  384. package/dist/services/document-service/common.mjs.map +1 -1
  385. package/dist/services/document-service/components.d.ts.map +1 -1
  386. package/dist/services/document-service/components.js +255 -257
  387. package/dist/services/document-service/components.js.map +1 -1
  388. package/dist/services/document-service/components.mjs +254 -262
  389. package/dist/services/document-service/components.mjs.map +1 -1
  390. package/dist/services/document-service/draft-and-publish.d.ts +1 -1
  391. package/dist/services/document-service/draft-and-publish.d.ts.map +1 -1
  392. package/dist/services/document-service/draft-and-publish.js +88 -48
  393. package/dist/services/document-service/draft-and-publish.js.map +1 -1
  394. package/dist/services/document-service/draft-and-publish.mjs +87 -54
  395. package/dist/services/document-service/draft-and-publish.mjs.map +1 -1
  396. package/dist/services/document-service/entries.js +109 -91
  397. package/dist/services/document-service/entries.js.map +1 -1
  398. package/dist/services/document-service/entries.mjs +108 -92
  399. package/dist/services/document-service/entries.mjs.map +1 -1
  400. package/dist/services/document-service/events.d.ts +1 -1
  401. package/dist/services/document-service/events.d.ts.map +1 -1
  402. package/dist/services/document-service/events.js +52 -40
  403. package/dist/services/document-service/events.js.map +1 -1
  404. package/dist/services/document-service/events.mjs +51 -41
  405. package/dist/services/document-service/events.mjs.map +1 -1
  406. package/dist/services/document-service/index.js +53 -33
  407. package/dist/services/document-service/index.js.map +1 -1
  408. package/dist/services/document-service/index.mjs +52 -34
  409. package/dist/services/document-service/index.mjs.map +1 -1
  410. package/dist/services/document-service/internationalization.js +62 -46
  411. package/dist/services/document-service/internationalization.js.map +1 -1
  412. package/dist/services/document-service/internationalization.mjs +61 -50
  413. package/dist/services/document-service/internationalization.mjs.map +1 -1
  414. package/dist/services/document-service/middlewares/errors.js +23 -19
  415. package/dist/services/document-service/middlewares/errors.js.map +1 -1
  416. package/dist/services/document-service/middlewares/errors.mjs +22 -20
  417. package/dist/services/document-service/middlewares/errors.mjs.map +1 -1
  418. package/dist/services/document-service/middlewares/middleware-manager.js +46 -44
  419. package/dist/services/document-service/middlewares/middleware-manager.js.map +1 -1
  420. package/dist/services/document-service/middlewares/middleware-manager.mjs +45 -45
  421. package/dist/services/document-service/middlewares/middleware-manager.mjs.map +1 -1
  422. package/dist/services/document-service/params.js +11 -5
  423. package/dist/services/document-service/params.js.map +1 -1
  424. package/dist/services/document-service/params.mjs +10 -6
  425. package/dist/services/document-service/params.mjs.map +1 -1
  426. package/dist/services/document-service/repository.d.ts.map +1 -1
  427. package/dist/services/document-service/repository.js +354 -319
  428. package/dist/services/document-service/repository.js.map +1 -1
  429. package/dist/services/document-service/repository.mjs +353 -320
  430. package/dist/services/document-service/repository.mjs.map +1 -1
  431. package/dist/services/document-service/transform/data.js +22 -12
  432. package/dist/services/document-service/transform/data.js.map +1 -1
  433. package/dist/services/document-service/transform/data.mjs +21 -13
  434. package/dist/services/document-service/transform/data.mjs.map +1 -1
  435. package/dist/services/document-service/transform/fields.js +26 -17
  436. package/dist/services/document-service/transform/fields.js.map +1 -1
  437. package/dist/services/document-service/transform/fields.mjs +25 -18
  438. package/dist/services/document-service/transform/fields.mjs.map +1 -1
  439. package/dist/services/document-service/transform/id-map.d.ts +1 -1
  440. package/dist/services/document-service/transform/id-map.d.ts.map +1 -1
  441. package/dist/services/document-service/transform/id-map.js +115 -77
  442. package/dist/services/document-service/transform/id-map.js.map +1 -1
  443. package/dist/services/document-service/transform/id-map.mjs +114 -78
  444. package/dist/services/document-service/transform/id-map.mjs.map +1 -1
  445. package/dist/services/document-service/transform/id-transform.d.ts +1 -1
  446. package/dist/services/document-service/transform/id-transform.d.ts.map +1 -1
  447. package/dist/services/document-service/transform/id-transform.js +37 -29
  448. package/dist/services/document-service/transform/id-transform.js.map +1 -1
  449. package/dist/services/document-service/transform/id-transform.mjs +36 -30
  450. package/dist/services/document-service/transform/id-transform.mjs.map +1 -1
  451. package/dist/services/document-service/transform/populate.js +23 -18
  452. package/dist/services/document-service/transform/populate.js.map +1 -1
  453. package/dist/services/document-service/transform/populate.mjs +22 -19
  454. package/dist/services/document-service/transform/populate.mjs.map +1 -1
  455. package/dist/services/document-service/transform/query.js +11 -6
  456. package/dist/services/document-service/transform/query.js.map +1 -1
  457. package/dist/services/document-service/transform/query.mjs +10 -7
  458. package/dist/services/document-service/transform/query.mjs.map +1 -1
  459. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +1 -1
  460. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -1
  461. package/dist/services/document-service/transform/relations/extract/data-ids.js +70 -54
  462. package/dist/services/document-service/transform/relations/extract/data-ids.js.map +1 -1
  463. package/dist/services/document-service/transform/relations/extract/data-ids.mjs +69 -55
  464. package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +1 -1
  465. package/dist/services/document-service/transform/relations/transform/data-ids.js +96 -72
  466. package/dist/services/document-service/transform/relations/transform/data-ids.js.map +1 -1
  467. package/dist/services/document-service/transform/relations/transform/data-ids.mjs +95 -73
  468. package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +1 -1
  469. package/dist/services/document-service/transform/relations/transform/default-locale.js +47 -29
  470. package/dist/services/document-service/transform/relations/transform/default-locale.js.map +1 -1
  471. package/dist/services/document-service/transform/relations/transform/default-locale.mjs +46 -30
  472. package/dist/services/document-service/transform/relations/transform/default-locale.mjs.map +1 -1
  473. package/dist/services/document-service/transform/relations/utils/dp.d.ts +1 -1
  474. package/dist/services/document-service/transform/relations/utils/dp.d.ts.map +1 -1
  475. package/dist/services/document-service/transform/relations/utils/dp.js +52 -26
  476. package/dist/services/document-service/transform/relations/utils/dp.js.map +1 -1
  477. package/dist/services/document-service/transform/relations/utils/dp.mjs +51 -27
  478. package/dist/services/document-service/transform/relations/utils/dp.mjs.map +1 -1
  479. package/dist/services/document-service/transform/relations/utils/i18n.d.ts +1 -1
  480. package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -1
  481. package/dist/services/document-service/transform/relations/utils/i18n.js +20 -18
  482. package/dist/services/document-service/transform/relations/utils/i18n.js.map +1 -1
  483. package/dist/services/document-service/transform/relations/utils/i18n.mjs +19 -21
  484. package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +1 -1
  485. package/dist/services/document-service/transform/relations/utils/map-relation.js +116 -73
  486. package/dist/services/document-service/transform/relations/utils/map-relation.js.map +1 -1
  487. package/dist/services/document-service/transform/relations/utils/map-relation.mjs +115 -75
  488. package/dist/services/document-service/transform/relations/utils/map-relation.mjs.map +1 -1
  489. package/dist/services/document-service/utils/bidirectional-relations.d.ts +95 -0
  490. package/dist/services/document-service/utils/bidirectional-relations.d.ts.map +1 -0
  491. package/dist/services/document-service/utils/bidirectional-relations.js +148 -0
  492. package/dist/services/document-service/utils/bidirectional-relations.js.map +1 -0
  493. package/dist/services/document-service/utils/bidirectional-relations.mjs +145 -0
  494. package/dist/services/document-service/utils/bidirectional-relations.mjs.map +1 -0
  495. package/dist/services/document-service/utils/populate.d.ts +1 -1
  496. package/dist/services/document-service/utils/populate.d.ts.map +1 -1
  497. package/dist/services/document-service/utils/populate.js +66 -42
  498. package/dist/services/document-service/utils/populate.js.map +1 -1
  499. package/dist/services/document-service/utils/populate.mjs +65 -43
  500. package/dist/services/document-service/utils/populate.mjs.map +1 -1
  501. package/dist/services/document-service/utils/unidirectional-relations.d.ts +1 -1
  502. package/dist/services/document-service/utils/unidirectional-relations.d.ts.map +1 -1
  503. package/dist/services/document-service/utils/unidirectional-relations.js +109 -62
  504. package/dist/services/document-service/utils/unidirectional-relations.js.map +1 -1
  505. package/dist/services/document-service/utils/unidirectional-relations.mjs +108 -64
  506. package/dist/services/document-service/utils/unidirectional-relations.mjs.map +1 -1
  507. package/dist/services/entity-service/index.js +230 -161
  508. package/dist/services/entity-service/index.js.map +1 -1
  509. package/dist/services/entity-service/index.mjs +229 -160
  510. package/dist/services/entity-service/index.mjs.map +1 -1
  511. package/dist/services/entity-validator/blocks-validator.js +135 -103
  512. package/dist/services/entity-validator/blocks-validator.js.map +1 -1
  513. package/dist/services/entity-validator/blocks-validator.mjs +134 -104
  514. package/dist/services/entity-validator/blocks-validator.mjs.map +1 -1
  515. package/dist/services/entity-validator/index.d.ts +1 -1
  516. package/dist/services/entity-validator/index.d.ts.map +1 -1
  517. package/dist/services/entity-validator/index.js +362 -367
  518. package/dist/services/entity-validator/index.js.map +1 -1
  519. package/dist/services/entity-validator/index.mjs +358 -364
  520. package/dist/services/entity-validator/index.mjs.map +1 -1
  521. package/dist/services/entity-validator/validators.js +268 -210
  522. package/dist/services/entity-validator/validators.js.map +1 -1
  523. package/dist/services/entity-validator/validators.mjs +267 -216
  524. package/dist/services/entity-validator/validators.mjs.map +1 -1
  525. package/dist/services/errors.js +65 -65
  526. package/dist/services/errors.js.map +1 -1
  527. package/dist/services/errors.mjs +64 -66
  528. package/dist/services/errors.mjs.map +1 -1
  529. package/dist/services/event-hub.js +82 -69
  530. package/dist/services/event-hub.js.map +1 -1
  531. package/dist/services/event-hub.mjs +81 -71
  532. package/dist/services/event-hub.mjs.map +1 -1
  533. package/dist/services/features.js +19 -14
  534. package/dist/services/features.js.map +1 -1
  535. package/dist/services/features.mjs +18 -15
  536. package/dist/services/features.mjs.map +1 -1
  537. package/dist/services/fs.js +41 -40
  538. package/dist/services/fs.js.map +1 -1
  539. package/dist/services/fs.mjs +40 -39
  540. package/dist/services/fs.mjs.map +1 -1
  541. package/dist/services/metrics/admin-user-hash.js +13 -11
  542. package/dist/services/metrics/admin-user-hash.js.map +1 -1
  543. package/dist/services/metrics/admin-user-hash.mjs +12 -10
  544. package/dist/services/metrics/admin-user-hash.mjs.map +1 -1
  545. package/dist/services/metrics/index.js +46 -40
  546. package/dist/services/metrics/index.js.map +1 -1
  547. package/dist/services/metrics/index.mjs +45 -42
  548. package/dist/services/metrics/index.mjs.map +1 -1
  549. package/dist/services/metrics/is-truthy.js +13 -6
  550. package/dist/services/metrics/is-truthy.js.map +1 -1
  551. package/dist/services/metrics/is-truthy.mjs +12 -6
  552. package/dist/services/metrics/is-truthy.mjs.map +1 -1
  553. package/dist/services/metrics/middleware.d.ts.map +1 -1
  554. package/dist/services/metrics/middleware.js +37 -22
  555. package/dist/services/metrics/middleware.js.map +1 -1
  556. package/dist/services/metrics/middleware.mjs +36 -24
  557. package/dist/services/metrics/middleware.mjs.map +1 -1
  558. package/dist/services/metrics/rate-limiter.d.ts.map +1 -1
  559. package/dist/services/metrics/rate-limiter.js +24 -19
  560. package/dist/services/metrics/rate-limiter.js.map +1 -1
  561. package/dist/services/metrics/rate-limiter.mjs +23 -21
  562. package/dist/services/metrics/rate-limiter.mjs.map +1 -1
  563. package/dist/services/metrics/sender.js +78 -69
  564. package/dist/services/metrics/sender.js.map +1 -1
  565. package/dist/services/metrics/sender.mjs +77 -64
  566. package/dist/services/metrics/sender.mjs.map +1 -1
  567. package/dist/services/query-params.js +13 -10
  568. package/dist/services/query-params.js.map +1 -1
  569. package/dist/services/query-params.mjs +12 -12
  570. package/dist/services/query-params.mjs.map +1 -1
  571. package/dist/services/reloader.js +35 -32
  572. package/dist/services/reloader.js.map +1 -1
  573. package/dist/services/reloader.mjs +34 -33
  574. package/dist/services/reloader.mjs.map +1 -1
  575. package/dist/services/request-context.js +11 -8
  576. package/dist/services/request-context.js.map +1 -1
  577. package/dist/services/request-context.mjs +10 -10
  578. package/dist/services/request-context.mjs.map +1 -1
  579. package/dist/services/server/admin-api.js +11 -10
  580. package/dist/services/server/admin-api.js.map +1 -1
  581. package/dist/services/server/admin-api.mjs +10 -11
  582. package/dist/services/server/admin-api.mjs.map +1 -1
  583. package/dist/services/server/api.js +33 -27
  584. package/dist/services/server/api.js.map +1 -1
  585. package/dist/services/server/api.mjs +32 -26
  586. package/dist/services/server/api.mjs.map +1 -1
  587. package/dist/services/server/compose-endpoint.js +116 -105
  588. package/dist/services/server/compose-endpoint.js.map +1 -1
  589. package/dist/services/server/compose-endpoint.mjs +115 -105
  590. package/dist/services/server/compose-endpoint.mjs.map +1 -1
  591. package/dist/services/server/content-api.js +11 -9
  592. package/dist/services/server/content-api.js.map +1 -1
  593. package/dist/services/server/content-api.mjs +10 -10
  594. package/dist/services/server/content-api.mjs.map +1 -1
  595. package/dist/services/server/http-server.js +48 -44
  596. package/dist/services/server/http-server.js.map +1 -1
  597. package/dist/services/server/http-server.mjs +47 -43
  598. package/dist/services/server/http-server.mjs.map +1 -1
  599. package/dist/services/server/index.js +85 -82
  600. package/dist/services/server/index.js.map +1 -1
  601. package/dist/services/server/index.mjs +84 -81
  602. package/dist/services/server/index.mjs.map +1 -1
  603. package/dist/services/server/koa.js +49 -47
  604. package/dist/services/server/koa.js.map +1 -1
  605. package/dist/services/server/koa.mjs +48 -44
  606. package/dist/services/server/koa.mjs.map +1 -1
  607. package/dist/services/server/middleware.js +86 -82
  608. package/dist/services/server/middleware.js.map +1 -1
  609. package/dist/services/server/middleware.mjs +85 -82
  610. package/dist/services/server/middleware.mjs.map +1 -1
  611. package/dist/services/server/policy.js +24 -17
  612. package/dist/services/server/policy.js.map +1 -1
  613. package/dist/services/server/policy.mjs +23 -18
  614. package/dist/services/server/policy.mjs.map +1 -1
  615. package/dist/services/server/register-middlewares.js +68 -61
  616. package/dist/services/server/register-middlewares.js.map +1 -1
  617. package/dist/services/server/register-middlewares.mjs +67 -63
  618. package/dist/services/server/register-middlewares.mjs.map +1 -1
  619. package/dist/services/server/register-routes.js +90 -67
  620. package/dist/services/server/register-routes.js.map +1 -1
  621. package/dist/services/server/register-routes.mjs +89 -67
  622. package/dist/services/server/register-routes.mjs.map +1 -1
  623. package/dist/services/server/routing.js +94 -81
  624. package/dist/services/server/routing.js.map +1 -1
  625. package/dist/services/server/routing.mjs +93 -81
  626. package/dist/services/server/routing.mjs.map +1 -1
  627. package/dist/services/utils/dynamic-zones.js +13 -14
  628. package/dist/services/utils/dynamic-zones.js.map +1 -1
  629. package/dist/services/utils/dynamic-zones.mjs +12 -16
  630. package/dist/services/utils/dynamic-zones.mjs.map +1 -1
  631. package/dist/services/webhook-runner.js +124 -122
  632. package/dist/services/webhook-runner.js.map +1 -1
  633. package/dist/services/webhook-runner.mjs +123 -121
  634. package/dist/services/webhook-runner.mjs.map +1 -1
  635. package/dist/services/webhook-store.js +132 -99
  636. package/dist/services/webhook-store.js.map +1 -1
  637. package/dist/services/webhook-store.mjs +131 -101
  638. package/dist/services/webhook-store.mjs.map +1 -1
  639. package/dist/services/worker-queue.js +44 -49
  640. package/dist/services/worker-queue.js.map +1 -1
  641. package/dist/services/worker-queue.mjs +43 -49
  642. package/dist/services/worker-queue.mjs.map +1 -1
  643. package/dist/utils/convert-custom-field-type.js +17 -20
  644. package/dist/utils/convert-custom-field-type.js.map +1 -1
  645. package/dist/utils/convert-custom-field-type.mjs +16 -21
  646. package/dist/utils/convert-custom-field-type.mjs.map +1 -1
  647. package/dist/utils/cron.js +64 -30
  648. package/dist/utils/cron.js.map +1 -1
  649. package/dist/utils/cron.mjs +63 -31
  650. package/dist/utils/cron.mjs.map +1 -1
  651. package/dist/utils/fetch.js +24 -18
  652. package/dist/utils/fetch.js.map +1 -1
  653. package/dist/utils/fetch.mjs +23 -19
  654. package/dist/utils/fetch.mjs.map +1 -1
  655. package/dist/utils/filepath-to-prop-path.js +20 -28
  656. package/dist/utils/filepath-to-prop-path.js.map +1 -1
  657. package/dist/utils/filepath-to-prop-path.mjs +19 -26
  658. package/dist/utils/filepath-to-prop-path.mjs.map +1 -1
  659. package/dist/utils/is-initialized.js +21 -12
  660. package/dist/utils/is-initialized.js.map +1 -1
  661. package/dist/utils/is-initialized.mjs +20 -13
  662. package/dist/utils/is-initialized.mjs.map +1 -1
  663. package/dist/utils/lifecycles.js +6 -5
  664. package/dist/utils/lifecycles.js.map +1 -1
  665. package/dist/utils/lifecycles.mjs +5 -6
  666. package/dist/utils/lifecycles.mjs.map +1 -1
  667. package/dist/utils/load-config-file.js +40 -38
  668. package/dist/utils/load-config-file.js.map +1 -1
  669. package/dist/utils/load-config-file.mjs +39 -36
  670. package/dist/utils/load-config-file.mjs.map +1 -1
  671. package/dist/utils/load-files.js +40 -35
  672. package/dist/utils/load-files.js.map +1 -1
  673. package/dist/utils/load-files.mjs +39 -32
  674. package/dist/utils/load-files.mjs.map +1 -1
  675. package/dist/utils/open-browser.js +8 -8
  676. package/dist/utils/open-browser.js.map +1 -1
  677. package/dist/utils/open-browser.mjs +7 -7
  678. package/dist/utils/open-browser.mjs.map +1 -1
  679. package/dist/utils/resolve-working-dirs.js +23 -10
  680. package/dist/utils/resolve-working-dirs.js.map +1 -1
  681. package/dist/utils/resolve-working-dirs.mjs +22 -9
  682. package/dist/utils/resolve-working-dirs.mjs.map +1 -1
  683. package/dist/utils/signals.js +20 -14
  684. package/dist/utils/signals.js.map +1 -1
  685. package/dist/utils/signals.mjs +19 -15
  686. package/dist/utils/signals.mjs.map +1 -1
  687. package/dist/utils/startup-logger.d.ts.map +1 -1
  688. package/dist/utils/startup-logger.js +107 -78
  689. package/dist/utils/startup-logger.js.map +1 -1
  690. package/dist/utils/startup-logger.mjs +106 -75
  691. package/dist/utils/startup-logger.mjs.map +1 -1
  692. package/dist/utils/transform-content-types-to-models.js +350 -261
  693. package/dist/utils/transform-content-types-to-models.js.map +1 -1
  694. package/dist/utils/transform-content-types-to-models.mjs +349 -269
  695. package/dist/utils/transform-content-types-to-models.mjs.map +1 -1
  696. package/dist/utils/update-notifier/index.d.ts.map +1 -1
  697. package/dist/utils/update-notifier/index.js +68 -73
  698. package/dist/utils/update-notifier/index.js.map +1 -1
  699. package/dist/utils/update-notifier/index.mjs +67 -67
  700. package/dist/utils/update-notifier/index.mjs.map +1 -1
  701. package/package.json +25 -26
@@ -1,25 +1,28 @@
1
- import { yup } from "@strapi/utils";
1
+ import { yup } from '@strapi/utils';
2
+
2
3
  const strapiServerSchema = yup.object().shape({
3
- bootstrap: yup.mixed().isFunction(),
4
- destroy: yup.mixed().isFunction(),
5
- register: yup.mixed().isFunction(),
6
- config: yup.object(),
7
- routes: yup.lazy((value) => {
8
- if (Array.isArray(value)) {
9
- return yup.array();
10
- }
11
- return yup.object();
12
- }),
13
- controllers: yup.object(),
14
- services: yup.object(),
15
- policies: yup.object(),
16
- middlewares: yup.object(),
17
- contentTypes: yup.object()
4
+ bootstrap: yup.mixed().isFunction(),
5
+ destroy: yup.mixed().isFunction(),
6
+ register: yup.mixed().isFunction(),
7
+ config: yup.object(),
8
+ routes: yup.lazy((value)=>{
9
+ if (Array.isArray(value)) {
10
+ return yup.array();
11
+ }
12
+ return yup.object();
13
+ }),
14
+ controllers: yup.object(),
15
+ services: yup.object(),
16
+ policies: yup.object(),
17
+ middlewares: yup.object(),
18
+ contentTypes: yup.object()
18
19
  }).noUnknown();
19
- const validateModule = (data) => {
20
- return strapiServerSchema.validateSync(data, { strict: true, abortEarly: false });
21
- };
22
- export {
23
- validateModule
20
+ const validateModule = (data)=>{
21
+ return strapiServerSchema.validateSync(data, {
22
+ strict: true,
23
+ abortEarly: false
24
+ });
24
25
  };
26
+
27
+ export { validateModule };
25
28
  //# sourceMappingURL=validation.mjs.map
@@ -1 +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
+ {"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":["strapiServerSchema","yup","object","shape","bootstrap","mixed","isFunction","destroy","register","config","routes","lazy","value","Array","isArray","array","controllers","services","policies","middlewares","contentTypes","noUnknown","validateModule","data","validateSync","strict","abortEarly"],"mappings":";;AAEA,MAAMA,kBAAqBC,GAAAA,GAAAA,CACxBC,MAAM,EAAA,CACNC,KAAK,CAAC;IACLC,SAAWH,EAAAA,GAAAA,CAAII,KAAK,EAAA,CAAGC,UAAU,EAAA;IACjCC,OAASN,EAAAA,GAAAA,CAAII,KAAK,EAAA,CAAGC,UAAU,EAAA;IAC/BE,QAAUP,EAAAA,GAAAA,CAAII,KAAK,EAAA,CAAGC,UAAU,EAAA;AAChCG,IAAAA,MAAAA,EAAQR,IAAIC,MAAM,EAAA;IAClBQ,MAAQT,EAAAA,GAAAA,CAAIU,IAAI,CAAC,CAACC,KAAAA,GAAAA;QAChB,IAAIC,KAAAA,CAAMC,OAAO,CAACF,KAAQ,CAAA,EAAA;AACxB,YAAA,OAAOX,IAAIc,KAAK,EAAA;AAClB;AACA,QAAA,OAAOd,IAAIC,MAAM,EAAA;AACnB,KAAA,CAAA;AACAc,IAAAA,WAAAA,EAAaf,IAAIC,MAAM,EAAA;AACvBe,IAAAA,QAAAA,EAAUhB,IAAIC,MAAM,EAAA;AACpBgB,IAAAA,QAAAA,EAAUjB,IAAIC,MAAM,EAAA;AACpBiB,IAAAA,WAAAA,EAAalB,IAAIC,MAAM,EAAA;AACvBkB,IAAAA,YAAAA,EAAcnB,IAAIC,MAAM;AAC1B,CAAA,CAAA,CACCmB,SAAS,EAAA;AAEZ,MAAMC,iBAAiB,CAACC,IAAAA,GAAAA;IACtB,OAAOvB,kBAAAA,CAAmBwB,YAAY,CAACD,IAAM,EAAA;QAAEE,MAAQ,EAAA,IAAA;QAAMC,UAAY,EAAA;AAAM,KAAA,CAAA;AACjF;;;;"}
@@ -6,6 +6,7 @@ declare const _default: Readonly<{
6
6
  }) => Promise<void>;
7
7
  readonly isEE: boolean;
8
8
  readonly seats: number | undefined;
9
+ readonly type: string | undefined;
9
10
  features: Readonly<{
10
11
  list: () => {
11
12
  [key: string]: any;
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/ee/index.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;;;;;;;;;;;;;;;;;iCAsPb,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;;;;;;;;;;;;;;;;;;iCA0Pb,MAAM;;;AAnBnC,wBAqBG"}
package/dist/ee/index.js CHANGED
@@ -1,158 +1,192 @@
1
- "use strict";
2
- const fp = require("lodash/fp");
3
- const license = require("./license.js");
4
- const cron = require("../utils/cron.js");
5
- const ONE_MINUTE = 1e3 * 60;
1
+ 'use strict';
2
+
3
+ var fp = require('lodash/fp');
4
+ var license = require('./license.js');
5
+ var cron = require('../utils/cron.js');
6
+
7
+ const ONE_MINUTE = 1000 * 60;
6
8
  const ee = {
7
- enabled: false,
8
- licenseInfo: {}
9
+ enabled: false,
10
+ licenseInfo: {}
9
11
  };
10
- const disable = (message) => {
11
- const shouldEmitEvent = ee.enabled !== false;
12
- ee.logger?.warn(`${message} Switching to CE.`);
13
- ee.licenseInfo = fp.pick("licenseKey", ee.licenseInfo);
14
- ee.enabled = false;
15
- if (shouldEmitEvent) {
16
- strapi.eventHub.emit("ee.disable");
17
- }
12
+ const disable = (message)=>{
13
+ // Prevent emitting ee.disable if it was already disabled
14
+ const shouldEmitEvent = ee.enabled !== false;
15
+ ee.logger?.warn(`${message} Switching to CE.`);
16
+ // Only keep the license key for potential re-enabling during a later check
17
+ ee.licenseInfo = fp.pick('licenseKey', ee.licenseInfo);
18
+ ee.enabled = false;
19
+ if (shouldEmitEvent) {
20
+ // Notify EE features that they should be disabled
21
+ strapi.eventHub.emit('ee.disable');
22
+ }
18
23
  };
19
- const enable = () => {
20
- const shouldEmitEvent = ee.enabled !== true;
21
- ee.enabled = true;
22
- if (shouldEmitEvent) {
23
- strapi.eventHub.emit("ee.enable");
24
- }
24
+ const enable = ()=>{
25
+ // Prevent emitting ee.enable if it was already enabled
26
+ const shouldEmitEvent = ee.enabled !== true;
27
+ ee.enabled = true;
28
+ if (shouldEmitEvent) {
29
+ // Notify EE features that they should be disabled
30
+ strapi.eventHub.emit('ee.enable');
31
+ }
25
32
  };
26
33
  let initialized = false;
27
- const init = (licenseDir, logger) => {
28
- if (initialized) {
29
- return;
30
- }
31
- initialized = true;
32
- ee.logger = logger;
33
- if (process.env.STRAPI_DISABLE_EE?.toLowerCase() === "true") {
34
- return;
35
- }
36
- try {
37
- const license$1 = process.env.STRAPI_LICENSE || license.readLicense(licenseDir);
38
- if (license$1) {
39
- ee.licenseInfo = license.verifyLicense(license$1);
40
- enable();
41
- }
42
- } catch (error) {
43
- if (error instanceof Error) {
44
- disable(error.message);
45
- } else {
46
- disable("Invalid license.");
34
+ /**
35
+ * Optimistically enable EE if the format of the license is valid, only run once.
36
+ */ const init = (licenseDir, logger)=>{
37
+ if (initialized) {
38
+ return;
47
39
  }
48
- }
49
- };
50
- const onlineUpdate = async ({ strapi: strapi2 }) => {
51
- const { get: get2, commit, rollback } = await strapi2.db?.transaction();
52
- const transaction = get2();
53
- try {
54
- const storedInfo = await strapi2.db?.queryBuilder("strapi::core-store").where({ key: "ee_information" }).select("value").first().transacting(transaction).forUpdate().execute().then((result2) => result2 ? JSON.parse(result2.value) : result2);
55
- const shouldContactRegistry = (storedInfo?.lastCheckAt ?? 0) < Date.now() - ONE_MINUTE;
56
- const result = { lastCheckAt: Date.now() };
57
- const fallback = (error) => {
58
- if (error instanceof license.LicenseCheckError && error.shouldFallback && storedInfo?.license) {
59
- ee.logger?.warn(
60
- `${error.message} The last stored one will be used as a potential fallback.`
61
- );
62
- return storedInfo.license;
63
- }
64
- result.error = error.message;
65
- disable(error.message);
66
- };
67
- if (!ee?.licenseInfo?.licenseKey) {
68
- throw new Error("Missing license key.");
40
+ initialized = true;
41
+ ee.logger = logger;
42
+ if (process.env.STRAPI_DISABLE_EE?.toLowerCase() === 'true') {
43
+ return;
69
44
  }
70
- const license$1 = shouldContactRegistry ? await license.fetchLicense({ strapi: strapi2 }, ee.licenseInfo.licenseKey, strapi2.config.get("uuid")).catch(
71
- fallback
72
- ) : storedInfo.license;
73
- if (license$1) {
74
- try {
75
- const newLicenseInfo = license.verifyLicense(license$1);
76
- const licenseInfoChanged = !fp.isEqual(newLicenseInfo.features, ee.licenseInfo.features) || newLicenseInfo.seats !== ee.licenseInfo.seats || newLicenseInfo.type !== ee.licenseInfo.type;
77
- ee.licenseInfo = newLicenseInfo;
78
- const wasEnabled = ee.enabled;
79
- validateInfo();
80
- if (licenseInfoChanged && wasEnabled) {
81
- strapi2.eventHub.emit("ee.update");
45
+ try {
46
+ const license$1 = process.env.STRAPI_LICENSE || license.readLicense(licenseDir);
47
+ if (license$1) {
48
+ ee.licenseInfo = license.verifyLicense(license$1);
49
+ enable();
82
50
  }
83
- } catch (error) {
51
+ } catch (error) {
84
52
  if (error instanceof Error) {
85
- disable(error.message);
53
+ disable(error.message);
86
54
  } else {
87
- disable("Invalid license.");
55
+ disable('Invalid license.');
88
56
  }
89
- }
90
- } else if (!shouldContactRegistry) {
91
- disable(storedInfo.error);
92
57
  }
93
- if (shouldContactRegistry) {
94
- result.license = license$1 ?? null;
95
- const query = strapi2.db.queryBuilder("strapi::core-store").transacting(transaction);
96
- if (!storedInfo) {
97
- query.insert({ key: "ee_information", value: JSON.stringify(result) });
98
- } else {
99
- query.update({ value: JSON.stringify(result) }).where({ key: "ee_information" });
100
- }
101
- await query.execute();
58
+ };
59
+ /**
60
+ * Contact the license registry to update the license to its latest state.
61
+ *
62
+ * Store the result in database to avoid unecessary requests, and will fallback to that in case of a network failure.
63
+ */ const onlineUpdate = async ({ strapi: strapi1 })=>{
64
+ const { get, commit, rollback } = await strapi1.db?.transaction();
65
+ const transaction = get();
66
+ try {
67
+ const storedInfo = await strapi1.db?.queryBuilder('strapi::core-store').where({
68
+ key: 'ee_information'
69
+ }).select('value').first().transacting(transaction).forUpdate().execute().then((result)=>result ? JSON.parse(result.value) : result);
70
+ const shouldContactRegistry = (storedInfo?.lastCheckAt ?? 0) < Date.now() - ONE_MINUTE;
71
+ const result = {
72
+ lastCheckAt: Date.now()
73
+ };
74
+ const fallback = (error)=>{
75
+ if (error instanceof license.LicenseCheckError && error.shouldFallback && storedInfo?.license) {
76
+ ee.logger?.warn(`${error.message} The last stored one will be used as a potential fallback.`);
77
+ return storedInfo.license;
78
+ }
79
+ result.error = error.message;
80
+ disable(error.message);
81
+ };
82
+ if (!ee?.licenseInfo?.licenseKey) {
83
+ throw new Error('Missing license key.');
84
+ }
85
+ const license$1 = shouldContactRegistry ? await license.fetchLicense({
86
+ strapi: strapi1
87
+ }, ee.licenseInfo.licenseKey, strapi1.config.get('uuid')).catch(fallback) : storedInfo.license;
88
+ if (license$1) {
89
+ try {
90
+ // Verify license and check if its info changed
91
+ const newLicenseInfo = license.verifyLicense(license$1);
92
+ const licenseInfoChanged = !fp.isEqual(newLicenseInfo.features, ee.licenseInfo.features) || newLicenseInfo.seats !== ee.licenseInfo.seats || newLicenseInfo.type !== ee.licenseInfo.type;
93
+ // Store the new license info
94
+ ee.licenseInfo = newLicenseInfo;
95
+ const wasEnabled = ee.enabled;
96
+ validateInfo();
97
+ // Notify EE features
98
+ if (licenseInfoChanged && wasEnabled) {
99
+ strapi1.eventHub.emit('ee.update');
100
+ }
101
+ } catch (error) {
102
+ if (error instanceof Error) {
103
+ disable(error.message);
104
+ } else {
105
+ disable('Invalid license.');
106
+ }
107
+ }
108
+ } else if (!shouldContactRegistry) {
109
+ disable(storedInfo.error);
110
+ }
111
+ if (shouldContactRegistry) {
112
+ result.license = license$1 ?? null;
113
+ const query = strapi1.db.queryBuilder('strapi::core-store').transacting(transaction);
114
+ if (!storedInfo) {
115
+ query.insert({
116
+ key: 'ee_information',
117
+ value: JSON.stringify(result)
118
+ });
119
+ } else {
120
+ query.update({
121
+ value: JSON.stringify(result)
122
+ }).where({
123
+ key: 'ee_information'
124
+ });
125
+ }
126
+ await query.execute();
127
+ }
128
+ await commit();
129
+ } catch (error) {
130
+ // Example of errors: SQLite does not support FOR UPDATE
131
+ await rollback();
102
132
  }
103
- await commit();
104
- } catch (error) {
105
- await rollback();
106
- }
107
133
  };
108
- const validateInfo = () => {
109
- if (typeof ee.licenseInfo.expireAt === "undefined") {
110
- throw new Error("Missing license key.");
111
- }
112
- const expirationTime = new Date(ee.licenseInfo.expireAt).getTime();
113
- if (expirationTime < (/* @__PURE__ */ new Date()).getTime()) {
114
- return disable("License expired.");
115
- }
116
- enable();
134
+ const validateInfo = ()=>{
135
+ if (typeof ee.licenseInfo.expireAt === 'undefined') {
136
+ throw new Error('Missing license key.');
137
+ }
138
+ const expirationTime = new Date(ee.licenseInfo.expireAt).getTime();
139
+ if (expirationTime < new Date().getTime()) {
140
+ return disable('License expired.');
141
+ }
142
+ enable();
117
143
  };
118
- const checkLicense = async ({ strapi: strapi2 }) => {
119
- const shouldStayOffline = ee.licenseInfo.type === "gold" && // This env variable support is temporarily used to ease the migration between online vs offline
120
- process.env.STRAPI_DISABLE_LICENSE_PING?.toLowerCase() === "true";
121
- if (!shouldStayOffline) {
122
- await onlineUpdate({ strapi: strapi2 });
123
- strapi2.cron.add({
124
- onlineUpdate: {
125
- task: () => onlineUpdate({ strapi: strapi2 }),
126
- options: cron.shiftCronExpression("0 0 */12 * * *")
127
- }
128
- });
129
- } else {
130
- if (!ee.licenseInfo.expireAt) {
131
- return disable("Your license does not have offline support.");
144
+ const checkLicense = async ({ strapi: strapi1 })=>{
145
+ const shouldStayOffline = ee.licenseInfo.type === 'gold' && // This env variable support is temporarily used to ease the migration between online vs offline
146
+ process.env.STRAPI_DISABLE_LICENSE_PING?.toLowerCase() === 'true';
147
+ if (!shouldStayOffline) {
148
+ await onlineUpdate({
149
+ strapi: strapi1
150
+ });
151
+ strapi1.cron.add({
152
+ onlineUpdate: {
153
+ task: ()=>onlineUpdate({
154
+ strapi: strapi1
155
+ }),
156
+ options: cron.shiftCronExpression('0 0 */12 * * *')
157
+ }
158
+ });
159
+ } else {
160
+ if (!ee.licenseInfo.expireAt) {
161
+ return disable('Your license does not have offline support.');
162
+ }
163
+ validateInfo();
132
164
  }
133
- validateInfo();
134
- }
135
165
  };
136
- const list = () => {
137
- return ee.licenseInfo.features?.map(
138
- (feature) => typeof feature === "object" ? feature : { name: feature }
139
- ) || [];
166
+ const list = ()=>{
167
+ return ee.licenseInfo.features?.map((feature)=>typeof feature === 'object' ? feature : {
168
+ name: feature
169
+ }) || [];
140
170
  };
141
- const get = (featureName) => list().find((feature) => feature.name === featureName);
142
- const index = Object.freeze({
143
- init,
144
- checkLicense,
145
- get isEE() {
146
- return ee.enabled;
147
- },
148
- get seats() {
149
- return ee.licenseInfo.seats;
150
- },
151
- features: Object.freeze({
152
- list,
153
- get,
154
- isEnabled: (featureName) => get(featureName) !== void 0
155
- })
171
+ const get = (featureName)=>list().find((feature)=>feature.name === featureName);
172
+ var index = Object.freeze({
173
+ init,
174
+ checkLicense,
175
+ get isEE () {
176
+ return ee.enabled;
177
+ },
178
+ get seats () {
179
+ return ee.licenseInfo.seats;
180
+ },
181
+ get type () {
182
+ return ee.licenseInfo.type;
183
+ },
184
+ features: Object.freeze({
185
+ list,
186
+ get,
187
+ isEnabled: (featureName)=>get(featureName) !== undefined
188
+ })
156
189
  });
190
+
157
191
  module.exports = index;
158
192
  //# 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 { 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\n strapi.cron.add({\n onlineUpdate: {\n task: () => onlineUpdate({ strapi }),\n options: shiftCronExpression('0 0 */12 * * *'),\n },\n });\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\n strapi.cron.add({\n onlineUpdate: {\n task: () => onlineUpdate({ strapi }),\n options: shiftCronExpression('0 0 */12 * * *'),\n },\n });\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 get type() {\n return ee.licenseInfo.type;\n },\n\n features: Object.freeze({\n list,\n get,\n isEnabled: (featureName: string) => get(featureName) !== undefined,\n }),\n});\n"],"names":["ONE_MINUTE","ee","enabled","licenseInfo","disable","message","shouldEmitEvent","logger","warn","pick","strapi","eventHub","emit","enable","initialized","init","licenseDir","process","env","STRAPI_DISABLE_EE","toLowerCase","license","STRAPI_LICENSE","readLicense","verifyLicense","error","Error","onlineUpdate","get","commit","rollback","db","transaction","storedInfo","queryBuilder","where","key","select","first","transacting","forUpdate","execute","then","result","JSON","parse","value","shouldContactRegistry","lastCheckAt","Date","now","fallback","LicenseCheckError","shouldFallback","licenseKey","fetchLicense","config","catch","newLicenseInfo","licenseInfoChanged","isEqual","features","seats","type","wasEnabled","validateInfo","query","insert","stringify","update","expireAt","expirationTime","getTime","checkLicense","shouldStayOffline","STRAPI_DISABLE_LICENSE_PING","cron","add","task","options","shiftCronExpression","list","map","feature","name","featureName","find","Object","freeze","isEE","isEnabled","undefined"],"mappings":"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"}