modelence 0.7.2 → 0.9.0-dev.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/app/authConfig.d.ts +68 -0
  2. package/dist/app/authConfig.d.ts.map +1 -0
  3. package/dist/app/authConfig.js +8 -0
  4. package/dist/app/authConfig.js.map +1 -0
  5. package/dist/app/backendApi.d.ts +29 -0
  6. package/dist/app/backendApi.d.ts.map +1 -0
  7. package/dist/app/backendApi.js +69 -0
  8. package/dist/app/backendApi.js.map +1 -0
  9. package/dist/app/email.d.ts +3 -0
  10. package/dist/app/email.d.ts.map +1 -0
  11. package/dist/app/email.js +8 -0
  12. package/dist/app/email.js.map +1 -0
  13. package/dist/app/emailConfig.d.ts +27 -0
  14. package/dist/app/emailConfig.d.ts.map +1 -0
  15. package/dist/app/emailConfig.js +8 -0
  16. package/dist/app/emailConfig.js.map +1 -0
  17. package/dist/app/index.d.ts +20 -0
  18. package/dist/app/index.d.ts.map +1 -0
  19. package/dist/app/index.js +258 -0
  20. package/dist/app/index.js.map +1 -0
  21. package/dist/app/loggerProcess.d.ts +5 -0
  22. package/dist/app/loggerProcess.d.ts.map +1 -0
  23. package/dist/app/loggerProcess.js +90 -0
  24. package/dist/app/loggerProcess.js.map +1 -0
  25. package/dist/app/metrics.d.ts +6 -0
  26. package/dist/app/metrics.d.ts.map +1 -0
  27. package/dist/app/metrics.js +92 -0
  28. package/dist/app/metrics.js.map +1 -0
  29. package/dist/app/module.d.ts +77 -0
  30. package/dist/app/module.d.ts.map +1 -0
  31. package/dist/app/module.js +46 -0
  32. package/dist/app/module.js.map +1 -0
  33. package/dist/app/server.d.ts +37 -0
  34. package/dist/app/server.d.ts.map +1 -0
  35. package/dist/app/server.js +198 -0
  36. package/dist/app/server.js.map +1 -0
  37. package/dist/app/state.d.ts +19 -0
  38. package/dist/app/state.d.ts.map +1 -0
  39. package/dist/app/state.js +27 -0
  40. package/dist/app/state.js.map +1 -0
  41. package/dist/app/websocketConfig.d.ts +7 -0
  42. package/dist/app/websocketConfig.d.ts.map +1 -0
  43. package/dist/app/websocketConfig.js +8 -0
  44. package/dist/app/websocketConfig.js.map +1 -0
  45. package/dist/auth/client/index.d.ts +69 -0
  46. package/dist/auth/client/index.d.ts.map +1 -0
  47. package/dist/auth/client/index.js +79 -0
  48. package/dist/auth/client/index.js.map +1 -0
  49. package/dist/auth/db.d.ts +176 -0
  50. package/dist/auth/db.d.ts.map +1 -0
  51. package/dist/auth/db.js +117 -0
  52. package/dist/auth/db.js.map +1 -0
  53. package/dist/auth/deleteUser.d.ts +5 -0
  54. package/dist/auth/deleteUser.d.ts.map +1 -0
  55. package/dist/auth/deleteUser.js +34 -0
  56. package/dist/auth/deleteUser.js.map +1 -0
  57. package/dist/auth/disposableEmails.d.ts +6 -0
  58. package/dist/auth/disposableEmails.d.ts.map +1 -0
  59. package/dist/auth/disposableEmails.js +47 -0
  60. package/dist/auth/disposableEmails.js.map +1 -0
  61. package/dist/auth/index.d.ts +7 -0
  62. package/dist/auth/index.d.ts.map +1 -0
  63. package/dist/auth/index.js +33 -0
  64. package/dist/auth/index.js.map +1 -0
  65. package/dist/auth/login.d.ts +9 -0
  66. package/dist/auth/login.d.ts.map +1 -0
  67. package/dist/auth/login.js +100 -0
  68. package/dist/auth/login.js.map +1 -0
  69. package/dist/auth/password.d.ts +14 -0
  70. package/dist/auth/password.d.ts.map +1 -0
  71. package/dist/auth/password.js +26 -0
  72. package/dist/auth/password.js.map +1 -0
  73. package/dist/auth/profile.d.ts +10 -0
  74. package/dist/auth/profile.d.ts.map +1 -0
  75. package/dist/auth/profile.js +13 -0
  76. package/dist/auth/profile.js.map +1 -0
  77. package/dist/auth/providers/github.d.ts +3 -0
  78. package/dist/auth/providers/github.d.ts.map +1 -0
  79. package/dist/auth/providers/github.js +122 -0
  80. package/dist/auth/providers/github.js.map +1 -0
  81. package/dist/auth/providers/google.d.ts +3 -0
  82. package/dist/auth/providers/google.d.ts.map +1 -0
  83. package/dist/auth/providers/google.js +108 -0
  84. package/dist/auth/providers/google.js.map +1 -0
  85. package/dist/auth/providers/oauth-common.d.ts +13 -0
  86. package/dist/auth/providers/oauth-common.d.ts.map +1 -0
  87. package/dist/auth/providers/oauth-common.js +109 -0
  88. package/dist/auth/providers/oauth-common.js.map +1 -0
  89. package/dist/auth/resetPassword.d.ts +10 -0
  90. package/dist/auth/resetPassword.d.ts.map +1 -0
  91. package/dist/auth/resetPassword.js +108 -0
  92. package/dist/auth/resetPassword.js.map +1 -0
  93. package/dist/auth/role.d.ts +8 -0
  94. package/dist/auth/role.d.ts.map +1 -0
  95. package/dist/auth/role.js +37 -0
  96. package/dist/auth/role.js.map +1 -0
  97. package/dist/auth/session.d.ts +24 -0
  98. package/dist/auth/session.d.ts.map +1 -0
  99. package/dist/auth/session.js +84 -0
  100. package/dist/auth/session.js.map +1 -0
  101. package/dist/auth/signup.d.ts +3 -0
  102. package/dist/auth/signup.d.ts.map +1 -0
  103. package/dist/auth/signup.js +89 -0
  104. package/dist/auth/signup.js.map +1 -0
  105. package/dist/auth/templates/emailVerficationTemplate.d.ts +6 -0
  106. package/dist/auth/templates/emailVerficationTemplate.d.ts.map +1 -0
  107. package/dist/auth/templates/emailVerficationTemplate.js +9 -0
  108. package/dist/auth/templates/emailVerficationTemplate.js.map +1 -0
  109. package/dist/auth/types.d.ts +22 -0
  110. package/dist/auth/types.d.ts.map +1 -0
  111. package/dist/auth/types.js +2 -0
  112. package/dist/auth/types.js.map +1 -0
  113. package/dist/auth/user.d.ts +5 -0
  114. package/dist/auth/user.d.ts.map +1 -0
  115. package/dist/auth/user.js +152 -0
  116. package/dist/auth/user.js.map +1 -0
  117. package/dist/auth/validators.d.ts +3 -0
  118. package/dist/auth/validators.d.ts.map +1 -0
  119. package/dist/auth/validators.js +8 -0
  120. package/dist/auth/validators.js.map +1 -0
  121. package/dist/auth/verification.d.ts +8 -0
  122. package/dist/auth/verification.d.ts.map +1 -0
  123. package/dist/auth/verification.js +94 -0
  124. package/dist/auth/verification.js.map +1 -0
  125. package/dist/bin/auth.d.ts +4 -0
  126. package/dist/bin/auth.d.ts.map +1 -0
  127. package/dist/bin/auth.js +48 -0
  128. package/dist/bin/auth.js.map +1 -0
  129. package/dist/bin/build.d.ts +2 -0
  130. package/dist/bin/build.d.ts.map +1 -0
  131. package/dist/bin/build.js +78 -0
  132. package/dist/bin/build.js.map +1 -0
  133. package/dist/bin/config.d.ts +11 -0
  134. package/dist/bin/config.d.ts.map +1 -0
  135. package/dist/bin/config.js +91 -0
  136. package/dist/bin/config.js.map +1 -0
  137. package/dist/bin/deploy.d.ts +6 -0
  138. package/dist/bin/deploy.d.ts.map +1 -0
  139. package/dist/bin/deploy.js +129 -0
  140. package/dist/bin/deploy.js.map +1 -0
  141. package/dist/bin/dev.d.ts +2 -0
  142. package/dist/bin/dev.d.ts.map +1 -0
  143. package/dist/bin/dev.js +14 -0
  144. package/dist/bin/dev.js.map +1 -0
  145. package/dist/bin/modelence.d.ts +3 -0
  146. package/dist/bin/modelence.d.ts.map +1 -0
  147. package/dist/bin/modelence.js +57 -3
  148. package/dist/bin/modelence.js.map +1 -1
  149. package/dist/bin/setup.d.ts +5 -0
  150. package/dist/bin/setup.d.ts.map +1 -0
  151. package/dist/bin/setup.js +91 -0
  152. package/dist/bin/setup.js.map +1 -0
  153. package/dist/bin/start.d.ts +2 -0
  154. package/dist/bin/start.d.ts.map +1 -0
  155. package/dist/bin/start.js +15 -0
  156. package/dist/bin/start.js.map +1 -0
  157. package/dist/client/AppProvider.d.ts +8 -0
  158. package/dist/client/AppProvider.d.ts.map +1 -0
  159. package/dist/client/AppProvider.js +31 -0
  160. package/dist/client/AppProvider.js.map +1 -0
  161. package/dist/client/errorHandler.d.ts +4 -0
  162. package/dist/client/errorHandler.d.ts.map +1 -0
  163. package/dist/client/errorHandler.js +10 -0
  164. package/dist/client/errorHandler.js.map +1 -0
  165. package/dist/client/localStorage.d.ts +3 -0
  166. package/dist/client/localStorage.d.ts.map +1 -0
  167. package/dist/client/localStorage.js +14 -0
  168. package/dist/client/localStorage.js.map +1 -0
  169. package/dist/client/method.d.ts +6 -0
  170. package/dist/client/method.d.ts.map +1 -0
  171. package/dist/client/method.js +52 -0
  172. package/dist/client/method.js.map +1 -0
  173. package/dist/client/renderApp.d.ts +9 -0
  174. package/dist/client/renderApp.d.ts.map +1 -0
  175. package/dist/client/renderApp.js +28 -0
  176. package/dist/client/renderApp.js.map +1 -0
  177. package/dist/client/session.d.ts +34 -0
  178. package/dist/client/session.d.ts.map +1 -0
  179. package/dist/client/session.js +83 -0
  180. package/dist/client/session.js.map +1 -0
  181. package/dist/client.d.ts +10 -133
  182. package/dist/client.d.ts.map +1 -0
  183. package/dist/client.js +14 -1
  184. package/dist/client.js.map +1 -1
  185. package/dist/config/client.d.ts +10 -0
  186. package/dist/config/client.d.ts.map +1 -0
  187. package/dist/config/client.js +14 -0
  188. package/dist/config/client.js.map +1 -0
  189. package/dist/config/server.d.ts +48 -0
  190. package/dist/config/server.d.ts.map +1 -0
  191. package/dist/config/server.js +85 -0
  192. package/dist/config/server.js.map +1 -0
  193. package/dist/config/sync.d.ts +2 -0
  194. package/dist/config/sync.d.ts.map +1 -0
  195. package/dist/config/sync.js +32 -0
  196. package/dist/config/sync.js.map +1 -0
  197. package/dist/config/types.d.ts +19 -0
  198. package/dist/config/types.d.ts.map +1 -0
  199. package/dist/config/types.js +2 -0
  200. package/dist/config/types.js.map +1 -0
  201. package/dist/cron/jobs.d.ts +13 -0
  202. package/dist/cron/jobs.d.ts.map +1 -0
  203. package/dist/cron/jobs.js +155 -0
  204. package/dist/cron/jobs.js.map +1 -0
  205. package/dist/cron/types.d.ts +29 -0
  206. package/dist/cron/types.d.ts.map +1 -0
  207. package/dist/cron/types.js +2 -0
  208. package/dist/cron/types.js.map +1 -0
  209. package/dist/data/schemaSerializer.d.ts +37 -0
  210. package/dist/data/schemaSerializer.d.ts.map +1 -0
  211. package/dist/data/schemaSerializer.js +104 -0
  212. package/dist/data/schemaSerializer.js.map +1 -0
  213. package/dist/{types-WgRbQ-tj.d.ts → data/store.d.ts} +13 -231
  214. package/dist/data/store.d.ts.map +1 -0
  215. package/dist/data/store.js +501 -0
  216. package/dist/data/store.js.map +1 -0
  217. package/dist/data/types.d.ts +47 -0
  218. package/dist/data/types.d.ts.map +1 -0
  219. package/dist/data/types.js +35 -0
  220. package/dist/data/types.js.map +1 -0
  221. package/dist/db/client.d.ts +5 -0
  222. package/dist/db/client.d.ts.map +1 -0
  223. package/dist/db/client.js +41 -0
  224. package/dist/db/client.js.map +1 -0
  225. package/dist/error.d.ts +16 -0
  226. package/dist/error.d.ts.map +1 -0
  227. package/dist/error.js +24 -0
  228. package/dist/error.js.map +1 -0
  229. package/dist/index.d.ts +6 -31
  230. package/dist/index.d.ts.map +1 -0
  231. package/dist/index.js +2 -1
  232. package/dist/index.js.map +1 -1
  233. package/dist/lock/db.d.ts +19 -0
  234. package/dist/lock/db.d.ts.map +1 -0
  235. package/dist/lock/db.js +28 -0
  236. package/dist/lock/db.js.map +1 -0
  237. package/dist/lock/helpers.d.ts +28 -0
  238. package/dist/lock/helpers.d.ts.map +1 -0
  239. package/dist/lock/helpers.js +107 -0
  240. package/dist/lock/helpers.js.map +1 -0
  241. package/dist/lock/index.d.ts +4 -0
  242. package/dist/lock/index.d.ts.map +1 -0
  243. package/dist/lock/index.js +4 -0
  244. package/dist/lock/index.js.map +1 -0
  245. package/dist/lock/module.d.ts +7 -0
  246. package/dist/lock/module.d.ts.map +1 -0
  247. package/dist/lock/module.js +9 -0
  248. package/dist/lock/module.js.map +1 -0
  249. package/dist/methods/index.d.ts +7 -0
  250. package/dist/methods/index.d.ts.map +1 -0
  251. package/dist/methods/index.js +65 -0
  252. package/dist/methods/index.js.map +1 -0
  253. package/dist/methods/serialize.d.ts +15 -0
  254. package/dist/methods/serialize.d.ts.map +1 -0
  255. package/dist/methods/serialize.js +56 -0
  256. package/dist/methods/serialize.js.map +1 -0
  257. package/dist/methods/types.d.ts +37 -0
  258. package/dist/methods/types.d.ts.map +1 -0
  259. package/dist/methods/types.js +2 -0
  260. package/dist/methods/types.js.map +1 -0
  261. package/dist/migration/db.d.ts +17 -0
  262. package/dist/migration/db.d.ts.map +1 -0
  263. package/dist/migration/db.js +13 -0
  264. package/dist/migration/db.js.map +1 -0
  265. package/dist/migration/index.d.ts +11 -0
  266. package/dist/migration/index.d.ts.map +1 -0
  267. package/dist/migration/index.js +85 -0
  268. package/dist/migration/index.js.map +1 -0
  269. package/dist/mongo.d.ts +2 -3
  270. package/dist/mongo.d.ts.map +1 -0
  271. package/dist/mongo.js +2 -1
  272. package/dist/mongo.js.map +1 -1
  273. package/dist/rate-limit/db.d.ts +29 -0
  274. package/dist/rate-limit/db.d.ts.map +1 -0
  275. package/dist/rate-limit/db.js +25 -0
  276. package/dist/rate-limit/db.js.map +1 -0
  277. package/dist/rate-limit/index.d.ts +4 -0
  278. package/dist/rate-limit/index.d.ts.map +1 -0
  279. package/dist/rate-limit/index.js +6 -0
  280. package/dist/rate-limit/index.js.map +1 -0
  281. package/dist/rate-limit/rules.d.ts +22 -0
  282. package/dist/rate-limit/rules.d.ts.map +1 -0
  283. package/dist/rate-limit/rules.js +112 -0
  284. package/dist/rate-limit/rules.js.map +1 -0
  285. package/dist/rate-limit/types.d.ts +12 -0
  286. package/dist/rate-limit/types.d.ts.map +1 -0
  287. package/dist/rate-limit/types.js +2 -0
  288. package/dist/rate-limit/types.js.map +1 -0
  289. package/dist/routes/handler.d.ts +4 -0
  290. package/dist/routes/handler.d.ts.map +1 -0
  291. package/dist/routes/handler.js +66 -0
  292. package/dist/routes/handler.js.map +1 -0
  293. package/dist/routes/types.d.ts +45 -0
  294. package/dist/routes/types.d.ts.map +1 -0
  295. package/dist/routes/types.js +2 -0
  296. package/dist/routes/types.js.map +1 -0
  297. package/dist/server.d.ts +19 -551
  298. package/dist/server.d.ts.map +1 -0
  299. package/dist/server.js +15 -18
  300. package/dist/server.js.map +1 -1
  301. package/dist/system/index.d.ts +4 -0
  302. package/dist/system/index.d.ts.map +1 -0
  303. package/dist/system/index.js +21 -0
  304. package/dist/system/index.js.map +1 -0
  305. package/dist/telemetry/index.d.ts +11 -0
  306. package/dist/telemetry/index.d.ts.map +1 -0
  307. package/dist/telemetry/index.js +79 -0
  308. package/dist/telemetry/index.js.map +1 -0
  309. package/dist/telemetry.d.ts +2 -11
  310. package/dist/telemetry.d.ts.map +1 -0
  311. package/dist/telemetry.js +1 -1
  312. package/dist/telemetry.js.map +1 -1
  313. package/dist/time.d.ts +8 -0
  314. package/dist/time.d.ts.map +1 -0
  315. package/dist/time.js +13 -0
  316. package/dist/time.js.map +1 -0
  317. package/dist/types/email.d.ts +25 -0
  318. package/dist/types/email.d.ts.map +1 -0
  319. package/dist/types/email.js +2 -0
  320. package/dist/types/email.js.map +1 -0
  321. package/dist/types/index.d.ts +14 -0
  322. package/dist/types/index.d.ts.map +1 -0
  323. package/dist/types/index.js +2 -0
  324. package/dist/types/index.js.map +1 -0
  325. package/dist/types.d.ts +10 -7
  326. package/dist/types.d.ts.map +1 -0
  327. package/dist/types.js +1 -1
  328. package/dist/types.js.map +1 -1
  329. package/dist/utils/index.d.ts +4 -0
  330. package/dist/utils/index.d.ts.map +1 -0
  331. package/dist/utils/index.js +15 -0
  332. package/dist/utils/index.js.map +1 -0
  333. package/dist/viteServer.d.ts +13 -0
  334. package/dist/viteServer.d.ts.map +1 -0
  335. package/dist/viteServer.js +132 -0
  336. package/dist/viteServer.js.map +1 -0
  337. package/dist/websocket/client.d.ts +9 -0
  338. package/dist/websocket/client.d.ts.map +1 -0
  339. package/dist/websocket/client.js +16 -0
  340. package/dist/websocket/client.js.map +1 -0
  341. package/dist/websocket/clientChannel.d.ts +9 -0
  342. package/dist/websocket/clientChannel.d.ts.map +1 -0
  343. package/dist/websocket/clientChannel.js +26 -0
  344. package/dist/websocket/clientChannel.js.map +1 -0
  345. package/dist/websocket/serverChannel.d.ts +14 -0
  346. package/dist/websocket/serverChannel.d.ts.map +1 -0
  347. package/dist/websocket/serverChannel.js +21 -0
  348. package/dist/websocket/serverChannel.js.map +1 -0
  349. package/dist/websocket/socketio/client.d.ts +4 -0
  350. package/dist/websocket/socketio/client.d.ts.map +1 -0
  351. package/dist/websocket/socketio/client.js +48 -0
  352. package/dist/websocket/socketio/client.js.map +1 -0
  353. package/dist/websocket/socketio/server.d.ts +10 -0
  354. package/dist/websocket/socketio/server.d.ts.map +1 -0
  355. package/dist/websocket/socketio/server.js +80 -0
  356. package/dist/websocket/socketio/server.js.map +1 -0
  357. package/dist/websocket/types.d.ts +45 -0
  358. package/dist/websocket/types.d.ts.map +1 -0
  359. package/dist/websocket/types.js +2 -0
  360. package/dist/websocket/types.js.map +1 -0
  361. package/package.json +5 -6
  362. package/dist/chunk-3S2FFBNS.js +0 -2
  363. package/dist/chunk-3S2FFBNS.js.map +0 -1
  364. package/dist/chunk-55J6XMHW.js +0 -2
  365. package/dist/chunk-55J6XMHW.js.map +0 -1
  366. package/dist/chunk-C3UESBRX.js +0 -2
  367. package/dist/chunk-C3UESBRX.js.map +0 -1
  368. package/dist/chunk-DO5TZLF5.js +0 -2
  369. package/dist/chunk-DO5TZLF5.js.map +0 -1
  370. package/dist/chunk-KUL6YKKP.js +0 -3
  371. package/dist/chunk-KUL6YKKP.js.map +0 -1
  372. package/dist/chunk-PB6WQQ4L.js +0 -3
  373. package/dist/chunk-PB6WQQ4L.js.map +0 -1
  374. package/dist/index-CwdohC5n.d.ts +0 -15
  375. package/dist/package-IIELPLTY.js +0 -2
  376. package/dist/package-IIELPLTY.js.map +0 -1
  377. package/dist/types-Ds1ESQSs.d.ts +0 -106
