gitspace 0.2.0-rc.20 → 0.2.0-rc.21
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/package.json +11 -6
- package/.claude/settings.local.json +0 -10
- package/.gitspace/bundle.json +0 -50
- package/.gitspace/events.json +0 -11
- package/.gitspace/processes.json +0 -23
- package/.gitspace/scripts/select/01-status.sh +0 -39
- package/.gitspace/scripts/setup/01-install-deps.sh +0 -12
- package/.gitspace/scripts/setup/02-typecheck.sh +0 -16
- package/AGENTS.md +0 -469
- package/CLAUDE.md +0 -1
- package/bun.lock +0 -794
- package/docs/CONNECTION.md +0 -623
- package/docs/GATEWAY-WORKER.md +0 -319
- package/docs/GETTING-STARTED.md +0 -448
- package/docs/GITSPACE-PLATFORM.md +0 -1819
- package/docs/INFRASTRUCTURE.md +0 -1347
- package/docs/PROTOCOL.md +0 -619
- package/docs/QUICKSTART.md +0 -183
- package/docs/RELAY.md +0 -327
- package/docs/REMOTE-DESIGN.md +0 -554
- package/docs/ROADMAP.md +0 -564
- package/docs/SITE_DOCS_FIGMA_MAKE.md +0 -1176
- package/docs/STACK-DESIGN.md +0 -588
- package/docs/UNIFIED_ARCHITECTURE.md +0 -138
- package/experiments/pty-benchmark.ts +0 -148
- package/experiments/pty-latency.ts +0 -100
- package/experiments/router/client.ts +0 -199
- package/experiments/router/protocol.ts +0 -74
- package/experiments/router/router.ts +0 -217
- package/experiments/router/session.ts +0 -180
- package/experiments/router/test.ts +0 -133
- package/experiments/socket-bandwidth.ts +0 -77
- package/homebrew/gitspace.rb +0 -45
- package/landing-page/ATTRIBUTIONS.md +0 -3
- package/landing-page/README.md +0 -11
- package/landing-page/bun.lock +0 -801
- package/landing-page/guidelines/Guidelines.md +0 -61
- package/landing-page/index.html +0 -37
- package/landing-page/package.json +0 -90
- package/landing-page/postcss.config.mjs +0 -15
- package/landing-page/public/_redirects +0 -1
- package/landing-page/public/favicon.png +0 -0
- package/landing-page/src/app/App.tsx +0 -53
- package/landing-page/src/app/components/figma/ImageWithFallback.tsx +0 -27
- package/landing-page/src/app/components/ui/accordion.tsx +0 -66
- package/landing-page/src/app/components/ui/alert-dialog.tsx +0 -157
- package/landing-page/src/app/components/ui/alert.tsx +0 -66
- package/landing-page/src/app/components/ui/aspect-ratio.tsx +0 -11
- package/landing-page/src/app/components/ui/avatar.tsx +0 -53
- package/landing-page/src/app/components/ui/badge.tsx +0 -46
- package/landing-page/src/app/components/ui/breadcrumb.tsx +0 -109
- package/landing-page/src/app/components/ui/button.tsx +0 -57
- package/landing-page/src/app/components/ui/calendar.tsx +0 -75
- package/landing-page/src/app/components/ui/card.tsx +0 -92
- package/landing-page/src/app/components/ui/carousel.tsx +0 -241
- package/landing-page/src/app/components/ui/chart.tsx +0 -353
- package/landing-page/src/app/components/ui/checkbox.tsx +0 -32
- package/landing-page/src/app/components/ui/collapsible.tsx +0 -33
- package/landing-page/src/app/components/ui/command.tsx +0 -177
- package/landing-page/src/app/components/ui/context-menu.tsx +0 -252
- package/landing-page/src/app/components/ui/dialog.tsx +0 -135
- package/landing-page/src/app/components/ui/drawer.tsx +0 -132
- package/landing-page/src/app/components/ui/dropdown-menu.tsx +0 -257
- package/landing-page/src/app/components/ui/form.tsx +0 -168
- package/landing-page/src/app/components/ui/hover-card.tsx +0 -44
- package/landing-page/src/app/components/ui/input-otp.tsx +0 -77
- package/landing-page/src/app/components/ui/input.tsx +0 -21
- package/landing-page/src/app/components/ui/label.tsx +0 -24
- package/landing-page/src/app/components/ui/menubar.tsx +0 -276
- package/landing-page/src/app/components/ui/navigation-menu.tsx +0 -168
- package/landing-page/src/app/components/ui/pagination.tsx +0 -127
- package/landing-page/src/app/components/ui/popover.tsx +0 -48
- package/landing-page/src/app/components/ui/progress.tsx +0 -31
- package/landing-page/src/app/components/ui/radio-group.tsx +0 -45
- package/landing-page/src/app/components/ui/resizable.tsx +0 -56
- package/landing-page/src/app/components/ui/scroll-area.tsx +0 -58
- package/landing-page/src/app/components/ui/select.tsx +0 -189
- package/landing-page/src/app/components/ui/separator.tsx +0 -28
- package/landing-page/src/app/components/ui/sheet.tsx +0 -139
- package/landing-page/src/app/components/ui/sidebar.tsx +0 -726
- package/landing-page/src/app/components/ui/skeleton.tsx +0 -13
- package/landing-page/src/app/components/ui/slider.tsx +0 -63
- package/landing-page/src/app/components/ui/sonner.tsx +0 -25
- package/landing-page/src/app/components/ui/switch.tsx +0 -31
- package/landing-page/src/app/components/ui/table.tsx +0 -116
- package/landing-page/src/app/components/ui/tabs.tsx +0 -66
- package/landing-page/src/app/components/ui/textarea.tsx +0 -18
- package/landing-page/src/app/components/ui/toggle-group.tsx +0 -73
- package/landing-page/src/app/components/ui/toggle.tsx +0 -47
- package/landing-page/src/app/components/ui/tooltip.tsx +0 -61
- package/landing-page/src/app/components/ui/use-mobile.ts +0 -21
- package/landing-page/src/app/components/ui/utils.ts +0 -6
- package/landing-page/src/components/docs/DocsContent.tsx +0 -801
- package/landing-page/src/components/docs/DocsSidebar.tsx +0 -90
- package/landing-page/src/components/landing/CTA.tsx +0 -59
- package/landing-page/src/components/landing/Comparison.tsx +0 -84
- package/landing-page/src/components/landing/FaultyTerminal.tsx +0 -424
- package/landing-page/src/components/landing/Features.tsx +0 -201
- package/landing-page/src/components/landing/Hero.tsx +0 -142
- package/landing-page/src/components/landing/Pricing.tsx +0 -140
- package/landing-page/src/components/landing/Roadmap.tsx +0 -86
- package/landing-page/src/components/landing/Security.tsx +0 -81
- package/landing-page/src/components/landing/TerminalWindow.tsx +0 -27
- package/landing-page/src/components/landing/UseCases.tsx +0 -55
- package/landing-page/src/components/landing/Workflow.tsx +0 -101
- package/landing-page/src/components/layout/DashboardNavbar.tsx +0 -37
- package/landing-page/src/components/layout/Footer.tsx +0 -55
- package/landing-page/src/components/layout/LandingNavbar.tsx +0 -82
- package/landing-page/src/components/ui/badge.tsx +0 -39
- package/landing-page/src/components/ui/breadcrumb.tsx +0 -115
- package/landing-page/src/components/ui/button.tsx +0 -57
- package/landing-page/src/components/ui/card.tsx +0 -79
- package/landing-page/src/components/ui/mock-terminal.tsx +0 -68
- package/landing-page/src/components/ui/separator.tsx +0 -28
- package/landing-page/src/lib/utils.ts +0 -6
- package/landing-page/src/main.tsx +0 -10
- package/landing-page/src/pages/Dashboard.tsx +0 -133
- package/landing-page/src/pages/DocsPage.tsx +0 -79
- package/landing-page/src/pages/LandingPage.tsx +0 -31
- package/landing-page/src/pages/TerminalView.tsx +0 -106
- package/landing-page/src/styles/fonts.css +0 -0
- package/landing-page/src/styles/index.css +0 -3
- package/landing-page/src/styles/tailwind.css +0 -4
- package/landing-page/src/styles/theme.css +0 -181
- package/landing-page/vite.config.ts +0 -19
- package/scripts/GHOSTTY_TAB_BUG.md +0 -106
- package/scripts/build.ts +0 -298
- package/scripts/migrate-secrets.ts +0 -77
- package/scripts/release.ts +0 -140
- package/scripts/sample-events.ts +0 -263
- package/scripts/test-tabs-minimal.ts +0 -68
- package/scripts/test-tabs-workaround.ts +0 -95
- package/scripts/test-tabs.ts +0 -171
- package/src/__tests__/test-utils.ts +0 -298
- package/src/app/input/__tests__/sessionCommands.test.ts +0 -40
- package/src/app/input/sessionCommands.ts +0 -94
- package/src/app/session/__tests__/useAttachController.test.ts +0 -229
- package/src/app/session/createSessionBackend.bun.ts +0 -76
- package/src/app/session/createSessionBackend.web.ts +0 -104
- package/src/app/session/types.ts +0 -16
- package/src/app/session/useAttachController.ts +0 -220
- package/src/app/session/useProcessActions.ts +0 -201
- package/src/app/session/useSessionClient.ts +0 -35
- package/src/app/session/useWorkspaceDeleteFlow.ts +0 -170
- package/src/app.tui.tsx +0 -2929
- package/src/app.web.tsx +0 -1454
- package/src/commands/__tests__/connect-key.test.ts +0 -10
- package/src/commands/__tests__/events.test.ts +0 -201
- package/src/commands/__tests__/notifications.test.ts +0 -349
- package/src/commands/__tests__/process.test.ts +0 -251
- package/src/commands/__tests__/serve-messages.test.ts +0 -190
- package/src/commands/__tests__/serve-process-hosting.test.ts +0 -63
- package/src/commands/access.ts +0 -298
- package/src/commands/add.ts +0 -455
- package/src/commands/auth.ts +0 -369
- package/src/commands/bundle.ts +0 -232
- package/src/commands/config.ts +0 -242
- package/src/commands/connect-key.ts +0 -1
- package/src/commands/connect.ts +0 -576
- package/src/commands/directory.ts +0 -16
- package/src/commands/events.ts +0 -157
- package/src/commands/host.ts +0 -566
- package/src/commands/identity.ts +0 -184
- package/src/commands/linear.ts +0 -717
- package/src/commands/list.ts +0 -181
- package/src/commands/migrate.ts +0 -52
- package/src/commands/notifications.ts +0 -351
- package/src/commands/process.ts +0 -104
- package/src/commands/relay.ts +0 -315
- package/src/commands/remove.ts +0 -279
- package/src/commands/review.ts +0 -787
- package/src/commands/serve.ts +0 -1946
- package/src/commands/share.ts +0 -451
- package/src/commands/status.ts +0 -125
- package/src/commands/switch.ts +0 -361
- package/src/commands/tmux.ts +0 -317
- package/src/components/DPad.web.tsx +0 -343
- package/src/components/DiffViewer.web.tsx +0 -1192
- package/src/components/Events.tsx +0 -137
- package/src/components/Events.tui.tsx +0 -129
- package/src/components/Events.web.tsx +0 -386
- package/src/components/FloatingControls.web.tsx +0 -112
- package/src/components/FloatingJogWheel.web.tsx +0 -240
- package/src/components/Flow.tsx +0 -458
- package/src/components/Flow.tui.tsx +0 -343
- package/src/components/Flow.web.tsx +0 -442
- package/src/components/Inbox.tsx +0 -448
- package/src/components/Inbox.tui.tsx +0 -262
- package/src/components/Inbox.web.tsx +0 -329
- package/src/components/MachineList.tsx +0 -187
- package/src/components/MachineList.tui.tsx +0 -161
- package/src/components/MachineList.web.tsx +0 -210
- package/src/components/NumPad.web.tsx +0 -270
- package/src/components/ProjectList.tsx +0 -175
- package/src/components/ProjectList.tui.tsx +0 -109
- package/src/components/ProjectList.web.tsx +0 -143
- package/src/components/ProjectOnboardingStep.ts +0 -23
- package/src/components/ProjectOnboardingStep.tui.tsx +0 -88
- package/src/components/ProjectOnboardingStep.web.tsx +0 -59
- package/src/components/RemoteMachineScreen.tui.tsx +0 -690
- package/src/components/ScriptTerminal.tui.tsx +0 -160
- package/src/components/ScriptTerminal.web.tsx +0 -89
- package/src/components/SessionTerminal.tui.tsx +0 -406
- package/src/components/SessionTerminal.web.tsx +0 -467
- package/src/components/SpacesBrowser.tsx +0 -540
- package/src/components/SpacesBrowser.tui.tsx +0 -258
- package/src/components/SpacesBrowser.web.tsx +0 -332
- package/src/components/TerminalControls.web.tsx +0 -464
- package/src/components/ThreadPanel.web.tsx +0 -798
- package/src/components/__tests__/SpacesBrowser.test.ts +0 -541
- package/src/components/__tests__/SpacesBrowser.tui.test.tsx +0 -249
- package/src/components/__tests__/script-terminal-buffer.tui.test.ts +0 -72
- package/src/components/index.ts +0 -105
- package/src/components/review-decision-colors.ts +0 -11
- package/src/components/script-terminal-buffer.tui.ts +0 -37
- package/src/components/session-terminal-page-navigation.ts +0 -48
- package/src/components/terminal-bracketed-paste.tui.test.ts +0 -43
- package/src/components/terminal-bracketed-paste.tui.ts +0 -46
- package/src/core/__tests__/access.test.ts +0 -240
- package/src/core/__tests__/bundle-refresh.test.ts +0 -567
- package/src/core/__tests__/bundle.test.ts +0 -209
- package/src/core/__tests__/github-review.test.ts +0 -781
- package/src/core/__tests__/project-lifecycle.test.ts +0 -137
- package/src/core/__tests__/workspace-lifecycle.test.ts +0 -159
- package/src/core/__tests__/workspace.test.ts +0 -149
- package/src/core/access.ts +0 -277
- package/src/core/bundle-refresh.ts +0 -1064
- package/src/core/bundle.ts +0 -326
- package/src/core/config.ts +0 -405
- package/src/core/git.ts +0 -768
- package/src/core/github-review.ts +0 -761
- package/src/core/github.ts +0 -151
- package/src/core/identity.ts +0 -631
- package/src/core/linear.ts +0 -403
- package/src/core/preferences-service.ts +0 -17
- package/src/core/project-catalog.ts +0 -52
- package/src/core/project-lifecycle.ts +0 -163
- package/src/core/review-executor.ts +0 -316
- package/src/core/review.ts +0 -407
- package/src/core/secret-runtime.ts +0 -167
- package/src/core/shell.ts +0 -117
- package/src/core/trusted-relays.ts +0 -315
- package/src/core/workspace-lifecycle.ts +0 -216
- package/src/core/workspace.ts +0 -363
- package/src/hooks/__tests__/useLocalSession.tui.test.ts +0 -557
- package/src/hooks/index.ts +0 -8
- package/src/hooks/index.tui.ts +0 -32
- package/src/hooks/useDaemonStatus.tui.ts +0 -174
- package/src/hooks/useLocalSession.tui.ts +0 -395
- package/src/hooks/useRelayConnection.web.ts +0 -54
- package/src/hooks/useRemoteMachines.tui.ts +0 -166
- package/src/hooks/useRemoteTerminal.tui.ts +0 -22
- package/src/hooks/useReview.web.ts +0 -248
- package/src/hooks/useTerminal.web.ts +0 -36
- package/src/hooks/useUserActivity.ts +0 -61
- package/src/hooks/useVisualViewport.web.ts +0 -104
- package/src/index.ts +0 -1376
- package/src/lib/events/__tests__/collector-filter.test.ts +0 -105
- package/src/lib/events/__tests__/store-query.test.ts +0 -103
- package/src/lib/events/collector.ts +0 -494
- package/src/lib/events/filters.ts +0 -26
- package/src/lib/events/index.ts +0 -11
- package/src/lib/events/indexer.ts +0 -14
- package/src/lib/events/paths.ts +0 -69
- package/src/lib/events/reader.ts +0 -212
- package/src/lib/events/store.ts +0 -141
- package/src/lib/invite.web.ts +0 -58
- package/src/lib/preferences-service.web.ts +0 -41
- package/src/lib/processes/__tests__/config.test.ts +0 -83
- package/src/lib/processes/__tests__/names.test.ts +0 -125
- package/src/lib/processes/__tests__/schema.test.ts +0 -208
- package/src/lib/processes/__tests__/watchdog.test.ts +0 -210
- package/src/lib/processes/autostart.ts +0 -16
- package/src/lib/processes/config.ts +0 -187
- package/src/lib/processes/control.ts +0 -53
- package/src/lib/processes/editor.ts +0 -32
- package/src/lib/processes/events-config.ts +0 -37
- package/src/lib/processes/index.ts +0 -14
- package/src/lib/processes/instances.ts +0 -20
- package/src/lib/processes/manager.ts +0 -131
- package/src/lib/processes/names.ts +0 -71
- package/src/lib/processes/registry.ts +0 -26
- package/src/lib/processes/runner.ts +0 -211
- package/src/lib/processes/scheduler.ts +0 -17
- package/src/lib/processes/schema.ts +0 -74
- package/src/lib/processes/session-list.ts +0 -15
- package/src/lib/processes/state.ts +0 -82
- package/src/lib/processes/watchdog.test.ts +0 -79
- package/src/lib/processes/watchdog.ts +0 -106
- package/src/lib/remote-session/__tests__/protocol.test.ts +0 -291
- package/src/lib/remote-session/index.ts +0 -7
- package/src/lib/remote-session/protocol.ts +0 -443
- package/src/lib/remote-session/session-handler.ts +0 -1298
- package/src/lib/remote-session/workspace-scanner.ts +0 -161
- package/src/lib/sonner.web.ts +0 -1
- package/src/lib/storage/identity-store.web.ts +0 -94
- package/src/lib/tmux-lite/README.md +0 -81
- package/src/lib/tmux-lite/cli.ts +0 -855
- package/src/lib/tmux-lite/crypto/__tests__/helpers/handshake-runner.ts +0 -349
- package/src/lib/tmux-lite/crypto/__tests__/helpers/mock-relay.ts +0 -291
- package/src/lib/tmux-lite/crypto/__tests__/helpers/test-identities.ts +0 -142
- package/src/lib/tmux-lite/crypto/__tests__/integration/authorization.integration.test.ts +0 -339
- package/src/lib/tmux-lite/crypto/__tests__/integration/e2e-communication.integration.test.ts +0 -477
- package/src/lib/tmux-lite/crypto/__tests__/integration/error-handling.integration.test.ts +0 -499
- package/src/lib/tmux-lite/crypto/__tests__/integration/handshake.integration.test.ts +0 -371
- package/src/lib/tmux-lite/crypto/__tests__/integration/security.integration.test.ts +0 -573
- package/src/lib/tmux-lite/crypto/access-control.test.ts +0 -512
- package/src/lib/tmux-lite/crypto/access-control.ts +0 -320
- package/src/lib/tmux-lite/crypto/frames.test.ts +0 -262
- package/src/lib/tmux-lite/crypto/frames.ts +0 -141
- package/src/lib/tmux-lite/crypto/handshake.ts +0 -894
- package/src/lib/tmux-lite/crypto/identity.test.ts +0 -220
- package/src/lib/tmux-lite/crypto/identity.ts +0 -286
- package/src/lib/tmux-lite/crypto/index.ts +0 -51
- package/src/lib/tmux-lite/crypto/invites.test.ts +0 -381
- package/src/lib/tmux-lite/crypto/invites.ts +0 -215
- package/src/lib/tmux-lite/crypto/keyexchange.ts +0 -435
- package/src/lib/tmux-lite/crypto/keys.test.ts +0 -58
- package/src/lib/tmux-lite/crypto/keys.ts +0 -47
- package/src/lib/tmux-lite/crypto/secretbox.test.ts +0 -169
- package/src/lib/tmux-lite/crypto/secretbox.ts +0 -124
- package/src/lib/tmux-lite/handshake-handler.ts +0 -451
- package/src/lib/tmux-lite/process-run.integration.test.ts +0 -266
- package/src/lib/tmux-lite/protocol.test.ts +0 -307
- package/src/lib/tmux-lite/protocol.ts +0 -291
- package/src/lib/tmux-lite/relay-client.ts +0 -506
- package/src/lib/tmux-lite/server-lifecycle.test.ts +0 -212
- package/src/lib/tmux-lite/server.ts +0 -1412
- package/src/lib/tmux-lite/shell-integration.sh +0 -37
- package/src/lib/tmux-lite/terminal-queries.test.ts +0 -54
- package/src/lib/tmux-lite/terminal-queries.ts +0 -49
- package/src/notifications/__tests__/useNotifications.test.ts +0 -739
- package/src/notifications/index.ts +0 -32
- package/src/notifications/policy.test.ts +0 -424
- package/src/notifications/policy.ts +0 -139
- package/src/notifications/types.ts +0 -82
- package/src/notifications/useNotifications.ts +0 -350
- package/src/pages/ReviewPage.web.tsx +0 -511
- package/src/preferences/index.ts +0 -1
- package/src/preferences/types.ts +0 -9
- package/src/relay/__tests__/e2e-flow.test.ts +0 -1284
- package/src/relay/__tests__/helpers/auth.ts +0 -354
- package/src/relay/__tests__/helpers/ports.ts +0 -51
- package/src/relay/__tests__/protocol-validation.test.ts +0 -265
- package/src/relay/authorization.ts +0 -303
- package/src/relay/embedded-assets.generated.d.ts +0 -15
- package/src/relay/identity.ts +0 -352
- package/src/relay/index.ts +0 -57
- package/src/relay/pipes.test.ts +0 -427
- package/src/relay/pipes.ts +0 -195
- package/src/relay/protocol.ts +0 -804
- package/src/relay/registries.test.ts +0 -437
- package/src/relay/registries.ts +0 -593
- package/src/relay/server.test.ts +0 -1323
- package/src/relay/server.ts +0 -1128
- package/src/relay/signing.ts +0 -238
- package/src/relay/types.ts +0 -69
- package/src/relay-client/__tests__/machine-directory-client.test.ts +0 -152
- package/src/relay-client/__tests__/useMachineDirectory.test.ts +0 -172
- package/src/relay-client/adapters/browser.ts +0 -27
- package/src/relay-client/adapters/node.ts +0 -29
- package/src/relay-client/index.ts +0 -33
- package/src/relay-client/machine-directory-client.ts +0 -244
- package/src/relay-client/useMachineDirectory.ts +0 -175
- package/src/serve/client-session-manager.ts +0 -635
- package/src/serve/daemon.ts +0 -497
- package/src/serve/pty-session.ts +0 -236
- package/src/serve/types.ts +0 -174
- package/src/session/__tests__/backend-manager.test.ts +0 -101
- package/src/session/__tests__/local-session-backend.test.ts +0 -1129
- package/src/session/__tests__/reducer.test.ts +0 -80
- package/src/session/__tests__/remote-session-backend.test.ts +0 -995
- package/src/session/__tests__/session-name.test.ts +0 -35
- package/src/session/__tests__/useBundleRefreshAttachFlow.test.ts +0 -431
- package/src/session/__tests__/useRemoteSessionClient.test.ts +0 -424
- package/src/session/__tests__/workspace-shell-hooks.integration.test.ts +0 -268
- package/src/session/__tests__/workspace-shell-hooks.test.ts +0 -24
- package/src/session/adapters/browser-remote.ts +0 -101
- package/src/session/adapters/node-remote.ts +0 -135
- package/src/session/backend-key.ts +0 -5
- package/src/session/backend-manager.ts +0 -80
- package/src/session/backend.ts +0 -93
- package/src/session/backends/local-session-backend.ts +0 -1119
- package/src/session/backends/remote-session-backend.ts +0 -1378
- package/src/session/crypto/__tests__/web-terminal.test.ts +0 -1158
- package/src/session/crypto/frames.web.ts +0 -205
- package/src/session/crypto/handshake.web.ts +0 -396
- package/src/session/crypto/identity.web.ts +0 -133
- package/src/session/crypto/keyexchange.web.ts +0 -246
- package/src/session/crypto/relay-signing.web.ts +0 -53
- package/src/session/events.ts +0 -38
- package/src/session/index.ts +0 -116
- package/src/session/reducer.ts +0 -274
- package/src/session/selectors.ts +0 -28
- package/src/session/session-name.ts +0 -50
- package/src/session/types.ts +0 -101
- package/src/session/useBundleRefreshAttachFlow.ts +0 -608
- package/src/session/useRemoteSessionClient.ts +0 -424
- package/src/session/useSessionEngine.ts +0 -432
- package/src/session/workspace-shell-hooks.ts +0 -35
- package/src/tui/__tests__/input-text.test.ts +0 -24
- package/src/tui/__tests__/local-terminal-sync.test.ts +0 -82
- package/src/tui/__tests__/session-terminal-page-navigation.test.ts +0 -94
- package/src/tui/app.tsx +0 -2
- package/src/tui/index.ts +0 -18
- package/src/tui/input-text.ts +0 -38
- package/src/tui/local-terminal-sync.ts +0 -41
- package/src/types/bundle-refresh.ts +0 -42
- package/src/types/bundle.ts +0 -130
- package/src/types/config.ts +0 -287
- package/src/types/errors.ts +0 -292
- package/src/types/events.ts +0 -91
- package/src/types/identity.ts +0 -284
- package/src/types/processes.ts +0 -45
- package/src/types/review.ts +0 -349
- package/src/types/script-phase.ts +0 -3
- package/src/types/workspace-fuzzy.ts +0 -49
- package/src/types/workspace.ts +0 -151
- package/src/utils/__tests__/onboarding.test.ts +0 -358
- package/src/utils/__tests__/run-scripts.test.ts +0 -535
- package/src/utils/__tests__/run-workspace-scripts.test.ts +0 -406
- package/src/utils/__tests__/workspace-setup.integration.test.ts +0 -633
- package/src/utils/__tests__/workspace-state.test.ts +0 -78
- package/src/utils/bun-socket-writer.ts +0 -80
- package/src/utils/clipboard.ts +0 -53
- package/src/utils/deps.test.ts +0 -31
- package/src/utils/deps.ts +0 -145
- package/src/utils/device.web.ts +0 -163
- package/src/utils/fuzzy-match.ts +0 -125
- package/src/utils/hostnames.ts +0 -43
- package/src/utils/hunk-header.ts +0 -17
- package/src/utils/id.ts +0 -9
- package/src/utils/logger.ts +0 -127
- package/src/utils/markdown.ts +0 -254
- package/src/utils/normalize-env-key.ts +0 -13
- package/src/utils/onboarding.ts +0 -279
- package/src/utils/prompts.ts +0 -176
- package/src/utils/run-commands.ts +0 -112
- package/src/utils/run-scripts.ts +0 -337
- package/src/utils/run-workspace-scripts.ts +0 -355
- package/src/utils/sanitize.test.ts +0 -149
- package/src/utils/sanitize.ts +0 -162
- package/src/utils/secrets.ts +0 -836
- package/src/utils/shell-escape.ts +0 -40
- package/src/utils/utf8.ts +0 -79
- package/src/utils/workspace-id.ts +0 -55
- package/src/utils/workspace-state.ts +0 -427
- package/src/version.generated.d.ts +0 -2
- package/todo-security.md +0 -92
- package/tsconfig.json +0 -29
- package/web/README.md +0 -73
- package/web/bun.lock +0 -675
- package/web/eslint.config.js +0 -23
- package/web/index.css +0 -249
- package/web/index.html +0 -16
- package/web/main.tsx +0 -10
- package/web/package.json +0 -39
- package/web/public/vite.svg +0 -1
- package/web/tsconfig.app.json +0 -35
- package/web/tsconfig.json +0 -7
- package/web/tsconfig.node.json +0 -26
- package/web/vite.config.ts +0 -39
- package/worker/bun.lock +0 -237
- package/worker/package.json +0 -22
- package/worker/schema.sql +0 -96
- package/worker/src/handlers/auth.ts +0 -451
- package/worker/src/handlers/subdomains.ts +0 -376
- package/worker/src/handlers/user.ts +0 -98
- package/worker/src/index.ts +0 -70
- package/worker/src/middleware/auth.ts +0 -152
- package/worker/src/services/cloudflare.ts +0 -609
- package/worker/src/types.ts +0 -96
- package/worker/tsconfig.json +0 -15
- package/worker/wrangler.toml +0 -26
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Saved events filter helpers
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import { existsSync, readFileSync } from 'fs';
|
|
6
|
-
import { join } from 'path';
|
|
7
|
-
import type { EventsConfigFile, SavedEventFilter } from '../../types/events.js';
|
|
8
|
-
|
|
9
|
-
export function getEventsConfigPath(workspacePath: string): string {
|
|
10
|
-
return join(workspacePath, '.gitspace', 'events.json');
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
export function loadSavedEventFilters(workspacePath: string): SavedEventFilter[] {
|
|
14
|
-
const path = getEventsConfigPath(workspacePath);
|
|
15
|
-
if (!existsSync(path)) {
|
|
16
|
-
return [];
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
try {
|
|
20
|
-
const raw = readFileSync(path, 'utf-8');
|
|
21
|
-
const parsed = JSON.parse(raw) as EventsConfigFile;
|
|
22
|
-
return Array.isArray(parsed.savedFilters) ? parsed.savedFilters : [];
|
|
23
|
-
} catch {
|
|
24
|
-
return [];
|
|
25
|
-
}
|
|
26
|
-
}
|
package/src/lib/events/index.ts
DELETED
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Wide event index maintenance helpers
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import { writeFileSync } from 'fs';
|
|
6
|
-
import type { WideEventIndex } from '../../types/events.js';
|
|
7
|
-
|
|
8
|
-
export function writeIndexFile(path: string, index: WideEventIndex): void {
|
|
9
|
-
const data = {
|
|
10
|
-
...index,
|
|
11
|
-
minTs: index.minTs === Number.POSITIVE_INFINITY ? index.maxTs : index.minTs,
|
|
12
|
-
};
|
|
13
|
-
writeFileSync(path, JSON.stringify(data, null, 2), 'utf-8');
|
|
14
|
-
}
|
package/src/lib/events/paths.ts
DELETED
|
@@ -1,69 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Wide event path helpers
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import { existsSync, readdirSync } from 'fs';
|
|
6
|
-
import { join, relative, sep } from 'path';
|
|
7
|
-
import { getGitspaceDir } from '../../core/config.js';
|
|
8
|
-
import { encodeProcessNameForPath } from '../processes/names.js';
|
|
9
|
-
|
|
10
|
-
const DEFAULT_INSTANCE = 1;
|
|
11
|
-
|
|
12
|
-
export interface WorkspaceRef {
|
|
13
|
-
projectName: string;
|
|
14
|
-
workspaceId: string;
|
|
15
|
-
workspacePath: string;
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
/**
|
|
19
|
-
* Resolve workspace/project info from a cwd path
|
|
20
|
-
*/
|
|
21
|
-
export function resolveWorkspaceRef(cwd: string): WorkspaceRef | null {
|
|
22
|
-
const spacesDir = getGitspaceDir();
|
|
23
|
-
const rel = relative(spacesDir, cwd);
|
|
24
|
-
if (!rel || rel.startsWith('..')) {
|
|
25
|
-
return null;
|
|
26
|
-
}
|
|
27
|
-
const parts = rel.split(sep).filter(Boolean);
|
|
28
|
-
if (parts.length < 3) {
|
|
29
|
-
return null;
|
|
30
|
-
}
|
|
31
|
-
if (parts[1] !== 'workspaces') {
|
|
32
|
-
return null;
|
|
33
|
-
}
|
|
34
|
-
const projectName = parts[0];
|
|
35
|
-
const workspaceId = parts[2];
|
|
36
|
-
const workspacePath = join(spacesDir, projectName, 'workspaces', workspaceId);
|
|
37
|
-
return { projectName, workspaceId, workspacePath };
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
/**
|
|
41
|
-
* Get events directory for a process
|
|
42
|
-
*/
|
|
43
|
-
export function getProcessEventsDir(
|
|
44
|
-
workspacePath: string,
|
|
45
|
-
processName: string,
|
|
46
|
-
processInstance?: number
|
|
47
|
-
): string {
|
|
48
|
-
const instance = processInstance ?? DEFAULT_INSTANCE;
|
|
49
|
-
return join(workspacePath, '.events', 'processes', `${encodeProcessNameForPath(processName)}-${instance}`);
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
export function getProcessSnapshotsPath(
|
|
53
|
-
workspacePath: string,
|
|
54
|
-
processName: string,
|
|
55
|
-
processInstance?: number
|
|
56
|
-
): string {
|
|
57
|
-
return join(getProcessEventsDir(workspacePath, processName, processInstance), 'wide-snapshots.ndjson');
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
/**
|
|
61
|
-
* Get all process events directories for a workspace
|
|
62
|
-
*/
|
|
63
|
-
export function listProcessEventsDirs(workspacePath: string): string[] {
|
|
64
|
-
const base = join(workspacePath, '.events', 'processes');
|
|
65
|
-
if (!existsSync(base)) return [];
|
|
66
|
-
return readdirSync(base)
|
|
67
|
-
.filter((entry: string) => !entry.startsWith('.'))
|
|
68
|
-
.map((entry: string) => join(base, entry));
|
|
69
|
-
}
|
package/src/lib/events/reader.ts
DELETED
|
@@ -1,212 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Wide event reader for CLI queries
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import { join } from 'path';
|
|
6
|
-
import { readFileSync } from 'fs';
|
|
7
|
-
import type { WideEvent, WideEventFilter, WideSnapshot, WideSnapshotTimelineEntry } from '../../types/events.js';
|
|
8
|
-
import { listEventIndexes, selectFilesForQuery, queryEvents } from './store.js';
|
|
9
|
-
import { listProcessEventsDirs } from './paths.js';
|
|
10
|
-
|
|
11
|
-
export interface WideEventQueryParams {
|
|
12
|
-
eventsDir: string;
|
|
13
|
-
filter: WideEventFilter;
|
|
14
|
-
limit?: number;
|
|
15
|
-
sinceMs?: number;
|
|
16
|
-
untilMs?: number;
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
export function readWideEvents(params: WideEventQueryParams): WideEvent[] {
|
|
20
|
-
const indexes = listEventIndexes(params.eventsDir);
|
|
21
|
-
const selected = selectFilesForQuery(indexes, {
|
|
22
|
-
filter: params.filter,
|
|
23
|
-
limit: params.limit,
|
|
24
|
-
sinceMs: params.sinceMs,
|
|
25
|
-
untilMs: params.untilMs,
|
|
26
|
-
});
|
|
27
|
-
const sorted = [...selected].sort((a, b) => b.maxTs - a.maxTs);
|
|
28
|
-
const results = queryEvents(
|
|
29
|
-
params.eventsDir,
|
|
30
|
-
sorted,
|
|
31
|
-
{
|
|
32
|
-
filter: params.filter,
|
|
33
|
-
limit: params.limit,
|
|
34
|
-
sinceMs: params.sinceMs,
|
|
35
|
-
untilMs: params.untilMs,
|
|
36
|
-
}
|
|
37
|
-
);
|
|
38
|
-
return results.reverse();
|
|
39
|
-
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
export function getEventsFilePath(eventsDir: string, indexFile: string): string {
|
|
43
|
-
return join(eventsDir, indexFile);
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
type SnapshotCacheEntry = {
|
|
47
|
-
snapshots: Map<string, WideSnapshot>;
|
|
48
|
-
bytes: number;
|
|
49
|
-
updatedAt: number;
|
|
50
|
-
};
|
|
51
|
-
|
|
52
|
-
const workspaceSnapshotCache = new Map<string, SnapshotCacheEntry>();
|
|
53
|
-
const DEFAULT_CACHE_BYTES = 64 * 1024 * 1024;
|
|
54
|
-
const DEFAULT_CACHE_TTL_MS = 1000;
|
|
55
|
-
const DEFAULT_MAX_TIMELINE = 200;
|
|
56
|
-
|
|
57
|
-
function estimateSnapshotSize(snapshot: WideSnapshot): number {
|
|
58
|
-
return Buffer.byteLength(JSON.stringify(snapshot));
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
function readSnapshotFile(filePath: string): WideSnapshot[] {
|
|
62
|
-
try {
|
|
63
|
-
const content = readFileSync(filePath, 'utf-8');
|
|
64
|
-
const snapshots: WideSnapshot[] = [];
|
|
65
|
-
for (const line of content.split('\n')) {
|
|
66
|
-
if (line.trim().length === 0) continue;
|
|
67
|
-
try {
|
|
68
|
-
const parsed = JSON.parse(line) as WideSnapshot;
|
|
69
|
-
if (!parsed || typeof parsed !== 'object') continue;
|
|
70
|
-
if (typeof parsed.correlationId !== 'string') continue;
|
|
71
|
-
if (typeof parsed.updatedAt !== 'number' || Number.isNaN(parsed.updatedAt)) continue;
|
|
72
|
-
if (typeof parsed.eventName !== 'string') continue;
|
|
73
|
-
if (typeof parsed.level !== 'string') continue;
|
|
74
|
-
if (typeof parsed.message !== 'string') continue;
|
|
75
|
-
if (typeof parsed.lastEventId !== 'string') continue;
|
|
76
|
-
if (!parsed.timelineMap || typeof parsed.timelineMap !== 'object') continue;
|
|
77
|
-
if (!Array.isArray(parsed.timelineOrder)) continue;
|
|
78
|
-
if (!parsed.timelineOrder.every((entry) => typeof entry === 'string')) continue;
|
|
79
|
-
snapshots.push(parsed);
|
|
80
|
-
} catch {
|
|
81
|
-
// Skip malformed snapshot entries
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
return snapshots;
|
|
85
|
-
} catch {
|
|
86
|
-
return [];
|
|
87
|
-
}
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
function mergeSnapshot(
|
|
91
|
-
existing: WideSnapshot | undefined,
|
|
92
|
-
incoming: WideSnapshot,
|
|
93
|
-
maxTimeline: number
|
|
94
|
-
): WideSnapshot {
|
|
95
|
-
if (!existing) {
|
|
96
|
-
return incoming;
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
const orderedEntries: Array<{ entry: WideSnapshotTimelineEntry; seq: number }> = [];
|
|
100
|
-
existing.timelineOrder.forEach((key, index) => {
|
|
101
|
-
const entry = existing.timelineMap[key];
|
|
102
|
-
if (entry) {
|
|
103
|
-
orderedEntries.push({ entry, seq: index });
|
|
104
|
-
}
|
|
105
|
-
});
|
|
106
|
-
const incomingOffset = orderedEntries.length;
|
|
107
|
-
incoming.timelineOrder.forEach((key, index) => {
|
|
108
|
-
const entry = incoming.timelineMap[key];
|
|
109
|
-
if (entry) {
|
|
110
|
-
orderedEntries.push({ entry, seq: incomingOffset + index });
|
|
111
|
-
}
|
|
112
|
-
});
|
|
113
|
-
|
|
114
|
-
orderedEntries.sort((a, b) => {
|
|
115
|
-
if (a.entry.timestampMs !== b.entry.timestampMs) {
|
|
116
|
-
return a.entry.timestampMs - b.entry.timestampMs;
|
|
117
|
-
}
|
|
118
|
-
return a.seq - b.seq;
|
|
119
|
-
});
|
|
120
|
-
|
|
121
|
-
const maxEntries = Math.max(1, maxTimeline);
|
|
122
|
-
const trimmedEntries =
|
|
123
|
-
orderedEntries.length > maxEntries
|
|
124
|
-
? orderedEntries.slice(orderedEntries.length - maxEntries)
|
|
125
|
-
: orderedEntries;
|
|
126
|
-
|
|
127
|
-
const timelineMap: Record<string, WideSnapshotTimelineEntry> = {};
|
|
128
|
-
const timelineOrder: string[] = [];
|
|
129
|
-
const keyCounts = new Map<string, number>();
|
|
130
|
-
for (const { entry } of trimmedEntries) {
|
|
131
|
-
const baseName = entry.eventName;
|
|
132
|
-
const count = keyCounts.get(baseName) ?? 0;
|
|
133
|
-
const next = count + 1;
|
|
134
|
-
keyCounts.set(baseName, next);
|
|
135
|
-
const key = next === 1 ? baseName : `${baseName}#${next}`;
|
|
136
|
-
timelineMap[key] = { ...entry, key };
|
|
137
|
-
timelineOrder.push(key);
|
|
138
|
-
}
|
|
139
|
-
|
|
140
|
-
const isIncomingLatest = incoming.updatedAt >= existing.updatedAt;
|
|
141
|
-
|
|
142
|
-
return {
|
|
143
|
-
correlationId: incoming.correlationId,
|
|
144
|
-
updatedAt: Math.max(existing.updatedAt, incoming.updatedAt),
|
|
145
|
-
processName: isIncomingLatest ? incoming.processName : existing.processName,
|
|
146
|
-
processInstance: isIncomingLatest ? incoming.processInstance : existing.processInstance,
|
|
147
|
-
level: isIncomingLatest ? incoming.level : existing.level,
|
|
148
|
-
message: isIncomingLatest ? incoming.message : existing.message,
|
|
149
|
-
eventName: isIncomingLatest ? incoming.eventName : existing.eventName,
|
|
150
|
-
lastEventId: isIncomingLatest ? incoming.lastEventId : existing.lastEventId,
|
|
151
|
-
timelineMap,
|
|
152
|
-
timelineOrder,
|
|
153
|
-
raw: isIncomingLatest ? incoming.raw : existing.raw,
|
|
154
|
-
};
|
|
155
|
-
}
|
|
156
|
-
|
|
157
|
-
function applyCacheLimit(entry: SnapshotCacheEntry, maxBytes: number): void {
|
|
158
|
-
if (entry.bytes <= maxBytes) return;
|
|
159
|
-
const sorted = Array.from(entry.snapshots.values()).sort((a, b) => a.updatedAt - b.updatedAt);
|
|
160
|
-
for (const snapshot of sorted) {
|
|
161
|
-
if (entry.bytes <= maxBytes) break;
|
|
162
|
-
entry.snapshots.delete(snapshot.correlationId);
|
|
163
|
-
entry.bytes = Math.max(0, entry.bytes - estimateSnapshotSize(snapshot));
|
|
164
|
-
}
|
|
165
|
-
}
|
|
166
|
-
|
|
167
|
-
export interface ReadWorkspaceSnapshotsOptions {
|
|
168
|
-
maxBytes?: number;
|
|
169
|
-
maxTimeline?: number;
|
|
170
|
-
refresh?: boolean;
|
|
171
|
-
}
|
|
172
|
-
|
|
173
|
-
export function readWorkspaceSnapshots(
|
|
174
|
-
workspacePath: string,
|
|
175
|
-
options: ReadWorkspaceSnapshotsOptions = {}
|
|
176
|
-
): WideSnapshot[] {
|
|
177
|
-
const cached = workspaceSnapshotCache.get(workspacePath);
|
|
178
|
-
const isFresh = cached ? Date.now() - cached.updatedAt <= DEFAULT_CACHE_TTL_MS : false;
|
|
179
|
-
if (cached && !options.refresh && isFresh) {
|
|
180
|
-
return Array.from(cached.snapshots.values()).sort((a, b) => b.updatedAt - a.updatedAt);
|
|
181
|
-
}
|
|
182
|
-
|
|
183
|
-
const maxBytes = options.maxBytes ?? DEFAULT_CACHE_BYTES;
|
|
184
|
-
const maxTimeline = options.maxTimeline ?? DEFAULT_MAX_TIMELINE;
|
|
185
|
-
|
|
186
|
-
const entry: SnapshotCacheEntry = {
|
|
187
|
-
snapshots: new Map<string, WideSnapshot>(),
|
|
188
|
-
bytes: 0,
|
|
189
|
-
updatedAt: Date.now(),
|
|
190
|
-
};
|
|
191
|
-
|
|
192
|
-
const processDirs = listProcessEventsDirs(workspacePath);
|
|
193
|
-
for (const dir of processDirs) {
|
|
194
|
-
const filePath = join(dir, 'wide-snapshots.ndjson');
|
|
195
|
-
const snapshots = readSnapshotFile(filePath);
|
|
196
|
-
for (const snapshot of snapshots) {
|
|
197
|
-
const existing = entry.snapshots.get(snapshot.correlationId);
|
|
198
|
-
const merged = mergeSnapshot(existing, snapshot, maxTimeline);
|
|
199
|
-
if (!existing) {
|
|
200
|
-
entry.bytes += estimateSnapshotSize(merged);
|
|
201
|
-
} else {
|
|
202
|
-
entry.bytes = Math.max(0, entry.bytes - estimateSnapshotSize(existing));
|
|
203
|
-
entry.bytes += estimateSnapshotSize(merged);
|
|
204
|
-
}
|
|
205
|
-
entry.snapshots.set(merged.correlationId, merged);
|
|
206
|
-
}
|
|
207
|
-
}
|
|
208
|
-
|
|
209
|
-
applyCacheLimit(entry, maxBytes);
|
|
210
|
-
workspaceSnapshotCache.set(workspacePath, entry);
|
|
211
|
-
return Array.from(entry.snapshots.values()).sort((a, b) => b.updatedAt - a.updatedAt);
|
|
212
|
-
}
|
package/src/lib/events/store.ts
DELETED
|
@@ -1,141 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Wide event storage and query helpers
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import { existsSync, readFileSync, readdirSync } from 'fs';
|
|
6
|
-
import { join } from 'path';
|
|
7
|
-
import type { WideEvent, WideEventFilter, WideEventIndex } from '../../types/events.js';
|
|
8
|
-
|
|
9
|
-
export interface WideEventQueryOptions {
|
|
10
|
-
filter: WideEventFilter;
|
|
11
|
-
limit?: number;
|
|
12
|
-
sinceMs?: number;
|
|
13
|
-
untilMs?: number;
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
export function listEventIndexes(eventsDir: string): WideEventIndex[] {
|
|
17
|
-
if (!existsSync(eventsDir)) {
|
|
18
|
-
return [];
|
|
19
|
-
}
|
|
20
|
-
return readdirSync(eventsDir)
|
|
21
|
-
.filter((file) => file.endsWith('.index.json'))
|
|
22
|
-
.map((file) => {
|
|
23
|
-
const path = join(eventsDir, file);
|
|
24
|
-
try {
|
|
25
|
-
const data = JSON.parse(readFileSync(path, 'utf-8')) as WideEventIndex;
|
|
26
|
-
return data;
|
|
27
|
-
} catch {
|
|
28
|
-
return null;
|
|
29
|
-
}
|
|
30
|
-
})
|
|
31
|
-
.filter((item): item is WideEventIndex => Boolean(item));
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
export function selectFilesForQuery(indexes: WideEventIndex[], options: WideEventQueryOptions): WideEventIndex[] {
|
|
35
|
-
return indexes.filter((index) => {
|
|
36
|
-
if (options.sinceMs !== undefined && index.maxTs < options.sinceMs) {
|
|
37
|
-
return false;
|
|
38
|
-
}
|
|
39
|
-
if (options.untilMs !== undefined && index.minTs > options.untilMs) {
|
|
40
|
-
return false;
|
|
41
|
-
}
|
|
42
|
-
if (options.filter.level && !index.levels.includes(options.filter.level)) {
|
|
43
|
-
return false;
|
|
44
|
-
}
|
|
45
|
-
if (options.filter.eventName && !index.eventNames.includes(options.filter.eventName)) {
|
|
46
|
-
return false;
|
|
47
|
-
}
|
|
48
|
-
return true;
|
|
49
|
-
});
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
export function queryEvents(
|
|
53
|
-
eventsDir: string,
|
|
54
|
-
indexes: WideEventIndex[],
|
|
55
|
-
options: WideEventQueryOptions
|
|
56
|
-
): WideEvent[] {
|
|
57
|
-
const results: WideEvent[] = [];
|
|
58
|
-
const limit = options.limit ?? 100;
|
|
59
|
-
|
|
60
|
-
for (const index of indexes) {
|
|
61
|
-
const path = join(eventsDir, index.file);
|
|
62
|
-
if (!existsSync(path)) continue;
|
|
63
|
-
|
|
64
|
-
const lines = readFileSync(path, 'utf-8').split('\n');
|
|
65
|
-
for (let i = lines.length - 1; i >= 0; i -= 1) {
|
|
66
|
-
const line = lines[i];
|
|
67
|
-
if (!line || !line.trim()) continue;
|
|
68
|
-
try {
|
|
69
|
-
const raw = JSON.parse(line) as Record<string, unknown>;
|
|
70
|
-
const event = normalizeStoredEvent(raw);
|
|
71
|
-
if (!event) continue;
|
|
72
|
-
if (!matchesQuery(event, options)) continue;
|
|
73
|
-
results.push(event);
|
|
74
|
-
if (results.length >= limit) {
|
|
75
|
-
return results;
|
|
76
|
-
}
|
|
77
|
-
} catch {
|
|
78
|
-
// Ignore malformed lines
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
return results;
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
function normalizeStoredEvent(raw: Record<string, unknown>): WideEvent | null {
|
|
87
|
-
if (!raw || typeof raw !== 'object') return null;
|
|
88
|
-
const eventId = typeof raw.eventId === 'string' ? raw.eventId : null;
|
|
89
|
-
const eventName = typeof raw.eventName === 'string' ? raw.eventName : null;
|
|
90
|
-
const level = typeof raw.level === 'string' ? raw.level : null;
|
|
91
|
-
const timestamp = typeof raw.timestamp === 'string' ? raw.timestamp : null;
|
|
92
|
-
const message = typeof raw.message === 'string' ? raw.message : null;
|
|
93
|
-
const timestampMs = typeof raw.timestampMs === 'number' ? raw.timestampMs : Date.parse(timestamp ?? '');
|
|
94
|
-
const sessionId = typeof raw.sessionId === 'string' ? raw.sessionId : '';
|
|
95
|
-
const workspaceId = typeof raw.workspaceId === 'string' ? raw.workspaceId : '';
|
|
96
|
-
const projectName = typeof raw.projectName === 'string' ? raw.projectName : '';
|
|
97
|
-
const processName = typeof raw.processName === 'string' ? raw.processName : undefined;
|
|
98
|
-
const processInstance = typeof raw.processInstance === 'number' ? raw.processInstance : undefined;
|
|
99
|
-
const kind = raw.kind === 'wide' || raw.kind === 'source' ? raw.kind : undefined;
|
|
100
|
-
const correlationId = typeof raw.correlationId === 'string' ? raw.correlationId : undefined;
|
|
101
|
-
const timeline = Array.isArray(raw.timeline)
|
|
102
|
-
? (raw.timeline as WideEvent['timeline'])
|
|
103
|
-
: undefined;
|
|
104
|
-
|
|
105
|
-
if (!eventId || !eventName || !level || !timestamp || !message || Number.isNaN(timestampMs)) {
|
|
106
|
-
return null;
|
|
107
|
-
}
|
|
108
|
-
|
|
109
|
-
return {
|
|
110
|
-
eventId,
|
|
111
|
-
eventName,
|
|
112
|
-
level,
|
|
113
|
-
timestamp,
|
|
114
|
-
timestampMs,
|
|
115
|
-
message,
|
|
116
|
-
sessionId,
|
|
117
|
-
workspaceId,
|
|
118
|
-
projectName,
|
|
119
|
-
processName,
|
|
120
|
-
processInstance,
|
|
121
|
-
raw,
|
|
122
|
-
kind,
|
|
123
|
-
correlationId,
|
|
124
|
-
timeline,
|
|
125
|
-
};
|
|
126
|
-
|
|
127
|
-
}
|
|
128
|
-
|
|
129
|
-
function matchesQuery(event: WideEvent, options: WideEventQueryOptions): boolean {
|
|
130
|
-
const { filter, sinceMs, untilMs } = options;
|
|
131
|
-
if (filter.eventName && event.eventName !== filter.eventName) return false;
|
|
132
|
-
if (filter.eventId && event.eventId !== filter.eventId) return false;
|
|
133
|
-
if (filter.level && event.level !== filter.level) return false;
|
|
134
|
-
if (filter.message && !event.message.includes(filter.message)) return false;
|
|
135
|
-
if (filter.processName && event.processName !== filter.processName) return false;
|
|
136
|
-
if (filter.kind && event.kind !== filter.kind) return false;
|
|
137
|
-
if (filter.correlationId && event.correlationId !== filter.correlationId) return false;
|
|
138
|
-
if (sinceMs !== undefined && event.timestampMs < sinceMs) return false;
|
|
139
|
-
if (untilMs !== undefined && event.timestampMs > untilMs) return false;
|
|
140
|
-
return true;
|
|
141
|
-
}
|
package/src/lib/invite.web.ts
DELETED
|
@@ -1,58 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Invite token parsing
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
export interface ParsedInvite {
|
|
6
|
-
inviteToken: string; // Full invite token for X3DH authorization
|
|
7
|
-
machineId: string;
|
|
8
|
-
inviteId: string; // Short hash for relay lookup
|
|
9
|
-
relayUrl?: string;
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
/**
|
|
13
|
-
* Parse invite from URL hash
|
|
14
|
-
* Format: #invite=base64url(JSON)
|
|
15
|
-
*/
|
|
16
|
-
export async function parseInviteFromHash(hash: string): Promise<ParsedInvite | null> {
|
|
17
|
-
try {
|
|
18
|
-
const prefix = "#invite=";
|
|
19
|
-
if (!hash.startsWith(prefix)) return null;
|
|
20
|
-
|
|
21
|
-
const encoded = hash.slice(prefix.length);
|
|
22
|
-
|
|
23
|
-
// Decode base64url
|
|
24
|
-
const base64 = encoded.replace(/-/g, "+").replace(/_/g, "/");
|
|
25
|
-
const padding = "=".repeat((4 - (base64.length % 4)) % 4);
|
|
26
|
-
const decoded = atob(base64 + padding);
|
|
27
|
-
|
|
28
|
-
const invite = JSON.parse(decoded);
|
|
29
|
-
|
|
30
|
-
// Generate invite ID from token (first 16 chars of hash)
|
|
31
|
-
const inviteId = await generateInviteId(encoded);
|
|
32
|
-
|
|
33
|
-
return {
|
|
34
|
-
inviteToken: encoded, // Full token for X3DH auth
|
|
35
|
-
machineId: invite.machineId,
|
|
36
|
-
inviteId, // Short hash for relay lookup
|
|
37
|
-
relayUrl: invite.relayUrl,
|
|
38
|
-
};
|
|
39
|
-
} catch (e) {
|
|
40
|
-
console.error("Failed to parse invite:", e);
|
|
41
|
-
return null;
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
/**
|
|
46
|
-
* Generate invite ID from token (simple hash)
|
|
47
|
-
*/
|
|
48
|
-
async function generateInviteId(token: string): Promise<string> {
|
|
49
|
-
const encoder = new TextEncoder();
|
|
50
|
-
const data = encoder.encode(token);
|
|
51
|
-
const hashBuffer = await crypto.subtle.digest("SHA-256", data);
|
|
52
|
-
const hashArray = new Uint8Array(hashBuffer);
|
|
53
|
-
const hashBase64 = btoa(String.fromCharCode(...hashArray))
|
|
54
|
-
.replace(/\+/g, "-")
|
|
55
|
-
.replace(/\//g, "_")
|
|
56
|
-
.replace(/=/g, "");
|
|
57
|
-
return hashBase64.slice(0, 16);
|
|
58
|
-
}
|
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
import type { PreferencesService } from '../preferences/index.js';
|
|
2
|
-
import type { NotificationConfig } from '../notifications/types.js';
|
|
3
|
-
import { DEFAULT_NOTIFICATION_CONFIG } from '../notifications/types.js';
|
|
4
|
-
|
|
5
|
-
const NOTIFICATION_CONFIG_STORAGE_KEY = 'gitspace:web:notification-config';
|
|
6
|
-
|
|
7
|
-
/**
|
|
8
|
-
* Browser preferences service backed by localStorage.
|
|
9
|
-
*/
|
|
10
|
-
export const browserPreferencesService: PreferencesService = {
|
|
11
|
-
async getNotificationConfig(): Promise<NotificationConfig> {
|
|
12
|
-
try {
|
|
13
|
-
const raw = localStorage.getItem(NOTIFICATION_CONFIG_STORAGE_KEY);
|
|
14
|
-
if (!raw) {
|
|
15
|
-
return { ...DEFAULT_NOTIFICATION_CONFIG };
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
const parsed = JSON.parse(raw) as Partial<NotificationConfig>;
|
|
19
|
-
return {
|
|
20
|
-
enabled: parsed.enabled ?? DEFAULT_NOTIFICATION_CONFIG.enabled,
|
|
21
|
-
minCommandDurationMs:
|
|
22
|
-
parsed.minCommandDurationMs ?? DEFAULT_NOTIFICATION_CONFIG.minCommandDurationMs,
|
|
23
|
-
types: {
|
|
24
|
-
...DEFAULT_NOTIFICATION_CONFIG.types,
|
|
25
|
-
...(parsed.types || {}),
|
|
26
|
-
},
|
|
27
|
-
toast: {
|
|
28
|
-
...DEFAULT_NOTIFICATION_CONFIG.toast,
|
|
29
|
-
...(parsed.toast || {}),
|
|
30
|
-
},
|
|
31
|
-
};
|
|
32
|
-
} catch {
|
|
33
|
-
return { ...DEFAULT_NOTIFICATION_CONFIG };
|
|
34
|
-
}
|
|
35
|
-
},
|
|
36
|
-
|
|
37
|
-
async updateNotificationConfig(config: NotificationConfig): Promise<NotificationConfig> {
|
|
38
|
-
localStorage.setItem(NOTIFICATION_CONFIG_STORAGE_KEY, JSON.stringify(config));
|
|
39
|
-
return config;
|
|
40
|
-
},
|
|
41
|
-
};
|
|
@@ -1,83 +0,0 @@
|
|
|
1
|
-
import { describe, expect, it } from 'bun:test';
|
|
2
|
-
import { mkdtempSync, mkdirSync, rmSync, writeFileSync } from 'fs';
|
|
3
|
-
import { join } from 'path';
|
|
4
|
-
import { tmpdir } from 'os';
|
|
5
|
-
import {
|
|
6
|
-
getProcessesConfigPath,
|
|
7
|
-
loadProcessesConfig,
|
|
8
|
-
loadProcessesConfigWithDiagnostics,
|
|
9
|
-
} from '../config.js';
|
|
10
|
-
|
|
11
|
-
function makeWorkspace(): string {
|
|
12
|
-
const dir = mkdtempSync(join(tmpdir(), 'gssh-process-config-'));
|
|
13
|
-
mkdirSync(join(dir, '.gitspace'), { recursive: true });
|
|
14
|
-
return dir;
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
function withWorkspace<T>(run: (workspace: string) => T): T {
|
|
18
|
-
const workspace = makeWorkspace();
|
|
19
|
-
try {
|
|
20
|
-
return run(workspace);
|
|
21
|
-
} finally {
|
|
22
|
-
rmSync(workspace, { recursive: true, force: true });
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
describe('loadProcessesConfigWithDiagnostics', () => {
|
|
27
|
-
it('parses JSONC comments and trailing commas', () => {
|
|
28
|
-
withWorkspace((workspace) => {
|
|
29
|
-
const path = getProcessesConfigPath(workspace);
|
|
30
|
-
writeFileSync(path, [
|
|
31
|
-
'{',
|
|
32
|
-
' // One process',
|
|
33
|
-
' "processes": [',
|
|
34
|
-
' {',
|
|
35
|
-
' "name": "web",',
|
|
36
|
-
' "command": "bun",',
|
|
37
|
-
' "args": ["run", "dev",],',
|
|
38
|
-
' },',
|
|
39
|
-
' ],',
|
|
40
|
-
'}',
|
|
41
|
-
'',
|
|
42
|
-
].join('\n'));
|
|
43
|
-
|
|
44
|
-
const result = loadProcessesConfigWithDiagnostics(workspace);
|
|
45
|
-
expect(result.error).toBeNull();
|
|
46
|
-
expect(result.config.processes).toHaveLength(1);
|
|
47
|
-
expect(result.config.processes[0]?.name).toBe('web');
|
|
48
|
-
});
|
|
49
|
-
});
|
|
50
|
-
|
|
51
|
-
it('returns parse diagnostics for malformed JSONC', () => {
|
|
52
|
-
withWorkspace((workspace) => {
|
|
53
|
-
const path = getProcessesConfigPath(workspace);
|
|
54
|
-
writeFileSync(path, '{\n "processes": [\n {\n');
|
|
55
|
-
|
|
56
|
-
const result = loadProcessesConfigWithDiagnostics(workspace);
|
|
57
|
-
expect(result.config.processes).toEqual([]);
|
|
58
|
-
expect(result.error).toContain('Failed to parse .gitspace/processes.json');
|
|
59
|
-
});
|
|
60
|
-
});
|
|
61
|
-
|
|
62
|
-
it('returns validation diagnostics for invalid config', () => {
|
|
63
|
-
withWorkspace((workspace) => {
|
|
64
|
-
const path = getProcessesConfigPath(workspace);
|
|
65
|
-
writeFileSync(path, '{"processes":[{"name":"web"}]}');
|
|
66
|
-
|
|
67
|
-
const result = loadProcessesConfigWithDiagnostics(workspace);
|
|
68
|
-
expect(result.error).toContain('Invalid .gitspace/processes.json');
|
|
69
|
-
expect(result.error).toContain('missing command');
|
|
70
|
-
});
|
|
71
|
-
});
|
|
72
|
-
|
|
73
|
-
it('loadProcessesConfig stays backward-compatible', () => {
|
|
74
|
-
withWorkspace((workspace) => {
|
|
75
|
-
const path = getProcessesConfigPath(workspace);
|
|
76
|
-
writeFileSync(path, '{"processes":[{"name":"api","command":"bun"}]}');
|
|
77
|
-
|
|
78
|
-
const config = loadProcessesConfig(workspace);
|
|
79
|
-
expect(config.processes).toHaveLength(1);
|
|
80
|
-
expect(config.processes[0]?.name).toBe('api');
|
|
81
|
-
});
|
|
82
|
-
});
|
|
83
|
-
});
|