@strapi/core 0.0.0-experimental.fc1ac2acd58c8a5a858679956b6d102ac5ee4011 → 0.0.0-experimental.fca58d9b01ba89012d84a58a20556a6fd716cb92

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 (1014) hide show
  1. package/LICENSE +18 -3
  2. package/dist/Strapi.d.ts +52 -59
  3. package/dist/Strapi.d.ts.map +1 -1
  4. package/dist/Strapi.js +436 -431
  5. package/dist/Strapi.js.map +1 -1
  6. package/dist/Strapi.mjs +427 -442
  7. package/dist/Strapi.mjs.map +1 -1
  8. package/dist/compile.js +23 -14
  9. package/dist/compile.js.map +1 -1
  10. package/dist/compile.mjs +22 -14
  11. package/dist/compile.mjs.map +1 -1
  12. package/dist/configuration/config-loader.d.ts.map +1 -1
  13. package/dist/configuration/config-loader.js +110 -93
  14. package/dist/configuration/config-loader.js.map +1 -1
  15. package/dist/configuration/config-loader.mjs +109 -92
  16. package/dist/configuration/config-loader.mjs.map +1 -1
  17. package/dist/configuration/get-dirs.d.ts +10 -0
  18. package/dist/configuration/get-dirs.d.ts.map +1 -0
  19. package/dist/configuration/get-dirs.js +33 -0
  20. package/dist/configuration/get-dirs.js.map +1 -0
  21. package/dist/configuration/get-dirs.mjs +31 -0
  22. package/dist/configuration/get-dirs.mjs.map +1 -0
  23. package/dist/configuration/index.d.ts +5 -7
  24. package/dist/configuration/index.d.ts.map +1 -1
  25. package/dist/configuration/index.js +86 -72
  26. package/dist/configuration/index.js.map +1 -1
  27. package/dist/configuration/index.mjs +84 -68
  28. package/dist/configuration/index.mjs.map +1 -1
  29. package/dist/configuration/urls.d.ts.map +1 -1
  30. package/dist/configuration/urls.js +74 -61
  31. package/dist/configuration/urls.js.map +1 -1
  32. package/dist/configuration/urls.mjs +73 -62
  33. package/dist/configuration/urls.mjs.map +1 -1
  34. package/dist/container.d.ts +2 -2
  35. package/dist/container.d.ts.map +1 -1
  36. package/dist/container.js +27 -23
  37. package/dist/container.js.map +1 -1
  38. package/dist/container.mjs +26 -24
  39. package/dist/container.mjs.map +1 -1
  40. package/dist/core-api/controller/collection-type.d.ts +3 -3
  41. package/dist/core-api/controller/collection-type.d.ts.map +1 -1
  42. package/dist/core-api/controller/collection-type.js +77 -73
  43. package/dist/core-api/controller/collection-type.js.map +1 -1
  44. package/dist/core-api/controller/collection-type.mjs +76 -74
  45. package/dist/core-api/controller/collection-type.mjs.map +1 -1
  46. package/dist/core-api/controller/index.d.ts +3 -3
  47. package/dist/core-api/controller/index.d.ts.map +1 -1
  48. package/dist/core-api/controller/index.js +63 -48
  49. package/dist/core-api/controller/index.js.map +1 -1
  50. package/dist/core-api/controller/index.mjs +62 -49
  51. package/dist/core-api/controller/index.mjs.map +1 -1
  52. package/dist/core-api/controller/single-type.d.ts +3 -3
  53. package/dist/core-api/controller/single-type.d.ts.map +1 -1
  54. package/dist/core-api/controller/single-type.js +41 -39
  55. package/dist/core-api/controller/single-type.js.map +1 -1
  56. package/dist/core-api/controller/single-type.mjs +40 -40
  57. package/dist/core-api/controller/single-type.mjs.map +1 -1
  58. package/dist/core-api/controller/transform.d.ts +2 -2
  59. package/dist/core-api/controller/transform.d.ts.map +1 -1
  60. package/dist/core-api/controller/transform.js +72 -66
  61. package/dist/core-api/controller/transform.js.map +1 -1
  62. package/dist/core-api/controller/transform.mjs +71 -67
  63. package/dist/core-api/controller/transform.mjs.map +1 -1
  64. package/dist/core-api/routes/index.d.ts.map +1 -1
  65. package/dist/core-api/routes/index.js +64 -62
  66. package/dist/core-api/routes/index.js.map +1 -1
  67. package/dist/core-api/routes/index.mjs +62 -62
  68. package/dist/core-api/routes/index.mjs.map +1 -1
  69. package/dist/core-api/service/collection-type.d.ts +11 -17
  70. package/dist/core-api/service/collection-type.d.ts.map +1 -1
  71. package/dist/core-api/service/collection-type.js +73 -49
  72. package/dist/core-api/service/collection-type.js.map +1 -1
  73. package/dist/core-api/service/collection-type.mjs +72 -51
  74. package/dist/core-api/service/collection-type.mjs.map +1 -1
  75. package/dist/core-api/service/core-service.js +9 -8
  76. package/dist/core-api/service/core-service.js.map +1 -1
  77. package/dist/core-api/service/core-service.mjs +8 -9
  78. package/dist/core-api/service/core-service.mjs.map +1 -1
  79. package/dist/core-api/service/index.d.ts +3 -3
  80. package/dist/core-api/service/index.d.ts.map +1 -1
  81. package/dist/core-api/service/index.js +13 -13
  82. package/dist/core-api/service/index.js.map +1 -1
  83. package/dist/core-api/service/index.mjs +12 -14
  84. package/dist/core-api/service/index.mjs.map +1 -1
  85. package/dist/core-api/service/pagination.d.ts +4 -11
  86. package/dist/core-api/service/pagination.d.ts.map +1 -1
  87. package/dist/core-api/service/pagination.js +68 -68
  88. package/dist/core-api/service/pagination.js.map +1 -1
  89. package/dist/core-api/service/pagination.mjs +66 -71
  90. package/dist/core-api/service/pagination.mjs.map +1 -1
  91. package/dist/core-api/service/single-type.d.ts +4 -4
  92. package/dist/core-api/service/single-type.d.ts.map +1 -1
  93. package/dist/core-api/service/single-type.js +43 -32
  94. package/dist/core-api/service/single-type.js.map +1 -1
  95. package/dist/core-api/service/single-type.mjs +42 -34
  96. package/dist/core-api/service/single-type.mjs.map +1 -1
  97. package/dist/domain/content-type/index.d.ts +1 -1
  98. package/dist/domain/content-type/index.d.ts.map +1 -1
  99. package/dist/domain/content-type/index.js +95 -100
  100. package/dist/domain/content-type/index.js.map +1 -1
  101. package/dist/domain/content-type/index.mjs +94 -100
  102. package/dist/domain/content-type/index.mjs.map +1 -1
  103. package/dist/domain/content-type/validator.js +84 -69
  104. package/dist/domain/content-type/validator.js.map +1 -1
  105. package/dist/domain/content-type/validator.mjs +83 -68
  106. package/dist/domain/content-type/validator.mjs.map +1 -1
  107. package/dist/domain/module/index.d.ts +24 -23
  108. package/dist/domain/module/index.d.ts.map +1 -1
  109. package/dist/domain/module/index.js +109 -99
  110. package/dist/domain/module/index.js.map +1 -1
  111. package/dist/domain/module/index.mjs +108 -98
  112. package/dist/domain/module/index.mjs.map +1 -1
  113. package/dist/domain/module/validation.js +25 -20
  114. package/dist/domain/module/validation.js.map +1 -1
  115. package/dist/domain/module/validation.mjs +24 -21
  116. package/dist/domain/module/validation.mjs.map +1 -1
  117. package/dist/ee/index.d.ts +5 -2
  118. package/dist/ee/index.d.ts.map +1 -1
  119. package/dist/ee/index.js +171 -132
  120. package/dist/ee/index.js.map +1 -1
  121. package/dist/ee/index.mjs +170 -134
  122. package/dist/ee/index.mjs.map +1 -1
  123. package/dist/ee/license.d.ts +2 -2
  124. package/dist/ee/license.d.ts.map +1 -1
  125. package/dist/ee/license.js +100 -74
  126. package/dist/ee/license.js.map +1 -1
  127. package/dist/ee/license.mjs +99 -75
  128. package/dist/ee/license.mjs.map +1 -1
  129. package/dist/factories.d.ts +10 -10
  130. package/dist/factories.d.ts.map +1 -1
  131. package/dist/factories.js +72 -63
  132. package/dist/factories.js.map +1 -1
  133. package/dist/factories.mjs +71 -67
  134. package/dist/factories.mjs.map +1 -1
  135. package/dist/index.d.ts +18 -2
  136. package/dist/index.d.ts.map +1 -1
  137. package/dist/index.js +32 -5
  138. package/dist/index.js.map +1 -1
  139. package/dist/index.mjs +29 -5
  140. package/dist/index.mjs.map +1 -1
  141. package/dist/loaders/admin.d.ts +2 -2
  142. package/dist/loaders/admin.d.ts.map +1 -1
  143. package/dist/loaders/admin.js +21 -21
  144. package/dist/loaders/admin.js.map +1 -1
  145. package/dist/loaders/admin.mjs +20 -21
  146. package/dist/loaders/admin.mjs.map +1 -1
  147. package/dist/loaders/apis.d.ts +2 -2
  148. package/dist/loaders/apis.d.ts.map +1 -1
  149. package/dist/loaders/apis.js +143 -120
  150. package/dist/loaders/apis.js.map +1 -1
  151. package/dist/loaders/apis.mjs +142 -119
  152. package/dist/loaders/apis.mjs.map +1 -1
  153. package/dist/loaders/components.d.ts +2 -2
  154. package/dist/loaders/components.d.ts.map +1 -1
  155. package/dist/loaders/components.js +33 -34
  156. package/dist/loaders/components.js.map +1 -1
  157. package/dist/loaders/components.mjs +32 -34
  158. package/dist/loaders/components.mjs.map +1 -1
  159. package/dist/loaders/index.d.ts +2 -2
  160. package/dist/loaders/index.d.ts.map +1 -1
  161. package/dist/loaders/index.js +22 -22
  162. package/dist/loaders/index.js.map +1 -1
  163. package/dist/loaders/index.mjs +21 -23
  164. package/dist/loaders/index.mjs.map +1 -1
  165. package/dist/loaders/middlewares.d.ts +2 -2
  166. package/dist/loaders/middlewares.d.ts.map +1 -1
  167. package/dist/loaders/middlewares.js +29 -25
  168. package/dist/loaders/middlewares.js.map +1 -1
  169. package/dist/loaders/middlewares.mjs +28 -25
  170. package/dist/loaders/middlewares.mjs.map +1 -1
  171. package/dist/loaders/plugins/get-enabled-plugins.d.ts +2 -2
  172. package/dist/loaders/plugins/get-enabled-plugins.d.ts.map +1 -1
  173. package/dist/loaders/plugins/get-enabled-plugins.js +125 -100
  174. package/dist/loaders/plugins/get-enabled-plugins.js.map +1 -1
  175. package/dist/loaders/plugins/get-enabled-plugins.mjs +124 -99
  176. package/dist/loaders/plugins/get-enabled-plugins.mjs.map +1 -1
  177. package/dist/loaders/plugins/get-user-plugins-config.js +25 -24
  178. package/dist/loaders/plugins/get-user-plugins-config.js.map +1 -1
  179. package/dist/loaders/plugins/get-user-plugins-config.mjs +24 -23
  180. package/dist/loaders/plugins/get-user-plugins-config.mjs.map +1 -1
  181. package/dist/loaders/plugins/index.d.ts +2 -2
  182. package/dist/loaders/plugins/index.d.ts.map +1 -1
  183. package/dist/loaders/plugins/index.js +141 -104
  184. package/dist/loaders/plugins/index.js.map +1 -1
  185. package/dist/loaders/plugins/index.mjs +121 -104
  186. package/dist/loaders/plugins/index.mjs.map +1 -1
  187. package/dist/loaders/policies.d.ts +2 -2
  188. package/dist/loaders/policies.d.ts.map +1 -1
  189. package/dist/loaders/policies.js +24 -20
  190. package/dist/loaders/policies.js.map +1 -1
  191. package/dist/loaders/policies.mjs +23 -20
  192. package/dist/loaders/policies.mjs.map +1 -1
  193. package/dist/loaders/sanitizers.d.ts +2 -2
  194. package/dist/loaders/sanitizers.d.ts.map +1 -1
  195. package/dist/loaders/sanitizers.js +10 -4
  196. package/dist/loaders/sanitizers.js.map +1 -1
  197. package/dist/loaders/sanitizers.mjs +9 -6
  198. package/dist/loaders/sanitizers.mjs.map +1 -1
  199. package/dist/loaders/src-index.d.ts +2 -2
  200. package/dist/loaders/src-index.d.ts.map +1 -1
  201. package/dist/loaders/src-index.js +35 -27
  202. package/dist/loaders/src-index.js.map +1 -1
  203. package/dist/loaders/src-index.mjs +34 -29
  204. package/dist/loaders/src-index.mjs.map +1 -1
  205. package/dist/loaders/validators.d.ts +2 -2
  206. package/dist/loaders/validators.d.ts.map +1 -1
  207. package/dist/loaders/validators.js +9 -4
  208. package/dist/loaders/validators.js.map +1 -1
  209. package/dist/loaders/validators.mjs +8 -6
  210. package/dist/loaders/validators.mjs.map +1 -1
  211. package/dist/middlewares/body.d.ts +4 -4
  212. package/dist/middlewares/body.d.ts.map +1 -1
  213. package/dist/middlewares/body.js +58 -54
  214. package/dist/middlewares/body.js.map +1 -1
  215. package/dist/middlewares/body.mjs +57 -51
  216. package/dist/middlewares/body.mjs.map +1 -1
  217. package/dist/middlewares/compression.d.ts +2 -2
  218. package/dist/middlewares/compression.d.ts.map +1 -1
  219. package/dist/middlewares/compression.js +6 -6
  220. package/dist/middlewares/compression.js.map +1 -1
  221. package/dist/middlewares/compression.mjs +5 -5
  222. package/dist/middlewares/compression.mjs.map +1 -1
  223. package/dist/middlewares/cors.d.ts +2 -2
  224. package/dist/middlewares/cors.d.ts.map +1 -1
  225. package/dist/middlewares/cors.js +59 -46
  226. package/dist/middlewares/cors.js.map +1 -1
  227. package/dist/middlewares/cors.mjs +58 -45
  228. package/dist/middlewares/cors.mjs.map +1 -1
  229. package/dist/middlewares/errors.d.ts +2 -2
  230. package/dist/middlewares/errors.d.ts.map +1 -1
  231. package/dist/middlewares/errors.js +32 -30
  232. package/dist/middlewares/errors.js.map +1 -1
  233. package/dist/middlewares/errors.mjs +31 -31
  234. package/dist/middlewares/errors.mjs.map +1 -1
  235. package/dist/middlewares/favicon.d.ts +2 -2
  236. package/dist/middlewares/favicon.d.ts.map +1 -1
  237. package/dist/middlewares/favicon.js +27 -17
  238. package/dist/middlewares/favicon.js.map +1 -1
  239. package/dist/middlewares/favicon.mjs +26 -16
  240. package/dist/middlewares/favicon.mjs.map +1 -1
  241. package/dist/middlewares/index.d.ts +2 -2
  242. package/dist/middlewares/index.d.ts.map +1 -1
  243. package/dist/middlewares/index.js +32 -30
  244. package/dist/middlewares/index.js.map +1 -1
  245. package/dist/middlewares/index.mjs +31 -31
  246. package/dist/middlewares/index.mjs.map +1 -1
  247. package/dist/middlewares/ip.d.ts +2 -2
  248. package/dist/middlewares/ip.d.ts.map +1 -1
  249. package/dist/middlewares/ip.js +6 -6
  250. package/dist/middlewares/ip.js.map +1 -1
  251. package/dist/middlewares/ip.mjs +5 -5
  252. package/dist/middlewares/ip.mjs.map +1 -1
  253. package/dist/middlewares/logger.d.ts +2 -2
  254. package/dist/middlewares/logger.d.ts.map +1 -1
  255. package/dist/middlewares/logger.js +10 -9
  256. package/dist/middlewares/logger.js.map +1 -1
  257. package/dist/middlewares/logger.mjs +9 -10
  258. package/dist/middlewares/logger.mjs.map +1 -1
  259. package/dist/middlewares/powered-by.d.ts +2 -2
  260. package/dist/middlewares/powered-by.d.ts.map +1 -1
  261. package/dist/middlewares/powered-by.js +13 -9
  262. package/dist/middlewares/powered-by.js.map +1 -1
  263. package/dist/middlewares/powered-by.mjs +12 -10
  264. package/dist/middlewares/powered-by.mjs.map +1 -1
  265. package/dist/middlewares/public.d.ts +2 -2
  266. package/dist/middlewares/public.d.ts.map +1 -1
  267. package/dist/middlewares/public.js +33 -29
  268. package/dist/middlewares/public.js.map +1 -1
  269. package/dist/middlewares/public.mjs +32 -28
  270. package/dist/middlewares/public.mjs.map +1 -1
  271. package/dist/middlewares/query.d.ts +2 -2
  272. package/dist/middlewares/query.d.ts.map +1 -1
  273. package/dist/middlewares/query.js +35 -32
  274. package/dist/middlewares/query.js.map +1 -1
  275. package/dist/middlewares/query.mjs +34 -31
  276. package/dist/middlewares/query.mjs.map +1 -1
  277. package/dist/middlewares/response-time.d.ts +2 -2
  278. package/dist/middlewares/response-time.d.ts.map +1 -1
  279. package/dist/middlewares/response-time.js +10 -9
  280. package/dist/middlewares/response-time.js.map +1 -1
  281. package/dist/middlewares/response-time.mjs +9 -10
  282. package/dist/middlewares/response-time.mjs.map +1 -1
  283. package/dist/middlewares/responses.d.ts +3 -3
  284. package/dist/middlewares/responses.d.ts.map +1 -1
  285. package/dist/middlewares/responses.js +14 -12
  286. package/dist/middlewares/responses.js.map +1 -1
  287. package/dist/middlewares/responses.mjs +13 -13
  288. package/dist/middlewares/responses.mjs.map +1 -1
  289. package/dist/middlewares/security.d.ts +2 -2
  290. package/dist/middlewares/security.d.ts.map +1 -1
  291. package/dist/middlewares/security.js +110 -65
  292. package/dist/middlewares/security.js.map +1 -1
  293. package/dist/middlewares/security.mjs +108 -63
  294. package/dist/middlewares/security.mjs.map +1 -1
  295. package/dist/middlewares/session.d.ts +2 -2
  296. package/dist/middlewares/session.d.ts.map +1 -1
  297. package/dist/middlewares/session.js +26 -25
  298. package/dist/middlewares/session.js.map +1 -1
  299. package/dist/middlewares/session.mjs +25 -24
  300. package/dist/middlewares/session.mjs.map +1 -1
  301. package/dist/migrations/database/5.0.0-discard-drafts.d.ts +33 -0
  302. package/dist/migrations/database/5.0.0-discard-drafts.d.ts.map +1 -0
  303. package/dist/migrations/database/5.0.0-discard-drafts.js +168 -0
  304. package/dist/migrations/database/5.0.0-discard-drafts.js.map +1 -0
  305. package/dist/migrations/database/5.0.0-discard-drafts.mjs +165 -0
  306. package/dist/migrations/database/5.0.0-discard-drafts.mjs.map +1 -0
  307. package/dist/migrations/draft-publish.d.ts +2 -2
  308. package/dist/migrations/draft-publish.d.ts.map +1 -1
  309. package/dist/migrations/draft-publish.js +59 -49
  310. package/dist/migrations/draft-publish.js.map +1 -1
  311. package/dist/migrations/draft-publish.mjs +58 -51
  312. package/dist/migrations/draft-publish.mjs.map +1 -1
  313. package/dist/migrations/i18n.d.ts +5 -0
  314. package/dist/migrations/i18n.d.ts.map +1 -0
  315. package/dist/migrations/i18n.js +71 -0
  316. package/dist/migrations/i18n.js.map +1 -0
  317. package/dist/migrations/i18n.mjs +68 -0
  318. package/dist/migrations/i18n.mjs.map +1 -0
  319. package/dist/migrations/index.d.ts +5 -0
  320. package/dist/migrations/index.d.ts.map +1 -0
  321. package/dist/migrations/index.js +29 -0
  322. package/dist/migrations/index.js.map +1 -0
  323. package/dist/migrations/index.mjs +26 -0
  324. package/dist/migrations/index.mjs.map +1 -0
  325. package/dist/package.json.js +182 -0
  326. package/dist/package.json.js.map +1 -0
  327. package/dist/package.json.mjs +159 -0
  328. package/dist/package.json.mjs.map +1 -0
  329. package/dist/providers/admin.d.ts +3 -0
  330. package/dist/providers/admin.d.ts.map +1 -0
  331. package/dist/providers/admin.js +30 -0
  332. package/dist/providers/admin.js.map +1 -0
  333. package/dist/providers/admin.mjs +28 -0
  334. package/dist/providers/admin.mjs.map +1 -0
  335. package/dist/providers/coreStore.d.ts +3 -0
  336. package/dist/providers/coreStore.d.ts.map +1 -0
  337. package/dist/providers/coreStore.js +16 -0
  338. package/dist/providers/coreStore.js.map +1 -0
  339. package/dist/providers/coreStore.mjs +14 -0
  340. package/dist/providers/coreStore.mjs.map +1 -0
  341. package/dist/providers/cron.d.ts +3 -0
  342. package/dist/providers/cron.d.ts.map +1 -0
  343. package/dist/providers/cron.js +23 -0
  344. package/dist/providers/cron.js.map +1 -0
  345. package/dist/providers/cron.mjs +21 -0
  346. package/dist/providers/cron.mjs.map +1 -0
  347. package/dist/providers/index.d.ts +3 -0
  348. package/dist/providers/index.d.ts.map +1 -0
  349. package/dist/providers/index.js +20 -0
  350. package/dist/providers/index.js.map +1 -0
  351. package/dist/providers/index.mjs +18 -0
  352. package/dist/providers/index.mjs.map +1 -0
  353. package/dist/providers/provider.d.ts +9 -0
  354. package/dist/providers/provider.d.ts.map +1 -0
  355. package/dist/providers/provider.js +6 -0
  356. package/dist/providers/provider.js.map +1 -0
  357. package/dist/providers/provider.mjs +4 -0
  358. package/dist/providers/provider.mjs.map +1 -0
  359. package/dist/providers/registries.d.ts +3 -0
  360. package/dist/providers/registries.d.ts.map +1 -0
  361. package/dist/providers/registries.js +40 -0
  362. package/dist/providers/registries.js.map +1 -0
  363. package/dist/providers/registries.mjs +38 -0
  364. package/dist/providers/registries.mjs.map +1 -0
  365. package/dist/providers/telemetry.d.ts +3 -0
  366. package/dist/providers/telemetry.d.ts.map +1 -0
  367. package/dist/providers/telemetry.js +22 -0
  368. package/dist/providers/telemetry.js.map +1 -0
  369. package/dist/providers/telemetry.mjs +20 -0
  370. package/dist/providers/telemetry.mjs.map +1 -0
  371. package/dist/providers/webhooks.d.ts +3 -0
  372. package/dist/providers/webhooks.d.ts.map +1 -0
  373. package/dist/providers/webhooks.js +32 -0
  374. package/dist/providers/webhooks.js.map +1 -0
  375. package/dist/providers/webhooks.mjs +30 -0
  376. package/dist/providers/webhooks.mjs.map +1 -0
  377. package/dist/registries/apis.d.ts +2 -2
  378. package/dist/registries/apis.d.ts.map +1 -1
  379. package/dist/registries/apis.js +23 -20
  380. package/dist/registries/apis.js.map +1 -1
  381. package/dist/registries/apis.mjs +22 -22
  382. package/dist/registries/apis.mjs.map +1 -1
  383. package/dist/registries/components.d.ts +6 -6
  384. package/dist/registries/components.d.ts.map +1 -1
  385. package/dist/registries/components.js +35 -37
  386. package/dist/registries/components.js.map +1 -1
  387. package/dist/registries/components.mjs +34 -39
  388. package/dist/registries/components.mjs.map +1 -1
  389. package/dist/registries/content-types.d.ts +5 -5
  390. package/dist/registries/content-types.d.ts.map +1 -1
  391. package/dist/registries/content-types.js +54 -59
  392. package/dist/registries/content-types.js.map +1 -1
  393. package/dist/registries/content-types.mjs +53 -61
  394. package/dist/registries/content-types.mjs.map +1 -1
  395. package/dist/registries/controllers.d.ts +10 -10
  396. package/dist/registries/controllers.d.ts.map +1 -1
  397. package/dist/registries/controllers.js +70 -71
  398. package/dist/registries/controllers.js.map +1 -1
  399. package/dist/registries/controllers.mjs +69 -73
  400. package/dist/registries/controllers.mjs.map +1 -1
  401. package/dist/registries/custom-fields.d.ts +3 -3
  402. package/dist/registries/custom-fields.d.ts.map +1 -1
  403. package/dist/registries/custom-fields.js +75 -65
  404. package/dist/registries/custom-fields.js.map +1 -1
  405. package/dist/registries/custom-fields.mjs +74 -67
  406. package/dist/registries/custom-fields.mjs.map +1 -1
  407. package/dist/registries/hooks.js +46 -49
  408. package/dist/registries/hooks.js.map +1 -1
  409. package/dist/registries/hooks.mjs +45 -51
  410. package/dist/registries/hooks.mjs.map +1 -1
  411. package/dist/registries/index.d.ts +0 -1
  412. package/dist/registries/index.d.ts.map +1 -1
  413. package/dist/registries/middlewares.d.ts +6 -6
  414. package/dist/registries/middlewares.d.ts.map +1 -1
  415. package/dist/registries/middlewares.js +49 -51
  416. package/dist/registries/middlewares.js.map +1 -1
  417. package/dist/registries/middlewares.mjs +48 -53
  418. package/dist/registries/middlewares.mjs.map +1 -1
  419. package/dist/registries/models.js +14 -13
  420. package/dist/registries/models.js.map +1 -1
  421. package/dist/registries/models.mjs +13 -14
  422. package/dist/registries/models.mjs.map +1 -1
  423. package/dist/registries/modules.d.ts +2 -2
  424. package/dist/registries/modules.d.ts.map +1 -1
  425. package/dist/registries/modules.js +39 -36
  426. package/dist/registries/modules.js.map +1 -1
  427. package/dist/registries/modules.mjs +38 -38
  428. package/dist/registries/modules.mjs.map +1 -1
  429. package/dist/registries/namespace.js +21 -20
  430. package/dist/registries/namespace.js.map +1 -1
  431. package/dist/registries/namespace.mjs +20 -23
  432. package/dist/registries/namespace.mjs.map +1 -1
  433. package/dist/registries/plugins.d.ts +5 -5
  434. package/dist/registries/plugins.d.ts.map +1 -1
  435. package/dist/registries/plugins.js +23 -20
  436. package/dist/registries/plugins.js.map +1 -1
  437. package/dist/registries/plugins.mjs +22 -22
  438. package/dist/registries/plugins.mjs.map +1 -1
  439. package/dist/registries/policies.d.ts +22 -10
  440. package/dist/registries/policies.d.ts.map +1 -1
  441. package/dist/registries/policies.js +107 -54
  442. package/dist/registries/policies.js.map +1 -1
  443. package/dist/registries/policies.mjs +106 -56
  444. package/dist/registries/policies.mjs.map +1 -1
  445. package/dist/registries/sanitizers.js +23 -22
  446. package/dist/registries/sanitizers.js.map +1 -1
  447. package/dist/registries/sanitizers.mjs +22 -22
  448. package/dist/registries/sanitizers.mjs.map +1 -1
  449. package/dist/registries/services.d.ts +8 -8
  450. package/dist/registries/services.d.ts.map +1 -1
  451. package/dist/registries/services.js +71 -71
  452. package/dist/registries/services.js.map +1 -1
  453. package/dist/registries/services.mjs +70 -73
  454. package/dist/registries/services.mjs.map +1 -1
  455. package/dist/registries/validators.js +23 -22
  456. package/dist/registries/validators.js.map +1 -1
  457. package/dist/registries/validators.mjs +22 -22
  458. package/dist/registries/validators.mjs.map +1 -1
  459. package/dist/services/auth/index.d.ts +4 -4
  460. package/dist/services/auth/index.d.ts.map +1 -1
  461. package/dist/services/auth/index.js +74 -74
  462. package/dist/services/auth/index.js.map +1 -1
  463. package/dist/services/auth/index.mjs +73 -74
  464. package/dist/services/auth/index.mjs.map +1 -1
  465. package/dist/services/config.d.ts +3 -0
  466. package/dist/services/config.d.ts.map +1 -0
  467. package/dist/services/config.js +51 -0
  468. package/dist/services/config.js.map +1 -0
  469. package/dist/services/config.mjs +49 -0
  470. package/dist/services/config.mjs.map +1 -0
  471. package/dist/services/content-api/index.d.ts +31 -15
  472. package/dist/services/content-api/index.d.ts.map +1 -1
  473. package/dist/services/content-api/index.js +80 -53
  474. package/dist/services/content-api/index.js.map +1 -1
  475. package/dist/services/content-api/index.mjs +79 -53
  476. package/dist/services/content-api/index.mjs.map +1 -1
  477. package/dist/services/content-api/permissions/engine.js +8 -5
  478. package/dist/services/content-api/permissions/engine.js.map +1 -1
  479. package/dist/services/content-api/permissions/engine.mjs +7 -5
  480. package/dist/services/content-api/permissions/engine.mjs.map +1 -1
  481. package/dist/services/content-api/permissions/index.d.ts +13 -15
  482. package/dist/services/content-api/permissions/index.d.ts.map +1 -1
  483. package/dist/services/content-api/permissions/index.js +101 -81
  484. package/dist/services/content-api/permissions/index.js.map +1 -1
  485. package/dist/services/content-api/permissions/index.mjs +100 -81
  486. package/dist/services/content-api/permissions/index.mjs.map +1 -1
  487. package/dist/services/content-api/permissions/providers/action.d.ts +5 -6
  488. package/dist/services/content-api/permissions/providers/action.d.ts.map +1 -1
  489. package/dist/services/content-api/permissions/providers/action.js +17 -14
  490. package/dist/services/content-api/permissions/providers/action.js.map +1 -1
  491. package/dist/services/content-api/permissions/providers/action.mjs +16 -16
  492. package/dist/services/content-api/permissions/providers/action.mjs.map +1 -1
  493. package/dist/services/content-api/permissions/providers/condition.d.ts +5 -6
  494. package/dist/services/content-api/permissions/providers/condition.d.ts.map +1 -1
  495. package/dist/services/content-api/permissions/providers/condition.js +17 -14
  496. package/dist/services/content-api/permissions/providers/condition.js.map +1 -1
  497. package/dist/services/content-api/permissions/providers/condition.mjs +16 -16
  498. package/dist/services/content-api/permissions/providers/condition.mjs.map +1 -1
  499. package/dist/services/core-store.d.ts.map +1 -1
  500. package/dist/services/core-store.js +115 -95
  501. package/dist/services/core-store.js.map +1 -1
  502. package/dist/services/core-store.mjs +114 -97
  503. package/dist/services/core-store.mjs.map +1 -1
  504. package/dist/services/cron.d.ts +5 -5
  505. package/dist/services/cron.d.ts.map +1 -1
  506. package/dist/services/cron.js +74 -60
  507. package/dist/services/cron.js.map +1 -1
  508. package/dist/services/cron.mjs +73 -62
  509. package/dist/services/cron.mjs.map +1 -1
  510. package/dist/services/custom-fields.d.ts +2 -2
  511. package/dist/services/custom-fields.d.ts.map +1 -1
  512. package/dist/services/custom-fields.js +9 -7
  513. package/dist/services/custom-fields.js.map +1 -1
  514. package/dist/services/custom-fields.mjs +8 -9
  515. package/dist/services/custom-fields.mjs.map +1 -1
  516. package/dist/services/document-service/attributes/index.d.ts +6 -0
  517. package/dist/services/document-service/attributes/index.d.ts.map +1 -0
  518. package/dist/services/document-service/attributes/index.js +27 -0
  519. package/dist/services/document-service/attributes/index.js.map +1 -0
  520. package/dist/services/document-service/attributes/index.mjs +25 -0
  521. package/dist/services/document-service/attributes/index.mjs.map +1 -0
  522. package/dist/services/document-service/attributes/transforms.d.ts +10 -0
  523. package/dist/services/document-service/attributes/transforms.d.ts.map +1 -0
  524. package/dist/services/document-service/attributes/transforms.js +21 -0
  525. package/dist/services/document-service/attributes/transforms.js.map +1 -0
  526. package/dist/services/document-service/attributes/transforms.mjs +19 -0
  527. package/dist/services/document-service/attributes/transforms.mjs.map +1 -0
  528. package/dist/services/document-service/common.d.ts +2 -2
  529. package/dist/services/document-service/common.d.ts.map +1 -1
  530. package/dist/services/document-service/common.js +5 -4
  531. package/dist/services/document-service/common.js.map +1 -1
  532. package/dist/services/document-service/common.mjs +4 -5
  533. package/dist/services/document-service/common.mjs.map +1 -1
  534. package/dist/services/document-service/components.d.ts +25 -1
  535. package/dist/services/document-service/components.d.ts.map +1 -1
  536. package/dist/services/document-service/components.js +286 -0
  537. package/dist/services/document-service/components.js.map +1 -0
  538. package/dist/services/document-service/components.mjs +278 -0
  539. package/dist/services/document-service/components.mjs.map +1 -0
  540. package/dist/services/document-service/draft-and-publish.d.ts +7 -7
  541. package/dist/services/document-service/draft-and-publish.d.ts.map +1 -1
  542. package/dist/services/document-service/draft-and-publish.js +94 -54
  543. package/dist/services/document-service/draft-and-publish.js.map +1 -1
  544. package/dist/services/document-service/draft-and-publish.mjs +87 -54
  545. package/dist/services/document-service/draft-and-publish.mjs.map +1 -1
  546. package/dist/services/document-service/entries.d.ts +10 -0
  547. package/dist/services/document-service/entries.d.ts.map +1 -0
  548. package/dist/services/document-service/entries.js +113 -0
  549. package/dist/services/document-service/entries.js.map +1 -0
  550. package/dist/services/document-service/entries.mjs +111 -0
  551. package/dist/services/document-service/entries.mjs.map +1 -0
  552. package/dist/services/document-service/events.d.ts +25 -0
  553. package/dist/services/document-service/events.d.ts.map +1 -0
  554. package/dist/services/document-service/events.js +59 -0
  555. package/dist/services/document-service/events.js.map +1 -0
  556. package/dist/services/document-service/events.mjs +57 -0
  557. package/dist/services/document-service/events.mjs.map +1 -0
  558. package/dist/services/document-service/index.d.ts +3 -4
  559. package/dist/services/document-service/index.d.ts.map +1 -1
  560. package/dist/services/document-service/index.js +53 -19
  561. package/dist/services/document-service/index.js.map +1 -1
  562. package/dist/services/document-service/index.mjs +52 -20
  563. package/dist/services/document-service/index.mjs.map +1 -1
  564. package/dist/services/document-service/internationalization.d.ts +5 -5
  565. package/dist/services/document-service/internationalization.d.ts.map +1 -1
  566. package/dist/services/document-service/internationalization.js +66 -41
  567. package/dist/services/document-service/internationalization.js.map +1 -1
  568. package/dist/services/document-service/internationalization.mjs +61 -41
  569. package/dist/services/document-service/internationalization.mjs.map +1 -1
  570. package/dist/services/document-service/middlewares/errors.d.ts +6 -0
  571. package/dist/services/document-service/middlewares/errors.d.ts.map +1 -0
  572. package/dist/services/document-service/middlewares/errors.js +29 -0
  573. package/dist/services/document-service/middlewares/errors.js.map +1 -0
  574. package/dist/services/document-service/middlewares/errors.mjs +27 -0
  575. package/dist/services/document-service/middlewares/errors.mjs.map +1 -0
  576. package/dist/services/document-service/middlewares/index.d.ts +3 -0
  577. package/dist/services/document-service/middlewares/index.d.ts.map +1 -0
  578. package/dist/services/document-service/middlewares/middleware-manager.d.ts +10 -0
  579. package/dist/services/document-service/middlewares/middleware-manager.d.ts.map +1 -0
  580. package/dist/services/document-service/middlewares/middleware-manager.js +51 -0
  581. package/dist/services/document-service/middlewares/middleware-manager.js.map +1 -0
  582. package/dist/services/document-service/middlewares/middleware-manager.mjs +49 -0
  583. package/dist/services/document-service/middlewares/middleware-manager.mjs.map +1 -0
  584. package/dist/services/document-service/params.d.ts +3 -1
  585. package/dist/services/document-service/params.d.ts.map +1 -1
  586. package/dist/services/document-service/params.js +14 -0
  587. package/dist/services/document-service/params.js.map +1 -0
  588. package/dist/services/document-service/params.mjs +12 -0
  589. package/dist/services/document-service/params.mjs.map +1 -0
  590. package/dist/services/document-service/repository.d.ts.map +1 -1
  591. package/dist/services/document-service/repository.js +353 -293
  592. package/dist/services/document-service/repository.js.map +1 -1
  593. package/dist/services/document-service/repository.mjs +352 -294
  594. package/dist/services/document-service/repository.mjs.map +1 -1
  595. package/dist/services/document-service/transform/data.d.ts.map +1 -1
  596. package/dist/services/document-service/transform/data.js +22 -10
  597. package/dist/services/document-service/transform/data.js.map +1 -1
  598. package/dist/services/document-service/transform/data.mjs +21 -11
  599. package/dist/services/document-service/transform/data.mjs.map +1 -1
  600. package/dist/services/document-service/transform/fields.d.ts +2 -2
  601. package/dist/services/document-service/transform/fields.d.ts.map +1 -1
  602. package/dist/services/document-service/transform/fields.js +26 -17
  603. package/dist/services/document-service/transform/fields.js.map +1 -1
  604. package/dist/services/document-service/transform/fields.mjs +25 -18
  605. package/dist/services/document-service/transform/fields.mjs.map +1 -1
  606. package/dist/services/document-service/transform/id-map.d.ts +3 -3
  607. package/dist/services/document-service/transform/id-map.d.ts.map +1 -1
  608. package/dist/services/document-service/transform/id-map.js +116 -69
  609. package/dist/services/document-service/transform/id-map.js.map +1 -1
  610. package/dist/services/document-service/transform/id-map.mjs +115 -70
  611. package/dist/services/document-service/transform/id-map.mjs.map +1 -1
  612. package/dist/services/document-service/transform/id-transform.d.ts +2 -2
  613. package/dist/services/document-service/transform/id-transform.d.ts.map +1 -1
  614. package/dist/services/document-service/transform/id-transform.js +38 -30
  615. package/dist/services/document-service/transform/id-transform.js.map +1 -1
  616. package/dist/services/document-service/transform/id-transform.mjs +36 -30
  617. package/dist/services/document-service/transform/id-transform.mjs.map +1 -1
  618. package/dist/services/document-service/transform/populate.d.ts +2 -2
  619. package/dist/services/document-service/transform/populate.d.ts.map +1 -1
  620. package/dist/services/document-service/transform/populate.js +23 -18
  621. package/dist/services/document-service/transform/populate.js.map +1 -1
  622. package/dist/services/document-service/transform/populate.mjs +22 -19
  623. package/dist/services/document-service/transform/populate.mjs.map +1 -1
  624. package/dist/services/document-service/transform/query.d.ts +5 -0
  625. package/dist/services/document-service/transform/query.d.ts.map +1 -0
  626. package/dist/services/document-service/transform/query.js +14 -0
  627. package/dist/services/document-service/transform/query.js.map +1 -0
  628. package/dist/services/document-service/transform/query.mjs +12 -0
  629. package/dist/services/document-service/transform/query.mjs.map +1 -0
  630. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +8 -7
  631. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -1
  632. package/dist/services/document-service/transform/relations/extract/data-ids.js +75 -85
  633. package/dist/services/document-service/transform/relations/extract/data-ids.js.map +1 -1
  634. package/dist/services/document-service/transform/relations/extract/data-ids.mjs +74 -86
  635. package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +1 -1
  636. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts +8 -4
  637. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts.map +1 -1
  638. package/dist/services/document-service/transform/relations/transform/data-ids.js +103 -134
  639. package/dist/services/document-service/transform/relations/transform/data-ids.js.map +1 -1
  640. package/dist/services/document-service/transform/relations/transform/data-ids.mjs +102 -135
  641. package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +1 -1
  642. package/dist/services/document-service/transform/relations/transform/default-locale.d.ts +9 -0
  643. package/dist/services/document-service/transform/relations/transform/default-locale.d.ts.map +1 -0
  644. package/dist/services/document-service/transform/relations/transform/default-locale.js +50 -0
  645. package/dist/services/document-service/transform/relations/transform/default-locale.js.map +1 -0
  646. package/dist/services/document-service/transform/relations/transform/default-locale.mjs +48 -0
  647. package/dist/services/document-service/transform/relations/transform/default-locale.mjs.map +1 -0
  648. package/dist/services/document-service/transform/relations/utils/dp.d.ts +3 -3
  649. package/dist/services/document-service/transform/relations/utils/dp.d.ts.map +1 -1
  650. package/dist/services/document-service/transform/relations/utils/dp.js +53 -22
  651. package/dist/services/document-service/transform/relations/utils/dp.js.map +1 -1
  652. package/dist/services/document-service/transform/relations/utils/dp.mjs +52 -23
  653. package/dist/services/document-service/transform/relations/utils/dp.mjs.map +1 -1
  654. package/dist/services/document-service/transform/relations/utils/i18n.d.ts +6 -6
  655. package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -1
  656. package/dist/services/document-service/transform/relations/utils/i18n.js +19 -23
  657. package/dist/services/document-service/transform/relations/utils/i18n.js.map +1 -1
  658. package/dist/services/document-service/transform/relations/utils/i18n.mjs +18 -26
  659. package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +1 -1
  660. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts +6 -0
  661. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts.map +1 -0
  662. package/dist/services/document-service/transform/relations/utils/map-relation.js +130 -0
  663. package/dist/services/document-service/transform/relations/utils/map-relation.js.map +1 -0
  664. package/dist/services/document-service/transform/relations/utils/map-relation.mjs +127 -0
  665. package/dist/services/document-service/transform/relations/utils/map-relation.mjs.map +1 -0
  666. package/dist/services/document-service/transform/relations/utils/types.d.ts +6 -0
  667. package/dist/services/document-service/transform/relations/utils/types.d.ts.map +1 -1
  668. package/dist/services/document-service/transform/types.d.ts +3 -3
  669. package/dist/services/document-service/transform/types.d.ts.map +1 -1
  670. package/dist/services/document-service/utils/bidirectional-relations.d.ts +95 -0
  671. package/dist/services/document-service/utils/bidirectional-relations.d.ts.map +1 -0
  672. package/dist/services/document-service/utils/bidirectional-relations.js +148 -0
  673. package/dist/services/document-service/utils/bidirectional-relations.js.map +1 -0
  674. package/dist/services/document-service/utils/bidirectional-relations.mjs +145 -0
  675. package/dist/services/document-service/utils/bidirectional-relations.mjs.map +1 -0
  676. package/dist/services/document-service/utils/populate.d.ts +9 -2
  677. package/dist/services/document-service/utils/populate.d.ts.map +1 -1
  678. package/dist/services/document-service/utils/populate.js +67 -37
  679. package/dist/services/document-service/utils/populate.js.map +1 -1
  680. package/dist/services/document-service/utils/populate.mjs +66 -38
  681. package/dist/services/document-service/utils/populate.mjs.map +1 -1
  682. package/dist/services/document-service/utils/unidirectional-relations.d.ts +36 -0
  683. package/dist/services/document-service/utils/unidirectional-relations.d.ts.map +1 -0
  684. package/dist/services/document-service/utils/unidirectional-relations.js +116 -0
  685. package/dist/services/document-service/utils/unidirectional-relations.js.map +1 -0
  686. package/dist/services/document-service/utils/unidirectional-relations.mjs +113 -0
  687. package/dist/services/document-service/utils/unidirectional-relations.mjs.map +1 -0
  688. package/dist/services/entity-service/index.d.ts +4 -6
  689. package/dist/services/entity-service/index.d.ts.map +1 -1
  690. package/dist/services/entity-service/index.js +229 -319
  691. package/dist/services/entity-service/index.js.map +1 -1
  692. package/dist/services/entity-service/index.mjs +228 -318
  693. package/dist/services/entity-service/index.mjs.map +1 -1
  694. package/dist/services/entity-validator/blocks-validator.d.ts +1 -2
  695. package/dist/services/entity-validator/blocks-validator.d.ts.map +1 -1
  696. package/dist/services/entity-validator/blocks-validator.js +137 -104
  697. package/dist/services/entity-validator/blocks-validator.js.map +1 -1
  698. package/dist/services/entity-validator/blocks-validator.mjs +135 -105
  699. package/dist/services/entity-validator/blocks-validator.mjs.map +1 -1
  700. package/dist/services/entity-validator/index.d.ts +16 -2
  701. package/dist/services/entity-validator/index.d.ts.map +1 -1
  702. package/dist/services/entity-validator/index.js +362 -300
  703. package/dist/services/entity-validator/index.js.map +1 -1
  704. package/dist/services/entity-validator/index.mjs +358 -297
  705. package/dist/services/entity-validator/index.mjs.map +1 -1
  706. package/dist/services/entity-validator/validators.d.ts +36 -25
  707. package/dist/services/entity-validator/validators.d.ts.map +1 -1
  708. package/dist/services/entity-validator/validators.js +283 -105
  709. package/dist/services/entity-validator/validators.js.map +1 -1
  710. package/dist/services/entity-validator/validators.mjs +274 -103
  711. package/dist/services/entity-validator/validators.mjs.map +1 -1
  712. package/dist/services/errors.js +65 -65
  713. package/dist/services/errors.js.map +1 -1
  714. package/dist/services/errors.mjs +64 -66
  715. package/dist/services/errors.mjs.map +1 -1
  716. package/dist/services/event-hub.d.ts +1 -0
  717. package/dist/services/event-hub.d.ts.map +1 -1
  718. package/dist/services/event-hub.js +82 -64
  719. package/dist/services/event-hub.js.map +1 -1
  720. package/dist/services/event-hub.mjs +81 -66
  721. package/dist/services/event-hub.mjs.map +1 -1
  722. package/dist/services/features.d.ts +3 -3
  723. package/dist/services/features.d.ts.map +1 -1
  724. package/dist/services/features.js +19 -14
  725. package/dist/services/features.js.map +1 -1
  726. package/dist/services/features.mjs +18 -15
  727. package/dist/services/features.mjs.map +1 -1
  728. package/dist/services/fs.d.ts +2 -2
  729. package/dist/services/fs.d.ts.map +1 -1
  730. package/dist/services/fs.js +41 -40
  731. package/dist/services/fs.js.map +1 -1
  732. package/dist/services/fs.mjs +40 -39
  733. package/dist/services/fs.mjs.map +1 -1
  734. package/dist/services/metrics/admin-user-hash.d.ts +2 -2
  735. package/dist/services/metrics/admin-user-hash.d.ts.map +1 -1
  736. package/dist/services/metrics/admin-user-hash.js +13 -11
  737. package/dist/services/metrics/admin-user-hash.js.map +1 -1
  738. package/dist/services/metrics/admin-user-hash.mjs +12 -10
  739. package/dist/services/metrics/admin-user-hash.mjs.map +1 -1
  740. package/dist/services/metrics/index.d.ts +2 -2
  741. package/dist/services/metrics/index.d.ts.map +1 -1
  742. package/dist/services/metrics/index.js +46 -40
  743. package/dist/services/metrics/index.js.map +1 -1
  744. package/dist/services/metrics/index.mjs +45 -42
  745. package/dist/services/metrics/index.mjs.map +1 -1
  746. package/dist/services/metrics/is-truthy.js +13 -6
  747. package/dist/services/metrics/is-truthy.js.map +1 -1
  748. package/dist/services/metrics/is-truthy.mjs +12 -6
  749. package/dist/services/metrics/is-truthy.mjs.map +1 -1
  750. package/dist/services/metrics/middleware.d.ts +2 -2
  751. package/dist/services/metrics/middleware.d.ts.map +1 -1
  752. package/dist/services/metrics/middleware.js +37 -22
  753. package/dist/services/metrics/middleware.js.map +1 -1
  754. package/dist/services/metrics/middleware.mjs +36 -24
  755. package/dist/services/metrics/middleware.mjs.map +1 -1
  756. package/dist/services/metrics/rate-limiter.d.ts.map +1 -1
  757. package/dist/services/metrics/rate-limiter.js +24 -19
  758. package/dist/services/metrics/rate-limiter.js.map +1 -1
  759. package/dist/services/metrics/rate-limiter.mjs +23 -21
  760. package/dist/services/metrics/rate-limiter.mjs.map +1 -1
  761. package/dist/services/metrics/sender.d.ts +3 -3
  762. package/dist/services/metrics/sender.d.ts.map +1 -1
  763. package/dist/services/metrics/sender.js +78 -69
  764. package/dist/services/metrics/sender.js.map +1 -1
  765. package/dist/services/metrics/sender.mjs +77 -64
  766. package/dist/services/metrics/sender.mjs.map +1 -1
  767. package/dist/services/query-params.d.ts +7 -0
  768. package/dist/services/query-params.d.ts.map +1 -0
  769. package/dist/services/query-params.js +15 -0
  770. package/dist/services/query-params.js.map +1 -0
  771. package/dist/services/query-params.mjs +13 -0
  772. package/dist/services/query-params.mjs.map +1 -0
  773. package/dist/services/reloader.d.ts +7 -0
  774. package/dist/services/reloader.d.ts.map +1 -0
  775. package/dist/services/reloader.js +39 -0
  776. package/dist/services/reloader.js.map +1 -0
  777. package/dist/services/reloader.mjs +37 -0
  778. package/dist/services/reloader.mjs.map +1 -0
  779. package/dist/services/request-context.js +11 -8
  780. package/dist/services/request-context.js.map +1 -1
  781. package/dist/services/request-context.mjs +10 -10
  782. package/dist/services/request-context.mjs.map +1 -1
  783. package/dist/services/server/admin-api.d.ts +3 -3
  784. package/dist/services/server/admin-api.d.ts.map +1 -1
  785. package/dist/services/server/admin-api.js +11 -10
  786. package/dist/services/server/admin-api.js.map +1 -1
  787. package/dist/services/server/admin-api.mjs +10 -11
  788. package/dist/services/server/admin-api.mjs.map +1 -1
  789. package/dist/services/server/api.d.ts +3 -3
  790. package/dist/services/server/api.d.ts.map +1 -1
  791. package/dist/services/server/api.js +33 -27
  792. package/dist/services/server/api.js.map +1 -1
  793. package/dist/services/server/api.mjs +32 -26
  794. package/dist/services/server/api.mjs.map +1 -1
  795. package/dist/services/server/compose-endpoint.d.ts +2 -2
  796. package/dist/services/server/compose-endpoint.d.ts.map +1 -1
  797. package/dist/services/server/compose-endpoint.js +116 -106
  798. package/dist/services/server/compose-endpoint.js.map +1 -1
  799. package/dist/services/server/compose-endpoint.mjs +115 -106
  800. package/dist/services/server/compose-endpoint.mjs.map +1 -1
  801. package/dist/services/server/content-api.d.ts +3 -3
  802. package/dist/services/server/content-api.d.ts.map +1 -1
  803. package/dist/services/server/content-api.js +11 -9
  804. package/dist/services/server/content-api.js.map +1 -1
  805. package/dist/services/server/content-api.mjs +10 -10
  806. package/dist/services/server/content-api.mjs.map +1 -1
  807. package/dist/services/server/http-server.d.ts +2 -2
  808. package/dist/services/server/http-server.d.ts.map +1 -1
  809. package/dist/services/server/http-server.js +48 -44
  810. package/dist/services/server/http-server.js.map +1 -1
  811. package/dist/services/server/http-server.mjs +47 -43
  812. package/dist/services/server/http-server.mjs.map +1 -1
  813. package/dist/services/server/index.d.ts +2 -2
  814. package/dist/services/server/index.d.ts.map +1 -1
  815. package/dist/services/server/index.js +85 -83
  816. package/dist/services/server/index.js.map +1 -1
  817. package/dist/services/server/index.mjs +84 -82
  818. package/dist/services/server/index.mjs.map +1 -1
  819. package/dist/services/server/koa.d.ts.map +1 -1
  820. package/dist/services/server/koa.js +49 -47
  821. package/dist/services/server/koa.js.map +1 -1
  822. package/dist/services/server/koa.mjs +48 -44
  823. package/dist/services/server/koa.mjs.map +1 -1
  824. package/dist/services/server/middleware.d.ts +4 -4
  825. package/dist/services/server/middleware.d.ts.map +1 -1
  826. package/dist/services/server/middleware.js +86 -82
  827. package/dist/services/server/middleware.js.map +1 -1
  828. package/dist/services/server/middleware.mjs +85 -82
  829. package/dist/services/server/middleware.mjs.map +1 -1
  830. package/dist/services/server/policy.d.ts +3 -3
  831. package/dist/services/server/policy.d.ts.map +1 -1
  832. package/dist/services/server/policy.js +25 -18
  833. package/dist/services/server/policy.js.map +1 -1
  834. package/dist/services/server/policy.mjs +23 -18
  835. package/dist/services/server/policy.mjs.map +1 -1
  836. package/dist/services/server/register-middlewares.d.ts +2 -2
  837. package/dist/services/server/register-middlewares.d.ts.map +1 -1
  838. package/dist/services/server/register-middlewares.js +68 -61
  839. package/dist/services/server/register-middlewares.js.map +1 -1
  840. package/dist/services/server/register-middlewares.mjs +67 -63
  841. package/dist/services/server/register-middlewares.mjs.map +1 -1
  842. package/dist/services/server/register-routes.d.ts +2 -2
  843. package/dist/services/server/register-routes.d.ts.map +1 -1
  844. package/dist/services/server/register-routes.js +90 -67
  845. package/dist/services/server/register-routes.js.map +1 -1
  846. package/dist/services/server/register-routes.mjs +89 -67
  847. package/dist/services/server/register-routes.mjs.map +1 -1
  848. package/dist/services/server/routing.d.ts +5 -5
  849. package/dist/services/server/routing.d.ts.map +1 -1
  850. package/dist/services/server/routing.js +94 -81
  851. package/dist/services/server/routing.js.map +1 -1
  852. package/dist/services/server/routing.mjs +93 -81
  853. package/dist/services/server/routing.mjs.map +1 -1
  854. package/dist/services/utils/dynamic-zones.d.ts.map +1 -1
  855. package/dist/services/utils/dynamic-zones.js +13 -13
  856. package/dist/services/utils/dynamic-zones.js.map +1 -1
  857. package/dist/services/utils/dynamic-zones.mjs +12 -15
  858. package/dist/services/utils/dynamic-zones.mjs.map +1 -1
  859. package/dist/services/webhook-runner.d.ts +2 -1
  860. package/dist/services/webhook-runner.d.ts.map +1 -1
  861. package/dist/services/webhook-runner.js +124 -122
  862. package/dist/services/webhook-runner.js.map +1 -1
  863. package/dist/services/webhook-runner.mjs +123 -121
  864. package/dist/services/webhook-runner.mjs.map +1 -1
  865. package/dist/services/webhook-store.d.ts +2 -8
  866. package/dist/services/webhook-store.d.ts.map +1 -1
  867. package/dist/services/webhook-store.js +132 -93
  868. package/dist/services/webhook-store.js.map +1 -1
  869. package/dist/services/webhook-store.mjs +131 -95
  870. package/dist/services/webhook-store.mjs.map +1 -1
  871. package/dist/services/worker-queue.js +44 -49
  872. package/dist/services/worker-queue.js.map +1 -1
  873. package/dist/services/worker-queue.mjs +43 -49
  874. package/dist/services/worker-queue.mjs.map +1 -1
  875. package/dist/utils/convert-custom-field-type.d.ts +2 -2
  876. package/dist/utils/convert-custom-field-type.d.ts.map +1 -1
  877. package/dist/utils/convert-custom-field-type.js +17 -20
  878. package/dist/utils/convert-custom-field-type.js.map +1 -1
  879. package/dist/utils/convert-custom-field-type.mjs +16 -21
  880. package/dist/utils/convert-custom-field-type.mjs.map +1 -1
  881. package/dist/utils/cron.js +64 -30
  882. package/dist/utils/cron.js.map +1 -1
  883. package/dist/utils/cron.mjs +63 -31
  884. package/dist/utils/cron.mjs.map +1 -1
  885. package/dist/utils/fetch.d.ts +3 -3
  886. package/dist/utils/fetch.d.ts.map +1 -1
  887. package/dist/utils/fetch.js +24 -17
  888. package/dist/utils/fetch.js.map +1 -1
  889. package/dist/utils/fetch.mjs +23 -18
  890. package/dist/utils/fetch.mjs.map +1 -1
  891. package/dist/utils/filepath-to-prop-path.d.ts +1 -1
  892. package/dist/utils/filepath-to-prop-path.d.ts.map +1 -1
  893. package/dist/utils/filepath-to-prop-path.js +22 -9
  894. package/dist/utils/filepath-to-prop-path.js.map +1 -1
  895. package/dist/utils/filepath-to-prop-path.mjs +20 -7
  896. package/dist/utils/filepath-to-prop-path.mjs.map +1 -1
  897. package/dist/utils/index.d.ts +2 -1
  898. package/dist/utils/index.d.ts.map +1 -1
  899. package/dist/utils/is-initialized.d.ts +2 -2
  900. package/dist/utils/is-initialized.d.ts.map +1 -1
  901. package/dist/utils/is-initialized.js +21 -12
  902. package/dist/utils/is-initialized.js.map +1 -1
  903. package/dist/utils/is-initialized.mjs +20 -13
  904. package/dist/utils/is-initialized.mjs.map +1 -1
  905. package/dist/utils/lifecycles.js +6 -5
  906. package/dist/utils/lifecycles.js.map +1 -1
  907. package/dist/utils/lifecycles.mjs +5 -6
  908. package/dist/utils/lifecycles.mjs.map +1 -1
  909. package/dist/utils/load-config-file.js +40 -38
  910. package/dist/utils/load-config-file.js.map +1 -1
  911. package/dist/utils/load-config-file.mjs +39 -36
  912. package/dist/utils/load-config-file.mjs.map +1 -1
  913. package/dist/utils/load-files.d.ts.map +1 -1
  914. package/dist/utils/load-files.js +40 -35
  915. package/dist/utils/load-files.js.map +1 -1
  916. package/dist/utils/load-files.mjs +39 -32
  917. package/dist/utils/load-files.mjs.map +1 -1
  918. package/dist/utils/open-browser.d.ts +2 -2
  919. package/dist/utils/open-browser.d.ts.map +1 -1
  920. package/dist/utils/open-browser.js +8 -8
  921. package/dist/utils/open-browser.js.map +1 -1
  922. package/dist/utils/open-browser.mjs +7 -7
  923. package/dist/utils/open-browser.mjs.map +1 -1
  924. package/dist/utils/resolve-working-dirs.d.ts +19 -0
  925. package/dist/utils/resolve-working-dirs.d.ts.map +1 -0
  926. package/dist/utils/resolve-working-dirs.js +26 -0
  927. package/dist/utils/resolve-working-dirs.js.map +1 -0
  928. package/dist/utils/resolve-working-dirs.mjs +24 -0
  929. package/dist/utils/resolve-working-dirs.mjs.map +1 -0
  930. package/dist/utils/signals.d.ts +2 -2
  931. package/dist/utils/signals.d.ts.map +1 -1
  932. package/dist/utils/signals.js +20 -14
  933. package/dist/utils/signals.js.map +1 -1
  934. package/dist/utils/signals.mjs +19 -15
  935. package/dist/utils/signals.mjs.map +1 -1
  936. package/dist/utils/startup-logger.d.ts +2 -2
  937. package/dist/utils/startup-logger.d.ts.map +1 -1
  938. package/dist/utils/startup-logger.js +107 -78
  939. package/dist/utils/startup-logger.js.map +1 -1
  940. package/dist/utils/startup-logger.mjs +106 -75
  941. package/dist/utils/startup-logger.mjs.map +1 -1
  942. package/dist/utils/transform-content-types-to-models.d.ts +377 -90
  943. package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
  944. package/dist/utils/transform-content-types-to-models.js +357 -217
  945. package/dist/utils/transform-content-types-to-models.js.map +1 -1
  946. package/dist/utils/transform-content-types-to-models.mjs +351 -220
  947. package/dist/utils/transform-content-types-to-models.mjs.map +1 -1
  948. package/dist/utils/update-notifier/index.d.ts +2 -7
  949. package/dist/utils/update-notifier/index.d.ts.map +1 -1
  950. package/dist/utils/update-notifier/index.js +66 -74
  951. package/dist/utils/update-notifier/index.js.map +1 -1
  952. package/dist/utils/update-notifier/index.mjs +65 -68
  953. package/dist/utils/update-notifier/index.mjs.map +1 -1
  954. package/package.json +43 -40
  955. package/dist/registries/config.d.ts +0 -4
  956. package/dist/registries/config.d.ts.map +0 -1
  957. package/dist/registries/config.js +0 -31
  958. package/dist/registries/config.js.map +0 -1
  959. package/dist/registries/config.mjs +0 -32
  960. package/dist/registries/config.mjs.map +0 -1
  961. package/dist/services/document-service/middlewares.d.ts +0 -8
  962. package/dist/services/document-service/middlewares.d.ts.map +0 -1
  963. package/dist/services/document-service/middlewares.js +0 -46
  964. package/dist/services/document-service/middlewares.js.map +0 -1
  965. package/dist/services/document-service/middlewares.mjs +0 -46
  966. package/dist/services/document-service/middlewares.mjs.map +0 -1
  967. package/dist/services/document-service/transform/filters.d.ts +0 -3
  968. package/dist/services/document-service/transform/filters.d.ts.map +0 -1
  969. package/dist/services/document-service/transform/relations/transform/output-ids.d.ts +0 -4
  970. package/dist/services/document-service/transform/relations/transform/output-ids.d.ts.map +0 -1
  971. package/dist/services/document-service/transform/relations/utils/data.js +0 -12
  972. package/dist/services/document-service/transform/relations/utils/data.js.map +0 -1
  973. package/dist/services/document-service/transform/relations/utils/data.mjs +0 -12
  974. package/dist/services/document-service/transform/relations/utils/data.mjs.map +0 -1
  975. package/dist/services/document-service/transform/sort.d.ts +0 -5
  976. package/dist/services/document-service/transform/sort.d.ts.map +0 -1
  977. package/dist/services/document-service/transform/utils.d.ts +0 -9
  978. package/dist/services/document-service/transform/utils.d.ts.map +0 -1
  979. package/dist/services/entity-service/attributes/index.d.ts +0 -6
  980. package/dist/services/entity-service/attributes/index.d.ts.map +0 -1
  981. package/dist/services/entity-service/attributes/index.js +0 -22
  982. package/dist/services/entity-service/attributes/index.js.map +0 -1
  983. package/dist/services/entity-service/attributes/index.mjs +0 -22
  984. package/dist/services/entity-service/attributes/index.mjs.map +0 -1
  985. package/dist/services/entity-service/attributes/transforms.d.ts +0 -10
  986. package/dist/services/entity-service/attributes/transforms.d.ts.map +0 -1
  987. package/dist/services/entity-service/attributes/transforms.js +0 -20
  988. package/dist/services/entity-service/attributes/transforms.js.map +0 -1
  989. package/dist/services/entity-service/attributes/transforms.mjs +0 -19
  990. package/dist/services/entity-service/attributes/transforms.mjs.map +0 -1
  991. package/dist/services/entity-service/components.d.ts +0 -23
  992. package/dist/services/entity-service/components.d.ts.map +0 -1
  993. package/dist/services/entity-service/components.js +0 -384
  994. package/dist/services/entity-service/components.js.map +0 -1
  995. package/dist/services/entity-service/components.mjs +0 -382
  996. package/dist/services/entity-service/components.mjs.map +0 -1
  997. package/dist/services/entity-service/params.d.ts +0 -8
  998. package/dist/services/entity-service/params.d.ts.map +0 -1
  999. package/dist/services/entity-service/params.js +0 -8
  1000. package/dist/services/entity-service/params.js.map +0 -1
  1001. package/dist/services/entity-service/params.mjs +0 -8
  1002. package/dist/services/entity-service/params.mjs.map +0 -1
  1003. package/dist/services/utils/upload-files.d.ts +0 -8
  1004. package/dist/services/utils/upload-files.d.ts.map +0 -1
  1005. package/dist/services/utils/upload-files.js +0 -64
  1006. package/dist/services/utils/upload-files.js.map +0 -1
  1007. package/dist/services/utils/upload-files.mjs +0 -63
  1008. package/dist/services/utils/upload-files.mjs.map +0 -1
  1009. package/dist/utils/get-dirs.d.ts +0 -9
  1010. package/dist/utils/get-dirs.d.ts.map +0 -1
  1011. package/dist/utils/get-dirs.js +0 -30
  1012. package/dist/utils/get-dirs.js.map +0 -1
  1013. package/dist/utils/get-dirs.mjs +0 -30
  1014. package/dist/utils/get-dirs.mjs.map +0 -1
