@fuzdev/fuz_app 0.1.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 (457) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +49 -0
  3. package/dist/actions/action_bridge.d.ts +65 -0
  4. package/dist/actions/action_bridge.d.ts.map +1 -0
  5. package/dist/actions/action_bridge.js +76 -0
  6. package/dist/actions/action_codegen.d.ts +97 -0
  7. package/dist/actions/action_codegen.d.ts.map +1 -0
  8. package/dist/actions/action_codegen.js +280 -0
  9. package/dist/actions/action_registry.d.ts +35 -0
  10. package/dist/actions/action_registry.d.ts.map +1 -0
  11. package/dist/actions/action_registry.js +83 -0
  12. package/dist/actions/action_spec.d.ts +169 -0
  13. package/dist/actions/action_spec.d.ts.map +1 -0
  14. package/dist/actions/action_spec.js +76 -0
  15. package/dist/auth/account_queries.d.ts +96 -0
  16. package/dist/auth/account_queries.d.ts.map +1 -0
  17. package/dist/auth/account_queries.js +172 -0
  18. package/dist/auth/account_routes.d.ts +86 -0
  19. package/dist/auth/account_routes.d.ts.map +1 -0
  20. package/dist/auth/account_routes.js +406 -0
  21. package/dist/auth/account_schema.d.ts +192 -0
  22. package/dist/auth/account_schema.d.ts.map +1 -0
  23. package/dist/auth/account_schema.js +105 -0
  24. package/dist/auth/admin_routes.d.ts +29 -0
  25. package/dist/auth/admin_routes.d.ts.map +1 -0
  26. package/dist/auth/admin_routes.js +193 -0
  27. package/dist/auth/api_token.d.ts +33 -0
  28. package/dist/auth/api_token.d.ts.map +1 -0
  29. package/dist/auth/api_token.js +36 -0
  30. package/dist/auth/api_token_queries.d.ts +80 -0
  31. package/dist/auth/api_token_queries.d.ts.map +1 -0
  32. package/dist/auth/api_token_queries.js +116 -0
  33. package/dist/auth/app_settings_queries.d.ts +33 -0
  34. package/dist/auth/app_settings_queries.d.ts.map +1 -0
  35. package/dist/auth/app_settings_queries.js +51 -0
  36. package/dist/auth/app_settings_routes.d.ts +27 -0
  37. package/dist/auth/app_settings_routes.d.ts.map +1 -0
  38. package/dist/auth/app_settings_routes.js +66 -0
  39. package/dist/auth/app_settings_schema.d.ts +35 -0
  40. package/dist/auth/app_settings_schema.d.ts.map +1 -0
  41. package/dist/auth/app_settings_schema.js +22 -0
  42. package/dist/auth/audit_log_queries.d.ts +90 -0
  43. package/dist/auth/audit_log_queries.d.ts.map +1 -0
  44. package/dist/auth/audit_log_queries.js +205 -0
  45. package/dist/auth/audit_log_routes.d.ts +33 -0
  46. package/dist/auth/audit_log_routes.d.ts.map +1 -0
  47. package/dist/auth/audit_log_routes.js +106 -0
  48. package/dist/auth/audit_log_schema.d.ts +259 -0
  49. package/dist/auth/audit_log_schema.d.ts.map +1 -0
  50. package/dist/auth/audit_log_schema.js +123 -0
  51. package/dist/auth/bearer_auth.d.ts +32 -0
  52. package/dist/auth/bearer_auth.d.ts.map +1 -0
  53. package/dist/auth/bearer_auth.js +90 -0
  54. package/dist/auth/bootstrap_account.d.ts +82 -0
  55. package/dist/auth/bootstrap_account.d.ts.map +1 -0
  56. package/dist/auth/bootstrap_account.js +97 -0
  57. package/dist/auth/bootstrap_routes.d.ts +74 -0
  58. package/dist/auth/bootstrap_routes.d.ts.map +1 -0
  59. package/dist/auth/bootstrap_routes.js +154 -0
  60. package/dist/auth/daemon_token.d.ts +49 -0
  61. package/dist/auth/daemon_token.d.ts.map +1 -0
  62. package/dist/auth/daemon_token.js +49 -0
  63. package/dist/auth/daemon_token_middleware.d.ts +93 -0
  64. package/dist/auth/daemon_token_middleware.d.ts.map +1 -0
  65. package/dist/auth/daemon_token_middleware.js +167 -0
  66. package/dist/auth/ddl.d.ts +27 -0
  67. package/dist/auth/ddl.d.ts.map +1 -0
  68. package/dist/auth/ddl.js +111 -0
  69. package/dist/auth/deps.d.ts +52 -0
  70. package/dist/auth/deps.d.ts.map +1 -0
  71. package/dist/auth/deps.js +10 -0
  72. package/dist/auth/invite_queries.d.ts +68 -0
  73. package/dist/auth/invite_queries.d.ts.map +1 -0
  74. package/dist/auth/invite_queries.js +105 -0
  75. package/dist/auth/invite_routes.d.ts +18 -0
  76. package/dist/auth/invite_routes.d.ts.map +1 -0
  77. package/dist/auth/invite_routes.js +129 -0
  78. package/dist/auth/invite_schema.d.ts +51 -0
  79. package/dist/auth/invite_schema.d.ts.map +1 -0
  80. package/dist/auth/invite_schema.js +25 -0
  81. package/dist/auth/keyring.d.ts +87 -0
  82. package/dist/auth/keyring.d.ts.map +1 -0
  83. package/dist/auth/keyring.js +142 -0
  84. package/dist/auth/middleware.d.ts +40 -0
  85. package/dist/auth/middleware.d.ts.map +1 -0
  86. package/dist/auth/middleware.js +64 -0
  87. package/dist/auth/migrations.d.ts +42 -0
  88. package/dist/auth/migrations.d.ts.map +1 -0
  89. package/dist/auth/migrations.js +79 -0
  90. package/dist/auth/password.d.ts +39 -0
  91. package/dist/auth/password.d.ts.map +1 -0
  92. package/dist/auth/password.js +25 -0
  93. package/dist/auth/password_argon2.d.ts +43 -0
  94. package/dist/auth/password_argon2.d.ts.map +1 -0
  95. package/dist/auth/password_argon2.js +76 -0
  96. package/dist/auth/permit_queries.d.ts +72 -0
  97. package/dist/auth/permit_queries.d.ts.map +1 -0
  98. package/dist/auth/permit_queries.js +116 -0
  99. package/dist/auth/request_context.d.ts +114 -0
  100. package/dist/auth/request_context.d.ts.map +1 -0
  101. package/dist/auth/request_context.js +176 -0
  102. package/dist/auth/require_keeper.d.ts +20 -0
  103. package/dist/auth/require_keeper.d.ts.map +1 -0
  104. package/dist/auth/require_keeper.js +35 -0
  105. package/dist/auth/role_schema.d.ts +69 -0
  106. package/dist/auth/role_schema.d.ts.map +1 -0
  107. package/dist/auth/role_schema.js +70 -0
  108. package/dist/auth/route_guards.d.ts +21 -0
  109. package/dist/auth/route_guards.d.ts.map +1 -0
  110. package/dist/auth/route_guards.js +32 -0
  111. package/dist/auth/session_cookie.d.ts +158 -0
  112. package/dist/auth/session_cookie.d.ts.map +1 -0
  113. package/dist/auth/session_cookie.js +135 -0
  114. package/dist/auth/session_lifecycle.d.ts +35 -0
  115. package/dist/auth/session_lifecycle.d.ts.map +1 -0
  116. package/dist/auth/session_lifecycle.js +27 -0
  117. package/dist/auth/session_middleware.d.ts +33 -0
  118. package/dist/auth/session_middleware.d.ts.map +1 -0
  119. package/dist/auth/session_middleware.js +62 -0
  120. package/dist/auth/session_queries.d.ts +135 -0
  121. package/dist/auth/session_queries.d.ts.map +1 -0
  122. package/dist/auth/session_queries.js +186 -0
  123. package/dist/auth/signup_routes.d.ts +32 -0
  124. package/dist/auth/signup_routes.d.ts.map +1 -0
  125. package/dist/auth/signup_routes.js +150 -0
  126. package/dist/cli/args.d.ts +48 -0
  127. package/dist/cli/args.d.ts.map +1 -0
  128. package/dist/cli/args.js +76 -0
  129. package/dist/cli/config.d.ts +48 -0
  130. package/dist/cli/config.d.ts.map +1 -0
  131. package/dist/cli/config.js +77 -0
  132. package/dist/cli/daemon.d.ts +82 -0
  133. package/dist/cli/daemon.d.ts.map +1 -0
  134. package/dist/cli/daemon.js +149 -0
  135. package/dist/cli/help.d.ts +85 -0
  136. package/dist/cli/help.d.ts.map +1 -0
  137. package/dist/cli/help.js +138 -0
  138. package/dist/cli/logger.d.ts +46 -0
  139. package/dist/cli/logger.d.ts.map +1 -0
  140. package/dist/cli/logger.js +48 -0
  141. package/dist/cli/util.d.ts +36 -0
  142. package/dist/cli/util.d.ts.map +1 -0
  143. package/dist/cli/util.js +50 -0
  144. package/dist/crypto.d.ts +13 -0
  145. package/dist/crypto.d.ts.map +1 -0
  146. package/dist/crypto.js +19 -0
  147. package/dist/db/assert_row.d.ts +18 -0
  148. package/dist/db/assert_row.d.ts.map +1 -0
  149. package/dist/db/assert_row.js +24 -0
  150. package/dist/db/create_db.d.ts +38 -0
  151. package/dist/db/create_db.d.ts.map +1 -0
  152. package/dist/db/create_db.js +57 -0
  153. package/dist/db/db.d.ts +97 -0
  154. package/dist/db/db.d.ts.map +1 -0
  155. package/dist/db/db.js +76 -0
  156. package/dist/db/db_pg.d.ts +21 -0
  157. package/dist/db/db_pg.d.ts.map +1 -0
  158. package/dist/db/db_pg.js +45 -0
  159. package/dist/db/db_pglite.d.ts +21 -0
  160. package/dist/db/db_pglite.d.ts.map +1 -0
  161. package/dist/db/db_pglite.js +28 -0
  162. package/dist/db/migrate.d.ts +67 -0
  163. package/dist/db/migrate.d.ts.map +1 -0
  164. package/dist/db/migrate.js +118 -0
  165. package/dist/db/pg_error.d.ts +16 -0
  166. package/dist/db/pg_error.d.ts.map +1 -0
  167. package/dist/db/pg_error.js +15 -0
  168. package/dist/db/query_deps.d.ts +14 -0
  169. package/dist/db/query_deps.d.ts.map +1 -0
  170. package/dist/db/query_deps.js +9 -0
  171. package/dist/db/sql_identifier.d.ts +27 -0
  172. package/dist/db/sql_identifier.d.ts.map +1 -0
  173. package/dist/db/sql_identifier.js +31 -0
  174. package/dist/db/status.d.ts +62 -0
  175. package/dist/db/status.d.ts.map +1 -0
  176. package/dist/db/status.js +116 -0
  177. package/dist/dev/setup.d.ts +159 -0
  178. package/dist/dev/setup.d.ts.map +1 -0
  179. package/dist/dev/setup.js +265 -0
  180. package/dist/env/dotenv.d.ts +25 -0
  181. package/dist/env/dotenv.d.ts.map +1 -0
  182. package/dist/env/dotenv.js +52 -0
  183. package/dist/env/load.d.ts +52 -0
  184. package/dist/env/load.d.ts.map +1 -0
  185. package/dist/env/load.js +79 -0
  186. package/dist/env/mask.d.ts +19 -0
  187. package/dist/env/mask.d.ts.map +1 -0
  188. package/dist/env/mask.js +26 -0
  189. package/dist/env/resolve.d.ts +126 -0
  190. package/dist/env/resolve.d.ts.map +1 -0
  191. package/dist/env/resolve.js +200 -0
  192. package/dist/hono_context.d.ts +48 -0
  193. package/dist/hono_context.d.ts.map +1 -0
  194. package/dist/hono_context.js +22 -0
  195. package/dist/http/common_routes.d.ts +52 -0
  196. package/dist/http/common_routes.d.ts.map +1 -0
  197. package/dist/http/common_routes.js +65 -0
  198. package/dist/http/db_routes.d.ts +57 -0
  199. package/dist/http/db_routes.d.ts.map +1 -0
  200. package/dist/http/db_routes.js +176 -0
  201. package/dist/http/error_schemas.d.ts +169 -0
  202. package/dist/http/error_schemas.d.ts.map +1 -0
  203. package/dist/http/error_schemas.js +178 -0
  204. package/dist/http/middleware_spec.d.ts +19 -0
  205. package/dist/http/middleware_spec.d.ts.map +1 -0
  206. package/dist/http/middleware_spec.js +9 -0
  207. package/dist/http/origin.d.ts +57 -0
  208. package/dist/http/origin.d.ts.map +1 -0
  209. package/dist/http/origin.js +207 -0
  210. package/dist/http/proxy.d.ts +112 -0
  211. package/dist/http/proxy.d.ts.map +1 -0
  212. package/dist/http/proxy.js +240 -0
  213. package/dist/http/route_spec.d.ts +197 -0
  214. package/dist/http/route_spec.d.ts.map +1 -0
  215. package/dist/http/route_spec.js +243 -0
  216. package/dist/http/schema_helpers.d.ts +64 -0
  217. package/dist/http/schema_helpers.d.ts.map +1 -0
  218. package/dist/http/schema_helpers.js +90 -0
  219. package/dist/http/surface.d.ts +132 -0
  220. package/dist/http/surface.d.ts.map +1 -0
  221. package/dist/http/surface.js +156 -0
  222. package/dist/http/surface_query.d.ts +77 -0
  223. package/dist/http/surface_query.d.ts.map +1 -0
  224. package/dist/http/surface_query.js +86 -0
  225. package/dist/rate_limiter.d.ts +94 -0
  226. package/dist/rate_limiter.d.ts.map +1 -0
  227. package/dist/rate_limiter.js +156 -0
  228. package/dist/realtime/sse.d.ts +80 -0
  229. package/dist/realtime/sse.d.ts.map +1 -0
  230. package/dist/realtime/sse.js +109 -0
  231. package/dist/realtime/sse_auth_guard.d.ts +93 -0
  232. package/dist/realtime/sse_auth_guard.d.ts.map +1 -0
  233. package/dist/realtime/sse_auth_guard.js +111 -0
  234. package/dist/realtime/subscriber_registry.d.ts +85 -0
  235. package/dist/realtime/subscriber_registry.d.ts.map +1 -0
  236. package/dist/realtime/subscriber_registry.js +108 -0
  237. package/dist/runtime/deno.d.ts +21 -0
  238. package/dist/runtime/deno.d.ts.map +1 -0
  239. package/dist/runtime/deno.js +83 -0
  240. package/dist/runtime/deps.d.ts +113 -0
  241. package/dist/runtime/deps.d.ts.map +1 -0
  242. package/dist/runtime/deps.js +10 -0
  243. package/dist/runtime/fs.d.ts +15 -0
  244. package/dist/runtime/fs.d.ts.map +1 -0
  245. package/dist/runtime/fs.js +17 -0
  246. package/dist/runtime/mock.d.ts +81 -0
  247. package/dist/runtime/mock.d.ts.map +1 -0
  248. package/dist/runtime/mock.js +195 -0
  249. package/dist/runtime/node.d.ts +17 -0
  250. package/dist/runtime/node.d.ts.map +1 -0
  251. package/dist/runtime/node.js +117 -0
  252. package/dist/schema_meta.d.ts +16 -0
  253. package/dist/schema_meta.d.ts.map +1 -0
  254. package/dist/schema_meta.js +9 -0
  255. package/dist/sensitivity.d.ts +15 -0
  256. package/dist/sensitivity.d.ts.map +1 -0
  257. package/dist/sensitivity.js +9 -0
  258. package/dist/server/app_backend.d.ts +74 -0
  259. package/dist/server/app_backend.d.ts.map +1 -0
  260. package/dist/server/app_backend.js +39 -0
  261. package/dist/server/app_server.d.ts +201 -0
  262. package/dist/server/app_server.d.ts.map +1 -0
  263. package/dist/server/app_server.js +266 -0
  264. package/dist/server/env.d.ts +68 -0
  265. package/dist/server/env.d.ts.map +1 -0
  266. package/dist/server/env.js +95 -0
  267. package/dist/server/startup.d.ts +22 -0
  268. package/dist/server/startup.d.ts.map +1 -0
  269. package/dist/server/startup.js +48 -0
  270. package/dist/server/static.d.ts +39 -0
  271. package/dist/server/static.d.ts.map +1 -0
  272. package/dist/server/static.js +38 -0
  273. package/dist/server/validate_nginx.d.ts +34 -0
  274. package/dist/server/validate_nginx.d.ts.map +1 -0
  275. package/dist/server/validate_nginx.js +118 -0
  276. package/dist/testing/CLAUDE.md +3 -0
  277. package/dist/testing/admin_integration.d.ts +45 -0
  278. package/dist/testing/admin_integration.d.ts.map +1 -0
  279. package/dist/testing/admin_integration.js +840 -0
  280. package/dist/testing/adversarial_404.d.ts +15 -0
  281. package/dist/testing/adversarial_404.d.ts.map +1 -0
  282. package/dist/testing/adversarial_404.js +118 -0
  283. package/dist/testing/adversarial_headers.d.ts +36 -0
  284. package/dist/testing/adversarial_headers.d.ts.map +1 -0
  285. package/dist/testing/adversarial_headers.js +128 -0
  286. package/dist/testing/adversarial_input.d.ts +56 -0
  287. package/dist/testing/adversarial_input.d.ts.map +1 -0
  288. package/dist/testing/adversarial_input.js +494 -0
  289. package/dist/testing/app_server.d.ts +169 -0
  290. package/dist/testing/app_server.d.ts.map +1 -0
  291. package/dist/testing/app_server.js +240 -0
  292. package/dist/testing/assert_dev_env.d.ts +10 -0
  293. package/dist/testing/assert_dev_env.d.ts.map +1 -0
  294. package/dist/testing/assert_dev_env.js +13 -0
  295. package/dist/testing/assertions.d.ts +61 -0
  296. package/dist/testing/assertions.d.ts.map +1 -0
  297. package/dist/testing/assertions.js +96 -0
  298. package/dist/testing/attack_surface.d.ts +63 -0
  299. package/dist/testing/attack_surface.d.ts.map +1 -0
  300. package/dist/testing/attack_surface.js +224 -0
  301. package/dist/testing/audit_completeness.d.ts +29 -0
  302. package/dist/testing/audit_completeness.d.ts.map +1 -0
  303. package/dist/testing/audit_completeness.js +410 -0
  304. package/dist/testing/auth_apps.d.ts +55 -0
  305. package/dist/testing/auth_apps.d.ts.map +1 -0
  306. package/dist/testing/auth_apps.js +122 -0
  307. package/dist/testing/data_exposure.d.ts +62 -0
  308. package/dist/testing/data_exposure.d.ts.map +1 -0
  309. package/dist/testing/data_exposure.js +297 -0
  310. package/dist/testing/db.d.ts +111 -0
  311. package/dist/testing/db.d.ts.map +1 -0
  312. package/dist/testing/db.js +258 -0
  313. package/dist/testing/entities.d.ts +21 -0
  314. package/dist/testing/entities.d.ts.map +1 -0
  315. package/dist/testing/entities.js +42 -0
  316. package/dist/testing/error_coverage.d.ts +78 -0
  317. package/dist/testing/error_coverage.d.ts.map +1 -0
  318. package/dist/testing/error_coverage.js +135 -0
  319. package/dist/testing/integration.d.ts +37 -0
  320. package/dist/testing/integration.d.ts.map +1 -0
  321. package/dist/testing/integration.js +1139 -0
  322. package/dist/testing/integration_helpers.d.ts +107 -0
  323. package/dist/testing/integration_helpers.d.ts.map +1 -0
  324. package/dist/testing/integration_helpers.js +246 -0
  325. package/dist/testing/middleware.d.ts +125 -0
  326. package/dist/testing/middleware.d.ts.map +1 -0
  327. package/dist/testing/middleware.js +210 -0
  328. package/dist/testing/rate_limiting.d.ts +43 -0
  329. package/dist/testing/rate_limiting.d.ts.map +1 -0
  330. package/dist/testing/rate_limiting.js +216 -0
  331. package/dist/testing/round_trip.d.ts +37 -0
  332. package/dist/testing/round_trip.d.ts.map +1 -0
  333. package/dist/testing/round_trip.js +128 -0
  334. package/dist/testing/schema_generators.d.ts +33 -0
  335. package/dist/testing/schema_generators.d.ts.map +1 -0
  336. package/dist/testing/schema_generators.js +137 -0
  337. package/dist/testing/standard.d.ts +49 -0
  338. package/dist/testing/standard.d.ts.map +1 -0
  339. package/dist/testing/standard.js +16 -0
  340. package/dist/testing/stubs.d.ts +96 -0
  341. package/dist/testing/stubs.d.ts.map +1 -0
  342. package/dist/testing/stubs.js +192 -0
  343. package/dist/testing/surface_invariants.d.ts +189 -0
  344. package/dist/testing/surface_invariants.d.ts.map +1 -0
  345. package/dist/testing/surface_invariants.js +450 -0
  346. package/dist/ui/AccountSessions.svelte +75 -0
  347. package/dist/ui/AccountSessions.svelte.d.ts +19 -0
  348. package/dist/ui/AccountSessions.svelte.d.ts.map +1 -0
  349. package/dist/ui/AdminAccounts.svelte +107 -0
  350. package/dist/ui/AdminAccounts.svelte.d.ts +19 -0
  351. package/dist/ui/AdminAccounts.svelte.d.ts.map +1 -0
  352. package/dist/ui/AdminAuditLog.svelte +144 -0
  353. package/dist/ui/AdminAuditLog.svelte.d.ts +4 -0
  354. package/dist/ui/AdminAuditLog.svelte.d.ts.map +1 -0
  355. package/dist/ui/AdminInvites.svelte +142 -0
  356. package/dist/ui/AdminInvites.svelte.d.ts +4 -0
  357. package/dist/ui/AdminInvites.svelte.d.ts.map +1 -0
  358. package/dist/ui/AdminOverview.svelte +337 -0
  359. package/dist/ui/AdminOverview.svelte.d.ts +4 -0
  360. package/dist/ui/AdminOverview.svelte.d.ts.map +1 -0
  361. package/dist/ui/AdminPermitHistory.svelte +61 -0
  362. package/dist/ui/AdminPermitHistory.svelte.d.ts +19 -0
  363. package/dist/ui/AdminPermitHistory.svelte.d.ts.map +1 -0
  364. package/dist/ui/AdminSessions.svelte +85 -0
  365. package/dist/ui/AdminSessions.svelte.d.ts +19 -0
  366. package/dist/ui/AdminSessions.svelte.d.ts.map +1 -0
  367. package/dist/ui/AdminSettings.svelte +32 -0
  368. package/dist/ui/AdminSettings.svelte.d.ts +19 -0
  369. package/dist/ui/AdminSettings.svelte.d.ts.map +1 -0
  370. package/dist/ui/AdminSurface.svelte +42 -0
  371. package/dist/ui/AdminSurface.svelte.d.ts +4 -0
  372. package/dist/ui/AdminSurface.svelte.d.ts.map +1 -0
  373. package/dist/ui/AppShell.svelte +93 -0
  374. package/dist/ui/AppShell.svelte.d.ts +20 -0
  375. package/dist/ui/AppShell.svelte.d.ts.map +1 -0
  376. package/dist/ui/BootstrapForm.svelte +105 -0
  377. package/dist/ui/BootstrapForm.svelte.d.ts +4 -0
  378. package/dist/ui/BootstrapForm.svelte.d.ts.map +1 -0
  379. package/dist/ui/ColumnLayout.svelte +46 -0
  380. package/dist/ui/ColumnLayout.svelte.d.ts +11 -0
  381. package/dist/ui/ColumnLayout.svelte.d.ts.map +1 -0
  382. package/dist/ui/ConfirmButton.svelte +125 -0
  383. package/dist/ui/ConfirmButton.svelte.d.ts +54 -0
  384. package/dist/ui/ConfirmButton.svelte.d.ts.map +1 -0
  385. package/dist/ui/Datatable.svelte +185 -0
  386. package/dist/ui/Datatable.svelte.d.ts +35 -0
  387. package/dist/ui/Datatable.svelte.d.ts.map +1 -0
  388. package/dist/ui/LoginForm.svelte +82 -0
  389. package/dist/ui/LoginForm.svelte.d.ts +8 -0
  390. package/dist/ui/LoginForm.svelte.d.ts.map +1 -0
  391. package/dist/ui/LogoutButton.svelte +36 -0
  392. package/dist/ui/LogoutButton.svelte.d.ts +10 -0
  393. package/dist/ui/LogoutButton.svelte.d.ts.map +1 -0
  394. package/dist/ui/MenuLink.svelte +35 -0
  395. package/dist/ui/MenuLink.svelte.d.ts +12 -0
  396. package/dist/ui/MenuLink.svelte.d.ts.map +1 -0
  397. package/dist/ui/OpenSignupToggle.svelte +36 -0
  398. package/dist/ui/OpenSignupToggle.svelte.d.ts +19 -0
  399. package/dist/ui/OpenSignupToggle.svelte.d.ts.map +1 -0
  400. package/dist/ui/PopoverButton.svelte +136 -0
  401. package/dist/ui/PopoverButton.svelte.d.ts +63 -0
  402. package/dist/ui/PopoverButton.svelte.d.ts.map +1 -0
  403. package/dist/ui/SignupForm.svelte +117 -0
  404. package/dist/ui/SignupForm.svelte.d.ts +7 -0
  405. package/dist/ui/SignupForm.svelte.d.ts.map +1 -0
  406. package/dist/ui/SurfaceExplorer.svelte +287 -0
  407. package/dist/ui/SurfaceExplorer.svelte.d.ts +8 -0
  408. package/dist/ui/SurfaceExplorer.svelte.d.ts.map +1 -0
  409. package/dist/ui/account_sessions_state.svelte.d.ts +15 -0
  410. package/dist/ui/account_sessions_state.svelte.d.ts.map +1 -0
  411. package/dist/ui/account_sessions_state.svelte.js +45 -0
  412. package/dist/ui/admin_accounts_state.svelte.d.ts +19 -0
  413. package/dist/ui/admin_accounts_state.svelte.d.ts.map +1 -0
  414. package/dist/ui/admin_accounts_state.svelte.js +65 -0
  415. package/dist/ui/admin_invites_state.svelte.d.ts +19 -0
  416. package/dist/ui/admin_invites_state.svelte.d.ts.map +1 -0
  417. package/dist/ui/admin_invites_state.svelte.js +71 -0
  418. package/dist/ui/admin_sessions_state.svelte.d.ts +18 -0
  419. package/dist/ui/admin_sessions_state.svelte.d.ts.map +1 -0
  420. package/dist/ui/admin_sessions_state.svelte.js +62 -0
  421. package/dist/ui/app_settings_state.svelte.d.ts +14 -0
  422. package/dist/ui/app_settings_state.svelte.d.ts.map +1 -0
  423. package/dist/ui/app_settings_state.svelte.js +44 -0
  424. package/dist/ui/audit_log_state.svelte.d.ts +40 -0
  425. package/dist/ui/audit_log_state.svelte.d.ts.map +1 -0
  426. package/dist/ui/audit_log_state.svelte.js +153 -0
  427. package/dist/ui/auth_state.svelte.d.ts +85 -0
  428. package/dist/ui/auth_state.svelte.d.ts.map +1 -0
  429. package/dist/ui/auth_state.svelte.js +238 -0
  430. package/dist/ui/datatable.d.ts +25 -0
  431. package/dist/ui/datatable.d.ts.map +1 -0
  432. package/dist/ui/datatable.js +9 -0
  433. package/dist/ui/enter_advance.d.ts +13 -0
  434. package/dist/ui/enter_advance.d.ts.map +1 -0
  435. package/dist/ui/enter_advance.js +30 -0
  436. package/dist/ui/loadable.svelte.d.ts +55 -0
  437. package/dist/ui/loadable.svelte.d.ts.map +1 -0
  438. package/dist/ui/loadable.svelte.js +75 -0
  439. package/dist/ui/popover.svelte.d.ts +137 -0
  440. package/dist/ui/popover.svelte.d.ts.map +1 -0
  441. package/dist/ui/popover.svelte.js +288 -0
  442. package/dist/ui/position_helpers.d.ts +27 -0
  443. package/dist/ui/position_helpers.d.ts.map +1 -0
  444. package/dist/ui/position_helpers.js +81 -0
  445. package/dist/ui/sidebar_state.svelte.d.ts +30 -0
  446. package/dist/ui/sidebar_state.svelte.d.ts.map +1 -0
  447. package/dist/ui/sidebar_state.svelte.js +39 -0
  448. package/dist/ui/table_state.svelte.d.ts +63 -0
  449. package/dist/ui/table_state.svelte.d.ts.map +1 -0
  450. package/dist/ui/table_state.svelte.js +117 -0
  451. package/dist/ui/ui_fetch.d.ts +29 -0
  452. package/dist/ui/ui_fetch.d.ts.map +1 -0
  453. package/dist/ui/ui_fetch.js +37 -0
  454. package/dist/ui/ui_format.d.ts +63 -0
  455. package/dist/ui/ui_format.d.ts.map +1 -0
  456. package/dist/ui/ui_format.js +196 -0
  457. package/package.json +121 -0
