modelence 0.9.0-dev.0 → 0.9.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (377) hide show
  1. package/dist/bin/modelence.js +3 -57
  2. package/dist/bin/modelence.js.map +1 -1
  3. package/dist/chunk-3S2FFBNS.js +2 -0
  4. package/dist/chunk-3S2FFBNS.js.map +1 -0
  5. package/dist/chunk-55J6XMHW.js +2 -0
  6. package/dist/chunk-55J6XMHW.js.map +1 -0
  7. package/dist/chunk-C3UESBRX.js +2 -0
  8. package/dist/chunk-C3UESBRX.js.map +1 -0
  9. package/dist/chunk-DO5TZLF5.js +2 -0
  10. package/dist/chunk-DO5TZLF5.js.map +1 -0
  11. package/dist/chunk-PB6WQQ4L.js +3 -0
  12. package/dist/chunk-PB6WQQ4L.js.map +1 -0
  13. package/dist/chunk-YOLALUSB.js +3 -0
  14. package/dist/chunk-YOLALUSB.js.map +1 -0
  15. package/dist/client.d.ts +133 -10
  16. package/dist/client.js +1 -14
  17. package/dist/client.js.map +1 -1
  18. package/dist/index-CwdohC5n.d.ts +15 -0
  19. package/dist/index.d.ts +31 -6
  20. package/dist/index.js +1 -2
  21. package/dist/index.js.map +1 -1
  22. package/dist/mongo.d.ts +3 -2
  23. package/dist/mongo.js +1 -2
  24. package/dist/mongo.js.map +1 -1
  25. package/dist/package-FGEKA4ES.js +2 -0
  26. package/dist/package-FGEKA4ES.js.map +1 -0
  27. package/dist/server.d.ts +537 -19
  28. package/dist/server.js +18 -15
  29. package/dist/server.js.map +1 -1
  30. package/dist/telemetry.d.ts +11 -2
  31. package/dist/telemetry.js +1 -1
  32. package/dist/telemetry.js.map +1 -1
  33. package/dist/types-BOFsm7A2.d.ts +155 -0
  34. package/dist/{data/store.d.ts → types-SXHKNPNY.d.ts} +196 -14
  35. package/dist/types.d.ts +7 -10
  36. package/dist/types.js +1 -1
  37. package/dist/types.js.map +1 -1
  38. package/package.json +6 -5
  39. package/dist/app/authConfig.d.ts +0 -68
  40. package/dist/app/authConfig.d.ts.map +0 -1
  41. package/dist/app/authConfig.js +0 -8
  42. package/dist/app/authConfig.js.map +0 -1
  43. package/dist/app/backendApi.d.ts +0 -29
  44. package/dist/app/backendApi.d.ts.map +0 -1
  45. package/dist/app/backendApi.js +0 -69
  46. package/dist/app/backendApi.js.map +0 -1
  47. package/dist/app/email.d.ts +0 -3
  48. package/dist/app/email.d.ts.map +0 -1
  49. package/dist/app/email.js +0 -8
  50. package/dist/app/email.js.map +0 -1
  51. package/dist/app/emailConfig.d.ts +0 -27
  52. package/dist/app/emailConfig.d.ts.map +0 -1
  53. package/dist/app/emailConfig.js +0 -8
  54. package/dist/app/emailConfig.js.map +0 -1
  55. package/dist/app/index.d.ts +0 -20
  56. package/dist/app/index.d.ts.map +0 -1
  57. package/dist/app/index.js +0 -258
  58. package/dist/app/index.js.map +0 -1
  59. package/dist/app/loggerProcess.d.ts +0 -5
  60. package/dist/app/loggerProcess.d.ts.map +0 -1
  61. package/dist/app/loggerProcess.js +0 -90
  62. package/dist/app/loggerProcess.js.map +0 -1
  63. package/dist/app/metrics.d.ts +0 -6
  64. package/dist/app/metrics.d.ts.map +0 -1
  65. package/dist/app/metrics.js +0 -92
  66. package/dist/app/metrics.js.map +0 -1
  67. package/dist/app/module.d.ts +0 -77
  68. package/dist/app/module.d.ts.map +0 -1
  69. package/dist/app/module.js +0 -46
  70. package/dist/app/module.js.map +0 -1
  71. package/dist/app/server.d.ts +0 -37
  72. package/dist/app/server.d.ts.map +0 -1
  73. package/dist/app/server.js +0 -198
  74. package/dist/app/server.js.map +0 -1
  75. package/dist/app/state.d.ts +0 -19
  76. package/dist/app/state.d.ts.map +0 -1
  77. package/dist/app/state.js +0 -27
  78. package/dist/app/state.js.map +0 -1
  79. package/dist/app/websocketConfig.d.ts +0 -7
  80. package/dist/app/websocketConfig.d.ts.map +0 -1
  81. package/dist/app/websocketConfig.js +0 -8
  82. package/dist/app/websocketConfig.js.map +0 -1
  83. package/dist/auth/client/index.d.ts +0 -69
  84. package/dist/auth/client/index.d.ts.map +0 -1
  85. package/dist/auth/client/index.js +0 -79
  86. package/dist/auth/client/index.js.map +0 -1
  87. package/dist/auth/db.d.ts +0 -176
  88. package/dist/auth/db.d.ts.map +0 -1
  89. package/dist/auth/db.js +0 -117
  90. package/dist/auth/db.js.map +0 -1
  91. package/dist/auth/deleteUser.d.ts +0 -5
  92. package/dist/auth/deleteUser.d.ts.map +0 -1
  93. package/dist/auth/deleteUser.js +0 -34
  94. package/dist/auth/deleteUser.js.map +0 -1
  95. package/dist/auth/disposableEmails.d.ts +0 -6
  96. package/dist/auth/disposableEmails.d.ts.map +0 -1
  97. package/dist/auth/disposableEmails.js +0 -47
  98. package/dist/auth/disposableEmails.js.map +0 -1
  99. package/dist/auth/index.d.ts +0 -7
  100. package/dist/auth/index.d.ts.map +0 -1
  101. package/dist/auth/index.js +0 -33
  102. package/dist/auth/index.js.map +0 -1
  103. package/dist/auth/login.d.ts +0 -9
  104. package/dist/auth/login.d.ts.map +0 -1
  105. package/dist/auth/login.js +0 -100
  106. package/dist/auth/login.js.map +0 -1
  107. package/dist/auth/password.d.ts +0 -14
  108. package/dist/auth/password.d.ts.map +0 -1
  109. package/dist/auth/password.js +0 -26
  110. package/dist/auth/password.js.map +0 -1
  111. package/dist/auth/profile.d.ts +0 -10
  112. package/dist/auth/profile.d.ts.map +0 -1
  113. package/dist/auth/profile.js +0 -13
  114. package/dist/auth/profile.js.map +0 -1
  115. package/dist/auth/providers/github.d.ts +0 -3
  116. package/dist/auth/providers/github.d.ts.map +0 -1
  117. package/dist/auth/providers/github.js +0 -122
  118. package/dist/auth/providers/github.js.map +0 -1
  119. package/dist/auth/providers/google.d.ts +0 -3
  120. package/dist/auth/providers/google.d.ts.map +0 -1
  121. package/dist/auth/providers/google.js +0 -108
  122. package/dist/auth/providers/google.js.map +0 -1
  123. package/dist/auth/providers/oauth-common.d.ts +0 -13
  124. package/dist/auth/providers/oauth-common.d.ts.map +0 -1
  125. package/dist/auth/providers/oauth-common.js +0 -109
  126. package/dist/auth/providers/oauth-common.js.map +0 -1
  127. package/dist/auth/resetPassword.d.ts +0 -10
  128. package/dist/auth/resetPassword.d.ts.map +0 -1
  129. package/dist/auth/resetPassword.js +0 -108
  130. package/dist/auth/resetPassword.js.map +0 -1
  131. package/dist/auth/role.d.ts +0 -8
  132. package/dist/auth/role.d.ts.map +0 -1
  133. package/dist/auth/role.js +0 -37
  134. package/dist/auth/role.js.map +0 -1
  135. package/dist/auth/session.d.ts +0 -24
  136. package/dist/auth/session.d.ts.map +0 -1
  137. package/dist/auth/session.js +0 -84
  138. package/dist/auth/session.js.map +0 -1
  139. package/dist/auth/signup.d.ts +0 -3
  140. package/dist/auth/signup.d.ts.map +0 -1
  141. package/dist/auth/signup.js +0 -89
  142. package/dist/auth/signup.js.map +0 -1
  143. package/dist/auth/templates/emailVerficationTemplate.d.ts +0 -6
  144. package/dist/auth/templates/emailVerficationTemplate.d.ts.map +0 -1
  145. package/dist/auth/templates/emailVerficationTemplate.js +0 -9
  146. package/dist/auth/templates/emailVerficationTemplate.js.map +0 -1
  147. package/dist/auth/types.d.ts +0 -22
  148. package/dist/auth/types.d.ts.map +0 -1
  149. package/dist/auth/types.js +0 -2
  150. package/dist/auth/types.js.map +0 -1
  151. package/dist/auth/user.d.ts +0 -5
  152. package/dist/auth/user.d.ts.map +0 -1
  153. package/dist/auth/user.js +0 -152
  154. package/dist/auth/user.js.map +0 -1
  155. package/dist/auth/validators.d.ts +0 -3
  156. package/dist/auth/validators.d.ts.map +0 -1
  157. package/dist/auth/validators.js +0 -8
  158. package/dist/auth/validators.js.map +0 -1
  159. package/dist/auth/verification.d.ts +0 -8
  160. package/dist/auth/verification.d.ts.map +0 -1
  161. package/dist/auth/verification.js +0 -94
  162. package/dist/auth/verification.js.map +0 -1
  163. package/dist/bin/auth.d.ts +0 -4
  164. package/dist/bin/auth.d.ts.map +0 -1
  165. package/dist/bin/auth.js +0 -48
  166. package/dist/bin/auth.js.map +0 -1
  167. package/dist/bin/build.d.ts +0 -2
  168. package/dist/bin/build.d.ts.map +0 -1
  169. package/dist/bin/build.js +0 -78
  170. package/dist/bin/build.js.map +0 -1
  171. package/dist/bin/config.d.ts +0 -11
  172. package/dist/bin/config.d.ts.map +0 -1
  173. package/dist/bin/config.js +0 -91
  174. package/dist/bin/config.js.map +0 -1
  175. package/dist/bin/deploy.d.ts +0 -6
  176. package/dist/bin/deploy.d.ts.map +0 -1
  177. package/dist/bin/deploy.js +0 -129
  178. package/dist/bin/deploy.js.map +0 -1
  179. package/dist/bin/dev.d.ts +0 -2
  180. package/dist/bin/dev.d.ts.map +0 -1
  181. package/dist/bin/dev.js +0 -14
  182. package/dist/bin/dev.js.map +0 -1
  183. package/dist/bin/modelence.d.ts +0 -3
  184. package/dist/bin/modelence.d.ts.map +0 -1
  185. package/dist/bin/setup.d.ts +0 -5
  186. package/dist/bin/setup.d.ts.map +0 -1
  187. package/dist/bin/setup.js +0 -91
  188. package/dist/bin/setup.js.map +0 -1
  189. package/dist/bin/start.d.ts +0 -2
  190. package/dist/bin/start.d.ts.map +0 -1
  191. package/dist/bin/start.js +0 -15
  192. package/dist/bin/start.js.map +0 -1
  193. package/dist/client/AppProvider.d.ts +0 -8
  194. package/dist/client/AppProvider.d.ts.map +0 -1
  195. package/dist/client/AppProvider.js +0 -31
  196. package/dist/client/AppProvider.js.map +0 -1
  197. package/dist/client/errorHandler.d.ts +0 -4
  198. package/dist/client/errorHandler.d.ts.map +0 -1
  199. package/dist/client/errorHandler.js +0 -10
  200. package/dist/client/errorHandler.js.map +0 -1
  201. package/dist/client/localStorage.d.ts +0 -3
  202. package/dist/client/localStorage.d.ts.map +0 -1
  203. package/dist/client/localStorage.js +0 -14
  204. package/dist/client/localStorage.js.map +0 -1
  205. package/dist/client/method.d.ts +0 -6
  206. package/dist/client/method.d.ts.map +0 -1
  207. package/dist/client/method.js +0 -52
  208. package/dist/client/method.js.map +0 -1
  209. package/dist/client/renderApp.d.ts +0 -9
  210. package/dist/client/renderApp.d.ts.map +0 -1
  211. package/dist/client/renderApp.js +0 -28
  212. package/dist/client/renderApp.js.map +0 -1
  213. package/dist/client/session.d.ts +0 -34
  214. package/dist/client/session.d.ts.map +0 -1
  215. package/dist/client/session.js +0 -83
  216. package/dist/client/session.js.map +0 -1
  217. package/dist/client.d.ts.map +0 -1
  218. package/dist/config/client.d.ts +0 -10
  219. package/dist/config/client.d.ts.map +0 -1
  220. package/dist/config/client.js +0 -14
  221. package/dist/config/client.js.map +0 -1
  222. package/dist/config/server.d.ts +0 -48
  223. package/dist/config/server.d.ts.map +0 -1
  224. package/dist/config/server.js +0 -85
  225. package/dist/config/server.js.map +0 -1
  226. package/dist/config/sync.d.ts +0 -2
  227. package/dist/config/sync.d.ts.map +0 -1
  228. package/dist/config/sync.js +0 -32
  229. package/dist/config/sync.js.map +0 -1
  230. package/dist/config/types.d.ts +0 -19
  231. package/dist/config/types.d.ts.map +0 -1
  232. package/dist/config/types.js +0 -2
  233. package/dist/config/types.js.map +0 -1
  234. package/dist/cron/jobs.d.ts +0 -13
  235. package/dist/cron/jobs.d.ts.map +0 -1
  236. package/dist/cron/jobs.js +0 -155
  237. package/dist/cron/jobs.js.map +0 -1
  238. package/dist/cron/types.d.ts +0 -29
  239. package/dist/cron/types.d.ts.map +0 -1
  240. package/dist/cron/types.js +0 -2
  241. package/dist/cron/types.js.map +0 -1
  242. package/dist/data/schemaSerializer.d.ts +0 -37
  243. package/dist/data/schemaSerializer.d.ts.map +0 -1
  244. package/dist/data/schemaSerializer.js +0 -104
  245. package/dist/data/schemaSerializer.js.map +0 -1
  246. package/dist/data/store.d.ts.map +0 -1
  247. package/dist/data/store.js +0 -501
  248. package/dist/data/store.js.map +0 -1
  249. package/dist/data/types.d.ts +0 -47
  250. package/dist/data/types.d.ts.map +0 -1
  251. package/dist/data/types.js +0 -35
  252. package/dist/data/types.js.map +0 -1
  253. package/dist/db/client.d.ts +0 -5
  254. package/dist/db/client.d.ts.map +0 -1
  255. package/dist/db/client.js +0 -41
  256. package/dist/db/client.js.map +0 -1
  257. package/dist/error.d.ts +0 -16
  258. package/dist/error.d.ts.map +0 -1
  259. package/dist/error.js +0 -24
  260. package/dist/error.js.map +0 -1
  261. package/dist/index.d.ts.map +0 -1
  262. package/dist/lock/db.d.ts +0 -19
  263. package/dist/lock/db.d.ts.map +0 -1
  264. package/dist/lock/db.js +0 -28
  265. package/dist/lock/db.js.map +0 -1
  266. package/dist/lock/helpers.d.ts +0 -28
  267. package/dist/lock/helpers.d.ts.map +0 -1
  268. package/dist/lock/helpers.js +0 -107
  269. package/dist/lock/helpers.js.map +0 -1
  270. package/dist/lock/index.d.ts +0 -4
  271. package/dist/lock/index.d.ts.map +0 -1
  272. package/dist/lock/index.js +0 -4
  273. package/dist/lock/index.js.map +0 -1
  274. package/dist/lock/module.d.ts +0 -7
  275. package/dist/lock/module.d.ts.map +0 -1
  276. package/dist/lock/module.js +0 -9
  277. package/dist/lock/module.js.map +0 -1
  278. package/dist/methods/index.d.ts +0 -7
  279. package/dist/methods/index.d.ts.map +0 -1
  280. package/dist/methods/index.js +0 -65
  281. package/dist/methods/index.js.map +0 -1
  282. package/dist/methods/serialize.d.ts +0 -15
  283. package/dist/methods/serialize.d.ts.map +0 -1
  284. package/dist/methods/serialize.js +0 -56
  285. package/dist/methods/serialize.js.map +0 -1
  286. package/dist/methods/types.d.ts +0 -37
  287. package/dist/methods/types.d.ts.map +0 -1
  288. package/dist/methods/types.js +0 -2
  289. package/dist/methods/types.js.map +0 -1
  290. package/dist/migration/db.d.ts +0 -17
  291. package/dist/migration/db.d.ts.map +0 -1
  292. package/dist/migration/db.js +0 -13
  293. package/dist/migration/db.js.map +0 -1
  294. package/dist/migration/index.d.ts +0 -11
  295. package/dist/migration/index.d.ts.map +0 -1
  296. package/dist/migration/index.js +0 -85
  297. package/dist/migration/index.js.map +0 -1
  298. package/dist/mongo.d.ts.map +0 -1
  299. package/dist/rate-limit/db.d.ts +0 -29
  300. package/dist/rate-limit/db.d.ts.map +0 -1
  301. package/dist/rate-limit/db.js +0 -25
  302. package/dist/rate-limit/db.js.map +0 -1
  303. package/dist/rate-limit/index.d.ts +0 -4
  304. package/dist/rate-limit/index.d.ts.map +0 -1
  305. package/dist/rate-limit/index.js +0 -6
  306. package/dist/rate-limit/index.js.map +0 -1
  307. package/dist/rate-limit/rules.d.ts +0 -22
  308. package/dist/rate-limit/rules.d.ts.map +0 -1
  309. package/dist/rate-limit/rules.js +0 -112
  310. package/dist/rate-limit/rules.js.map +0 -1
  311. package/dist/rate-limit/types.d.ts +0 -12
  312. package/dist/rate-limit/types.d.ts.map +0 -1
  313. package/dist/rate-limit/types.js +0 -2
  314. package/dist/rate-limit/types.js.map +0 -1
  315. package/dist/routes/handler.d.ts +0 -4
  316. package/dist/routes/handler.d.ts.map +0 -1
  317. package/dist/routes/handler.js +0 -66
  318. package/dist/routes/handler.js.map +0 -1
  319. package/dist/routes/types.d.ts +0 -45
  320. package/dist/routes/types.d.ts.map +0 -1
  321. package/dist/routes/types.js +0 -2
  322. package/dist/routes/types.js.map +0 -1
  323. package/dist/server.d.ts.map +0 -1
  324. package/dist/system/index.d.ts +0 -4
  325. package/dist/system/index.d.ts.map +0 -1
  326. package/dist/system/index.js +0 -21
  327. package/dist/system/index.js.map +0 -1
  328. package/dist/telemetry/index.d.ts +0 -11
  329. package/dist/telemetry/index.d.ts.map +0 -1
  330. package/dist/telemetry/index.js +0 -79
  331. package/dist/telemetry/index.js.map +0 -1
  332. package/dist/telemetry.d.ts.map +0 -1
  333. package/dist/time.d.ts +0 -8
  334. package/dist/time.d.ts.map +0 -1
  335. package/dist/time.js +0 -13
  336. package/dist/time.js.map +0 -1
  337. package/dist/types/email.d.ts +0 -25
  338. package/dist/types/email.d.ts.map +0 -1
  339. package/dist/types/email.js +0 -2
  340. package/dist/types/email.js.map +0 -1
  341. package/dist/types/index.d.ts +0 -14
  342. package/dist/types/index.d.ts.map +0 -1
  343. package/dist/types/index.js +0 -2
  344. package/dist/types/index.js.map +0 -1
  345. package/dist/types.d.ts.map +0 -1
  346. package/dist/utils/index.d.ts +0 -4
  347. package/dist/utils/index.d.ts.map +0 -1
  348. package/dist/utils/index.js +0 -15
  349. package/dist/utils/index.js.map +0 -1
  350. package/dist/viteServer.d.ts +0 -13
  351. package/dist/viteServer.d.ts.map +0 -1
  352. package/dist/viteServer.js +0 -132
  353. package/dist/viteServer.js.map +0 -1
  354. package/dist/websocket/client.d.ts +0 -9
  355. package/dist/websocket/client.d.ts.map +0 -1
  356. package/dist/websocket/client.js +0 -16
  357. package/dist/websocket/client.js.map +0 -1
  358. package/dist/websocket/clientChannel.d.ts +0 -9
  359. package/dist/websocket/clientChannel.d.ts.map +0 -1
  360. package/dist/websocket/clientChannel.js +0 -26
  361. package/dist/websocket/clientChannel.js.map +0 -1
  362. package/dist/websocket/serverChannel.d.ts +0 -14
  363. package/dist/websocket/serverChannel.d.ts.map +0 -1
  364. package/dist/websocket/serverChannel.js +0 -21
  365. package/dist/websocket/serverChannel.js.map +0 -1
  366. package/dist/websocket/socketio/client.d.ts +0 -4
  367. package/dist/websocket/socketio/client.d.ts.map +0 -1
  368. package/dist/websocket/socketio/client.js +0 -48
  369. package/dist/websocket/socketio/client.js.map +0 -1
  370. package/dist/websocket/socketio/server.d.ts +0 -10
  371. package/dist/websocket/socketio/server.d.ts.map +0 -1
  372. package/dist/websocket/socketio/server.js +0 -80
  373. package/dist/websocket/socketio/server.js.map +0 -1
  374. package/dist/websocket/types.d.ts +0 -45
  375. package/dist/websocket/types.d.ts.map +0 -1
  376. package/dist/websocket/types.js +0 -2
  377. package/dist/websocket/types.js.map +0 -1