package/dist/ee/index.mjs CHANGED
@@ -1,154 +1,190 @@
1
- import { pick, isEqual } from "lodash/fp";
2
- import { readLicense, verifyLicense, LicenseCheckError, fetchLicense } from "./license.mjs";
3
- import { shiftCronExpression } from "../utils/cron.mjs";
4
- const ONE_MINUTE = 1e3 * 60;
1
+ import { pick, isEqual } from 'lodash/fp';
2
+ import { readLicense, verifyLicense, LicenseCheckError, fetchLicense } from './license.mjs';
3
+ import { shiftCronExpression } from '../utils/cron.mjs';
4
+
5
+ const ONE_MINUTE = 1000 * 60;
5
6
  const ee = {
6
- enabled: false,
7
- licenseInfo: {}
7
+ enabled: false,
8
+ licenseInfo: {}
8
9
  };
9
- const disable = (message) => {
10
- const shouldEmitEvent = ee.enabled !== false;
11
- ee.logger?.warn(`${message} Switching to CE.`);
12
- ee.licenseInfo = pick("licenseKey", ee.licenseInfo);
13
- ee.enabled = false;
14
- if (shouldEmitEvent) {
15
- strapi.eventHub.emit("ee.disable");
16
- }
10
+ const disable = (message)=>{
11
+ // Prevent emitting ee.disable if it was already disabled
12
+ const shouldEmitEvent = ee.enabled !== false;
13
+ ee.logger?.warn(`${message} Switching to CE.`);
14
+ // Only keep the license key for potential re-enabling during a later check
15
+ ee.licenseInfo = pick('licenseKey', ee.licenseInfo);
16
+ ee.enabled = false;
17
+ if (shouldEmitEvent) {
18
+ // Notify EE features that they should be disabled
19
+ strapi.eventHub.emit('ee.disable');
20
+ }
17
21
  };
18
- const enable = () => {
19
- const shouldEmitEvent = ee.enabled !== true;
20
- ee.enabled = true;
21
- if (shouldEmitEvent) {
22
- strapi.eventHub.emit("ee.enable");
23
- }
22
+ const enable = ()=>{
23
+ // Prevent emitting ee.enable if it was already enabled
24
+ const shouldEmitEvent = ee.enabled !== true;
25
+ ee.enabled = true;
26
+ if (shouldEmitEvent) {
27
+ // Notify EE features that they should be disabled
28
+ strapi.eventHub.emit('ee.enable');
29
+ }
24
30
  };
25
31
  let initialized = false;
26
- const init = (licenseDir, logger) => {
27
- if (initialized) {
28
- return;
29
- }
30
- initialized = true;
31
- ee.logger = logger;
32
- if (process.env.STRAPI_DISABLE_EE?.toLowerCase() === "true") {
33
- return;
34
- }
35
- try {
36
- const license = process.env.STRAPI_LICENSE || readLicense(licenseDir);
37
- if (license) {
38
- ee.licenseInfo = verifyLicense(license);
39
- enable();
40
- }
41
- } catch (error) {
42
- if (error instanceof Error) {
43
- disable(error.message);
44
- } else {
45
- disable("Invalid license.");
32
+ /**
33
+ * Optimistically enable EE if the format of the license is valid, only run once.
34
+ */ const init = (licenseDir, logger)=>{
35
+ if (initialized) {
36
+ return;
46
37
  }
47
- }
48
- };
49
- const onlineUpdate = async ({ strapi: strapi2 }) => {
50
- const { get: get2, commit, rollback } = await strapi2.db?.transaction();
51
- const transaction = get2();
52
- try {
53
- 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);
54
- const shouldContactRegistry = (storedInfo?.lastCheckAt ?? 0) < Date.now() - ONE_MINUTE;
55
- const result = { lastCheckAt: Date.now() };
56
- const fallback = (error) => {
57
- if (error instanceof LicenseCheckError && error.shouldFallback && storedInfo?.license) {
58
- ee.logger?.warn(
59
- `${error.message} The last stored one will be used as a potential fallback.`
60
- );
61
- return storedInfo.license;
62
- }
63
- result.error = error.message;
64
- disable(error.message);
65
- };
66
- if (!ee?.licenseInfo?.licenseKey) {
67
- throw new Error("Missing license key.");
38
+ initialized = true;
39
+ ee.logger = logger;
40
+ if (process.env.STRAPI_DISABLE_EE?.toLowerCase() === 'true') {
41
+ return;
68
42
  }
69
- const license = shouldContactRegistry ? await fetchLicense({ strapi: strapi2 }, ee.licenseInfo.licenseKey, strapi2.config.get("uuid")).catch(
70
- fallback
71
- ) : storedInfo.license;
72
- if (license) {
73
- try {
74
- const newLicenseInfo = verifyLicense(license);
75
- const licenseInfoChanged = !isEqual(newLicenseInfo.features, ee.licenseInfo.features) || newLicenseInfo.seats !== ee.licenseInfo.seats || newLicenseInfo.type !== ee.licenseInfo.type;
76
- ee.licenseInfo = newLicenseInfo;
77
- const wasEnabled = ee.enabled;
78
- validateInfo();
79
- if (licenseInfoChanged && wasEnabled) {
80
- strapi2.eventHub.emit("ee.update");
43
+ try {
44
+ const license = process.env.STRAPI_LICENSE || readLicense(licenseDir);
45
+ if (license) {
46
+ ee.licenseInfo = verifyLicense(license);
47
+ enable();
81
48
  }
82
- } catch (error) {
49
+ } catch (error) {
83
50
  if (error instanceof Error) {
84
- disable(error.message);
51
+ disable(error.message);
85
52
  } else {
86
- disable("Invalid license.");
53
+ disable('Invalid license.');
87
54
  }
88
- }
89
- } else if (!shouldContactRegistry) {
90
- disable(storedInfo.error);
91
55
  }
92
- if (shouldContactRegistry) {
93
- result.license = license ?? null;
94
- const query = strapi2.db.queryBuilder("strapi::core-store").transacting(transaction);
95
- if (!storedInfo) {
96
- query.insert({ key: "ee_information", value: JSON.stringify(result) });
97
- } else {
98
- query.update({ value: JSON.stringify(result) }).where({ key: "ee_information" });
99
- }
100
- await query.execute();
56
+ };
57
+ /**
58
+ * Contact the license registry to update the license to its latest state.
59
+ *
60
+ * Store the result in database to avoid unecessary requests, and will fallback to that in case of a network failure.
61
+ */ const onlineUpdate = async ({ strapi: strapi1 })=>{
62
+ const { get, commit, rollback } = await strapi1.db?.transaction();
63
+ const transaction = get();
64
+ try {
65
+ const storedInfo = await strapi1.db?.queryBuilder('strapi::core-store').where({
66
+ key: 'ee_information'
67
+ }).select('value').first().transacting(transaction).forUpdate().execute().then((result)=>result ? JSON.parse(result.value) : result);
68
+ const shouldContactRegistry = (storedInfo?.lastCheckAt ?? 0) < Date.now() - ONE_MINUTE;
69
+ const result = {
70
+ lastCheckAt: Date.now()
71
+ };
72
+ const fallback = (error)=>{
73
+ if (error instanceof LicenseCheckError && error.shouldFallback && storedInfo?.license) {
74
+ ee.logger?.warn(`${error.message} The last stored one will be used as a potential fallback.`);
75
+ return storedInfo.license;
76
+ }
77
+ result.error = error.message;
78
+ disable(error.message);
79
+ };
80
+ if (!ee?.licenseInfo?.licenseKey) {
81
+ throw new Error('Missing license key.');
82
+ }
83
+ const license = shouldContactRegistry ? await fetchLicense({
84
+ strapi: strapi1
85
+ }, ee.licenseInfo.licenseKey, strapi1.config.get('uuid')).catch(fallback) : storedInfo.license;
86
+ if (license) {
87
+ try {
88
+ // Verify license and check if its info changed
89
+ const newLicenseInfo = verifyLicense(license);
90
+ const licenseInfoChanged = !isEqual(newLicenseInfo.features, ee.licenseInfo.features) || newLicenseInfo.seats !== ee.licenseInfo.seats || newLicenseInfo.type !== ee.licenseInfo.type;
91
+ // Store the new license info
92
+ ee.licenseInfo = newLicenseInfo;
93
+ const wasEnabled = ee.enabled;
94
+ validateInfo();
95
+ // Notify EE features
96
+ if (licenseInfoChanged && wasEnabled) {
97
+ strapi1.eventHub.emit('ee.update');
98
+ }
99
+ } catch (error) {
100
+ if (error instanceof Error) {
101
+ disable(error.message);
102
+ } else {
103
+ disable('Invalid license.');
104
+ }
105
+ }
106
+ } else if (!shouldContactRegistry) {
107
+ disable(storedInfo.error);
108
+ }
109
+ if (shouldContactRegistry) {
110
+ result.license = license ?? null;
111
+ const query = strapi1.db.queryBuilder('strapi::core-store').transacting(transaction);
112
+ if (!storedInfo) {
113
+ query.insert({
114
+ key: 'ee_information',
115
+ value: JSON.stringify(result)
116
+ });
117
+ } else {
118
+ query.update({
119
+ value: JSON.stringify(result)
120
+ }).where({
121
+ key: 'ee_information'
122
+ });
123
+ }
124
+ await query.execute();
125
+ }
126
+ await commit();
127
+ } catch (error) {
128
+ // Example of errors: SQLite does not support FOR UPDATE
129
+ await rollback();
101
130
  }
102
- await commit();
103
- } catch (error) {
104
- await rollback();
105
- }
106
131
  };
107
- const validateInfo = () => {
108
- if (typeof ee.licenseInfo.expireAt === "undefined") {
109
- throw new Error("Missing license key.");
110
- }
111
- const expirationTime = new Date(ee.licenseInfo.expireAt).getTime();
112
- if (expirationTime < (/* @__PURE__ */ new Date()).getTime()) {
113
- return disable("License expired.");
114
- }
115
- enable();
132
+ const validateInfo = ()=>{
133
+ if (typeof ee.licenseInfo.expireAt === 'undefined') {
134
+ throw new Error('Missing license key.');
135
+ }
136
+ const expirationTime = new Date(ee.licenseInfo.expireAt).getTime();
137
+ if (expirationTime < new Date().getTime()) {
138
+ return disable('License expired.');
139
+ }
140
+ enable();
116
141
  };
117
- const checkLicense = async ({ strapi: strapi2 }) => {
118
- const shouldStayOffline = ee.licenseInfo.type === "gold" && // This env variable support is temporarily used to ease the migration between online vs offline
119
- process.env.STRAPI_DISABLE_LICENSE_PING?.toLowerCase() === "true";
120
- if (!shouldStayOffline) {
121
- await onlineUpdate({ strapi: strapi2 });
122
- strapi2.cron.add({ [shiftCronExpression("0 0 */12 * * *")]: onlineUpdate });
123
- } else {
124
- if (!ee.licenseInfo.expireAt) {
125
- return disable("Your license does not have offline support.");
142
+ const checkLicense = async ({ strapi: strapi1 })=>{
143
+ const shouldStayOffline = ee.licenseInfo.type === 'gold' && // This env variable support is temporarily used to ease the migration between online vs offline
144
+ process.env.STRAPI_DISABLE_LICENSE_PING?.toLowerCase() === 'true';
145
+ if (!shouldStayOffline) {
146
+ await onlineUpdate({
147
+ strapi: strapi1
148
+ });
149
+ strapi1.cron.add({
150
+ onlineUpdate: {
151
+ task: ()=>onlineUpdate({
152
+ strapi: strapi1
153
+ }),
154
+ options: shiftCronExpression('0 0 */12 * * *')
155
+ }
156
+ });
157
+ } else {
158
+ if (!ee.licenseInfo.expireAt) {
159
+ return disable('Your license does not have offline support.');
160
+ }
161
+ validateInfo();
126
162
  }
127
- validateInfo();
128
- }
129
163
  };
130
- const list = () => {
131
- return ee.licenseInfo.features?.map(
132
- (feature) => typeof feature === "object" ? feature : { name: feature }
133
- ) || [];
164
+ const list = ()=>{
165
+ return ee.licenseInfo.features?.map((feature)=>typeof feature === 'object' ? feature : {
166
+ name: feature
167
+ }) || [];
134
168
  };
135
- const get = (featureName) => list().find((feature) => feature.name === featureName);
136
- const index = Object.freeze({
137
- init,
138
- checkLicense,
139
- get isEE() {
140
- return ee.enabled;
141
- },
142
- get seats() {
143
- return ee.licenseInfo.seats;
144
- },
145
- features: Object.freeze({
146
- list,
147
- get,
148
- isEnabled: (featureName) => get(featureName) !== void 0
149
- })
169
+ const get = (featureName)=>list().find((feature)=>feature.name === featureName);
170
+ var index = Object.freeze({
171
+ init,
172
+ checkLicense,
173
+ get isEE () {
174
+ return ee.enabled;
175
+ },
176
+ get seats () {
177
+ return ee.licenseInfo.seats;
178
+ },
179
+ get type () {
180
+ return ee.licenseInfo.type;
181
+ },
182
+ features: Object.freeze({
183
+ list,
184
+ get,
185
+ isEnabled: (featureName)=>get(featureName) !== undefined
186
+ })
150
187
  });
151
- export {
152
- index as default
153
- };
188
+
189
+ export { index as default };
154
190
  //# 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\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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"}
@@ -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;AAiBD,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;AAmBD,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,iBAkClB,CAAC;AAEF,OAAO,EAAE,WAAW,EAAE,aAAa,EAAE,YAAY,EAAE,iBAAiB,EAAE,CAAC"}
@@ -1,88 +1,114 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const fs = require("fs");
4
- const path = require("path");
5
- const crypto = require("crypto");
6
- const strapiUtils = require("@strapi/utils");
7
- const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
8
- const fs__default = /* @__PURE__ */ _interopDefault(fs);
9
- const crypto__default = /* @__PURE__ */ _interopDefault(crypto);
1
+ 'use strict';
2
+
3
+ var fs = require('fs');
4
+ var path = require('path');
5
+ var crypto = require('crypto');
6
+ var strapiUtils = require('@strapi/utils');
7
+
10
8
  const DEFAULT_FEATURES = {
11
- bronze: [],
12
- silver: [],
13
- gold: [
14
- { name: "sso" },
15
- // Set a null retention duration to allow the user to override it
16
- // The default of 90 days is set in the audit logs service
17
- { name: "audit-logs", options: { retentionDays: null } },
18
- { name: "review-workflows" },
19
- { name: "cms-content-releases" }
20
- ]
9
+ bronze: [],
10
+ silver: [],
11
+ gold: [
12
+ {
13
+ name: 'sso'
14
+ },
15
+ // Set a null retention duration to allow the user to override it
16
+ // The default of 90 days is set in the audit logs service
17
+ {
18
+ name: 'audit-logs',
19
+ options: {
20
+ retentionDays: null
21
+ }
22
+ },
23
+ {
24
+ name: 'review-workflows'
25
+ },
26
+ {
27
+ name: 'cms-content-releases'
28
+ },
29
+ {
30
+ name: 'cms-content-history',
31
+ options: {
32
+ retentionDays: 99999
33
+ }
34
+ },
35
+ {
36
+ name: 'cms-advanced-preview'
37
+ }
38
+ ]
21
39
  };
22
- const publicKey = fs__default.default.readFileSync(path.resolve(__dirname, "../../resources/key.pub"));
40
+ const publicKey = fs.readFileSync(path.resolve(__dirname, '../../resources/key.pub'));
23
41
  class LicenseCheckError extends Error {
24
- shouldFallback = false;
25
- constructor(message, shouldFallback = false) {
26
- super(message);
27
- this.shouldFallback = shouldFallback;
28
- }
42
+ constructor(message, shouldFallback = false){
43
+ super(message);
44
+ this.shouldFallback = false;
45
+ this.shouldFallback = shouldFallback;
46
+ }
29
47
  }
30
- const readLicense = (directory) => {
31
- try {
32
- const path$1 = path.join(directory, "license.txt");
33
- return fs__default.default.readFileSync(path$1).toString();
34
- } catch (error) {
35
- if (typeof error === "object" && error !== null && "code" in error && error.code !== "ENOENT") {
36
- throw Error("License file not readable, review its format and access rules.");
48
+ const readLicense = (directory)=>{
49
+ try {
50
+ const path$1 = path.join(directory, 'license.txt');
51
+ return fs.readFileSync(path$1).toString();
52
+ } catch (error) {
53
+ if (typeof error === 'object' && error !== null && 'code' in error && error.code !== 'ENOENT') {
54
+ throw Error('License file not readable, review its format and access rules.');
55
+ }
37
56
  }
38
- }
39
57
  };
40
- const verifyLicense = (license) => {
41
- const [signature, base64Content] = Buffer.from(license, "base64").toString().split("\n");
42
- if (!signature || !base64Content) {
43
- throw new Error("Invalid license.");
44
- }
45
- const stringifiedContent = Buffer.from(base64Content, "base64").toString();
46
- const verify = crypto__default.default.createVerify("RSA-SHA256");
47
- verify.update(stringifiedContent);
48
- verify.end();
49
- const verified = verify.verify(publicKey, signature, "base64");
50
- if (!verified) {
51
- throw new Error("Invalid license.");
52
- }
53
- const licenseInfo = JSON.parse(stringifiedContent);
54
- if (!licenseInfo.features) {
55
- licenseInfo.features = DEFAULT_FEATURES[licenseInfo.type];
56
- }
57
- Object.freeze(licenseInfo.features);
58
- return licenseInfo;
58
+ const verifyLicense = (license)=>{
59
+ const [signature, base64Content] = Buffer.from(license, 'base64').toString().split('\n');
60
+ if (!signature || !base64Content) {
61
+ throw new Error('Invalid license.');
62
+ }
63
+ const stringifiedContent = Buffer.from(base64Content, 'base64').toString();
64
+ const verify = crypto.createVerify('RSA-SHA256');
65
+ verify.update(stringifiedContent);
66
+ verify.end();
67
+ const verified = verify.verify(publicKey, signature, 'base64');
68
+ if (!verified) {
69
+ throw new Error('Invalid license.');
70
+ }
71
+ const licenseInfo = JSON.parse(stringifiedContent);
72
+ if (!licenseInfo.features) {
73
+ licenseInfo.features = DEFAULT_FEATURES[licenseInfo.type];
74
+ }
75
+ Object.freeze(licenseInfo.features);
76
+ return licenseInfo;
59
77
  };
60
- const throwError = () => {
61
- throw new LicenseCheckError("Could not proceed to the online validation of your license.", true);
78
+ const throwError = ()=>{
79
+ throw new LicenseCheckError('Could not proceed to the online validation of your license.', true);
62
80
  };
63
- const fetchLicense = async ({ strapi }, key, projectId) => {
64
- const response = await strapi.fetch(`https://license.strapi.io/api/licenses/validate`, {
65
- method: "POST",
66
- headers: { "Content-Type": "application/json" },
67
- body: JSON.stringify({ key, projectId, deviceId: strapiUtils.machineID() })
68
- }).catch(throwError);
69
- const contentType = response.headers.get("Content-Type");
70
- if (contentType?.includes("application/json")) {
71
- const { data, error } = await response.json();
72
- switch (response.status) {
73
- case 200:
74
- return data.license;
75
- case 400:
76
- throw new LicenseCheckError(error.message);
77
- case 404:
78
- throw new LicenseCheckError("The license used does not exists.");
79
- default:
81
+ const fetchLicense = async ({ strapi }, key, projectId)=>{
82
+ const { installId: installIdFromPackageJson } = strapi.config;
83
+ const response = await strapi.fetch(`https://license.strapi.io/api/licenses/validate`, {
84
+ method: 'POST',
85
+ headers: {
86
+ 'Content-Type': 'application/json'
87
+ },
88
+ body: JSON.stringify({
89
+ key,
90
+ projectId,
91
+ deviceId: strapiUtils.generateInstallId(projectId, installIdFromPackageJson)
92
+ })
93
+ }).catch(throwError);
94
+ const contentType = response.headers.get('Content-Type');
95
+ if (contentType?.includes('application/json')) {
96
+ const { data, error } = await response.json();
97
+ switch(response.status){
98
+ case 200:
99
+ return data.license;
100
+ case 400:
101
+ throw new LicenseCheckError(error.message);
102
+ case 404:
103
+ throw new LicenseCheckError('The license used does not exists.');
104
+ default:
105
+ throwError();
106
+ }
107
+ } else {
80
108
  throwError();
81
109
  }
82
- } else {
83
- throwError();
84
- }
85
110
  };
111
+
86
112
  exports.LicenseCheckError = LicenseCheckError;
87
113
  exports.fetchLicense = fetchLicense;
88
114
  exports.readLicense = readLicense;