@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.
- package/LICENSE +21 -0
- package/README.md +49 -0
- package/dist/actions/action_bridge.d.ts +65 -0
- package/dist/actions/action_bridge.d.ts.map +1 -0
- package/dist/actions/action_bridge.js +76 -0
- package/dist/actions/action_codegen.d.ts +97 -0
- package/dist/actions/action_codegen.d.ts.map +1 -0
- package/dist/actions/action_codegen.js +280 -0
- package/dist/actions/action_registry.d.ts +35 -0
- package/dist/actions/action_registry.d.ts.map +1 -0
- package/dist/actions/action_registry.js +83 -0
- package/dist/actions/action_spec.d.ts +169 -0
- package/dist/actions/action_spec.d.ts.map +1 -0
- package/dist/actions/action_spec.js +76 -0
- package/dist/auth/account_queries.d.ts +96 -0
- package/dist/auth/account_queries.d.ts.map +1 -0
- package/dist/auth/account_queries.js +172 -0
- package/dist/auth/account_routes.d.ts +86 -0
- package/dist/auth/account_routes.d.ts.map +1 -0
- package/dist/auth/account_routes.js +406 -0
- package/dist/auth/account_schema.d.ts +192 -0
- package/dist/auth/account_schema.d.ts.map +1 -0
- package/dist/auth/account_schema.js +105 -0
- package/dist/auth/admin_routes.d.ts +29 -0
- package/dist/auth/admin_routes.d.ts.map +1 -0
- package/dist/auth/admin_routes.js +193 -0
- package/dist/auth/api_token.d.ts +33 -0
- package/dist/auth/api_token.d.ts.map +1 -0
- package/dist/auth/api_token.js +36 -0
- package/dist/auth/api_token_queries.d.ts +80 -0
- package/dist/auth/api_token_queries.d.ts.map +1 -0
- package/dist/auth/api_token_queries.js +116 -0
- package/dist/auth/app_settings_queries.d.ts +33 -0
- package/dist/auth/app_settings_queries.d.ts.map +1 -0
- package/dist/auth/app_settings_queries.js +51 -0
- package/dist/auth/app_settings_routes.d.ts +27 -0
- package/dist/auth/app_settings_routes.d.ts.map +1 -0
- package/dist/auth/app_settings_routes.js +66 -0
- package/dist/auth/app_settings_schema.d.ts +35 -0
- package/dist/auth/app_settings_schema.d.ts.map +1 -0
- package/dist/auth/app_settings_schema.js +22 -0
- package/dist/auth/audit_log_queries.d.ts +90 -0
- package/dist/auth/audit_log_queries.d.ts.map +1 -0
- package/dist/auth/audit_log_queries.js +205 -0
- package/dist/auth/audit_log_routes.d.ts +33 -0
- package/dist/auth/audit_log_routes.d.ts.map +1 -0
- package/dist/auth/audit_log_routes.js +106 -0
- package/dist/auth/audit_log_schema.d.ts +259 -0
- package/dist/auth/audit_log_schema.d.ts.map +1 -0
- package/dist/auth/audit_log_schema.js +123 -0
- package/dist/auth/bearer_auth.d.ts +32 -0
- package/dist/auth/bearer_auth.d.ts.map +1 -0
- package/dist/auth/bearer_auth.js +90 -0
- package/dist/auth/bootstrap_account.d.ts +82 -0
- package/dist/auth/bootstrap_account.d.ts.map +1 -0
- package/dist/auth/bootstrap_account.js +97 -0
- package/dist/auth/bootstrap_routes.d.ts +74 -0
- package/dist/auth/bootstrap_routes.d.ts.map +1 -0
- package/dist/auth/bootstrap_routes.js +154 -0
- package/dist/auth/daemon_token.d.ts +49 -0
- package/dist/auth/daemon_token.d.ts.map +1 -0
- package/dist/auth/daemon_token.js +49 -0
- package/dist/auth/daemon_token_middleware.d.ts +93 -0
- package/dist/auth/daemon_token_middleware.d.ts.map +1 -0
- package/dist/auth/daemon_token_middleware.js +167 -0
- package/dist/auth/ddl.d.ts +27 -0
- package/dist/auth/ddl.d.ts.map +1 -0
- package/dist/auth/ddl.js +111 -0
- package/dist/auth/deps.d.ts +52 -0
- package/dist/auth/deps.d.ts.map +1 -0
- package/dist/auth/deps.js +10 -0
- package/dist/auth/invite_queries.d.ts +68 -0
- package/dist/auth/invite_queries.d.ts.map +1 -0
- package/dist/auth/invite_queries.js +105 -0
- package/dist/auth/invite_routes.d.ts +18 -0
- package/dist/auth/invite_routes.d.ts.map +1 -0
- package/dist/auth/invite_routes.js +129 -0
- package/dist/auth/invite_schema.d.ts +51 -0
- package/dist/auth/invite_schema.d.ts.map +1 -0
- package/dist/auth/invite_schema.js +25 -0
- package/dist/auth/keyring.d.ts +87 -0
- package/dist/auth/keyring.d.ts.map +1 -0
- package/dist/auth/keyring.js +142 -0
- package/dist/auth/middleware.d.ts +40 -0
- package/dist/auth/middleware.d.ts.map +1 -0
- package/dist/auth/middleware.js +64 -0
- package/dist/auth/migrations.d.ts +42 -0
- package/dist/auth/migrations.d.ts.map +1 -0
- package/dist/auth/migrations.js +79 -0
- package/dist/auth/password.d.ts +39 -0
- package/dist/auth/password.d.ts.map +1 -0
- package/dist/auth/password.js +25 -0
- package/dist/auth/password_argon2.d.ts +43 -0
- package/dist/auth/password_argon2.d.ts.map +1 -0
- package/dist/auth/password_argon2.js +76 -0
- package/dist/auth/permit_queries.d.ts +72 -0
- package/dist/auth/permit_queries.d.ts.map +1 -0
- package/dist/auth/permit_queries.js +116 -0
- package/dist/auth/request_context.d.ts +114 -0
- package/dist/auth/request_context.d.ts.map +1 -0
- package/dist/auth/request_context.js +176 -0
- package/dist/auth/require_keeper.d.ts +20 -0
- package/dist/auth/require_keeper.d.ts.map +1 -0
- package/dist/auth/require_keeper.js +35 -0
- package/dist/auth/role_schema.d.ts +69 -0
- package/dist/auth/role_schema.d.ts.map +1 -0
- package/dist/auth/role_schema.js +70 -0
- package/dist/auth/route_guards.d.ts +21 -0
- package/dist/auth/route_guards.d.ts.map +1 -0
- package/dist/auth/route_guards.js +32 -0
- package/dist/auth/session_cookie.d.ts +158 -0
- package/dist/auth/session_cookie.d.ts.map +1 -0
- package/dist/auth/session_cookie.js +135 -0
- package/dist/auth/session_lifecycle.d.ts +35 -0
- package/dist/auth/session_lifecycle.d.ts.map +1 -0
- package/dist/auth/session_lifecycle.js +27 -0
- package/dist/auth/session_middleware.d.ts +33 -0
- package/dist/auth/session_middleware.d.ts.map +1 -0
- package/dist/auth/session_middleware.js +62 -0
- package/dist/auth/session_queries.d.ts +135 -0
- package/dist/auth/session_queries.d.ts.map +1 -0
- package/dist/auth/session_queries.js +186 -0
- package/dist/auth/signup_routes.d.ts +32 -0
- package/dist/auth/signup_routes.d.ts.map +1 -0
- package/dist/auth/signup_routes.js +150 -0
- package/dist/cli/args.d.ts +48 -0
- package/dist/cli/args.d.ts.map +1 -0
- package/dist/cli/args.js +76 -0
- package/dist/cli/config.d.ts +48 -0
- package/dist/cli/config.d.ts.map +1 -0
- package/dist/cli/config.js +77 -0
- package/dist/cli/daemon.d.ts +82 -0
- package/dist/cli/daemon.d.ts.map +1 -0
- package/dist/cli/daemon.js +149 -0
- package/dist/cli/help.d.ts +85 -0
- package/dist/cli/help.d.ts.map +1 -0
- package/dist/cli/help.js +138 -0
- package/dist/cli/logger.d.ts +46 -0
- package/dist/cli/logger.d.ts.map +1 -0
- package/dist/cli/logger.js +48 -0
- package/dist/cli/util.d.ts +36 -0
- package/dist/cli/util.d.ts.map +1 -0
- package/dist/cli/util.js +50 -0
- package/dist/crypto.d.ts +13 -0
- package/dist/crypto.d.ts.map +1 -0
- package/dist/crypto.js +19 -0
- package/dist/db/assert_row.d.ts +18 -0
- package/dist/db/assert_row.d.ts.map +1 -0
- package/dist/db/assert_row.js +24 -0
- package/dist/db/create_db.d.ts +38 -0
- package/dist/db/create_db.d.ts.map +1 -0
- package/dist/db/create_db.js +57 -0
- package/dist/db/db.d.ts +97 -0
- package/dist/db/db.d.ts.map +1 -0
- package/dist/db/db.js +76 -0
- package/dist/db/db_pg.d.ts +21 -0
- package/dist/db/db_pg.d.ts.map +1 -0
- package/dist/db/db_pg.js +45 -0
- package/dist/db/db_pglite.d.ts +21 -0
- package/dist/db/db_pglite.d.ts.map +1 -0
- package/dist/db/db_pglite.js +28 -0
- package/dist/db/migrate.d.ts +67 -0
- package/dist/db/migrate.d.ts.map +1 -0
- package/dist/db/migrate.js +118 -0
- package/dist/db/pg_error.d.ts +16 -0
- package/dist/db/pg_error.d.ts.map +1 -0
- package/dist/db/pg_error.js +15 -0
- package/dist/db/query_deps.d.ts +14 -0
- package/dist/db/query_deps.d.ts.map +1 -0
- package/dist/db/query_deps.js +9 -0
- package/dist/db/sql_identifier.d.ts +27 -0
- package/dist/db/sql_identifier.d.ts.map +1 -0
- package/dist/db/sql_identifier.js +31 -0
- package/dist/db/status.d.ts +62 -0
- package/dist/db/status.d.ts.map +1 -0
- package/dist/db/status.js +116 -0
- package/dist/dev/setup.d.ts +159 -0
- package/dist/dev/setup.d.ts.map +1 -0
- package/dist/dev/setup.js +265 -0
- package/dist/env/dotenv.d.ts +25 -0
- package/dist/env/dotenv.d.ts.map +1 -0
- package/dist/env/dotenv.js +52 -0
- package/dist/env/load.d.ts +52 -0
- package/dist/env/load.d.ts.map +1 -0
- package/dist/env/load.js +79 -0
- package/dist/env/mask.d.ts +19 -0
- package/dist/env/mask.d.ts.map +1 -0
- package/dist/env/mask.js +26 -0
- package/dist/env/resolve.d.ts +126 -0
- package/dist/env/resolve.d.ts.map +1 -0
- package/dist/env/resolve.js +200 -0
- package/dist/hono_context.d.ts +48 -0
- package/dist/hono_context.d.ts.map +1 -0
- package/dist/hono_context.js +22 -0
- package/dist/http/common_routes.d.ts +52 -0
- package/dist/http/common_routes.d.ts.map +1 -0
- package/dist/http/common_routes.js +65 -0
- package/dist/http/db_routes.d.ts +57 -0
- package/dist/http/db_routes.d.ts.map +1 -0
- package/dist/http/db_routes.js +176 -0
- package/dist/http/error_schemas.d.ts +169 -0
- package/dist/http/error_schemas.d.ts.map +1 -0
- package/dist/http/error_schemas.js +178 -0
- package/dist/http/middleware_spec.d.ts +19 -0
- package/dist/http/middleware_spec.d.ts.map +1 -0
- package/dist/http/middleware_spec.js +9 -0
- package/dist/http/origin.d.ts +57 -0
- package/dist/http/origin.d.ts.map +1 -0
- package/dist/http/origin.js +207 -0
- package/dist/http/proxy.d.ts +112 -0
- package/dist/http/proxy.d.ts.map +1 -0
- package/dist/http/proxy.js +240 -0
- package/dist/http/route_spec.d.ts +197 -0
- package/dist/http/route_spec.d.ts.map +1 -0
- package/dist/http/route_spec.js +243 -0
- package/dist/http/schema_helpers.d.ts +64 -0
- package/dist/http/schema_helpers.d.ts.map +1 -0
- package/dist/http/schema_helpers.js +90 -0
- package/dist/http/surface.d.ts +132 -0
- package/dist/http/surface.d.ts.map +1 -0
- package/dist/http/surface.js +156 -0
- package/dist/http/surface_query.d.ts +77 -0
- package/dist/http/surface_query.d.ts.map +1 -0
- package/dist/http/surface_query.js +86 -0
- package/dist/rate_limiter.d.ts +94 -0
- package/dist/rate_limiter.d.ts.map +1 -0
- package/dist/rate_limiter.js +156 -0
- package/dist/realtime/sse.d.ts +80 -0
- package/dist/realtime/sse.d.ts.map +1 -0
- package/dist/realtime/sse.js +109 -0
- package/dist/realtime/sse_auth_guard.d.ts +93 -0
- package/dist/realtime/sse_auth_guard.d.ts.map +1 -0
- package/dist/realtime/sse_auth_guard.js +111 -0
- package/dist/realtime/subscriber_registry.d.ts +85 -0
- package/dist/realtime/subscriber_registry.d.ts.map +1 -0
- package/dist/realtime/subscriber_registry.js +108 -0
- package/dist/runtime/deno.d.ts +21 -0
- package/dist/runtime/deno.d.ts.map +1 -0
- package/dist/runtime/deno.js +83 -0
- package/dist/runtime/deps.d.ts +113 -0
- package/dist/runtime/deps.d.ts.map +1 -0
- package/dist/runtime/deps.js +10 -0
- package/dist/runtime/fs.d.ts +15 -0
- package/dist/runtime/fs.d.ts.map +1 -0
- package/dist/runtime/fs.js +17 -0
- package/dist/runtime/mock.d.ts +81 -0
- package/dist/runtime/mock.d.ts.map +1 -0
- package/dist/runtime/mock.js +195 -0
- package/dist/runtime/node.d.ts +17 -0
- package/dist/runtime/node.d.ts.map +1 -0
- package/dist/runtime/node.js +117 -0
- package/dist/schema_meta.d.ts +16 -0
- package/dist/schema_meta.d.ts.map +1 -0
- package/dist/schema_meta.js +9 -0
- package/dist/sensitivity.d.ts +15 -0
- package/dist/sensitivity.d.ts.map +1 -0
- package/dist/sensitivity.js +9 -0
- package/dist/server/app_backend.d.ts +74 -0
- package/dist/server/app_backend.d.ts.map +1 -0
- package/dist/server/app_backend.js +39 -0
- package/dist/server/app_server.d.ts +201 -0
- package/dist/server/app_server.d.ts.map +1 -0
- package/dist/server/app_server.js +266 -0
- package/dist/server/env.d.ts +68 -0
- package/dist/server/env.d.ts.map +1 -0
- package/dist/server/env.js +95 -0
- package/dist/server/startup.d.ts +22 -0
- package/dist/server/startup.d.ts.map +1 -0
- package/dist/server/startup.js +48 -0
- package/dist/server/static.d.ts +39 -0
- package/dist/server/static.d.ts.map +1 -0
- package/dist/server/static.js +38 -0
- package/dist/server/validate_nginx.d.ts +34 -0
- package/dist/server/validate_nginx.d.ts.map +1 -0
- package/dist/server/validate_nginx.js +118 -0
- package/dist/testing/CLAUDE.md +3 -0
- package/dist/testing/admin_integration.d.ts +45 -0
- package/dist/testing/admin_integration.d.ts.map +1 -0
- package/dist/testing/admin_integration.js +840 -0
- package/dist/testing/adversarial_404.d.ts +15 -0
- package/dist/testing/adversarial_404.d.ts.map +1 -0
- package/dist/testing/adversarial_404.js +118 -0
- package/dist/testing/adversarial_headers.d.ts +36 -0
- package/dist/testing/adversarial_headers.d.ts.map +1 -0
- package/dist/testing/adversarial_headers.js +128 -0
- package/dist/testing/adversarial_input.d.ts +56 -0
- package/dist/testing/adversarial_input.d.ts.map +1 -0
- package/dist/testing/adversarial_input.js +494 -0
- package/dist/testing/app_server.d.ts +169 -0
- package/dist/testing/app_server.d.ts.map +1 -0
- package/dist/testing/app_server.js +240 -0
- package/dist/testing/assert_dev_env.d.ts +10 -0
- package/dist/testing/assert_dev_env.d.ts.map +1 -0
- package/dist/testing/assert_dev_env.js +13 -0
- package/dist/testing/assertions.d.ts +61 -0
- package/dist/testing/assertions.d.ts.map +1 -0
- package/dist/testing/assertions.js +96 -0
- package/dist/testing/attack_surface.d.ts +63 -0
- package/dist/testing/attack_surface.d.ts.map +1 -0
- package/dist/testing/attack_surface.js +224 -0
- package/dist/testing/audit_completeness.d.ts +29 -0
- package/dist/testing/audit_completeness.d.ts.map +1 -0
- package/dist/testing/audit_completeness.js +410 -0
- package/dist/testing/auth_apps.d.ts +55 -0
- package/dist/testing/auth_apps.d.ts.map +1 -0
- package/dist/testing/auth_apps.js +122 -0
- package/dist/testing/data_exposure.d.ts +62 -0
- package/dist/testing/data_exposure.d.ts.map +1 -0
- package/dist/testing/data_exposure.js +297 -0
- package/dist/testing/db.d.ts +111 -0
- package/dist/testing/db.d.ts.map +1 -0
- package/dist/testing/db.js +258 -0
- package/dist/testing/entities.d.ts +21 -0
- package/dist/testing/entities.d.ts.map +1 -0
- package/dist/testing/entities.js +42 -0
- package/dist/testing/error_coverage.d.ts +78 -0
- package/dist/testing/error_coverage.d.ts.map +1 -0
- package/dist/testing/error_coverage.js +135 -0
- package/dist/testing/integration.d.ts +37 -0
- package/dist/testing/integration.d.ts.map +1 -0
- package/dist/testing/integration.js +1139 -0
- package/dist/testing/integration_helpers.d.ts +107 -0
- package/dist/testing/integration_helpers.d.ts.map +1 -0
- package/dist/testing/integration_helpers.js +246 -0
- package/dist/testing/middleware.d.ts +125 -0
- package/dist/testing/middleware.d.ts.map +1 -0
- package/dist/testing/middleware.js +210 -0
- package/dist/testing/rate_limiting.d.ts +43 -0
- package/dist/testing/rate_limiting.d.ts.map +1 -0
- package/dist/testing/rate_limiting.js +216 -0
- package/dist/testing/round_trip.d.ts +37 -0
- package/dist/testing/round_trip.d.ts.map +1 -0
- package/dist/testing/round_trip.js +128 -0
- package/dist/testing/schema_generators.d.ts +33 -0
- package/dist/testing/schema_generators.d.ts.map +1 -0
- package/dist/testing/schema_generators.js +137 -0
- package/dist/testing/standard.d.ts +49 -0
- package/dist/testing/standard.d.ts.map +1 -0
- package/dist/testing/standard.js +16 -0
- package/dist/testing/stubs.d.ts +96 -0
- package/dist/testing/stubs.d.ts.map +1 -0
- package/dist/testing/stubs.js +192 -0
- package/dist/testing/surface_invariants.d.ts +189 -0
- package/dist/testing/surface_invariants.d.ts.map +1 -0
- package/dist/testing/surface_invariants.js +450 -0
- package/dist/ui/AccountSessions.svelte +75 -0
- package/dist/ui/AccountSessions.svelte.d.ts +19 -0
- package/dist/ui/AccountSessions.svelte.d.ts.map +1 -0
- package/dist/ui/AdminAccounts.svelte +107 -0
- package/dist/ui/AdminAccounts.svelte.d.ts +19 -0
- package/dist/ui/AdminAccounts.svelte.d.ts.map +1 -0
- package/dist/ui/AdminAuditLog.svelte +144 -0
- package/dist/ui/AdminAuditLog.svelte.d.ts +4 -0
- package/dist/ui/AdminAuditLog.svelte.d.ts.map +1 -0
- package/dist/ui/AdminInvites.svelte +142 -0
- package/dist/ui/AdminInvites.svelte.d.ts +4 -0
- package/dist/ui/AdminInvites.svelte.d.ts.map +1 -0
- package/dist/ui/AdminOverview.svelte +337 -0
- package/dist/ui/AdminOverview.svelte.d.ts +4 -0
- package/dist/ui/AdminOverview.svelte.d.ts.map +1 -0
- package/dist/ui/AdminPermitHistory.svelte +61 -0
- package/dist/ui/AdminPermitHistory.svelte.d.ts +19 -0
- package/dist/ui/AdminPermitHistory.svelte.d.ts.map +1 -0
- package/dist/ui/AdminSessions.svelte +85 -0
- package/dist/ui/AdminSessions.svelte.d.ts +19 -0
- package/dist/ui/AdminSessions.svelte.d.ts.map +1 -0
- package/dist/ui/AdminSettings.svelte +32 -0
- package/dist/ui/AdminSettings.svelte.d.ts +19 -0
- package/dist/ui/AdminSettings.svelte.d.ts.map +1 -0
- package/dist/ui/AdminSurface.svelte +42 -0
- package/dist/ui/AdminSurface.svelte.d.ts +4 -0
- package/dist/ui/AdminSurface.svelte.d.ts.map +1 -0
- package/dist/ui/AppShell.svelte +93 -0
- package/dist/ui/AppShell.svelte.d.ts +20 -0
- package/dist/ui/AppShell.svelte.d.ts.map +1 -0
- package/dist/ui/BootstrapForm.svelte +105 -0
- package/dist/ui/BootstrapForm.svelte.d.ts +4 -0
- package/dist/ui/BootstrapForm.svelte.d.ts.map +1 -0
- package/dist/ui/ColumnLayout.svelte +46 -0
- package/dist/ui/ColumnLayout.svelte.d.ts +11 -0
- package/dist/ui/ColumnLayout.svelte.d.ts.map +1 -0
- package/dist/ui/ConfirmButton.svelte +125 -0
- package/dist/ui/ConfirmButton.svelte.d.ts +54 -0
- package/dist/ui/ConfirmButton.svelte.d.ts.map +1 -0
- package/dist/ui/Datatable.svelte +185 -0
- package/dist/ui/Datatable.svelte.d.ts +35 -0
- package/dist/ui/Datatable.svelte.d.ts.map +1 -0
- package/dist/ui/LoginForm.svelte +82 -0
- package/dist/ui/LoginForm.svelte.d.ts +8 -0
- package/dist/ui/LoginForm.svelte.d.ts.map +1 -0
- package/dist/ui/LogoutButton.svelte +36 -0
- package/dist/ui/LogoutButton.svelte.d.ts +10 -0
- package/dist/ui/LogoutButton.svelte.d.ts.map +1 -0
- package/dist/ui/MenuLink.svelte +35 -0
- package/dist/ui/MenuLink.svelte.d.ts +12 -0
- package/dist/ui/MenuLink.svelte.d.ts.map +1 -0
- package/dist/ui/OpenSignupToggle.svelte +36 -0
- package/dist/ui/OpenSignupToggle.svelte.d.ts +19 -0
- package/dist/ui/OpenSignupToggle.svelte.d.ts.map +1 -0
- package/dist/ui/PopoverButton.svelte +136 -0
- package/dist/ui/PopoverButton.svelte.d.ts +63 -0
- package/dist/ui/PopoverButton.svelte.d.ts.map +1 -0
- package/dist/ui/SignupForm.svelte +117 -0
- package/dist/ui/SignupForm.svelte.d.ts +7 -0
- package/dist/ui/SignupForm.svelte.d.ts.map +1 -0
- package/dist/ui/SurfaceExplorer.svelte +287 -0
- package/dist/ui/SurfaceExplorer.svelte.d.ts +8 -0
- package/dist/ui/SurfaceExplorer.svelte.d.ts.map +1 -0
- package/dist/ui/account_sessions_state.svelte.d.ts +15 -0
- package/dist/ui/account_sessions_state.svelte.d.ts.map +1 -0
- package/dist/ui/account_sessions_state.svelte.js +45 -0
- package/dist/ui/admin_accounts_state.svelte.d.ts +19 -0
- package/dist/ui/admin_accounts_state.svelte.d.ts.map +1 -0
- package/dist/ui/admin_accounts_state.svelte.js +65 -0
- package/dist/ui/admin_invites_state.svelte.d.ts +19 -0
- package/dist/ui/admin_invites_state.svelte.d.ts.map +1 -0
- package/dist/ui/admin_invites_state.svelte.js +71 -0
- package/dist/ui/admin_sessions_state.svelte.d.ts +18 -0
- package/dist/ui/admin_sessions_state.svelte.d.ts.map +1 -0
- package/dist/ui/admin_sessions_state.svelte.js +62 -0
- package/dist/ui/app_settings_state.svelte.d.ts +14 -0
- package/dist/ui/app_settings_state.svelte.d.ts.map +1 -0
- package/dist/ui/app_settings_state.svelte.js +44 -0
- package/dist/ui/audit_log_state.svelte.d.ts +40 -0
- package/dist/ui/audit_log_state.svelte.d.ts.map +1 -0
- package/dist/ui/audit_log_state.svelte.js +153 -0
- package/dist/ui/auth_state.svelte.d.ts +85 -0
- package/dist/ui/auth_state.svelte.d.ts.map +1 -0
- package/dist/ui/auth_state.svelte.js +238 -0
- package/dist/ui/datatable.d.ts +25 -0
- package/dist/ui/datatable.d.ts.map +1 -0
- package/dist/ui/datatable.js +9 -0
- package/dist/ui/enter_advance.d.ts +13 -0
- package/dist/ui/enter_advance.d.ts.map +1 -0
- package/dist/ui/enter_advance.js +30 -0
- package/dist/ui/loadable.svelte.d.ts +55 -0
- package/dist/ui/loadable.svelte.d.ts.map +1 -0
- package/dist/ui/loadable.svelte.js +75 -0
- package/dist/ui/popover.svelte.d.ts +137 -0
- package/dist/ui/popover.svelte.d.ts.map +1 -0
- package/dist/ui/popover.svelte.js +288 -0
- package/dist/ui/position_helpers.d.ts +27 -0
- package/dist/ui/position_helpers.d.ts.map +1 -0
- package/dist/ui/position_helpers.js +81 -0
- package/dist/ui/sidebar_state.svelte.d.ts +30 -0
- package/dist/ui/sidebar_state.svelte.d.ts.map +1 -0
- package/dist/ui/sidebar_state.svelte.js +39 -0
- package/dist/ui/table_state.svelte.d.ts +63 -0
- package/dist/ui/table_state.svelte.d.ts.map +1 -0
- package/dist/ui/table_state.svelte.js +117 -0
- package/dist/ui/ui_fetch.d.ts +29 -0
- package/dist/ui/ui_fetch.d.ts.map +1 -0
- package/dist/ui/ui_fetch.js +37 -0
- package/dist/ui/ui_format.d.ts +63 -0
- package/dist/ui/ui_format.d.ts.map +1 -0
- package/dist/ui/ui_format.js +196 -0
- 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"}
|