@@ -0,0 +1,83 @@
1
+ import { create } from 'zustand';
2
+ import { z } from 'zod';
3
+ import { callMethod } from './method';
4
+ import { _setConfig } from '../config/client';
5
+ import { setLocalStorageSession } from './localStorage';
6
+ import { time } from '../time';
7
+ export const useSessionStore = create((set) => ({
8
+ user: null,
9
+ setUser: (user) => set({ user }),
10
+ }));
11
+ let isInitialized = false;
12
+ const SESSION_HEARTBEAT_INTERVAL = time.seconds(30);
13
+ let heartbeatTimer = null;
14
+ export async function initSession() {
15
+ if (isInitialized) {
16
+ return;
17
+ }
18
+ isInitialized = true;
19
+ const { configs, session, user } = await callMethod('_system.session.init');
20
+ _setConfig(configs);
21
+ setLocalStorageSession(session);
22
+ const parsedUser = user
23
+ ? (() => {
24
+ const parsedData = z
25
+ .object({
26
+ id: z.string(),
27
+ handle: z.string(),
28
+ roles: z.array(z.string()),
29
+ })
30
+ .parse(user);
31
+ return Object.freeze({
32
+ ...parsedData,
33
+ hasRole: (role) => parsedData.roles.includes(role),
34
+ requireRole: (role) => {
35
+ if (!parsedData.roles.includes(role)) {
36
+ throw new Error(`Access denied - role '${role}' required`);
37
+ }
38
+ },
39
+ });
40
+ })()
41
+ : null;
42
+ useSessionStore.getState().setUser(parsedUser);
43
+ await loopSessionHeartbeat();
44
+ }
45
+ async function loopSessionHeartbeat() {
46
+ try {
47
+ await callMethod('_system.session.heartbeat', {}, { errorHandler: () => { } });
48
+ }
49
+ catch {
50
+ // Silently ignore heartbeat errors - they're expected during HMR/reconnects
51
+ }
52
+ heartbeatTimer = setTimeout(loopSessionHeartbeat, SESSION_HEARTBEAT_INTERVAL);
53
+ }
54
+ export function setCurrentUser(user) {
55
+ useSessionStore.getState().setUser(user);
56
+ }
57
+ export function getHeartbeatTimer() {
58
+ return heartbeatTimer;
59
+ }
60
+ export function stopHeartbeatTimer() {
61
+ if (heartbeatTimer) {
62
+ clearTimeout(heartbeatTimer);
63
+ heartbeatTimer = null;
64
+ }
65
+ }
66
+ /**
67
+ * `useSession` is a hook that returns the current user, and in the future will also return other details about the current session.
68
+ *
69
+ * @example
70
+ * ```ts
71
+ * import { useSession } from 'modelence/client';
72
+ *
73
+ * function MyComponent() {
74
+ * const { user } = useSession();
75
+ * return <div>{user?.handle}</div>;
76
+ * }
77
+ * ```
78
+ */
79
+ export function useSession() {
80
+ const user = useSessionStore((state) => state.user);
81
+ return { user };
82
+ }
83
+ //# sourceMappingURL=session.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"session.js","sourceRoot":"","sources":["../../src/client/session.ts"],"names":[],"mappings":"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"}
package/dist/client.d.ts CHANGED
@@ -1,133 +1,10 @@
1
- import { b as ConfigKey, a as WebsocketClientProvider, c as ClientChannel } from './types-Ds1ESQSs.js';
2
- import React from 'react';
3
- import 'http';
4
- import 'mongodb';
5
-
6
- /**
7
- * @sidebarTitle getConfig (client)
8
- *
9
- * @param key
10
- * @returns
11
- */
12
- declare function getConfig(key: ConfigKey): string | number | boolean;
13
-
14
- type ErrorHandler = (error: Error, methodName: string) => void;
15
-
16
- declare function renderApp({ loadingElement, routesElement, favicon, errorHandler, }: {
17
- loadingElement: React.ReactNode;
18
- routesElement: React.ReactNode;
19
- favicon?: string;
20
- errorHandler?: ErrorHandler;
21
- }): void;
22
-
23
- type MethodArgs = Record<string, unknown>;
24
- type CallMethodOptions = {
25
- errorHandler?: (error: Error, methodName: string) => void;
26
- };
27
- declare function callMethod<T = unknown>(methodName: string, args?: MethodArgs, options?: CallMethodOptions): Promise<T>;
28
-
29
- type User = {
30
- id: string;
31
- handle: string;
32
- roles: string[];
33
- hasRole: (role: string) => boolean;
34
- requireRole: (role: string) => void;
35
- };
36
- /**
37
- * `useSession` is a hook that returns the current user, and in the future will also return other details about the current session.
38
- *
39
- * @example
40
- * ```ts
41
- * import { useSession } from 'modelence/client';
42
- *
43
- * function MyComponent() {
44
- * const { user } = useSession();
45
- * return <div>{user?.handle}</div>;
46
- * }
47
- * ```
48
- */
49
- declare function useSession(): {
50
- user: User | null;
51
- };
52
-
53
- type UserInfo = {
54
- id: string;
55
- handle: string;
56
- roles: string[];
57
- hasRole: (role: string) => boolean;
58
- requireRole: (role: string) => void;
59
- };
60
- /**
61
- * Sign up a new user with an email and password.
62
- *
63
- * @example
64
- * ```ts
65
- * await signupWithPassword({ email: 'test@example.com', password: '12345678' });
66
- * ```
67
- * @param options.email - The email of the user.
68
- * @param options.password - The password of the user.
69
- */
70
- declare function signupWithPassword(options: {
71
- email: string;
72
- password: string;
73
- }): Promise<void>;
74
- /**
75
- * Login a user with an email and password.
76
- *
77
- * @example
78
- * ```ts
79
- * await loginWithPassword({ email: 'test@example.com', password: '12345678' });
80
- * ```
81
- * @param options.email - The email of the user.
82
- * @param options.password - The password of the user.
83
- */
84
- declare function loginWithPassword(options: {
85
- email: string;
86
- password: string;
87
- }): Promise<UserInfo>;
88
- /**
89
- * Verify user's email with a verification token.
90
- *
91
- * @example
92
- * ```ts
93
- * await verifyEmail({ token: 'verification-token' });
94
- * ```
95
- * @param options.token - The email verification token.
96
- */
97
- declare function verifyEmail(options: {
98
- token: string;
99
- }): Promise<void>;
100
- /**
101
- * Logout the current user.
102
- *
103
- */
104
- declare function logout(): Promise<void>;
105
- /**
106
- * Send reset password token.
107
- * @param options.email - The email of the user.
108
- */
109
- declare function sendResetPasswordToken(options: {
110
- email: string;
111
- }): Promise<void>;
112
- /**
113
- * Reset password.
114
- * @param options.token - The password reset token.
115
- * @param options.password - The new password.
116
- */
117
- declare function resetPassword(options: {
118
- token: string;
119
- password: string;
120
- }): Promise<void>;
121
-
122
- declare function setWebsocketClientProvider(provider: WebsocketClientProvider): void;
123
- declare function getWebsocketClientProvider(): WebsocketClientProvider | null;
124
- declare function startWebsockets(props?: {
125
- provider?: WebsocketClientProvider;
126
- channels?: ClientChannel[];
127
- }): void;
128
-
129
- declare function getLocalStorageSession(): any;
130
-
131
- declare const AppProvider: any;
132
-
133
- export { AppProvider, ClientChannel, type MethodArgs, type UserInfo, callMethod, getConfig, getLocalStorageSession, getWebsocketClientProvider, loginWithPassword, logout, renderApp, resetPassword, sendResetPasswordToken, setWebsocketClientProvider, signupWithPassword, startWebsockets, useSession, verifyEmail };
1
+ export { getConfig } from './config/client';
2
+ export declare const AppProvider: any;
3
+ export { renderApp } from './client/renderApp';
4
+ export { callMethod, type MethodArgs } from './client/method';
5
+ export { useSession } from './client/session';
6
+ export { signupWithPassword, loginWithPassword, verifyEmail, logout, sendResetPasswordToken, resetPassword, type UserInfo, } from './auth/client';
7
+ export { getWebsocketClientProvider, setWebsocketClientProvider, startWebsockets, } from './websocket/client';
8
+ export { ClientChannel } from './websocket/clientChannel';
9
+ export { getLocalStorageSession } from './client/localStorage';
10
+ //# sourceMappingURL=client.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../src/client.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAE5C,eAAO,MAAM,WAAW,KAIC,CAAC;AAE1B,OAAO,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAC/C,OAAO,EAAE,UAAU,EAAE,KAAK,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAC9D,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EACL,kBAAkB,EAClB,iBAAiB,EACjB,WAAW,EACX,MAAM,EACN,sBAAsB,EACtB,aAAa,EACb,KAAK,QAAQ,GACd,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,0BAA0B,EAC1B,0BAA0B,EAC1B,eAAe,GAChB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAC1D,OAAO,EAAE,sBAAsB,EAAE,MAAM,uBAAuB,CAAC"}
package/dist/client.js CHANGED
@@ -1,2 +1,15 @@
1
- import {b as b$1}from'./chunk-3S2FFBNS.js';import {a as a$1}from'./chunk-DO5TZLF5.js';import N,{useState,useEffect}from'react';import {create}from'zustand';import {z}from'zod';import {jsx}from'react/jsx-runtime';import K from'react-dom/client';import Y from'socket.io-client';function a(){let e=localStorage.getItem("modelence.session");try{return e?JSON.parse(e):null}catch(r){return console.error("Error parsing session from localStorage",r),null}}function y(e){localStorage.setItem("modelence.session",JSON.stringify(e));}var v=(e,r)=>{throw new Error(`Error calling method '${r}': ${e.toString()}`)};function C(e){v=e;}function k(e,r){return v(e,r)}async function i(e,r={},t={}){try{return await U(`/api/_internal/method/${e}`,r)}catch(o){throw (t.errorHandler??k)(o,e),o}}async function U(e,r){let t=await fetch(e,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({args:r,authToken:a()?.authToken,clientInfo:{screenWidth:window.screen.width,screenHeight:window.screen.height,windowWidth:window.innerWidth,windowHeight:window.innerHeight,pixelRatio:window.devicePixelRatio,orientation:window.screen.orientation?.type}})});if(!t.ok){let s=await t.text();throw new Error(s)}let o=await t.text(),n=o?JSON.parse(o):void 0;if(!n)throw new Error("Invalid response from server");return b$1(n.data,n.typeMap)}var S={};function I(e){return S[e]?.value}function x(e){S=e;}var p=create(e=>({user:null,setUser:r=>e({user:r})})),P=false,_=a$1.seconds(30);async function E(){if(P)return;P=true;let{configs:e,session:r,user:t}=await i("_system.session.init");x(e),y(r);let o=t?(()=>{let n=z.object({id:z.string(),handle:z.string(),roles:z.array(z.string())}).parse(t);return Object.freeze({...n,hasRole:s=>n.roles.includes(s),requireRole:s=>{if(!n.roles.includes(s))throw new Error(`Access denied - role '${s}' required`)}})})():null;p.getState().setUser(o),await T();}async function T(){try{await i("_system.session.heartbeat",{},{errorHandler:()=>{}});}catch{}setTimeout(T,_);}function u(e){p.getState().setUser(e);}function j(){return {user:p(r=>r.user)}}var b=false;function g({children:e,loadingElement:r}){let[t,o]=useState(true);return useEffect(()=>{async function n(){b||(b=true,await E(),o(false));}n();},[]),t?r??jsx("div",{children:"Loading..."}):e}function B({loadingElement:e,routesElement:r,favicon:t,errorHandler:o}){if(o&&C(o),window.addEventListener("unload",()=>{}),K.createRoot(document.getElementById("root")).render(jsx(N.StrictMode,{children:jsx(W,{loadingElement:e,children:r})})),t){let n=document.querySelector("link[rel~='icon']");if(n)n.href=t;else {let s=document.createElement("link");s.rel="icon",s.href=t,document.head.appendChild(s);}}}async function D(e){let{email:r,password:t}=e;await i("_system.user.signupWithPassword",{email:r,password:t});}async function V(e){let{email:r,password:t}=e,{user:o}=await i("_system.user.loginWithPassword",{email:r,password:t});return u(o),o}async function F(e){let{token:r}=e;await i("_system.user.verifyEmail",{token:r});}async function G(){await i("_system.user.logout"),u(null);}async function Q(e){let{email:r}=e;await i("_system.user.sendResetPasswordToken",{email:r});}async function X(e){let{token:r,password:t}=e;await i("_system.user.resetPassword",{token:r,password:t});}var c;function Z(e){c=Y("/",{auth:{token:a()?.authToken}}),e.channels?.forEach(r=>r.init());}function ee({category:e,listener:r}){c.on(e,r);}function re({category:e,listener:r}){c.once(e,r);}function te({category:e,listener:r}){c.off(e,r);}function f({eventName:e,category:r,id:t}){c.emit(e,`${r}:${t}`);}function oe({category:e,id:r}){f({eventName:"joinChannel",category:e,id:r});}function ne({category:e,id:r}){f({eventName:"leaveChannel",category:e,id:r});}var ie={init:Z,on:ee,once:re,off:te,emit:f,joinChannel:oe,leaveChannel:ne},A=ie;var H=null;function M(e){H=e;}function d(){return H}function se(e){let r=e?.provider||A;r.init({channels:e?.channels}),M(r);}var m=class{constructor(r,t){this.category=r,this.onMessage=t;}init(){d()?.on({category:this.category,listener:this.onMessage});}joinChannel(r){d()?.joinChannel({category:this.category,id:r});}leaveChannel(r){d()?.leaveChannel({category:this.category,id:r});}};var W="useClient"in N?N.useClient(g):g;export{W as AppProvider,m as ClientChannel,i as callMethod,I as getConfig,a as getLocalStorageSession,d as getWebsocketClientProvider,V as loginWithPassword,G as logout,B as renderApp,X as resetPassword,Q as sendResetPasswordToken,M as setWebsocketClientProvider,D as signupWithPassword,se as startWebsockets,j as useSession,F as verifyEmail};//# sourceMappingURL=client.js.map
1
+ import React from 'react';
2
+ import { AppProvider as OriginalAppProvider } from './client/AppProvider';
3
+ export { getConfig } from './config/client';
4
+ export const AppProvider = 'useClient' in React
5
+ ? // @ts-ignore: React.useClient only exists in Next.js
6
+ React.useClient(OriginalAppProvider)
7
+ : OriginalAppProvider;
8
+ export { renderApp } from './client/renderApp';
9
+ export { callMethod } from './client/method';
10
+ export { useSession } from './client/session';
11
+ export { signupWithPassword, loginWithPassword, verifyEmail, logout, sendResetPasswordToken, resetPassword, } from './auth/client';
12
+ export { getWebsocketClientProvider, setWebsocketClientProvider, startWebsockets, } from './websocket/client';
13
+ export { ClientChannel } from './websocket/clientChannel';
14
+ export { getLocalStorageSession } from './client/localStorage';
2
15
  //# sourceMappingURL=client.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/client/localStorage.ts","../src/client/errorHandler.ts","../src/client/method.ts","../src/config/client.ts","../src/client/session.ts","../src/client/AppProvider.tsx","../src/client/renderApp.tsx","../src/auth/client/index.ts","../src/websocket/socketio/client.ts","../src/websocket/client.ts","../src/websocket/clientChannel.ts","../src/client.ts"],"names":["getLocalStorageSession","sessionJson","e","setLocalStorageSession","session","errorHandler","error","methodName","setErrorHandler","handler","handleError","callMethod","args","options","call","endpoint","response","text","result","reviveResponseTypes","config","getConfig","key","_setConfig","configs","useSessionStore","create","set","user","isInitialized","SESSION_HEARTBEAT_INTERVAL","time","initSession","parsedUser","parsedData","z","role","loopSessionHeartbeat","setCurrentUser","useSession","state","AppProvider","children","loadingElement","isLoading","setIsLoading","useState","useEffect","initConfig","jsx","renderApp","routesElement","favicon","ReactDOM","React","link","newLink","signupWithPassword","email","password","loginWithPassword","verifyEmail","token","logout","sendResetPasswordToken","resetPassword","socketClient","init","props","io","channel","on","category","listener","once","off","emit","eventName","id","joinChannel","leaveChannel","websocketProvider","client_default","websocketClientProvider","setWebsocketClientProvider","provider","getWebsocketClientProvider","startWebsockets","ClientChannel","onMessage"],"mappings":"oRAAO,SAASA,CAAAA,EAAyB,CACvC,IAAMC,CAAAA,CAAc,YAAA,CAAa,OAAA,CAAQ,mBAAmB,CAAA,CAC5D,GAAI,CACF,OAAOA,EAAc,IAAA,CAAK,KAAA,CAAMA,CAAW,CAAA,CAAI,IACjD,CAAA,MAASC,CAAAA,CAAG,CACV,OAAA,OAAA,CAAQ,KAAA,CAAM,yCAAA,CAA2CA,CAAC,CAAA,CACnD,IACT,CACF,CAEO,SAASC,CAAAA,CAAuBC,CAAAA,CAAiB,CACtD,YAAA,CAAa,OAAA,CAAQ,mBAAA,CAAqB,IAAA,CAAK,SAAA,CAAUA,CAAO,CAAC,EACnE,CCVA,IAAIC,CAAAA,CAA6B,CAACC,CAAAA,CAAOC,CAAAA,GAAe,CACtD,MAAM,IAAI,KAAA,CAAM,CAAA,sBAAA,EAAyBA,CAAU,CAAA,GAAA,EAAMD,CAAAA,CAAM,QAAA,EAAU,EAAE,CAC7E,CAAA,CAEO,SAASE,CAAAA,CAAgBC,CAAAA,CAAuB,CACrDJ,CAAAA,CAAeI,EACjB,CAEO,SAASC,CAAAA,CAAYJ,CAAAA,CAAcC,CAAAA,CAAoB,CAC5D,OAAOF,CAAAA,CAAaC,CAAAA,CAAOC,CAAU,CACvC,CCOA,eAAsBI,CAAAA,CACpBJ,CAAAA,CACAK,CAAAA,CAAmB,EAAC,CACpBC,CAAAA,CAA6B,EAAC,CAClB,CACZ,GAAI,CACF,OAAO,MAAMC,CAAAA,CAAQ,CAAA,sBAAA,EAAyBP,CAAU,CAAA,CAAA,CAAIK,CAAI,CAClE,CAAA,MAASN,CAAAA,CAAO,CAEd,MAAA,CADgBO,CAAAA,CAAQ,cAAgBH,CAAAA,EAChCJ,CAAAA,CAAgBC,CAAU,CAAA,CAC5BD,CACR,CACF,CAEA,eAAeQ,CAAAA,CAAkBC,CAAAA,CAAkBH,CAAAA,CAA8B,CAC/E,IAAMI,CAAAA,CAAW,MAAM,KAAA,CAAMD,CAAAA,CAAU,CACrC,MAAA,CAAQ,MAAA,CACR,OAAA,CAAS,CACP,cAAA,CAAgB,kBAClB,CAAA,CACA,IAAA,CAAM,IAAA,CAAK,SAAA,CAAU,CACnB,KAAAH,CAAAA,CACA,SAAA,CAAWZ,CAAAA,EAAuB,EAAG,SAAA,CACrC,UAAA,CAAY,CACV,WAAA,CAAa,MAAA,CAAO,MAAA,CAAO,KAAA,CAC3B,YAAA,CAAc,MAAA,CAAO,MAAA,CAAO,OAC5B,WAAA,CAAa,MAAA,CAAO,UAAA,CACpB,YAAA,CAAc,MAAA,CAAO,WAAA,CACrB,UAAA,CAAY,MAAA,CAAO,gBAAA,CACnB,WAAA,CAAa,MAAA,CAAO,MAAA,CAAO,WAAA,EAAa,IAC1C,CACF,CAAC,CACH,CAAC,CAAA,CAED,GAAI,CAACgB,CAAAA,CAAS,EAAA,CAAI,CAChB,IAAMV,CAAAA,CAAQ,MAAMU,CAAAA,CAAS,IAAA,GAC7B,MAAM,IAAI,KAAA,CAAMV,CAAK,CACvB,CAEA,IAAMW,CAAAA,CAAO,MAAMD,CAAAA,CAAS,IAAA,EAAK,CAC3BE,CAAAA,CAASD,CAAAA,CAAO,KAAK,KAAA,CAAMA,CAAI,CAAA,CAAI,MAAA,CACzC,GAAI,CAACC,CAAAA,CACH,MAAM,IAAI,KAAA,CAAM,8BAA8B,CAAA,CAGhD,OAAOC,GAAAA,CAAoBD,CAAAA,CAAO,IAAA,CAAMA,CAAAA,CAAO,OAAO,CACxD,CC/DA,IAAIE,CAAAA,CAAuC,EAAC,CAQrC,SAASC,CAAAA,CAAUC,CAAAA,CAAgB,CACxC,OAAOF,CAAAA,CAAOE,CAAG,CAAA,EAAG,KACtB,CAEO,SAASC,CAAAA,CAAWC,CAAAA,CAAkB,CAC3CJ,CAAAA,CAASI,EACX,CCKO,IAAMC,CAAAA,CAAkBC,MAAAA,CAAsBC,CAAAA,GAAS,CAC5D,IAAA,CAAM,IAAA,CACN,OAAA,CAAUC,CAAAA,EAASD,CAAAA,CAAI,CAAE,IAAA,CAAAC,CAAK,CAAC,CACjC,CAAA,CAAE,CAAA,CAEEC,CAAAA,CAAgB,KAAA,CACdC,EAA6BC,GAAAA,CAAK,OAAA,CAAQ,EAAE,CAAA,CAGlD,eAAsBC,CAAAA,EAAc,CAClC,GAAIH,CAAAA,CACF,OAGFA,CAAAA,CAAgB,IAAA,CAEhB,GAAM,CAAE,OAAA,CAAAL,CAAAA,CAAS,OAAA,CAAApB,CAAAA,CAAS,IAAA,CAAAwB,CAAK,CAAA,CAAI,MAAMjB,CAAAA,CAItC,sBAAsB,CAAA,CACzBY,CAAAA,CAAWC,CAAO,EAClBrB,CAAAA,CAAuBC,CAAO,CAAA,CAE9B,IAAM6B,CAAAA,CAAaL,CAAAA,CAAAA,CACd,IAAM,CACL,IAAMM,CAAAA,CAAaC,CAAAA,CAChB,MAAA,CAAO,CACN,EAAA,CAAIA,EAAE,MAAA,EAAO,CACb,MAAA,CAAQA,CAAAA,CAAE,MAAA,EAAO,CACjB,KAAA,CAAOA,CAAAA,CAAE,KAAA,CAAMA,CAAAA,CAAE,MAAA,EAAQ,CAC3B,CAAC,EACA,KAAA,CAAMP,CAAI,CAAA,CAEb,OAAO,MAAA,CAAO,MAAA,CAAO,CACnB,GAAGM,CAAAA,CACH,OAAA,CAAUE,CAAAA,EAAiBF,CAAAA,CAAW,KAAA,CAAM,QAAA,CAASE,CAAI,CAAA,CACzD,WAAA,CAAcA,CAAAA,EAAiB,CAC7B,GAAI,CAACF,CAAAA,CAAW,KAAA,CAAM,QAAA,CAASE,CAAI,CAAA,CACjC,MAAM,IAAI,KAAA,CAAM,CAAA,sBAAA,EAAyBA,CAAI,CAAA,UAAA,CAAY,CAE7D,CACF,CAAC,CACH,CAAA,GAAG,CACH,IAAA,CAEJX,CAAAA,CAAgB,QAAA,EAAS,CAAE,OAAA,CAAQQ,CAAU,CAAA,CAE7C,MAAMI,CAAAA,GACR,CAEA,eAAeA,CAAAA,EAAuB,CACpC,GAAI,CACF,MAAM1B,CAAAA,CAAW,2BAAA,CAA6B,EAAC,CAAG,CAAE,aAAc,IAAM,EAAG,CAAC,EAC9E,CAAA,KAAQ,EAGS,UAAA,CAAW0B,CAAAA,CAAsBP,CAA0B,EAC9E,CAEO,SAASQ,CAAAA,CAAeV,CAAAA,CAAmB,CAChDH,CAAAA,CAAgB,QAAA,EAAS,CAAE,OAAA,CAAQG,CAAI,EACzC,CA0BO,SAASW,CAAAA,EAAa,CAE3B,OAAO,CAAE,IAAA,CADId,CAAAA,CAAiBe,CAAAA,EAAUA,CAAAA,CAAM,IAAI,CACpC,CAChB,CC/FA,IAAIX,CAAAA,CAAgB,KAAA,CAEb,SAASY,CAAAA,CAAY,CAAE,QAAA,CAAAC,CAAAA,CAAU,cAAA,CAAAC,CAAe,CAAA,CAAqB,CAC1E,GAAM,CAACC,CAAAA,CAAWC,CAAY,CAAA,CAAIC,QAAAA,CAAS,IAAI,CAAA,CAiB/C,OAfAC,SAAAA,CAAU,IAAM,CACd,eAAeC,CAAAA,EAAa,CACtBnB,CAAAA,GAIJA,CAAAA,CAAgB,IAAA,CAEhB,MAAMG,CAAAA,EAAY,CAClBa,CAAAA,CAAa,KAAK,CAAA,EACpB,CAEAG,CAAAA,GACF,CAAA,CAAG,EAAE,CAAA,CAEDJ,CAAAA,CACKD,CAAAA,EAAkBM,GAAAA,CAAC,KAAA,CAAA,CAAI,QAAA,CAAA,YAAA,CAAU,CAAA,CAGnCP,CACT,CCrCO,SAASQ,CAAAA,CAAU,CACxB,cAAA,CAAAP,EACA,aAAA,CAAAQ,CAAAA,CACA,OAAA,CAAAC,CAAAA,CACA,YAAA,CAAA/C,CACF,CAAA,CAKG,CAgBD,GAfIA,CAAAA,EACFG,CAAAA,CAAgBH,CAAY,CAAA,CAG9B,MAAA,CAAO,iBAAiB,QAAA,CAAU,IAAM,EAGvC,CAAA,CAEDgD,CAAAA,CAAS,UAAA,CAAW,QAAA,CAAS,cAAA,CAAe,MAAM,CAAE,CAAA,CAAE,MAAA,CACpDJ,GAAAA,CAACK,EAAM,UAAA,CAAN,CACC,QAAA,CAAAL,GAAAA,CAACR,CAAAA,CAAA,CAAY,cAAA,CAAgBE,CAAAA,CAAiB,QAAA,CAAAQ,CAAAA,CAAc,CAAA,CAC9D,CACF,CAAA,CAEIC,CAAAA,CAAS,CACX,IAAMG,CAAAA,CAAO,QAAA,CAAS,aAAA,CAAc,mBAAmB,CAAA,CACvD,GAAKA,CAAAA,CAMHA,CAAAA,CAAK,IAAA,CAAOH,CAAAA,CAAAA,KANH,CACT,IAAMI,CAAAA,CAAU,SAAS,aAAA,CAAc,MAAM,CAAA,CAC7CA,CAAAA,CAAQ,GAAA,CAAM,MAAA,CACdA,CAAAA,CAAQ,IAAA,CAAOJ,CAAAA,CACf,QAAA,CAAS,IAAA,CAAK,WAAA,CAAYI,CAAO,EACnC,CAGF,CACF,CCrBA,eAAsBC,CAAAA,CAAmB5C,CAAAA,CAA8C,CACrF,GAAM,CAAE,KAAA,CAAA6C,CAAAA,CAAO,QAAA,CAAAC,CAAS,CAAA,CAAI9C,CAAAA,CAC5B,MAAMF,CAAAA,CAAW,iCAAA,CAAmC,CAAE,KAAA,CAAA+C,CAAAA,CAAO,QAAA,CAAAC,CAAS,CAAC,EACzE,CAYA,eAAsBC,CAAAA,CAAkB/C,CAAAA,CAA8C,CACpF,GAAM,CAAE,KAAA,CAAA6C,CAAAA,CAAO,QAAA,CAAAC,CAAS,CAAA,CAAI9C,CAAAA,CACtB,CAAE,IAAA,CAAAe,CAAK,CAAA,CAAI,MAAMjB,CAAAA,CAA+B,gCAAA,CAAkC,CACtF,MAAA+C,CAAAA,CACA,QAAA,CAAAC,CACF,CAAC,CAAA,CACD,OAAArB,CAAAA,CAAeV,CAAI,CAAA,CACZA,CACT,CAWA,eAAsBiC,CAAAA,CAAYhD,CAAAA,CAA4B,CAC5D,GAAM,CAAE,KAAA,CAAAiD,CAAM,CAAA,CAAIjD,CAAAA,CAClB,MAAMF,CAAAA,CAA+B,0BAAA,CAA4B,CAAE,KAAA,CAAAmD,CAAM,CAAC,EAC5E,CAMA,eAAsBC,CAAAA,EAAS,CAC7B,MAAMpD,CAAAA,CAAW,qBAAqB,CAAA,CACtC2B,CAAAA,CAAe,IAAI,EACrB,CAMA,eAAsB0B,CAAAA,CAAuBnD,CAAAA,CAA4B,CACvE,GAAM,CAAE,KAAA,CAAA6C,CAAM,CAAA,CAAI7C,CAAAA,CAClB,MAAMF,CAAAA,CAAW,qCAAA,CAAuC,CACtD,KAAA,CAAA+C,CACF,CAAC,EACH,CAOA,eAAsBO,CAAAA,CAAcpD,CAAAA,CAA8C,CAChF,GAAM,CAAE,KAAA,CAAAiD,CAAAA,CAAO,QAAA,CAAAH,CAAS,CAAA,CAAI9C,CAAAA,CAC5B,MAAMF,CAAAA,CAAW,6BAA8B,CAC7C,KAAA,CAAAmD,CAAAA,CACA,QAAA,CAAAH,CACF,CAAC,EACH,CCtFA,IAAIO,CAAAA,CAEJ,SAASC,CAAAA,CAAKC,CAAAA,CAAgD,CAC5DF,CAAAA,CAAeG,CAAAA,CAAG,GAAA,CAAK,CACrB,IAAA,CAAM,CACJ,KAAA,CAAOrE,CAAAA,EAAuB,EAAG,SACnC,CACF,CAAC,CAAA,CAEDoE,EAAM,QAAA,EAAU,OAAA,CAASE,CAAAA,EAAYA,CAAAA,CAAQ,IAAA,EAAM,EACrD,CAEA,SAASC,EAAAA,CAAgB,CACvB,QAAA,CAAAC,CAAAA,CACA,QAAA,CAAAC,CACF,CAAA,CAGG,CACDP,CAAAA,CAAa,EAAA,CAAGM,CAAAA,CAAUC,CAAQ,EACpC,CAEA,SAASC,EAAAA,CAAkB,CACzB,QAAA,CAAAF,CAAAA,CACA,QAAA,CAAAC,CACF,CAAA,CAGG,CACDP,CAAAA,CAAa,IAAA,CAAKM,CAAAA,CAAUC,CAAQ,EACtC,CAEA,SAASE,EAAAA,CAAiB,CACxB,QAAA,CAAAH,CAAAA,CACA,QAAA,CAAAC,CACF,CAAA,CAGG,CACDP,CAAAA,CAAa,GAAA,CAAIM,CAAAA,CAAUC,CAAQ,EACrC,CAEA,SAASG,CAAAA,CAAK,CAAE,SAAA,CAAAC,CAAAA,CAAW,QAAA,CAAAL,EAAU,EAAA,CAAAM,CAAG,CAAA,CAAwD,CAC9FZ,CAAAA,CAAa,IAAA,CAAKW,CAAAA,CAAW,CAAA,EAAGL,CAAQ,CAAA,CAAA,EAAIM,CAAE,CAAA,CAAE,EAClD,CAEA,SAASC,EAAAA,CAAY,CAAE,QAAA,CAAAP,CAAAA,CAAU,EAAA,CAAAM,CAAG,CAAA,CAAqC,CACvEF,CAAAA,CAAK,CACH,SAAA,CAAW,aAAA,CACX,QAAA,CAAAJ,CAAAA,CACA,GAAAM,CACF,CAAC,EACH,CAEA,SAASE,EAAAA,CAAa,CAAE,QAAA,CAAAR,CAAAA,CAAU,EAAA,CAAAM,CAAG,CAAA,CAAqC,CACxEF,CAAAA,CAAK,CACH,SAAA,CAAW,cAAA,CACX,QAAA,CAAAJ,CAAAA,CACA,EAAA,CAAAM,CACF,CAAC,EACH,CAEA,IAAMG,EAAAA,CAA6C,CACjD,IAAA,CAAAd,CAAAA,CACA,EAAA,CAAAI,GACA,IAAA,CAAAG,EAAAA,CACA,GAAA,CAAAC,EAAAA,CACA,IAAA,CAAAC,CAAAA,CACA,WAAA,CAAAG,EAAAA,CACA,YAAA,CAAAC,EACF,CAAA,CAEOE,CAAAA,CAAQD,EAAAA,CCzEf,IAAIE,EAA0D,IAAA,CAEvD,SAASC,CAAAA,CAA2BC,CAAAA,CAAmC,CAC5EF,CAAAA,CAA0BE,EAC5B,CAEO,SAASC,CAAAA,EAA6B,CAC3C,OAAOH,CACT,CAEO,SAASI,EAAAA,CAAgBnB,CAAAA,CAG7B,CACD,IAAMiB,CAAAA,CAAWjB,CAAAA,EAAO,QAAA,EAAYc,CAAAA,CACpCG,CAAAA,CAAS,IAAA,CAAK,CACZ,QAAA,CAAUjB,CAAAA,EAAO,QACnB,CAAC,CAAA,CACDgB,CAAAA,CAA2BC,CAAQ,EACrC,CCrBO,IAAMG,CAAAA,CAAN,KAAiC,CAItC,WAAA,CAAYhB,CAAAA,CAAkBiB,CAAAA,CAA8B,CAC1D,IAAA,CAAK,SAAWjB,CAAAA,CAChB,IAAA,CAAK,SAAA,CAAYiB,EACnB,CAEA,IAAA,EAAO,CACLH,CAAAA,EAA2B,EAAG,EAAA,CAAG,CAC/B,QAAA,CAAU,IAAA,CAAK,QAAA,CACf,SAAU,IAAA,CAAK,SACjB,CAAC,EACH,CAEA,WAAA,CAAYR,CAAAA,CAAY,CACtBQ,CAAAA,EAA2B,EAAG,WAAA,CAAY,CACxC,QAAA,CAAU,IAAA,CAAK,SACf,EAAA,CAAAR,CACF,CAAC,EACH,CAEA,YAAA,CAAaA,CAAAA,CAAY,CACvBQ,CAAAA,EAA2B,EAAG,YAAA,CAAa,CACzC,QAAA,CAAU,IAAA,CAAK,QAAA,CACf,EAAA,CAAAR,CACF,CAAC,EACH,CACF,ECzBO,IAAMrC,CAAAA,CACX,WAAA,GAAea,CAAAA,CAEXA,CAAAA,CAAM,SAAA,CAAUb,CAAmB,CAAA,CACnCA","file":"client.js","sourcesContent":["export function getLocalStorageSession() {\n const sessionJson = localStorage.getItem('modelence.session');\n try {\n return sessionJson ? JSON.parse(sessionJson) : null;\n } catch (e) {\n console.error('Error parsing session from localStorage', e);\n return null;\n }\n}\n\nexport function setLocalStorageSession(session: object) {\n localStorage.setItem('modelence.session', JSON.stringify(session));\n}\n","export type ErrorHandler = (error: Error, methodName: string) => void;\n\nlet errorHandler: ErrorHandler = (error, methodName) => {\n throw new Error(`Error calling method '${methodName}': ${error.toString()}`);\n};\n\nexport function setErrorHandler(handler: ErrorHandler) {\n errorHandler = handler;\n}\n\nexport function handleError(error: Error, methodName: string) {\n return errorHandler(error, methodName);\n}\n","/*\n The \"use client\" directive is specifically for the Next.js layout component, which is rendered on the server by default.\n Because of this, we are explicitly marking it as a client component, so we can render this component on the client\n and properly initialize config on the client side.\n \n While this is specific to Next.js, it is simply ignored outside of Next.js and should not cause errors.\n*/\n'use client';\n\nimport { getLocalStorageSession } from './localStorage';\nimport { handleError } from './errorHandler';\nimport { reviveResponseTypes } from '../methods/serialize';\n\nexport type MethodArgs = Record<string, unknown>;\n\nexport type CallMethodOptions = {\n errorHandler?: (error: Error, methodName: string) => void;\n};\n\nexport async function callMethod<T = unknown>(\n methodName: string,\n args: MethodArgs = {},\n options: CallMethodOptions = {}\n): Promise<T> {\n try {\n return await call<T>(`/api/_internal/method/${methodName}`, args);\n } catch (error) {\n const handler = options.errorHandler ?? handleError;\n handler(error as Error, methodName);\n throw error;\n }\n}\n\nasync function call<T = unknown>(endpoint: string, args: MethodArgs): Promise<T> {\n const response = await fetch(endpoint, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify({\n args,\n authToken: getLocalStorageSession()?.authToken,\n clientInfo: {\n screenWidth: window.screen.width,\n screenHeight: window.screen.height,\n windowWidth: window.innerWidth,\n windowHeight: window.innerHeight,\n pixelRatio: window.devicePixelRatio,\n orientation: window.screen.orientation?.type,\n },\n }),\n });\n\n if (!response.ok) {\n const error = await response.text();\n throw new Error(error);\n }\n\n const text = await response.text();\n const result = text ? JSON.parse(text) : undefined;\n if (!result) {\n throw new Error('Invalid response from server');\n }\n\n return reviveResponseTypes(result.data, result.typeMap);\n}\n","import { AppConfig, ConfigKey, Configs } from './types';\n\nlet config: Record<ConfigKey, AppConfig> = {};\n\n/**\n * @sidebarTitle getConfig (client)\n *\n * @param key\n * @returns\n */\nexport function getConfig(key: ConfigKey) {\n return config[key]?.value;\n}\n\nexport function _setConfig(configs: Configs) {\n config = configs;\n}\n","import { create } from 'zustand';\nimport { z } from 'zod';\nimport { callMethod } from './method';\nimport { _setConfig } from '../config/client';\nimport { setLocalStorageSession } from './localStorage';\nimport { time } from '../time';\nimport { Configs } from '../config/types';\n\ntype User = {\n id: string;\n handle: string;\n roles: string[];\n hasRole: (role: string) => boolean;\n requireRole: (role: string) => void;\n};\n\ntype SessionStore = {\n user: User | null;\n setUser: (user: User | null) => void;\n};\n\nexport const useSessionStore = create<SessionStore>((set) => ({\n user: null,\n setUser: (user) => set({ user }),\n}));\n\nlet isInitialized = false;\nconst SESSION_HEARTBEAT_INTERVAL = time.seconds(30);\nlet heartbeatTimer: ReturnType<typeof setTimeout> | null = null;\n\nexport async function initSession() {\n if (isInitialized) {\n return;\n }\n\n isInitialized = true;\n\n const { configs, session, user } = await callMethod<{\n configs: Configs;\n session: object;\n user: object;\n }>('_system.session.init');\n _setConfig(configs);\n setLocalStorageSession(session);\n\n const parsedUser = user\n ? (() => {\n const parsedData = z\n .object({\n id: z.string(),\n handle: z.string(),\n roles: z.array(z.string()),\n })\n .parse(user);\n\n return Object.freeze({\n ...parsedData,\n hasRole: (role: string) => parsedData.roles.includes(role),\n requireRole: (role: string) => {\n if (!parsedData.roles.includes(role)) {\n throw new Error(`Access denied - role '${role}' required`);\n }\n },\n });\n })()\n : null;\n\n useSessionStore.getState().setUser(parsedUser);\n\n await loopSessionHeartbeat();\n}\n\nasync function loopSessionHeartbeat() {\n try {\n await callMethod('_system.session.heartbeat', {}, { errorHandler: () => {} });\n } catch {\n // Silently ignore heartbeat errors - they're expected during HMR/reconnects\n }\n heartbeatTimer = setTimeout(loopSessionHeartbeat, SESSION_HEARTBEAT_INTERVAL);\n}\n\nexport function setCurrentUser(user: User | null) {\n useSessionStore.getState().setUser(user);\n}\n\nexport function getHeartbeatTimer() {\n return heartbeatTimer;\n}\n\nexport function stopHeartbeatTimer() {\n if (heartbeatTimer) {\n clearTimeout(heartbeatTimer);\n heartbeatTimer = null;\n }\n}\n\n/**\n * `useSession` is a hook that returns the current user, and in the future will also return other details about the current session.\n *\n * @example\n * ```ts\n * import { useSession } from 'modelence/client';\n *\n * function MyComponent() {\n * const { user } = useSession();\n * return <div>{user?.handle}</div>;\n * }\n * ```\n */\nexport function useSession() {\n const user = useSessionStore((state) => state.user);\n return { user };\n}\n","/*\n The \"use client\" directive is specifically for the Next.js layout component, which is rendered on the server by default.\n Because of this, we are explicitly marking it as a client component, so we can render this component on the client\n and properly initialize config on the client side.\n \n While this is specific to Next.js, it is simply ignored outside of Next.js and should not cause errors.\n*/\n'use client';\n\nimport React, { useState, useEffect, ReactNode } from 'react';\nimport { initSession } from './session';\n\ninterface AppProviderProps {\n children: ReactNode;\n loadingElement?: ReactNode;\n}\n\nlet isInitialized = false;\n\nexport function AppProvider({ children, loadingElement }: AppProviderProps) {\n const [isLoading, setIsLoading] = useState(true);\n\n useEffect(() => {\n async function initConfig() {\n if (isInitialized) {\n return;\n }\n\n isInitialized = true;\n\n await initSession();\n setIsLoading(false);\n }\n\n initConfig();\n }, []);\n\n if (isLoading) {\n return loadingElement ?? <div>Loading...</div>;\n }\n\n return children;\n}\n","import React from 'react';\nimport ReactDOM from 'react-dom/client';\nimport { AppProvider } from '../client';\nimport { setErrorHandler, ErrorHandler } from './errorHandler';\n\nexport function renderApp({\n loadingElement,\n routesElement,\n favicon,\n errorHandler,\n}: {\n loadingElement: React.ReactNode;\n routesElement: React.ReactNode;\n favicon?: string;\n errorHandler?: ErrorHandler;\n}) {\n if (errorHandler) {\n setErrorHandler(errorHandler);\n }\n\n window.addEventListener('unload', () => {\n // The presence of any 'unload' event handler, even empty,\n // prevents bfcache in most browsers\n });\n\n ReactDOM.createRoot(document.getElementById('root')!).render(\n <React.StrictMode>\n <AppProvider loadingElement={loadingElement}>{routesElement}</AppProvider>\n </React.StrictMode>\n );\n\n if (favicon) {\n const link = document.querySelector(\"link[rel~='icon']\") as HTMLLinkElement;\n if (!link) {\n const newLink = document.createElement('link');\n newLink.rel = 'icon';\n newLink.href = favicon;\n document.head.appendChild(newLink);\n } else {\n link.href = favicon;\n }\n }\n}\n","import { setCurrentUser } from '../../client/session';\nimport { callMethod } from '../../client/method';\n\nexport type UserInfo = {\n id: string;\n handle: string;\n roles: string[];\n hasRole: (role: string) => boolean;\n requireRole: (role: string) => void;\n};\n\n/**\n * Sign up a new user with an email and password.\n *\n * @example\n * ```ts\n * await signupWithPassword({ email: 'test@example.com', password: '12345678' });\n * ```\n * @param options.email - The email of the user.\n * @param options.password - The password of the user.\n */\nexport async function signupWithPassword(options: { email: string; password: string }) {\n const { email, password } = options;\n await callMethod('_system.user.signupWithPassword', { email, password });\n}\n\n/**\n * Login a user with an email and password.\n *\n * @example\n * ```ts\n * await loginWithPassword({ email: 'test@example.com', password: '12345678' });\n * ```\n * @param options.email - The email of the user.\n * @param options.password - The password of the user.\n */\nexport async function loginWithPassword(options: { email: string; password: string }) {\n const { email, password } = options;\n const { user } = await callMethod<{ user: UserInfo }>('_system.user.loginWithPassword', {\n email,\n password,\n });\n setCurrentUser(user);\n return user;\n}\n\n/**\n * Verify user's email with a verification token.\n *\n * @example\n * ```ts\n * await verifyEmail({ token: 'verification-token' });\n * ```\n * @param options.token - The email verification token.\n */\nexport async function verifyEmail(options: { token: string }) {\n const { token } = options;\n await callMethod<{ user: UserInfo }>('_system.user.verifyEmail', { token });\n}\n\n/**\n * Logout the current user.\n *\n */\nexport async function logout() {\n await callMethod('_system.user.logout');\n setCurrentUser(null);\n}\n\n/**\n * Send reset password token.\n * @param options.email - The email of the user.\n */\nexport async function sendResetPasswordToken(options: { email: string }) {\n const { email } = options;\n await callMethod('_system.user.sendResetPasswordToken', {\n email,\n });\n}\n\n/**\n * Reset password.\n * @param options.token - The password reset token.\n * @param options.password - The new password.\n */\nexport async function resetPassword(options: { token: string; password: string }) {\n const { token, password } = options;\n await callMethod('_system.user.resetPassword', {\n token,\n password,\n });\n}\n","import io, { Socket } from 'socket.io-client';\nimport { WebsocketClientProvider } from '../types';\nimport { ClientChannel } from '../clientChannel';\nimport { getLocalStorageSession } from '@/client/localStorage';\n\nlet socketClient: Socket;\n\nfunction init(props: { channels?: ClientChannel<unknown>[] }) {\n socketClient = io('/', {\n auth: {\n token: getLocalStorageSession()?.authToken,\n },\n });\n\n props.channels?.forEach((channel) => channel.init());\n}\n\nfunction on<T = unknown>({\n category,\n listener,\n}: {\n category: string;\n listener: (data: T) => void;\n}) {\n socketClient.on(category, listener);\n}\n\nfunction once<T = unknown>({\n category,\n listener,\n}: {\n category: string;\n listener: (data: T) => void;\n}) {\n socketClient.once(category, listener);\n}\n\nfunction off<T = unknown>({\n category,\n listener,\n}: {\n category: string;\n listener: (data: T) => void;\n}) {\n socketClient.off(category, listener);\n}\n\nfunction emit({ eventName, category, id }: { eventName: string; category: string; id: string }) {\n socketClient.emit(eventName, `${category}:${id}`);\n}\n\nfunction joinChannel({ category, id }: { category: string; id: string }) {\n emit({\n eventName: 'joinChannel',\n category,\n id,\n });\n}\n\nfunction leaveChannel({ category, id }: { category: string; id: string }) {\n emit({\n eventName: 'leaveChannel',\n category,\n id,\n });\n}\n\nconst websocketProvider: WebsocketClientProvider = {\n init,\n on,\n once,\n off,\n emit,\n joinChannel,\n leaveChannel,\n};\n\nexport default websocketProvider;\n","import { ClientChannel } from './clientChannel';\nimport websocketProvider from './socketio/client';\nimport { WebsocketClientProvider } from './types';\n\nlet websocketClientProvider: WebsocketClientProvider | null = null;\n\nexport function setWebsocketClientProvider(provider: WebsocketClientProvider) {\n websocketClientProvider = provider;\n}\n\nexport function getWebsocketClientProvider() {\n return websocketClientProvider;\n}\n\nexport function startWebsockets(props?: {\n provider?: WebsocketClientProvider;\n channels?: ClientChannel[];\n}) {\n const provider = props?.provider || websocketProvider;\n provider.init({\n channels: props?.channels,\n });\n setWebsocketClientProvider(provider);\n}\n","import { getWebsocketClientProvider } from './client';\n\nexport class ClientChannel<T = unknown> {\n public readonly category: string;\n private readonly onMessage: (data: T) => void;\n\n constructor(category: string, onMessage: (data: T) => void) {\n this.category = category;\n this.onMessage = onMessage;\n }\n\n init() {\n getWebsocketClientProvider()?.on({\n category: this.category,\n listener: this.onMessage,\n });\n }\n\n joinChannel(id: string) {\n getWebsocketClientProvider()?.joinChannel({\n category: this.category,\n id,\n });\n }\n\n leaveChannel(id: string) {\n getWebsocketClientProvider()?.leaveChannel({\n category: this.category,\n id,\n });\n }\n}\n","import React from 'react';\n\nimport { AppProvider as OriginalAppProvider } from './client/AppProvider';\n\nexport { getConfig } from './config/client';\n\nexport const AppProvider =\n 'useClient' in React\n ? // @ts-ignore: React.useClient only exists in Next.js\n React.useClient(OriginalAppProvider)\n : OriginalAppProvider;\n\nexport { renderApp } from './client/renderApp';\nexport { callMethod, type MethodArgs } from './client/method';\nexport { useSession } from './client/session';\nexport {\n signupWithPassword,\n loginWithPassword,\n verifyEmail,\n logout,\n sendResetPasswordToken,\n resetPassword,\n type UserInfo,\n} from './auth/client';\nexport {\n getWebsocketClientProvider,\n setWebsocketClientProvider,\n startWebsockets,\n} from './websocket/client';\nexport { ClientChannel } from './websocket/clientChannel';\nexport { getLocalStorageSession } from './client/localStorage';\n"]}