@@ -0,0 +1,287 @@
1
+ <script lang="ts">
2
+ import {slide} from 'svelte/transition';
3
+
4
+ import type {AppSurface, AppSurfaceRoute, AppSurfaceDiagnostic} from '../http/surface.js';
5
+ import {surface_auth_summary, format_route_key} from '../http/surface_query.js';
6
+
7
+ interface Props {
8
+ surface: AppSurface;
9
+ }
10
+
11
+ const {surface}: Props = $props();
12
+
13
+ const auth_types = ['all', 'none', 'authenticated', 'role', 'keeper'] as const;
14
+
15
+ let auth_filter: (typeof auth_types)[number] = $state('all');
16
+ let expanded_route: string | null = $state(null);
17
+
18
+ const summary = $derived(surface_auth_summary(surface));
19
+
20
+ const filtered_routes: Array<AppSurfaceRoute> = $derived(
21
+ auth_filter === 'all'
22
+ ? surface.routes
23
+ : surface.routes.filter((r) => r.auth.type === auth_filter),
24
+ );
25
+
26
+ let expanded_event: string | null = $state(null);
27
+
28
+ const toggle_route = (key: string): void => {
29
+ expanded_route = expanded_route === key ? null : key;
30
+ };
31
+
32
+ const toggle_event = (method: string): void => {
33
+ expanded_event = expanded_event === method ? null : method;
34
+ };
35
+
36
+ const format_auth = (auth: AppSurfaceRoute['auth']): string => {
37
+ if (auth.type === 'role') return `role:${auth.role}`;
38
+ return auth.type;
39
+ };
40
+
41
+ const auth_chip_class = (auth: AppSurfaceRoute['auth']): string => {
42
+ switch (auth.type) {
43
+ case 'none':
44
+ return 'chip color_b';
45
+ case 'authenticated':
46
+ return 'chip color_a';
47
+ case 'role':
48
+ return 'chip color_d';
49
+ case 'keeper':
50
+ return 'chip color_c';
51
+ }
52
+ };
53
+
54
+ const role_count = $derived(Array.from(summary.role.values()).reduce((sum, n) => sum + n, 0));
55
+ </script>
56
+
57
+ <section>
58
+ <div class="row" style:gap="var(--space_md)" style:flex-wrap="wrap" style:align-items="center">
59
+ <span class="chip">{surface.routes.length} routes</span>
60
+ {#if summary.none > 0}<span class="chip color_b">{summary.none} public</span>{/if}
61
+ {#if summary.authenticated > 0}<span class="chip color_a"
62
+ >{summary.authenticated} authenticated</span
63
+ >{/if}
64
+ {#if role_count > 0}<span class="chip color_d">{role_count} role</span>{/if}
65
+ {#if summary.keeper > 0}<span class="chip color_c">{summary.keeper} keeper</span>{/if}
66
+ <span class="chip">{surface.middleware.length} middleware</span>
67
+ {#if surface.env.length}<span class="chip">{surface.env.length} env</span>{/if}
68
+ {#if surface.events.length}<span class="chip">{surface.events.length} events</span>{/if}
69
+ {#if surface.diagnostics.length}{@const warnings = surface.diagnostics.filter(
70
+ (d: AppSurfaceDiagnostic) => d.level === 'warning',
71
+ )}{#if warnings.length}<span class="chip color_e"
72
+ >{warnings.length} warning{warnings.length === 1 ? '' : 's'}</span
73
+ >{/if}{/if}
74
+ </div>
75
+
76
+ <h3>routes</h3>
77
+ <div class="mb_sm">
78
+ <label>
79
+ auth filter
80
+ <select bind:value={auth_filter}>
81
+ {#each auth_types as t (t)}
82
+ <option value={t}>{t}</option>
83
+ {/each}
84
+ </select>
85
+ </label>
86
+ </div>
87
+ {#if filtered_routes.length === 0}
88
+ <p class="text_50">no routes match filter</p>
89
+ {:else}
90
+ <div style:overflow-x="auto">
91
+ <table>
92
+ <thead>
93
+ <tr>
94
+ <th>method</th>
95
+ <th>path</th>
96
+ <th>auth</th>
97
+ <th>middleware</th>
98
+ <th>description</th>
99
+ </tr>
100
+ </thead>
101
+ <tbody>
102
+ {#each filtered_routes as route (format_route_key(route))}
103
+ {@const key = format_route_key(route)}
104
+ <tr onclick={() => toggle_route(key)} style:cursor="pointer">
105
+ <td><code>{route.method}</code></td>
106
+ <td><code>{route.path}</code></td>
107
+ <td><span class={auth_chip_class(route.auth)}>{format_auth(route.auth)}</span></td>
108
+ <td class="text_50">{route.applicable_middleware.length}</td>
109
+ <td class="text_50">{route.description}</td>
110
+ </tr>
111
+ {#if expanded_route === key}
112
+ <tr>
113
+ <td colspan="5">
114
+ <div class="column" style:gap="var(--space_sm)">
115
+ {#if route.applicable_middleware.length > 0}
116
+ <div>
117
+ <strong>middleware:</strong>
118
+ {#each route.applicable_middleware as mw (mw)}
119
+ <code class="ml_xs">{mw}</code>
120
+ {/each}
121
+ </div>
122
+ {/if}
123
+ {#if route.params_schema}
124
+ <div>
125
+ <strong>params</strong>
126
+ <pre>{JSON.stringify(route.params_schema, null, 2)}</pre>
127
+ </div>
128
+ {/if}
129
+ {#if route.query_schema}
130
+ <div>
131
+ <strong>query</strong>
132
+ <pre>{JSON.stringify(route.query_schema, null, 2)}</pre>
133
+ </div>
134
+ {/if}
135
+ {#if route.input_schema}
136
+ <div>
137
+ <strong>input</strong>
138
+ <pre>{JSON.stringify(route.input_schema, null, 2)}</pre>
139
+ </div>
140
+ {/if}
141
+ <div>
142
+ <strong>output</strong>
143
+ <pre>{JSON.stringify(route.output_schema, null, 2)}</pre>
144
+ </div>
145
+ {#if route.error_schemas}
146
+ <div>
147
+ <strong>errors</strong>
148
+ <pre>{JSON.stringify(route.error_schemas, null, 2)}</pre>
149
+ </div>
150
+ {/if}
151
+ </div>
152
+ </td>
153
+ </tr>
154
+ {/if}
155
+ {/each}
156
+ </tbody>
157
+ </table>
158
+ </div>
159
+ {/if}
160
+
161
+ <h3>middleware</h3>
162
+ {#if surface.middleware.length === 0}
163
+ <p class="text_50">no middleware</p>
164
+ {:else}
165
+ <div style:overflow-x="auto">
166
+ <table>
167
+ <thead>
168
+ <tr>
169
+ <th>name</th>
170
+ <th>path</th>
171
+ <th>errors</th>
172
+ </tr>
173
+ </thead>
174
+ <tbody>
175
+ {#each surface.middleware as mw (mw.name + mw.path)}
176
+ <tr>
177
+ <td><code>{mw.name}</code></td>
178
+ <td><code>{mw.path}</code></td>
179
+ <td class="text_50"
180
+ >{mw.error_schemas ? Object.keys(mw.error_schemas).join(', ') : '-'}</td
181
+ >
182
+ </tr>
183
+ {/each}
184
+ </tbody>
185
+ </table>
186
+ </div>
187
+ {/if}
188
+
189
+ {#if surface.env.length}
190
+ <h3>environment</h3>
191
+ <div style:overflow-x="auto">
192
+ <table>
193
+ <thead>
194
+ <tr>
195
+ <th>name</th>
196
+ <th>description</th>
197
+ <th>sensitivity</th>
198
+ <th>optional</th>
199
+ <th>has default</th>
200
+ </tr>
201
+ </thead>
202
+ <tbody>
203
+ {#each surface.env as env_var (env_var.name)}
204
+ <tr>
205
+ <td><code>{env_var.name}</code></td>
206
+ <td class="text_50">{env_var.description}</td>
207
+ <td>{env_var.sensitivity ?? 'none'}</td>
208
+ <td>{env_var.optional ? 'yes' : 'no'}</td>
209
+ <td>{env_var.has_default ? 'yes' : 'no'}</td>
210
+ </tr>
211
+ {/each}
212
+ </tbody>
213
+ </table>
214
+ </div>
215
+ {/if}
216
+
217
+ {#if surface.events.length}
218
+ <h3>events</h3>
219
+ <div style:overflow-x="auto">
220
+ <table>
221
+ <thead>
222
+ <tr>
223
+ <th>method</th>
224
+ <th>description</th>
225
+ <th>channel</th>
226
+ <th>params</th>
227
+ </tr>
228
+ </thead>
229
+ <tbody>
230
+ {#each surface.events as event (event.method)}
231
+ <tr onclick={() => toggle_event(event.method)} style:cursor="pointer">
232
+ <td><code>{event.method}</code></td>
233
+ <td class="text_50">{event.description}</td>
234
+ <td>{event.channel ?? '-'}</td>
235
+ <td>
236
+ <!-- TODO fix the `as any` cast -->
237
+ {#if event.params_schema}
238
+ <code
239
+ >{Object.keys(
240
+ (event.params_schema as any).properties ?? event.params_schema,
241
+ ).join(', ')}</code
242
+ >
243
+ {:else}
244
+ <span class="text_50">none</span>
245
+ {/if}
246
+ </td>
247
+ </tr>
248
+ {#if expanded_event === event.method}
249
+ <tr transition:slide>
250
+ <td colspan="4">
251
+ <pre>{JSON.stringify(event.params_schema, null, 2)}</pre>
252
+ </td>
253
+ </tr>
254
+ {/if}
255
+ {/each}
256
+ </tbody>
257
+ </table>
258
+ </div>
259
+ {/if}
260
+
261
+ {#if surface.diagnostics.length}
262
+ <h3>diagnostics</h3>
263
+ <div style:overflow-x="auto">
264
+ <table>
265
+ <thead>
266
+ <tr>
267
+ <th>level</th>
268
+ <th>category</th>
269
+ <th>message</th>
270
+ <th>source</th>
271
+ </tr>
272
+ </thead>
273
+ <tbody>
274
+ {#each surface.diagnostics as d, i (i)}
275
+ <tr>
276
+ <td><span class={d.level === 'warning' ? 'chip color_e' : 'chip'}>{d.level}</span></td
277
+ >
278
+ <td><code>{d.category}</code></td>
279
+ <td>{d.message}</td>
280
+ <td class="text_50">{d.source ?? '-'}</td>
281
+ </tr>
282
+ {/each}
283
+ </tbody>
284
+ </table>
285
+ </div>
286
+ {/if}
287
+ </section>
@@ -0,0 +1,8 @@
1
+ import type { AppSurface } from '../http/surface.js';
2
+ interface Props {
3
+ surface: AppSurface;
4
+ }
5
+ declare const SurfaceExplorer: import("svelte").Component<Props, {}, "">;
6
+ type SurfaceExplorer = ReturnType<typeof SurfaceExplorer>;
7
+ export default SurfaceExplorer;
8
+ //# sourceMappingURL=SurfaceExplorer.svelte.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SurfaceExplorer.svelte.d.ts","sourceRoot":"../src/lib/","sources":["../../src/lib/ui/SurfaceExplorer.svelte"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAC,UAAU,EAAwC,MAAM,oBAAoB,CAAC;AAIzF,UAAU,KAAK;IACd,OAAO,EAAE,UAAU,CAAC;CACpB;AAuRF,QAAA,MAAM,eAAe,2CAAwC,CAAC;AAC9D,KAAK,eAAe,GAAG,UAAU,CAAC,OAAO,eAAe,CAAC,CAAC;AAC1D,eAAe,eAAe,CAAC"}
@@ -0,0 +1,15 @@
1
+ /**
2
+ * Reactive state for managing auth sessions on a settings page.
3
+ *
4
+ * @module
5
+ */
6
+ import { Loadable } from './loadable.svelte.js';
7
+ import type { AuthSession } from '../auth/account_schema.js';
8
+ export declare class AccountSessionsState extends Loadable {
9
+ sessions: Array<AuthSession>;
10
+ readonly active_count: number;
11
+ fetch(): Promise<void>;
12
+ revoke(id: string): Promise<void>;
13
+ revoke_all(): Promise<void>;
14
+ }
15
+ //# sourceMappingURL=account_sessions_state.svelte.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"account_sessions_state.svelte.d.ts","sourceRoot":"../src/lib/","sources":["../../src/lib/ui/account_sessions_state.svelte.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAC,QAAQ,EAAC,MAAM,sBAAsB,CAAC;AAE9C,OAAO,KAAK,EAAC,WAAW,EAAC,MAAM,2BAA2B,CAAC;AAE3D,qBAAa,oBAAqB,SAAQ,QAAQ;IACjD,QAAQ,EAAE,KAAK,CAAC,WAAW,CAAC,CAAc;IAE1C,QAAQ,CAAC,YAAY,SAAkC;IAEjD,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAWtB,MAAM,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAYjC,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;CAajC"}
@@ -0,0 +1,45 @@
1
+ /**
2
+ * Reactive state for managing auth sessions on a settings page.
3
+ *
4
+ * @module
5
+ */
6
+ import { Loadable } from './loadable.svelte.js';
7
+ import { parse_response_error, ui_fetch } from './ui_fetch.js';
8
+ export class AccountSessionsState extends Loadable {
9
+ sessions = $state([]);
10
+ active_count = $derived(this.sessions.length);
11
+ async fetch() {
12
+ await this.run(async () => {
13
+ const response = await ui_fetch('/api/account/sessions');
14
+ if (!response.ok) {
15
+ throw new Error(await parse_response_error(response, 'Failed to fetch sessions'));
16
+ }
17
+ const data = await response.json();
18
+ this.sessions = data.sessions ?? [];
19
+ });
20
+ }
21
+ async revoke(id) {
22
+ await this.run(async () => {
23
+ const response = await ui_fetch(`/api/account/sessions/${id}/revoke`, { method: 'POST' });
24
+ if (!response.ok) {
25
+ throw new Error(await parse_response_error(response, 'Failed to revoke session'));
26
+ }
27
+ });
28
+ if (!this.error) {
29
+ await this.fetch();
30
+ }
31
+ }
32
+ async revoke_all() {
33
+ await this.run(async () => {
34
+ const response = await ui_fetch('/api/account/sessions/revoke-all', { method: 'POST' });
35
+ if (!response.ok) {
36
+ throw new Error(await parse_response_error(response, 'Failed to revoke sessions'));
37
+ }
38
+ });
39
+ if (!this.error) {
40
+ // Current session is now revoked — next API call will 401.
41
+ // Clear local state so the UI shows the login page.
42
+ this.sessions = [];
43
+ }
44
+ }
45
+ }
@@ -0,0 +1,19 @@
1
+ /**
2
+ * Reactive state for admin account management.
3
+ *
4
+ * @module
5
+ */
6
+ import { SvelteSet } from 'svelte/reactivity';
7
+ import { Loadable } from './loadable.svelte.js';
8
+ import type { AdminAccountEntryJson } from '../auth/account_schema.js';
9
+ export declare class AdminAccountsState extends Loadable {
10
+ accounts: Array<AdminAccountEntryJson>;
11
+ grantable_roles: Array<string>;
12
+ readonly granting_keys: SvelteSet<string>;
13
+ readonly revoking_ids: SvelteSet<string>;
14
+ readonly account_count: number;
15
+ fetch(): Promise<void>;
16
+ grant_permit(account_id: string, role: string): Promise<void>;
17
+ revoke_permit(account_id: string, permit_id: string): Promise<void>;
18
+ }
19
+ //# sourceMappingURL=admin_accounts_state.svelte.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"admin_accounts_state.svelte.d.ts","sourceRoot":"../src/lib/","sources":["../../src/lib/ui/admin_accounts_state.svelte.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAC,SAAS,EAAC,MAAM,mBAAmB,CAAC;AAE5C,OAAO,EAAC,QAAQ,EAAC,MAAM,sBAAsB,CAAC;AAE9C,OAAO,KAAK,EAAC,qBAAqB,EAAC,MAAM,2BAA2B,CAAC;AAErE,qBAAa,kBAAmB,SAAQ,QAAQ;IAC/C,QAAQ,EAAE,KAAK,CAAC,qBAAqB,CAAC,CAAc;IACpD,eAAe,EAAE,KAAK,CAAC,MAAM,CAAC,CAAc;IAC5C,QAAQ,CAAC,aAAa,EAAE,SAAS,CAAC,MAAM,CAAC,CAAmB;IAC5D,QAAQ,CAAC,YAAY,EAAE,SAAS,CAAC,MAAM,CAAC,CAAmB;IAE3D,QAAQ,CAAC,aAAa,SAAkC;IAElD,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAYtB,YAAY,CAAC,UAAU,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAqB7D,aAAa,CAAC,UAAU,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAkBzE"}
@@ -0,0 +1,65 @@
1
+ /**
2
+ * Reactive state for admin account management.
3
+ *
4
+ * @module
5
+ */
6
+ import { SvelteSet } from 'svelte/reactivity';
7
+ import { Loadable } from './loadable.svelte.js';
8
+ import { parse_response_error, ui_fetch } from './ui_fetch.js';
9
+ export class AdminAccountsState extends Loadable {
10
+ accounts = $state([]);
11
+ grantable_roles = $state([]);
12
+ granting_keys = new SvelteSet();
13
+ revoking_ids = new SvelteSet();
14
+ account_count = $derived(this.accounts.length);
15
+ async fetch() {
16
+ await this.run(async () => {
17
+ const response = await ui_fetch('/api/admin/accounts');
18
+ if (!response.ok) {
19
+ throw new Error(await parse_response_error(response, 'Failed to fetch accounts'));
20
+ }
21
+ const data = await response.json();
22
+ this.accounts = data.accounts ?? [];
23
+ this.grantable_roles = data.grantable_roles ?? [];
24
+ });
25
+ }
26
+ async grant_permit(account_id, role) {
27
+ const key = `${account_id}:${role}`;
28
+ this.granting_keys.add(key);
29
+ try {
30
+ const response = await ui_fetch(`/api/admin/accounts/${account_id}/permits/grant`, {
31
+ method: 'POST',
32
+ headers: { 'Content-Type': 'application/json' },
33
+ body: JSON.stringify({ role }),
34
+ });
35
+ if (!response.ok) {
36
+ this.error = await parse_response_error(response);
37
+ return;
38
+ }
39
+ await this.fetch();
40
+ }
41
+ catch (e) {
42
+ this.error = e instanceof Error ? e.message : 'Failed to grant permit';
43
+ }
44
+ finally {
45
+ this.granting_keys.delete(key);
46
+ }
47
+ }
48
+ async revoke_permit(account_id, permit_id) {
49
+ this.revoking_ids.add(permit_id);
50
+ try {
51
+ const response = await ui_fetch(`/api/admin/accounts/${account_id}/permits/${permit_id}/revoke`, { method: 'POST' });
52
+ if (!response.ok) {
53
+ this.error = await parse_response_error(response);
54
+ return;
55
+ }
56
+ await this.fetch();
57
+ }
58
+ catch (e) {
59
+ this.error = e instanceof Error ? e.message : 'Failed to revoke permit';
60
+ }
61
+ finally {
62
+ this.revoking_ids.delete(permit_id);
63
+ }
64
+ }
65
+ }
@@ -0,0 +1,19 @@
1
+ /**
2
+ * Reactive state for admin invite management.
3
+ *
4
+ * @module
5
+ */
6
+ import { SvelteSet } from 'svelte/reactivity';
7
+ import { Loadable } from './loadable.svelte.js';
8
+ import type { InviteWithUsernamesJson } from '../auth/invite_schema.js';
9
+ export declare class AdminInvitesState extends Loadable {
10
+ invites: Array<InviteWithUsernamesJson>;
11
+ creating: boolean;
12
+ readonly deleting_ids: SvelteSet<string>;
13
+ readonly invite_count: number;
14
+ readonly unclaimed_count: number;
15
+ fetch(): Promise<void>;
16
+ create_invite(email?: string, username?: string): Promise<boolean>;
17
+ delete_invite(id: string): Promise<void>;
18
+ }
19
+ //# sourceMappingURL=admin_invites_state.svelte.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"admin_invites_state.svelte.d.ts","sourceRoot":"../src/lib/","sources":["../../src/lib/ui/admin_invites_state.svelte.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAC,SAAS,EAAC,MAAM,mBAAmB,CAAC;AAE5C,OAAO,EAAC,QAAQ,EAAC,MAAM,sBAAsB,CAAC;AAE9C,OAAO,KAAK,EAAC,uBAAuB,EAAC,MAAM,0BAA0B,CAAC;AAEtE,qBAAa,iBAAkB,SAAQ,QAAQ;IAC9C,OAAO,EAAE,KAAK,CAAC,uBAAuB,CAAC,CAAc;IACrD,QAAQ,UAAiB;IACzB,QAAQ,CAAC,YAAY,EAAE,SAAS,CAAC,MAAM,CAAC,CAAmB;IAE3D,QAAQ,CAAC,YAAY,SAAiC;IACtD,QAAQ,CAAC,eAAe,SAA8D;IAEhF,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAWtB,aAAa,CAAC,KAAK,CAAC,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IA2BlE,aAAa,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAe9C"}
@@ -0,0 +1,71 @@
1
+ /**
2
+ * Reactive state for admin invite management.
3
+ *
4
+ * @module
5
+ */
6
+ import { SvelteSet } from 'svelte/reactivity';
7
+ import { Loadable } from './loadable.svelte.js';
8
+ import { parse_response_error, ui_fetch } from './ui_fetch.js';
9
+ export class AdminInvitesState extends Loadable {
10
+ invites = $state([]);
11
+ creating = $state(false);
12
+ deleting_ids = new SvelteSet();
13
+ invite_count = $derived(this.invites.length);
14
+ unclaimed_count = $derived(this.invites.filter((i) => !i.claimed_at).length);
15
+ async fetch() {
16
+ await this.run(async () => {
17
+ const response = await ui_fetch('/api/admin/invites');
18
+ if (!response.ok) {
19
+ throw new Error(await parse_response_error(response, 'Failed to fetch invites'));
20
+ }
21
+ const data = await response.json();
22
+ this.invites = data.invites ?? [];
23
+ });
24
+ }
25
+ async create_invite(email, username) {
26
+ this.creating = true;
27
+ this.error = null;
28
+ try {
29
+ const body = {};
30
+ if (email)
31
+ body.email = email;
32
+ if (username)
33
+ body.username = username;
34
+ const response = await ui_fetch('/api/admin/invites', {
35
+ method: 'POST',
36
+ headers: { 'Content-Type': 'application/json' },
37
+ body: JSON.stringify(body),
38
+ });
39
+ if (!response.ok) {
40
+ this.error = await parse_response_error(response);
41
+ return false;
42
+ }
43
+ await this.fetch();
44
+ return true;
45
+ }
46
+ catch (e) {
47
+ this.error = e instanceof Error ? e.message : 'Failed to create invite';
48
+ return false;
49
+ }
50
+ finally {
51
+ this.creating = false;
52
+ }
53
+ }
54
+ async delete_invite(id) {
55
+ this.deleting_ids.add(id);
56
+ try {
57
+ const response = await ui_fetch(`/api/admin/invites/${id}`, { method: 'DELETE' });
58
+ if (!response.ok) {
59
+ this.error = await parse_response_error(response);
60
+ return;
61
+ }
62
+ await this.fetch();
63
+ }
64
+ catch (e) {
65
+ this.error = e instanceof Error ? e.message : 'Failed to delete invite';
66
+ }
67
+ finally {
68
+ this.deleting_ids.delete(id);
69
+ }
70
+ }
71
+ }
@@ -0,0 +1,18 @@
1
+ /**
2
+ * Reactive state for admin session overview.
3
+ *
4
+ * @module
5
+ */
6
+ import { SvelteSet } from 'svelte/reactivity';
7
+ import { Loadable } from './loadable.svelte.js';
8
+ import type { AdminSessionJson } from '../auth/audit_log_schema.js';
9
+ export declare class AdminSessionsState extends Loadable {
10
+ sessions: Array<AdminSessionJson>;
11
+ readonly revoking_account_ids: SvelteSet<string>;
12
+ readonly revoking_token_account_ids: SvelteSet<string>;
13
+ readonly active_count: number;
14
+ fetch(): Promise<void>;
15
+ revoke_all_for_account(account_id: string): Promise<void>;
16
+ revoke_all_tokens_for_account(account_id: string): Promise<void>;
17
+ }
18
+ //# sourceMappingURL=admin_sessions_state.svelte.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"admin_sessions_state.svelte.d.ts","sourceRoot":"../src/lib/","sources":["../../src/lib/ui/admin_sessions_state.svelte.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAC,SAAS,EAAC,MAAM,mBAAmB,CAAC;AAE5C,OAAO,EAAC,QAAQ,EAAC,MAAM,sBAAsB,CAAC;AAE9C,OAAO,KAAK,EAAC,gBAAgB,EAAC,MAAM,6BAA6B,CAAC;AAElE,qBAAa,kBAAmB,SAAQ,QAAQ;IAC/C,QAAQ,EAAE,KAAK,CAAC,gBAAgB,CAAC,CAAc;IAC/C,QAAQ,CAAC,oBAAoB,EAAE,SAAS,CAAC,MAAM,CAAC,CAAmB;IACnE,QAAQ,CAAC,0BAA0B,EAAE,SAAS,CAAC,MAAM,CAAC,CAAmB;IAEzE,QAAQ,CAAC,YAAY,SAAkC;IAEjD,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAWtB,sBAAsB,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAkBzD,6BAA6B,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAiBtE"}
@@ -0,0 +1,62 @@
1
+ /**
2
+ * Reactive state for admin session overview.
3
+ *
4
+ * @module
5
+ */
6
+ import { SvelteSet } from 'svelte/reactivity';
7
+ import { Loadable } from './loadable.svelte.js';
8
+ import { parse_response_error, ui_fetch } from './ui_fetch.js';
9
+ export class AdminSessionsState extends Loadable {
10
+ sessions = $state([]);
11
+ revoking_account_ids = new SvelteSet();
12
+ revoking_token_account_ids = new SvelteSet();
13
+ active_count = $derived(this.sessions.length);
14
+ async fetch() {
15
+ await this.run(async () => {
16
+ const response = await ui_fetch('/api/admin/sessions');
17
+ if (!response.ok) {
18
+ throw new Error(await parse_response_error(response, 'Failed to fetch sessions'));
19
+ }
20
+ const data = await response.json();
21
+ this.sessions = data.sessions ?? [];
22
+ });
23
+ }
24
+ async revoke_all_for_account(account_id) {
25
+ this.revoking_account_ids.add(account_id);
26
+ try {
27
+ const response = await ui_fetch(`/api/admin/accounts/${account_id}/sessions/revoke-all`, {
28
+ method: 'POST',
29
+ });
30
+ if (!response.ok) {
31
+ this.error = await parse_response_error(response);
32
+ return;
33
+ }
34
+ await this.fetch();
35
+ }
36
+ catch (e) {
37
+ this.error = e instanceof Error ? e.message : 'Failed to revoke sessions';
38
+ }
39
+ finally {
40
+ this.revoking_account_ids.delete(account_id);
41
+ }
42
+ }
43
+ async revoke_all_tokens_for_account(account_id) {
44
+ this.revoking_token_account_ids.add(account_id);
45
+ try {
46
+ const response = await ui_fetch(`/api/admin/accounts/${account_id}/tokens/revoke-all`, {
47
+ method: 'POST',
48
+ });
49
+ if (!response.ok) {
50
+ this.error = await parse_response_error(response);
51
+ return;
52
+ }
53
+ await this.fetch();
54
+ }
55
+ catch (e) {
56
+ this.error = e instanceof Error ? e.message : 'Failed to revoke tokens';
57
+ }
58
+ finally {
59
+ this.revoking_token_account_ids.delete(account_id);
60
+ }
61
+ }
62
+ }
@@ -0,0 +1,14 @@
1
+ /**
2
+ * Reactive state for admin app settings management.
3
+ *
4
+ * @module
5
+ */
6
+ import { Loadable } from './loadable.svelte.js';
7
+ import type { AppSettingsWithUsernameJson } from '../auth/app_settings_schema.js';
8
+ export declare class AppSettingsState extends Loadable {
9
+ settings: AppSettingsWithUsernameJson | null;
10
+ updating: boolean;
11
+ fetch(): Promise<void>;
12
+ update_open_signup(value: boolean): Promise<void>;
13
+ }
14
+ //# sourceMappingURL=app_settings_state.svelte.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"app_settings_state.svelte.d.ts","sourceRoot":"../src/lib/","sources":["../../src/lib/ui/app_settings_state.svelte.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAC,QAAQ,EAAC,MAAM,sBAAsB,CAAC;AAE9C,OAAO,KAAK,EAAC,2BAA2B,EAAC,MAAM,gCAAgC,CAAC;AAEhF,qBAAa,gBAAiB,SAAQ,QAAQ;IAC7C,QAAQ,EAAE,2BAA2B,GAAG,IAAI,CAAgB;IAC5D,QAAQ,UAAiB;IAEnB,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAWtB,kBAAkB,CAAC,KAAK,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;CAqBvD"}