@@ -1,85 +0,0 @@
1
- import { acquireLock, releaseLock } from '../lock';
2
- import { Module } from '../app/module';
3
- import { dbMigrations } from './db';
4
- import { logInfo } from '../telemetry';
5
- export async function runMigrations(migrations) {
6
- if (migrations.length === 0) {
7
- return;
8
- }
9
- const hasLock = await acquireLock('migrations');
10
- if (!hasLock) {
11
- logInfo('Another instance is running migrations. Skipping migration run.', {
12
- source: 'migrations',
13
- });
14
- return;
15
- }
16
- const versions = migrations.map(({ version }) => version);
17
- const existingVersions = await dbMigrations.fetch({
18
- version: { $in: versions },
19
- });
20
- const existingVersionSet = new Set(existingVersions.map(({ version }) => version));
21
- const pendingMigrations = migrations.filter(({ version }) => !existingVersionSet.has(version));
22
- if (pendingMigrations.length === 0) {
23
- return;
24
- }
25
- logInfo(`Running migrations (${pendingMigrations.length})...`, {
26
- source: 'migrations',
27
- });
28
- for (const { version, description, handler } of pendingMigrations) {
29
- logInfo(`Running migration v${version}: ${description}`, {
30
- source: 'migrations',
31
- });
32
- try {
33
- const output = await handler();
34
- const outputStr = (output || '').toString().trim();
35
- const maxSize = 15 * 1024 * 1024; // 15MB (leaving 1MB buffer for other fields and MongoDB overhead)
36
- const truncatedOutput = outputStr.length > maxSize
37
- ? outputStr.slice(0, maxSize) + '\n[Output truncated - exceeded size limit]'
38
- : outputStr;
39
- await dbMigrations.upsertOne({
40
- version,
41
- }, {
42
- $set: {
43
- version,
44
- status: 'completed',
45
- description,
46
- output: truncatedOutput,
47
- appliedAt: new Date(),
48
- },
49
- });
50
- logInfo(`Migration v${version} complete`, {
51
- source: 'migrations',
52
- });
53
- }
54
- catch (e) {
55
- if (e instanceof Error) {
56
- await dbMigrations.upsertOne({
57
- version,
58
- }, {
59
- $set: {
60
- version,
61
- status: 'failed',
62
- description,
63
- output: e.message || '',
64
- appliedAt: new Date(),
65
- },
66
- });
67
- logInfo(`Migration v${version} is failed: ${e.message}`, {
68
- source: 'migrations',
69
- });
70
- }
71
- }
72
- }
73
- await releaseLock('migrations');
74
- }
75
- export function startMigrations(migrations) {
76
- setTimeout(() => {
77
- runMigrations(migrations).catch((err) => {
78
- console.error('Error running migrations:', err);
79
- });
80
- }, 0);
81
- }
82
- export default new Module('_system.migration', {
83
- stores: [dbMigrations],
84
- });
85
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/migration/index.ts"],"names":[],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"mongo.d.ts","sourceRoot":"","sources":["../src/mongo.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;;AAElD,wBAAkB"}
@@ -1,29 +0,0 @@
1
- import { Store } from '../data/store';
2
- /**
3
- * Two-bucket sliding window approximation to track rate limits.
4
- * This is a trade-off between storage and accuracy.
5
- * We're not keeping exact event logs, so we can't track the exact number of events in a window.
6
- * Instead, we're adding a weighted average from the previous window to the current window.
7
- */
8
- export declare const dbRateLimits: Store<{
9
- bucket: import("zod").ZodString;
10
- type: import("zod").ZodEnum<["ip", "user"]>;
11
- value: import("zod").ZodString;
12
- windowMs: import("zod").ZodNumber;
13
- windowStart: import("zod").ZodDate;
14
- windowCount: import("zod").ZodNumber;
15
- prevWindowCount: import("zod").ZodNumber;
16
- expiresAt: import("zod").ZodDate;
17
- }, Record<string, (this: Pick<import("../types").InferDocumentType<{
18
- bucket: import("zod").ZodString;
19
- type: import("zod").ZodEnum<["ip", "user"]>;
20
- value: import("zod").ZodString;
21
- windowMs: import("zod").ZodNumber;
22
- windowStart: import("zod").ZodDate;
23
- windowCount: import("zod").ZodNumber;
24
- prevWindowCount: import("zod").ZodNumber;
25
- expiresAt: import("zod").ZodDate;
26
- }>, "value" | "type" | "expiresAt" | "bucket" | "windowMs" | "windowStart" | "windowCount" | "prevWindowCount"> & {
27
- _id: import("bson").ObjectId;
28
- }, ...args: any[]) => any>>;
29
- //# sourceMappingURL=db.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"db.d.ts","sourceRoot":"","sources":["../../src/rate-limit/db.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAGtC;;;;;GAKG;AACH,eAAO,MAAM,YAAY;;;;;;;;;;;;;;;;;;;;2BAiBvB,CAAC"}
@@ -1,25 +0,0 @@
1
- import { Store } from '../data/store';
2
- import { schema } from '../data/types';
3
- /**
4
- * Two-bucket sliding window approximation to track rate limits.
5
- * This is a trade-off between storage and accuracy.
6
- * We're not keeping exact event logs, so we can't track the exact number of events in a window.
7
- * Instead, we're adding a weighted average from the previous window to the current window.
8
- */
9
- export const dbRateLimits = new Store('_modelenceRateLimits', {
10
- schema: {
11
- bucket: schema.string(),
12
- type: schema.enum(['ip', 'user']),
13
- value: schema.string(),
14
- windowMs: schema.number(),
15
- windowStart: schema.date(),
16
- windowCount: schema.number(),
17
- prevWindowCount: schema.number(),
18
- expiresAt: schema.date(),
19
- },
20
- indexes: [
21
- { key: { bucket: 1, type: 1, value: 1, windowMs: 1 }, unique: true },
22
- { key: { expiresAt: 1 }, expireAfterSeconds: 0 },
23
- ],
24
- });
25
- //# sourceMappingURL=db.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"db.js","sourceRoot":"","sources":["../../src/rate-limit/db.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACtC,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEvC;;;;;GAKG;AACH,MAAM,CAAC,MAAM,YAAY,GAAG,IAAI,KAAK,CAAC,sBAAsB,EAAE;IAC5D,MAAM,EAAE;QACN,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE;QACvB,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;QACjC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE;QACtB,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE;QAEzB,WAAW,EAAE,MAAM,CAAC,IAAI,EAAE;QAC1B,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE;QAC5B,eAAe,EAAE,MAAM,CAAC,MAAM,EAAE;QAEhC,SAAS,EAAE,MAAM,CAAC,IAAI,EAAE;KACzB;IACD,OAAO,EAAE;QACP,EAAE,GAAG,EAAE,EAAE,MAAM,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;QACpE,EAAE,GAAG,EAAE,EAAE,SAAS,EAAE,CAAC,EAAE,EAAE,kBAAkB,EAAE,CAAC,EAAE;KACjD;CACF,CAAC,CAAC"}
@@ -1,4 +0,0 @@
1
- import { Module } from '../app/module';
2
- declare const _default: Module;
3
- export default _default;
4
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/rate-limit/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;;AAGvC,wBAEG"}
@@ -1,6 +0,0 @@
1
- import { Module } from '../app/module';
2
- import { dbRateLimits } from './db';
3
- export default new Module('_system.rateLimit', {
4
- stores: [dbRateLimits],
5
- });
6
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/rate-limit/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACvC,OAAO,EAAE,YAAY,EAAE,MAAM,MAAM,CAAC;AAEpC,eAAe,IAAI,MAAM,CAAC,mBAAmB,EAAE;IAC7C,MAAM,EAAE,CAAC,YAAY,CAAC;CACvB,CAAC,CAAC"}
@@ -1,22 +0,0 @@
1
- import { RateLimitRule, RateLimitType } from './types';
2
- export declare function initRateLimits(rateLimits: RateLimitRule[]): void;
3
- /**
4
- * This function will check all rate limit rules on the specified bucket and type,
5
- * throw an error if any of them are exceeded and increase the count of the rate limit record.
6
- *
7
- * @category Rate Limits
8
- *
9
- * @example
10
- * ```ts
11
- * await consumeRateLimit({ bucket: 'api', type: 'ip', value: '127.0.0.1' });
12
- * ```
13
- * @param options.bucket - The bucket for the rate limit.
14
- * @param options.type - The type of the rate limit.
15
- * @param options.value - The value for the rate limit.
16
- */
17
- export declare function consumeRateLimit(options: {
18
- bucket: string;
19
- type: RateLimitType;
20
- value: string;
21
- }): Promise<void>;
22
- //# sourceMappingURL=rules.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"rules.d.ts","sourceRoot":"","sources":["../../src/rate-limit/rules.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAMvD,wBAAgB,cAAc,CAAC,UAAU,EAAE,aAAa,EAAE,QAMzD;AAED;;;;;;;;;;;;;GAaG;AACH,wBAAsB,gBAAgB,CAAC,OAAO,EAAE;IAC9C,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,EAAE,aAAa,CAAC;IACpB,KAAK,EAAE,MAAM,CAAC;CACf,iBAOA"}
@@ -1,112 +0,0 @@
1
- import { dbRateLimits } from './db';
2
- import { RateLimitError } from '../error';
3
- let allRules = [];
4
- export function initRateLimits(rateLimits) {
5
- if (allRules.length > 0) {
6
- throw new Error('Duplicate call to initRateLimits - already initialized');
7
- }
8
- allRules = rateLimits;
9
- }
10
- /**
11
- * This function will check all rate limit rules on the specified bucket and type,
12
- * throw an error if any of them are exceeded and increase the count of the rate limit record.
13
- *
14
- * @category Rate Limits
15
- *
16
- * @example
17
- * ```ts
18
- * await consumeRateLimit({ bucket: 'api', type: 'ip', value: '127.0.0.1' });
19
- * ```
20
- * @param options.bucket - The bucket for the rate limit.
21
- * @param options.type - The type of the rate limit.
22
- * @param options.value - The value for the rate limit.
23
- */
24
- export async function consumeRateLimit(options) {
25
- const { bucket, type, value } = options;
26
- const rules = allRules.filter((rule) => rule.bucket === bucket && rule.type === type);
27
- for (const rule of rules) {
28
- await checkRateLimitRule(rule, value);
29
- }
30
- }
31
- // Two-bucket sliding window approximation to track rate limits.
32
- async function checkRateLimitRule(rule, value, createError) {
33
- const createRateLimitError = () => {
34
- return createError
35
- ? createError()
36
- : new RateLimitError(`Rate limit exceeded for ${rule.bucket}`);
37
- };
38
- const record = await dbRateLimits.findOne({
39
- bucket: rule.bucket,
40
- type: rule.type,
41
- value,
42
- windowMs: rule.window,
43
- });
44
- const now = Date.now();
45
- const currentWindowStart = Math.floor(now / rule.window) * rule.window;
46
- const { count, modifier } = record
47
- ? getCount(record, currentWindowStart, now)
48
- : {
49
- count: 0,
50
- modifier: {
51
- $setOnInsert: {
52
- windowStart: new Date(currentWindowStart),
53
- windowCount: 1,
54
- prevWindowCount: 0,
55
- expiresAt: new Date(currentWindowStart + rule.window + rule.window),
56
- },
57
- },
58
- };
59
- if (count >= rule.limit) {
60
- throw createRateLimitError();
61
- }
62
- /*
63
- Always use upsert, because there is a small chance the document might be auto-removed
64
- based on the expiration TTL index in between the check and the update
65
- */
66
- await dbRateLimits.upsertOne({ bucket: rule.bucket, type: rule.type, value, windowMs: rule.window }, modifier);
67
- }
68
- function getCount(record, currentWindowStart, now) {
69
- const prevWindowStart = currentWindowStart - record.windowMs;
70
- if (record.windowStart.getTime() === currentWindowStart) {
71
- const currentWindowCount = record.windowCount;
72
- const prevWindowCount = record.prevWindowCount;
73
- const prevWindowWeight = 1 - (now - currentWindowStart) / record.windowMs;
74
- return {
75
- count: Math.round(currentWindowCount + prevWindowCount * prevWindowWeight),
76
- modifier: {
77
- $inc: { windowCount: 1 },
78
- $setOnInsert: {
79
- windowStart: new Date(currentWindowStart),
80
- prevWindowCount: 0,
81
- expiresAt: new Date(currentWindowStart + record.windowMs + record.windowMs),
82
- },
83
- },
84
- };
85
- }
86
- if (record.windowStart.getTime() === prevWindowStart) {
87
- const weight = 1 - (now - currentWindowStart) / record.windowMs;
88
- return {
89
- count: Math.round(record.windowCount * weight),
90
- modifier: {
91
- $set: {
92
- windowStart: new Date(currentWindowStart),
93
- windowCount: 1,
94
- prevWindowCount: record.windowCount,
95
- expiresAt: new Date(currentWindowStart + record.windowMs + record.windowMs),
96
- },
97
- },
98
- };
99
- }
100
- return {
101
- count: 0,
102
- modifier: {
103
- $set: {
104
- windowStart: new Date(currentWindowStart),
105
- windowCount: 1,
106
- prevWindowCount: 0,
107
- expiresAt: new Date(currentWindowStart + record.windowMs + record.windowMs),
108
- },
109
- },
110
- };
111
- }
112
- //# sourceMappingURL=rules.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"rules.js","sourceRoot":"","sources":["../../src/rate-limit/rules.ts"],"names":[],"mappings":"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"}
@@ -1,12 +0,0 @@
1
- export type RateLimitType = 'ip' | 'user';
2
- export type RateLimitRule = {
3
- /** Logical action being limited, e.g. "signup" */
4
- bucket: string;
5
- /** Identifier type of the actor this rule applies to */
6
- type: RateLimitType;
7
- /** Time window size in milliseconds */
8
- window: number;
9
- /** Maximum allowed hits within the window */
10
- limit: number;
11
- };
12
- //# sourceMappingURL=types.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/rate-limit/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,aAAa,GAAG,IAAI,GAAG,MAAM,CAAC;AAE1C,MAAM,MAAM,aAAa,GAAG;IAC1B,kDAAkD;IAClD,MAAM,EAAE,MAAM,CAAC;IAEf,wDAAwD;IACxD,IAAI,EAAE,aAAa,CAAC;IAEpB,uCAAuC;IACvC,MAAM,EAAE,MAAM,CAAC;IAEf,6CAA6C;IAC7C,KAAK,EAAE,MAAM,CAAC;CACf,CAAC"}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=types.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/rate-limit/types.ts"],"names":[],"mappings":""}
@@ -1,4 +0,0 @@
1
- import { Request, Response, NextFunction } from 'express';
2
- import { RouteHandler } from './types';
3
- export declare function createRouteHandler(method: string, path: string, handler: RouteHandler): (req: Request, res: Response, next: NextFunction) => Promise<void>;
4
- //# sourceMappingURL=handler.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"handler.d.ts","sourceRoot":"","sources":["../../src/routes/handler.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAC1D,OAAO,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAQvC,wBAAgB,kBAAkB,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,YAAY,IACtE,KAAK,OAAO,EAAE,KAAK,QAAQ,EAAE,MAAM,YAAY,mBAmE9D"}
@@ -1,66 +0,0 @@
1
- import { ModelenceError } from '../error';
2
- import { authenticate } from '../auth';
3
- import { getMongodbUri } from '../db/client';
4
- import { startTransaction } from '../telemetry';
5
- // TODO: Use cookies for authentication and automatically add session/user to context if accessing from browser
6
- export function createRouteHandler(method, path, handler) {
7
- return async (req, res, next) => {
8
- const authToken = req.headers['x-modelence-auth-token'];
9
- let context = { session: null, user: null };
10
- if (typeof authToken === 'string' && getMongodbUri()) {
11
- try {
12
- const { session, user } = await authenticate(authToken);
13
- context = { session, user };
14
- }
15
- catch {
16
- // If authentication fails, context remains null
17
- }
18
- }
19
- const transaction = startTransaction('route', `route:${method.toLowerCase()}:${path}`, {
20
- method,
21
- path,
22
- query: req.query,
23
- body: req.body,
24
- params: req.params,
25
- });
26
- try {
27
- const response = await handler({
28
- query: req.query,
29
- body: req.body,
30
- params: req.params,
31
- headers: req.headers,
32
- cookies: req.cookies,
33
- rawBody: Buffer.isBuffer(req.body) ? req.body : undefined,
34
- req,
35
- res,
36
- next,
37
- }, context);
38
- transaction.end();
39
- // If the handler returns null, we expect it to handle the response itself
40
- if (response) {
41
- res.status(response.status || 200);
42
- if (response.redirect) {
43
- res.redirect(response.redirect);
44
- }
45
- if (response.headers) {
46
- Object.entries(response.headers).forEach(([key, value]) => {
47
- res.setHeader(key, value);
48
- });
49
- }
50
- res.send(response.data);
51
- }
52
- }
53
- catch (error) {
54
- transaction.end('error');
55
- if (error instanceof ModelenceError) {
56
- res.status(error.status).send(error.message);
57
- }
58
- else {
59
- console.error(`Error in route handler: ${req.path}`);
60
- console.error(error);
61
- res.status(500).send(String(error));
62
- }
63
- }
64
- };
65
- }
66
- //# sourceMappingURL=handler.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"handler.js","sourceRoot":"","sources":["../../src/routes/handler.ts"],"names":[],"mappings":"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"}
@@ -1,45 +0,0 @@
1
- import { Request, Response, NextFunction } from 'express';
2
- import type { Context } from '../methods/types';
3
- export type HttpMethod = 'get' | 'post' | 'put' | 'delete' | 'patch' | 'options' | 'head' | 'all' | 'use';
4
- export type RouteParams<T = unknown> = {
5
- query: Record<string, string>;
6
- body: T;
7
- params: Record<string, string>;
8
- headers: Record<string, string>;
9
- cookies: Record<string, string>;
10
- rawBody?: Buffer;
11
- req: Request;
12
- res: Response;
13
- next: NextFunction;
14
- };
15
- export type RouteResponse<T = unknown> = {
16
- data?: T;
17
- status?: number;
18
- headers?: Record<string, string>;
19
- redirect?: string;
20
- } | null;
21
- export type RouteHandler<T = unknown> = (params: RouteParams, context: Pick<Context, 'session' | 'user'>) => Promise<RouteResponse<T>> | RouteResponse<T>;
22
- export type RouteHandlers = {
23
- [key in HttpMethod]?: RouteHandler;
24
- };
25
- export type BodyConfig = {
26
- json?: boolean | {
27
- limit?: string;
28
- };
29
- urlencoded?: boolean | {
30
- limit?: string;
31
- extended?: boolean;
32
- };
33
- raw?: boolean | {
34
- limit?: string;
35
- type?: string | string[];
36
- };
37
- };
38
- export type RouteDefinition = {
39
- path: string;
40
- handlers: RouteHandlers;
41
- errorHandler?: RouteHandler;
42
- body?: BodyConfig;
43
- };
44
- export type ExpressHandler = (req: Request, res: Response) => Promise<void> | void;
45
- //# sourceMappingURL=types.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/routes/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAC1D,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;AAEhD,MAAM,MAAM,UAAU,GAClB,KAAK,GACL,MAAM,GACN,KAAK,GACL,QAAQ,GACR,OAAO,GACP,SAAS,GACT,MAAM,GACN,KAAK,GACL,KAAK,CAAC;AAEV,MAAM,MAAM,WAAW,CAAC,CAAC,GAAG,OAAO,IAAI;IACrC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC9B,IAAI,EAAE,CAAC,CAAC;IACR,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC/B,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAChC,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAChC,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,GAAG,EAAE,OAAO,CAAC;IACb,GAAG,EAAE,QAAQ,CAAC;IACd,IAAI,EAAE,YAAY,CAAC;CACpB,CAAC;AAEF,MAAM,MAAM,aAAa,CAAC,CAAC,GAAG,OAAO,IAAI;IACvC,IAAI,CAAC,EAAE,CAAC,CAAC;IACT,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACjC,QAAQ,CAAC,EAAE,MAAM,CAAC;CAGnB,GAAG,IAAI,CAAC;AAET,MAAM,MAAM,YAAY,CAAC,CAAC,GAAG,OAAO,IAAI,CACtC,MAAM,EAAE,WAAW,EACnB,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,SAAS,GAAG,MAAM,CAAC,KACvC,OAAO,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,GAAG,aAAa,CAAC,CAAC,CAAC,CAAC;AAElD,MAAM,MAAM,aAAa,GAAG;KACzB,GAAG,IAAI,UAAU,CAAC,CAAC,EAAE,YAAY;CACnC,CAAC;AAEF,MAAM,MAAM,UAAU,GAAG;IACvB,IAAI,CAAC,EACD,OAAO,GACP;QACE,KAAK,CAAC,EAAE,MAAM,CAAC;KAChB,CAAC;IACN,UAAU,CAAC,EACP,OAAO,GACP;QACE,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,QAAQ,CAAC,EAAE,OAAO,CAAC;KACpB,CAAC;IACN,GAAG,CAAC,EACA,OAAO,GACP;QACE,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,IAAI,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;KAC1B,CAAC;CACP,CAAC;AAEF,MAAM,MAAM,eAAe,GAAG;IAC5B,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,aAAa,CAAC;IACxB,YAAY,CAAC,EAAE,YAAY,CAAC;IAC5B,IAAI,CAAC,EAAE,UAAU,CAAC;CACnB,CAAC;AAEF,MAAM,MAAM,cAAc,GAAG,CAAC,GAAG,EAAE,OAAO,EAAE,GAAG,EAAE,QAAQ,KAAK,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC"}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=types.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/routes/types.ts"],"names":[],"mappings":""}
@@ -1 +0,0 @@
1
- {"version":3,"file":"server.d.ts","sourceRoot":"","sources":["../src/server.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,KAAK,UAAU,EAAE,MAAM,OAAO,CAAC;AAClD,YAAY,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC/D,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AACtC,OAAO,EACL,YAAY,EACZ,WAAW,EACX,aAAa,EACb,eAAe,EACf,UAAU,GACX,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAEnC,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AAGxC,OAAO,EAAE,eAAe,IAAI,OAAO,EAAE,MAAM,WAAW,CAAC;AACvD,YAAY,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AAC7C,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAG5D,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AACtC,OAAO,EAAE,KAAK,EAAE,MAAM,cAAc,CAAC;AAGrC,OAAO,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC;AAGlD,YAAY,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACvE,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAEtD,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,YAAY,EAAE,2BAA2B,EAAE,MAAM,kBAAkB,CAAC;AACpE,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAC1D,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;AACtC,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC"}
@@ -1,4 +0,0 @@
1
- import { Module } from '../app/module';
2
- declare const _default: Module;
3
- export default _default;
4
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/system/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;;AAEvC,wBAkBG"}
@@ -1,21 +0,0 @@
1
- import { Module } from '../app/module';
2
- export default new Module('_system', {
3
- configSchema: {
4
- mongodbUrl: {
5
- type: 'string',
6
- isPublic: false,
7
- default: '',
8
- },
9
- env: {
10
- type: 'string',
11
- isPublic: true,
12
- default: '',
13
- },
14
- 'site.url': {
15
- type: 'string',
16
- isPublic: true,
17
- default: '',
18
- },
19
- },
20
- });
21
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/system/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEvC,eAAe,IAAI,MAAM,CAAC,SAAS,EAAE;IACnC,YAAY,EAAE;QACZ,UAAU,EAAE;YACV,IAAI,EAAE,QAAQ;YACd,QAAQ,EAAE,KAAK;YACf,OAAO,EAAE,EAAE;SACZ;QACD,GAAG,EAAE;YACH,IAAI,EAAE,QAAQ;YACd,QAAQ,EAAE,IAAI;YACd,OAAO,EAAE,EAAE;SACZ;QACD,UAAU,EAAE;YACV,IAAI,EAAE,QAAQ;YACd,QAAQ,EAAE,IAAI;YACd,OAAO,EAAE,EAAE;SACZ;KACF;CACF,CAAC,CAAC"}
@@ -1,11 +0,0 @@
1
- export declare function logDebug(message: string, args: object): void;
2
- export declare function logInfo(message: string, args: object): void;
3
- export declare function logError(message: string, args: object): void;
4
- interface WrappedTransaction {
5
- end(result?: string, context?: Record<string, unknown>): void;
6
- setContext(context: Record<string, unknown>): void;
7
- }
8
- export declare function startTransaction(type: 'method' | 'cron' | 'ai' | 'custom' | 'route', name: string, context?: Record<string, unknown>): WrappedTransaction;
9
- export declare function captureError(error: Error): void;
10
- export {};
11
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/telemetry/index.ts"],"names":[],"mappings":"AAwBA,wBAAgB,QAAQ,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,QAOrD;AAED,wBAAgB,OAAO,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,QAOpD;AAED,wBAAgB,QAAQ,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,QAOrD;AAED,UAAU,kBAAkB;IAC1B,GAAG,CAAC,MAAM,CAAC,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;IAC9D,UAAU,CAAC,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;CACpD;AAED,wBAAgB,gBAAgB,CAC9B,IAAI,EAAE,QAAQ,GAAG,MAAM,GAAG,IAAI,GAAG,QAAQ,GAAG,OAAO,EACnD,IAAI,EAAE,MAAM,EACZ,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAChC,kBAAkB,CAgCpB;AAED,wBAAgB,YAAY,CAAC,KAAK,EAAE,KAAK,QAOxC"}
@@ -1,79 +0,0 @@
1
- import { getLogger, getApm } from '../app/metrics';
2
- import { isTelemetryEnabled } from '../app/state';
3
- /**
4
- * Gets the logging level for console logs based on the MODELENCE_LOG_LEVEL environment variable.
5
- *
6
- * @returns The log level ('error' | 'info' | 'debug' | '')
7
- *
8
- * Behavior:
9
- * - If MODELENCE_LOG_LEVEL is set, returns that value
10
- * - If telemetry is disabled and MODELENCE_LOG_LEVEL is not set, defaults to 'info'
11
- * - If telemetry is enabled and MODELENCE_LOG_LEVEL is not set, returns '' (no console logging)
12
- */
13
- function getLogLevel() {
14
- let defaultLoglevel = '';
15
- if (!isTelemetryEnabled()) {
16
- defaultLoglevel = 'info';
17
- }
18
- return process.env.MODELENCE_LOG_LEVEL || defaultLoglevel;
19
- }
20
- export function logDebug(message, args) {
21
- if (isTelemetryEnabled()) {
22
- getLogger().debug(message, args);
23
- }
24
- if (getLogLevel() === 'debug') {
25
- console.debug(message, args);
26
- }
27
- }
28
- export function logInfo(message, args) {
29
- if (isTelemetryEnabled()) {
30
- getLogger().info(message, args);
31
- }
32
- if (['debug', 'info'].includes(getLogLevel())) {
33
- console.info(message, args);
34
- }
35
- }
36
- export function logError(message, args) {
37
- if (isTelemetryEnabled()) {
38
- getLogger().error(message, args);
39
- }
40
- if (['debug', 'info', 'error'].includes(getLogLevel())) {
41
- console.error(message, args);
42
- }
43
- }
44
- export function startTransaction(type, name, context) {
45
- if (!isTelemetryEnabled()) {
46
- return {
47
- end: () => {
48
- // do nothing
49
- },
50
- setContext: () => {
51
- // do nothing
52
- },
53
- };
54
- }
55
- const apm = getApm();
56
- const transaction = apm.startTransaction(name, type);
57
- if (context) {
58
- apm.setCustomContext(context);
59
- }
60
- return {
61
- end: (result, { endTime, context } = {}) => {
62
- if (context) {
63
- apm.setCustomContext(context);
64
- }
65
- transaction.end(result, endTime);
66
- },
67
- setContext: (context) => {
68
- apm.setCustomContext(context);
69
- },
70
- };
71
- }
72
- export function captureError(error) {
73
- if (!isTelemetryEnabled()) {
74
- console.error(error);
75
- return;
76
- }
77
- getApm().captureError(error);
78
- }
79
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/telemetry/index.ts"],"names":[],"mappings":"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"}