1
+ {"version":3,"file":"client.js","sourceRoot":"","sources":["../src/client.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAE,WAAW,IAAI,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAE1E,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAE5C,MAAM,CAAC,MAAM,WAAW,GACtB,WAAW,IAAI,KAAK;IAClB,CAAC,CAAC,qDAAqD;QACrD,KAAK,CAAC,SAAS,CAAC,mBAAmB,CAAC;IACtC,CAAC,CAAC,mBAAmB,CAAC;AAE1B,OAAO,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAC/C,OAAO,EAAE,UAAU,EAAmB,MAAM,iBAAiB,CAAC;AAC9D,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EACL,kBAAkB,EAClB,iBAAiB,EACjB,WAAW,EACX,MAAM,EACN,sBAAsB,EACtB,aAAa,GAEd,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,0BAA0B,EAC1B,0BAA0B,EAC1B,eAAe,GAChB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAC1D,OAAO,EAAE,sBAAsB,EAAE,MAAM,uBAAuB,CAAC"}
@@ -0,0 +1,10 @@
1
+ import { ConfigKey, Configs } from './types';
2
+ /**
3
+ * @sidebarTitle getConfig (client)
4
+ *
5
+ * @param key
6
+ * @returns
7
+ */
8
+ export declare function getConfig(key: ConfigKey): string | number | boolean;
9
+ export declare function _setConfig(configs: Configs): void;
10
+ //# sourceMappingURL=client.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../src/config/client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAa,SAAS,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAIxD;;;;;GAKG;AACH,wBAAgB,SAAS,CAAC,GAAG,EAAE,SAAS,6BAEvC;AAED,wBAAgB,UAAU,CAAC,OAAO,EAAE,OAAO,QAE1C"}
@@ -0,0 +1,14 @@
1
+ let config = {};
2
+ /**
3
+ * @sidebarTitle getConfig (client)
4
+ *
5
+ * @param key
6
+ * @returns
7
+ */
8
+ export function getConfig(key) {
9
+ return config[key]?.value;
10
+ }
11
+ export function _setConfig(configs) {
12
+ config = configs;
13
+ }
14
+ //# sourceMappingURL=client.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"client.js","sourceRoot":"","sources":["../../src/config/client.ts"],"names":[],"mappings":"AAEA,IAAI,MAAM,GAAiC,EAAE,CAAC;AAE9C;;;;;GAKG;AACH,MAAM,UAAU,SAAS,CAAC,GAAc;IACtC,OAAO,MAAM,CAAC,GAAG,CAAC,EAAE,KAAK,CAAC;AAC5B,CAAC;AAED,MAAM,UAAU,UAAU,CAAC,OAAgB;IACzC,MAAM,GAAG,OAAO,CAAC;AACnB,CAAC"}
@@ -0,0 +1,48 @@
1
+ import { AppConfig, ConfigKey, ConfigSchema } from './types';
2
+ /**
3
+ * @sidebarTitle getConfig (server)
4
+ *
5
+ * @param key - The configuration key to retrieve
6
+ * @returns The configuration value (string, number, or boolean)
7
+ *
8
+ * @example
9
+ * ```ts
10
+ * import { getConfig } from 'modelence/server';
11
+ *
12
+ * // Get the site URL
13
+ * const siteUrl = getConfig('_system.site.url');
14
+ * ```
15
+ *
16
+ * Set via environment variable:
17
+ * ```bash
18
+ * MODELENCE_SITE_URL=https://myapp.com
19
+ * ```
20
+ *
21
+ * @example
22
+ * ```ts
23
+ * import { getConfig } from 'modelence/server';
24
+ *
25
+ * // Get the current environment (e.g., 'development', 'staging', 'production')
26
+ * const env = getConfig('_system.env');
27
+ *
28
+ * if (env === 'production') {
29
+ * // Enable production features
30
+ * }
31
+ * ```
32
+ *
33
+ * Set via environment variable:
34
+ * ```bash
35
+ * MODELENCE_SITE_ENV=production
36
+ * ```
37
+ */
38
+ export declare function getConfig(key: ConfigKey): string | number | boolean;
39
+ export declare function getPublicConfigs(): {
40
+ [k: string]: {
41
+ key: string;
42
+ type: import("./types").ConfigType;
43
+ value: string | number | boolean;
44
+ };
45
+ };
46
+ export declare function loadConfigs(configs: AppConfig[]): void;
47
+ export declare function setSchema(schema: ConfigSchema): void;
48
+ //# sourceMappingURL=server.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"server.d.ts","sourceRoot":"","sources":["../../src/config/server.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAM7D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAmCG;AACH,wBAAgB,SAAS,CAAC,GAAG,EAAE,SAAS,6BAEvC;AAED,wBAAgB,gBAAgB;;;;;;EAqB/B;AAED,wBAAgB,WAAW,CAAC,OAAO,EAAE,SAAS,EAAE,QAiB/C;AAED,wBAAgB,SAAS,CAAC,MAAM,EAAE,YAAY,QAW7C"}
@@ -0,0 +1,85 @@
1
+ let configSchema = {};
2
+ let config = {};
3
+ let isInitialized = false;
4
+ /**
5
+ * @sidebarTitle getConfig (server)
6
+ *
7
+ * @param key - The configuration key to retrieve
8
+ * @returns The configuration value (string, number, or boolean)
9
+ *
10
+ * @example
11
+ * ```ts
12
+ * import { getConfig } from 'modelence/server';
13
+ *
14
+ * // Get the site URL
15
+ * const siteUrl = getConfig('_system.site.url');
16
+ * ```
17
+ *
18
+ * Set via environment variable:
19
+ * ```bash
20
+ * MODELENCE_SITE_URL=https://myapp.com
21
+ * ```
22
+ *
23
+ * @example
24
+ * ```ts
25
+ * import { getConfig } from 'modelence/server';
26
+ *
27
+ * // Get the current environment (e.g., 'development', 'staging', 'production')
28
+ * const env = getConfig('_system.env');
29
+ *
30
+ * if (env === 'production') {
31
+ * // Enable production features
32
+ * }
33
+ * ```
34
+ *
35
+ * Set via environment variable:
36
+ * ```bash
37
+ * MODELENCE_SITE_ENV=production
38
+ * ```
39
+ */
40
+ export function getConfig(key) {
41
+ return config[key]?.value ?? configSchema[key]?.default;
42
+ }
43
+ export function getPublicConfigs() {
44
+ if (!isInitialized) {
45
+ throw new Error('Config is not initialized: an attempt was made to access configs before they were loaded');
46
+ }
47
+ return Object.fromEntries(Object.entries(configSchema)
48
+ .filter(([_, schema]) => schema.isPublic)
49
+ .map(([key, schema]) => {
50
+ return [
51
+ key,
52
+ {
53
+ key,
54
+ type: schema.type,
55
+ value: config[key]?.value ?? schema.default,
56
+ },
57
+ ];
58
+ }));
59
+ }
60
+ export function loadConfigs(configs) {
61
+ configs.forEach(({ key, type, value }) => {
62
+ const isSystemConfig = key.toLowerCase().startsWith('_system.');
63
+ if (!isSystemConfig && !configSchema[key]) {
64
+ // Ignore unknown configs
65
+ return;
66
+ }
67
+ config[key] = {
68
+ key,
69
+ type,
70
+ value,
71
+ };
72
+ });
73
+ isInitialized = true;
74
+ }
75
+ export function setSchema(schema) {
76
+ // TODO: more validation on the schema structure
77
+ Object.entries(schema).forEach(([key, value]) => {
78
+ const { type, isPublic } = value;
79
+ if (type === 'secret' && isPublic) {
80
+ throw new Error(`Config ${key} with type "secret" cannot be public`);
81
+ }
82
+ });
83
+ configSchema = schema;
84
+ }
85
+ //# sourceMappingURL=server.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"server.js","sourceRoot":"","sources":["../../src/config/server.ts"],"names":[],"mappings":"AAEA,IAAI,YAAY,GAAiB,EAAE,CAAC;AACpC,IAAI,MAAM,GAAiC,EAAE,CAAC;AAC9C,IAAI,aAAa,GAAG,KAAK,CAAC;AAE1B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAmCG;AACH,MAAM,UAAU,SAAS,CAAC,GAAc;IACtC,OAAO,MAAM,CAAC,GAAG,CAAC,EAAE,KAAK,IAAI,YAAY,CAAC,GAAG,CAAC,EAAE,OAAO,CAAC;AAC1D,CAAC;AAED,MAAM,UAAU,gBAAgB;IAC9B,IAAI,CAAC,aAAa,EAAE,CAAC;QACnB,MAAM,IAAI,KAAK,CACb,0FAA0F,CAC3F,CAAC;IACJ,CAAC;IAED,OAAO,MAAM,CAAC,WAAW,CACvB,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC;SACzB,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,QAAQ,CAAC;SACxC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,MAAM,CAAC,EAAE,EAAE;QACrB,OAAO;YACL,GAAG;YACH;gBACE,GAAG;gBACH,IAAI,EAAE,MAAM,CAAC,IAAI;gBACjB,KAAK,EAAE,MAAM,CAAC,GAAG,CAAC,EAAE,KAAK,IAAI,MAAM,CAAC,OAAO;aAC5C;SACF,CAAC;IACJ,CAAC,CAAC,CACL,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,WAAW,CAAC,OAAoB;IAC9C,OAAO,CAAC,OAAO,CAAC,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,KAAK,EAAE,EAAE,EAAE;QACvC,MAAM,cAAc,GAAG,GAAG,CAAC,WAAW,EAAE,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;QAEhE,IAAI,CAAC,cAAc,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,EAAE,CAAC;YAC1C,yBAAyB;YACzB,OAAO;QACT,CAAC;QAED,MAAM,CAAC,GAAG,CAAC,GAAG;YACZ,GAAG;YACH,IAAI;YACJ,KAAK;SACN,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,aAAa,GAAG,IAAI,CAAC;AACvB,CAAC;AAED,MAAM,UAAU,SAAS,CAAC,MAAoB;IAC5C,gDAAgD;IAChD,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE;QAC9C,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,GAAG,KAAK,CAAC;QAEjC,IAAI,IAAI,KAAK,QAAQ,IAAI,QAAQ,EAAE,CAAC;YAClC,MAAM,IAAI,KAAK,CAAC,UAAU,GAAG,sCAAsC,CAAC,CAAC;QACvE,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,YAAY,GAAG,MAAM,CAAC;AACxB,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare function startConfigSync(): void;
2
+ //# sourceMappingURL=sync.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sync.d.ts","sourceRoot":"","sources":["../../src/config/sync.ts"],"names":[],"mappings":"AAQA,wBAAgB,eAAe,SAuB9B"}
@@ -0,0 +1,32 @@
1
+ import { time } from '../time';
2
+ import { fetchConfigs, syncStatus } from '../app/backendApi';
3
+ import { loadConfigs } from './server';
4
+ let isSyncing = false;
5
+ const SYNC_INTERVAL = time.seconds(10);
6
+ export function startConfigSync() {
7
+ setInterval(async () => {
8
+ if (isSyncing) {
9
+ return;
10
+ }
11
+ isSyncing = true;
12
+ // TODO: move this sync outside of config
13
+ try {
14
+ await syncStatus();
15
+ }
16
+ catch (error) {
17
+ console.error('Error syncing status', error);
18
+ }
19
+ try {
20
+ await syncConfig();
21
+ }
22
+ catch (error) {
23
+ console.error('Error syncing config', error);
24
+ }
25
+ isSyncing = false;
26
+ }, SYNC_INTERVAL);
27
+ }
28
+ async function syncConfig() {
29
+ const { configs } = await fetchConfigs();
30
+ loadConfigs(configs);
31
+ }
32
+ //# sourceMappingURL=sync.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sync.js","sourceRoot":"","sources":["../../src/config/sync.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,SAAS,CAAC;AAC/B,OAAO,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAEvC,IAAI,SAAS,GAAG,KAAK,CAAC;AAEtB,MAAM,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;AAEvC,MAAM,UAAU,eAAe;IAC7B,WAAW,CAAC,KAAK,IAAI,EAAE;QACrB,IAAI,SAAS,EAAE,CAAC;YACd,OAAO;QACT,CAAC;QAED,SAAS,GAAG,IAAI,CAAC;QAEjB,yCAAyC;QACzC,IAAI,CAAC;YACH,MAAM,UAAU,EAAE,CAAC;QACrB,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CAAC,sBAAsB,EAAE,KAAK,CAAC,CAAC;QAC/C,CAAC;QAED,IAAI,CAAC;YACH,MAAM,UAAU,EAAE,CAAC;QACrB,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CAAC,sBAAsB,EAAE,KAAK,CAAC,CAAC;QAC/C,CAAC;QAED,SAAS,GAAG,KAAK,CAAC;IACpB,CAAC,EAAE,aAAa,CAAC,CAAC;AACpB,CAAC;AAED,KAAK,UAAU,UAAU;IACvB,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,YAAY,EAAE,CAAC;IACzC,WAAW,CAAC,OAAO,CAAC,CAAC;AACvB,CAAC"}
@@ -0,0 +1,19 @@
1
+ export type ConfigType = 'text' | 'string' | 'number' | 'boolean' | 'secret';
2
+ export type ConfigKey = string;
3
+ type ConfigParams = {
4
+ type: ConfigType;
5
+ default: ValueType<ConfigType>;
6
+ isPublic: boolean;
7
+ };
8
+ export type AppConfig = {
9
+ key: ConfigKey;
10
+ value: ValueType<ConfigType>;
11
+ type: ConfigType;
12
+ };
13
+ export type ConfigSchema = {
14
+ [key: string]: ConfigParams;
15
+ };
16
+ export type Configs = Record<ConfigKey, AppConfig>;
17
+ type ValueType<T> = T extends 'number' ? number : T extends 'string' ? string : T extends 'text' ? string : T extends 'boolean' ? boolean : T extends 'secret' ? string : never;
18
+ export {};
19
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/config/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,UAAU,GAAG,MAAM,GAAG,QAAQ,GAAG,QAAQ,GAAG,SAAS,GAAG,QAAQ,CAAC;AAE7E,MAAM,MAAM,SAAS,GAAG,MAAM,CAAC;AAE/B,KAAK,YAAY,GAAG;IAClB,IAAI,EAAE,UAAU,CAAC;IACjB,OAAO,EAAE,SAAS,CAAC,UAAU,CAAC,CAAC;IAC/B,QAAQ,EAAE,OAAO,CAAC;CACnB,CAAC;AAEF,MAAM,MAAM,SAAS,GAAG;IACtB,GAAG,EAAE,SAAS,CAAC;IACf,KAAK,EAAE,SAAS,CAAC,UAAU,CAAC,CAAC;IAC7B,IAAI,EAAE,UAAU,CAAC;CAClB,CAAC;AAEF,MAAM,MAAM,YAAY,GAAG;IACzB,CAAC,GAAG,EAAE,MAAM,GAAG,YAAY,CAAC;CAC7B,CAAC;AAEF,MAAM,MAAM,OAAO,GAAG,MAAM,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;AAEnD,KAAK,SAAS,CAAC,CAAC,IAAI,CAAC,SAAS,QAAQ,GAClC,MAAM,GACN,CAAC,SAAS,QAAQ,GAChB,MAAM,GACN,CAAC,SAAS,MAAM,GACd,MAAM,GACN,CAAC,SAAS,SAAS,GACjB,OAAO,GACP,CAAC,SAAS,QAAQ,GAChB,MAAM,GACN,KAAK,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/config/types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,13 @@
1
+ import { CronJob, CronJobInputParams } from './types';
2
+ import { Module } from '../app/module';
3
+ export declare function defineCronJob(alias: CronJob['alias'], { description, interval, timeout, handler }: CronJobInputParams): void;
4
+ export declare function startCronJobs(): Promise<void>;
5
+ export declare function getCronJobsMetadata(): {
6
+ alias: string;
7
+ description: string;
8
+ interval: number;
9
+ timeout: number;
10
+ }[];
11
+ declare const _default: Module;
12
+ export default _default;
13
+ //# sourceMappingURL=jobs.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"jobs.d.ts","sourceRoot":"","sources":["../../src/cron/jobs.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,OAAO,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;AAEtD,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAmBvC,wBAAgB,aAAa,CAC3B,KAAK,EAAE,OAAO,CAAC,OAAO,CAAC,EACvB,EAAE,WAAgB,EAAE,QAAQ,EAAE,OAAyB,EAAE,OAAO,EAAE,EAAE,kBAAkB,QA4BvF;AAED,wBAAsB,aAAa,kBA4BlC;AAmED,wBAAgB,mBAAmB;;;;;IAOlC;;AAED,wBAEG"}