@build-astron-co/nimbus 0.4.2 → 0.4.3
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/dist/src/agent/compaction-agent.js +24 -12
- package/dist/src/agent/context-manager.js +2 -1
- package/dist/src/agent/expand-files.js +2 -1
- package/dist/src/agent/loop.js +71 -33
- package/dist/src/agent/permissions.js +4 -2
- package/dist/src/agent/system-prompt.js +34 -17
- package/dist/src/app.js +1 -1
- package/dist/src/auth/keychain.js +8 -4
- package/dist/src/auth/store.js +70 -107
- package/dist/src/cli/init.js +35 -19
- package/dist/src/cli/run.js +18 -10
- package/dist/src/cli/serve.js +4 -2
- package/dist/src/cli.js +52 -11
- package/dist/src/commands/alias.js +5 -3
- package/dist/src/commands/audit/index.js +2 -1
- package/dist/src/commands/aws-terraform.js +36 -18
- package/dist/src/commands/completions.js +1 -1
- package/dist/src/commands/config.js +3 -2
- package/dist/src/commands/connect-github.js +92 -0
- package/dist/src/commands/cost/index.js +3 -2
- package/dist/src/commands/deploy.js +15 -10
- package/dist/src/commands/doctor.js +6 -3
- package/dist/src/commands/drift/index.js +2 -1
- package/dist/src/commands/export.js +5 -3
- package/dist/src/commands/generate-terraform.js +110 -2
- package/dist/src/commands/import.js +3 -3
- package/dist/src/commands/incident.js +10 -5
- package/dist/src/commands/login.js +8 -93
- package/dist/src/commands/logs.js +16 -8
- package/dist/src/commands/onboarding.js +6 -4
- package/dist/src/commands/pipeline.js +6 -3
- package/dist/src/commands/plugin.js +3 -2
- package/dist/src/commands/profile.js +27 -14
- package/dist/src/commands/questionnaire.js +1 -1
- package/dist/src/commands/rollback.js +3 -2
- package/dist/src/commands/rollout.js +5 -3
- package/dist/src/commands/runbook.js +17 -10
- package/dist/src/commands/schedule.js +10 -5
- package/dist/src/commands/status.js +2 -1
- package/dist/src/commands/team-context.js +12 -7
- package/dist/src/commands/template.js +1 -1
- package/dist/src/commands/tf/index.js +6 -3
- package/dist/src/commands/version.js +6 -3
- package/dist/src/commands/watch.js +6 -3
- package/dist/src/compat/sqlite.js +5 -3
- package/dist/src/config/mode-store.js +2 -1
- package/dist/src/config/profiles.js +4 -2
- package/dist/src/config/types.js +2 -1
- package/dist/src/engine/executor.js +8 -4
- package/dist/src/engine/planner.js +9 -5
- package/dist/src/llm/providers/anthropic.js +6 -3
- package/dist/src/llm/providers/ollama.js +1 -1
- package/dist/src/llm/router.js +22 -7
- package/dist/src/sessions/manager.js +6 -3
- package/dist/src/sharing/viewer.js +2 -1
- package/dist/src/tools/file-ops.js +1 -2
- package/dist/src/tools/schemas/devops.js +197 -108
- package/dist/src/tools/schemas/standard.js +1 -1
- package/dist/src/ui/App.js +25 -13
- package/dist/src/ui/FileDiffModal.js +22 -11
- package/dist/src/ui/HelpModal.js +2 -1
- package/dist/src/ui/InputBox.js +6 -3
- package/dist/src/ui/MessageList.js +40 -20
- package/dist/src/ui/TerminalPane.js +2 -1
- package/dist/src/ui/ToolCallDisplay.js +12 -6
- package/dist/src/ui/TreePane.js +2 -1
- package/dist/src/ui/ink/index.js +37 -21
- package/dist/src/watcher/index.js +8 -4
- package/package.json +3 -5
- package/src/__tests__/alias.test.ts +0 -133
- package/src/__tests__/app.test.ts +0 -76
- package/src/__tests__/audit.test.ts +0 -877
- package/src/__tests__/circuit-breaker.test.ts +0 -116
- package/src/__tests__/cli-run.test.ts +0 -351
- package/src/__tests__/compat-sqlite.test.ts +0 -68
- package/src/__tests__/context-manager.test.ts +0 -632
- package/src/__tests__/context.test.ts +0 -242
- package/src/__tests__/devops-terminal-gaps.test.ts +0 -718
- package/src/__tests__/doctor.test.ts +0 -48
- package/src/__tests__/enterprise.test.ts +0 -401
- package/src/__tests__/export.test.ts +0 -236
- package/src/__tests__/gap-11-18-20.test.ts +0 -958
- package/src/__tests__/generator.test.ts +0 -433
- package/src/__tests__/helm-streaming.test.ts +0 -127
- package/src/__tests__/hooks.test.ts +0 -582
- package/src/__tests__/incident.test.ts +0 -179
- package/src/__tests__/init.test.ts +0 -487
- package/src/__tests__/intent-parser.test.ts +0 -229
- package/src/__tests__/llm-router.test.ts +0 -209
- package/src/__tests__/logs.test.ts +0 -107
- package/src/__tests__/loop-errors.test.ts +0 -244
- package/src/__tests__/lsp.test.ts +0 -293
- package/src/__tests__/modes.test.ts +0 -336
- package/src/__tests__/perf-optimizations.test.ts +0 -847
- package/src/__tests__/permissions.test.ts +0 -338
- package/src/__tests__/pipeline.test.ts +0 -50
- package/src/__tests__/polish-phase3.test.ts +0 -340
- package/src/__tests__/profile.test.ts +0 -237
- package/src/__tests__/rollback.test.ts +0 -83
- package/src/__tests__/runbook.test.ts +0 -219
- package/src/__tests__/schedule.test.ts +0 -206
- package/src/__tests__/serve.test.ts +0 -275
- package/src/__tests__/sessions.test.ts +0 -322
- package/src/__tests__/sharing.test.ts +0 -340
- package/src/__tests__/snapshots.test.ts +0 -581
- package/src/__tests__/standalone-migration.test.ts +0 -199
- package/src/__tests__/state-db.test.ts +0 -334
- package/src/__tests__/status.test.ts +0 -158
- package/src/__tests__/stream-with-tools.test.ts +0 -778
- package/src/__tests__/subagents.test.ts +0 -176
- package/src/__tests__/system-prompt.test.ts +0 -248
- package/src/__tests__/terminal-gap-v2.test.ts +0 -395
- package/src/__tests__/terminal-parity.test.ts +0 -393
- package/src/__tests__/tf-apply.test.ts +0 -187
- package/src/__tests__/tool-converter.test.ts +0 -256
- package/src/__tests__/tool-schemas.test.ts +0 -602
- package/src/__tests__/tools.test.ts +0 -144
- package/src/__tests__/version-json.test.ts +0 -184
- package/src/__tests__/version.test.ts +0 -49
- package/src/__tests__/watch.test.ts +0 -129
- package/src/agent/compaction-agent.ts +0 -266
- package/src/agent/context-manager.ts +0 -499
- package/src/agent/context.ts +0 -427
- package/src/agent/deploy-preview.ts +0 -487
- package/src/agent/expand-files.ts +0 -108
- package/src/agent/index.ts +0 -68
- package/src/agent/loop.ts +0 -1998
- package/src/agent/modes.ts +0 -429
- package/src/agent/permissions.ts +0 -513
- package/src/agent/subagents/base.ts +0 -116
- package/src/agent/subagents/cost.ts +0 -51
- package/src/agent/subagents/explore.ts +0 -42
- package/src/agent/subagents/general.ts +0 -54
- package/src/agent/subagents/index.ts +0 -102
- package/src/agent/subagents/infra.ts +0 -59
- package/src/agent/subagents/security.ts +0 -69
- package/src/agent/system-prompt.ts +0 -990
- package/src/app.ts +0 -180
- package/src/audit/activity-log.ts +0 -290
- package/src/audit/compliance-checker.ts +0 -540
- package/src/audit/cost-tracker.ts +0 -318
- package/src/audit/index.ts +0 -23
- package/src/audit/security-scanner.ts +0 -641
- package/src/auth/guard.ts +0 -75
- package/src/auth/index.ts +0 -56
- package/src/auth/keychain.ts +0 -82
- package/src/auth/oauth.ts +0 -465
- package/src/auth/providers.ts +0 -470
- package/src/auth/sso.ts +0 -113
- package/src/auth/store.ts +0 -505
- package/src/auth/types.ts +0 -187
- package/src/build.ts +0 -141
- package/src/cli/index.ts +0 -16
- package/src/cli/init.ts +0 -1227
- package/src/cli/openapi-spec.ts +0 -356
- package/src/cli/run.ts +0 -628
- package/src/cli/serve-auth.ts +0 -80
- package/src/cli/serve.ts +0 -539
- package/src/cli/web.ts +0 -71
- package/src/cli.ts +0 -1728
- package/src/clients/core-engine-client.ts +0 -227
- package/src/clients/enterprise-client.ts +0 -334
- package/src/clients/generator-client.ts +0 -351
- package/src/clients/git-client.ts +0 -627
- package/src/clients/github-client.ts +0 -410
- package/src/clients/helm-client.ts +0 -504
- package/src/clients/index.ts +0 -80
- package/src/clients/k8s-client.ts +0 -497
- package/src/clients/llm-client.ts +0 -161
- package/src/clients/rest-client.ts +0 -130
- package/src/clients/service-discovery.ts +0 -38
- package/src/clients/terraform-client.ts +0 -482
- package/src/clients/tools-client.ts +0 -1843
- package/src/clients/ws-client.ts +0 -115
- package/src/commands/alias.ts +0 -100
- package/src/commands/analyze/index.ts +0 -352
- package/src/commands/apply/helm.ts +0 -473
- package/src/commands/apply/index.ts +0 -213
- package/src/commands/apply/k8s.ts +0 -454
- package/src/commands/apply/terraform.ts +0 -582
- package/src/commands/ask.ts +0 -167
- package/src/commands/audit/index.ts +0 -357
- package/src/commands/auth-cloud.ts +0 -407
- package/src/commands/auth-list.ts +0 -134
- package/src/commands/auth-profile.ts +0 -121
- package/src/commands/auth-refresh.ts +0 -187
- package/src/commands/auth-status.ts +0 -141
- package/src/commands/aws/ec2.ts +0 -501
- package/src/commands/aws/iam.ts +0 -397
- package/src/commands/aws/index.ts +0 -133
- package/src/commands/aws/lambda.ts +0 -396
- package/src/commands/aws/rds.ts +0 -439
- package/src/commands/aws/s3.ts +0 -439
- package/src/commands/aws/vpc.ts +0 -393
- package/src/commands/aws-discover.ts +0 -542
- package/src/commands/aws-terraform.ts +0 -755
- package/src/commands/azure/aks.ts +0 -376
- package/src/commands/azure/functions.ts +0 -253
- package/src/commands/azure/index.ts +0 -116
- package/src/commands/azure/storage.ts +0 -478
- package/src/commands/azure/vm.ts +0 -355
- package/src/commands/billing/index.ts +0 -256
- package/src/commands/chat.ts +0 -320
- package/src/commands/completions.ts +0 -268
- package/src/commands/config.ts +0 -372
- package/src/commands/cost/cloud-cost-estimator.ts +0 -266
- package/src/commands/cost/estimator.ts +0 -79
- package/src/commands/cost/index.ts +0 -810
- package/src/commands/cost/parsers/terraform.ts +0 -273
- package/src/commands/cost/parsers/types.ts +0 -25
- package/src/commands/cost/pricing/aws.ts +0 -544
- package/src/commands/cost/pricing/azure.ts +0 -499
- package/src/commands/cost/pricing/gcp.ts +0 -396
- package/src/commands/cost/pricing/index.ts +0 -40
- package/src/commands/demo.ts +0 -250
- package/src/commands/deploy.ts +0 -260
- package/src/commands/doctor.ts +0 -1386
- package/src/commands/drift/index.ts +0 -787
- package/src/commands/explain.ts +0 -277
- package/src/commands/export.ts +0 -146
- package/src/commands/feedback.ts +0 -389
- package/src/commands/fix.ts +0 -324
- package/src/commands/fs/index.ts +0 -402
- package/src/commands/gcp/compute.ts +0 -325
- package/src/commands/gcp/functions.ts +0 -271
- package/src/commands/gcp/gke.ts +0 -438
- package/src/commands/gcp/iam.ts +0 -344
- package/src/commands/gcp/index.ts +0 -129
- package/src/commands/gcp/storage.ts +0 -284
- package/src/commands/generate-helm.ts +0 -1249
- package/src/commands/generate-k8s.ts +0 -1508
- package/src/commands/generate-terraform.ts +0 -1202
- package/src/commands/gh/index.ts +0 -863
- package/src/commands/git/index.ts +0 -1343
- package/src/commands/helm/index.ts +0 -1126
- package/src/commands/help.ts +0 -715
- package/src/commands/history.ts +0 -149
- package/src/commands/import.ts +0 -868
- package/src/commands/incident.ts +0 -166
- package/src/commands/index.ts +0 -367
- package/src/commands/init.ts +0 -1051
- package/src/commands/k8s/index.ts +0 -1137
- package/src/commands/login.ts +0 -716
- package/src/commands/logout.ts +0 -83
- package/src/commands/logs.ts +0 -167
- package/src/commands/onboarding.ts +0 -405
- package/src/commands/pipeline.ts +0 -186
- package/src/commands/plan/display.ts +0 -279
- package/src/commands/plan/index.ts +0 -599
- package/src/commands/plugin.ts +0 -398
- package/src/commands/preview.ts +0 -452
- package/src/commands/profile.ts +0 -342
- package/src/commands/questionnaire.ts +0 -1172
- package/src/commands/resume.ts +0 -47
- package/src/commands/rollback.ts +0 -315
- package/src/commands/rollout.ts +0 -88
- package/src/commands/runbook.ts +0 -346
- package/src/commands/schedule.ts +0 -236
- package/src/commands/status.ts +0 -252
- package/src/commands/team/index.ts +0 -346
- package/src/commands/team-context.ts +0 -220
- package/src/commands/template.ts +0 -233
- package/src/commands/tf/index.ts +0 -1093
- package/src/commands/upgrade.ts +0 -609
- package/src/commands/usage/index.ts +0 -134
- package/src/commands/version.ts +0 -174
- package/src/commands/watch.ts +0 -153
- package/src/compat/index.ts +0 -2
- package/src/compat/runtime.ts +0 -12
- package/src/compat/sqlite.ts +0 -177
- package/src/config/index.ts +0 -17
- package/src/config/manager.ts +0 -530
- package/src/config/mode-store.ts +0 -62
- package/src/config/profiles.ts +0 -84
- package/src/config/safety-policy.ts +0 -358
- package/src/config/schema.ts +0 -125
- package/src/config/types.ts +0 -609
- package/src/config/workspace-state.ts +0 -53
- package/src/context/context-db.ts +0 -199
- package/src/demo/index.ts +0 -349
- package/src/demo/scenarios/full-journey.ts +0 -229
- package/src/demo/scenarios/getting-started.ts +0 -127
- package/src/demo/scenarios/helm-release.ts +0 -341
- package/src/demo/scenarios/k8s-deployment.ts +0 -194
- package/src/demo/scenarios/terraform-vpc.ts +0 -170
- package/src/demo/types.ts +0 -92
- package/src/engine/cost-estimator.ts +0 -480
- package/src/engine/diagram-generator.ts +0 -256
- package/src/engine/drift-detector.ts +0 -902
- package/src/engine/executor.ts +0 -1066
- package/src/engine/index.ts +0 -76
- package/src/engine/orchestrator.ts +0 -636
- package/src/engine/planner.ts +0 -787
- package/src/engine/safety.ts +0 -743
- package/src/engine/verifier.ts +0 -770
- package/src/enterprise/audit.ts +0 -348
- package/src/enterprise/auth.ts +0 -270
- package/src/enterprise/billing.ts +0 -822
- package/src/enterprise/index.ts +0 -17
- package/src/enterprise/teams.ts +0 -443
- package/src/generator/best-practices.ts +0 -1608
- package/src/generator/helm.ts +0 -630
- package/src/generator/index.ts +0 -37
- package/src/generator/intent-parser.ts +0 -514
- package/src/generator/kubernetes.ts +0 -976
- package/src/generator/terraform.ts +0 -1875
- package/src/history/index.ts +0 -8
- package/src/history/manager.ts +0 -250
- package/src/history/types.ts +0 -34
- package/src/hooks/config.ts +0 -432
- package/src/hooks/engine.ts +0 -392
- package/src/hooks/index.ts +0 -4
- package/src/llm/auth-bridge.ts +0 -198
- package/src/llm/circuit-breaker.ts +0 -140
- package/src/llm/config-loader.ts +0 -201
- package/src/llm/cost-calculator.ts +0 -171
- package/src/llm/index.ts +0 -8
- package/src/llm/model-aliases.ts +0 -115
- package/src/llm/provider-registry.ts +0 -63
- package/src/llm/providers/anthropic.ts +0 -462
- package/src/llm/providers/bedrock.ts +0 -477
- package/src/llm/providers/google.ts +0 -405
- package/src/llm/providers/ollama.ts +0 -767
- package/src/llm/providers/openai-compatible.ts +0 -340
- package/src/llm/providers/openai.ts +0 -328
- package/src/llm/providers/openrouter.ts +0 -338
- package/src/llm/router.ts +0 -1104
- package/src/llm/types.ts +0 -232
- package/src/lsp/client.ts +0 -298
- package/src/lsp/languages.ts +0 -119
- package/src/lsp/manager.ts +0 -294
- package/src/mcp/client.ts +0 -402
- package/src/mcp/index.ts +0 -5
- package/src/mcp/manager.ts +0 -133
- package/src/nimbus.ts +0 -234
- package/src/plugins/index.ts +0 -27
- package/src/plugins/loader.ts +0 -334
- package/src/plugins/manager.ts +0 -376
- package/src/plugins/types.ts +0 -284
- package/src/scanners/cicd-scanner.ts +0 -258
- package/src/scanners/cloud-scanner.ts +0 -466
- package/src/scanners/framework-scanner.ts +0 -469
- package/src/scanners/iac-scanner.ts +0 -388
- package/src/scanners/index.ts +0 -539
- package/src/scanners/language-scanner.ts +0 -276
- package/src/scanners/package-manager-scanner.ts +0 -277
- package/src/scanners/types.ts +0 -172
- package/src/sessions/manager.ts +0 -472
- package/src/sessions/types.ts +0 -44
- package/src/sharing/sync.ts +0 -300
- package/src/sharing/viewer.ts +0 -163
- package/src/snapshots/index.ts +0 -2
- package/src/snapshots/manager.ts +0 -530
- package/src/state/artifacts.ts +0 -147
- package/src/state/audit.ts +0 -137
- package/src/state/billing.ts +0 -240
- package/src/state/checkpoints.ts +0 -117
- package/src/state/config.ts +0 -67
- package/src/state/conversations.ts +0 -14
- package/src/state/credentials.ts +0 -154
- package/src/state/db.ts +0 -58
- package/src/state/index.ts +0 -26
- package/src/state/messages.ts +0 -115
- package/src/state/projects.ts +0 -123
- package/src/state/schema.ts +0 -236
- package/src/state/sessions.ts +0 -147
- package/src/state/teams.ts +0 -200
- package/src/telemetry.ts +0 -108
- package/src/tools/aws-ops.ts +0 -952
- package/src/tools/azure-ops.ts +0 -579
- package/src/tools/file-ops.ts +0 -615
- package/src/tools/gcp-ops.ts +0 -625
- package/src/tools/git-ops.ts +0 -773
- package/src/tools/github-ops.ts +0 -799
- package/src/tools/helm-ops.ts +0 -943
- package/src/tools/index.ts +0 -17
- package/src/tools/k8s-ops.ts +0 -819
- package/src/tools/schemas/converter.ts +0 -184
- package/src/tools/schemas/devops.ts +0 -3502
- package/src/tools/schemas/index.ts +0 -73
- package/src/tools/schemas/standard.ts +0 -1148
- package/src/tools/schemas/types.ts +0 -735
- package/src/tools/spawn-exec.ts +0 -148
- package/src/tools/terraform-ops.ts +0 -862
- package/src/types/ambient.d.ts +0 -193
- package/src/types/config.ts +0 -83
- package/src/types/drift.ts +0 -116
- package/src/types/enterprise.ts +0 -335
- package/src/types/index.ts +0 -20
- package/src/types/plan.ts +0 -44
- package/src/types/request.ts +0 -65
- package/src/types/response.ts +0 -54
- package/src/types/service.ts +0 -51
- package/src/ui/App.tsx +0 -2114
- package/src/ui/DeployPreview.tsx +0 -174
- package/src/ui/FileDiffModal.tsx +0 -162
- package/src/ui/Header.tsx +0 -131
- package/src/ui/HelpModal.tsx +0 -57
- package/src/ui/InputBox.tsx +0 -503
- package/src/ui/MessageList.tsx +0 -1032
- package/src/ui/PermissionPrompt.tsx +0 -163
- package/src/ui/StatusBar.tsx +0 -277
- package/src/ui/TerminalPane.tsx +0 -84
- package/src/ui/ToolCallDisplay.tsx +0 -643
- package/src/ui/TreePane.tsx +0 -132
- package/src/ui/chat-ui.ts +0 -850
- package/src/ui/index.ts +0 -33
- package/src/ui/ink/index.ts +0 -1444
- package/src/ui/streaming.ts +0 -176
- package/src/ui/theme.ts +0 -104
- package/src/ui/types.ts +0 -75
- package/src/utils/analytics.ts +0 -72
- package/src/utils/cost-warning.ts +0 -27
- package/src/utils/env.ts +0 -46
- package/src/utils/errors.ts +0 -69
- package/src/utils/event-bus.ts +0 -38
- package/src/utils/index.ts +0 -24
- package/src/utils/logger.ts +0 -171
- package/src/utils/rate-limiter.ts +0 -121
- package/src/utils/service-auth.ts +0 -49
- package/src/utils/validation.ts +0 -53
- package/src/version.ts +0 -4
- package/src/watcher/index.ts +0 -214
- package/src/wizard/approval.ts +0 -383
- package/src/wizard/index.ts +0 -25
- package/src/wizard/prompts.ts +0 -338
- package/src/wizard/types.ts +0 -172
- package/src/wizard/ui.ts +0 -556
- package/src/wizard/wizard.ts +0 -304
- package/tsconfig.json +0 -24
package/src/state/credentials.ts
DELETED
|
@@ -1,154 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Auth token and device-code management helpers.
|
|
3
|
-
*
|
|
4
|
-
* Refactored from the auth-service database adapter
|
|
5
|
-
* (services/auth-service/src/db/adapter.ts) into standalone functions
|
|
6
|
-
* that operate against the unified Nimbus database.
|
|
7
|
-
*/
|
|
8
|
-
|
|
9
|
-
import type { Database } from '../compat/sqlite';
|
|
10
|
-
import { getDb } from './db';
|
|
11
|
-
|
|
12
|
-
/** Row shape for the device_codes table. */
|
|
13
|
-
export interface DeviceCodeRecord {
|
|
14
|
-
deviceCode: string;
|
|
15
|
-
userCode: string;
|
|
16
|
-
clientId: string | null;
|
|
17
|
-
scope: string | null;
|
|
18
|
-
status: string;
|
|
19
|
-
token: string | null;
|
|
20
|
-
expiresAt: string;
|
|
21
|
-
createdAt: string;
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
/** Row shape for the tokens table. */
|
|
25
|
-
export interface TokenRecord {
|
|
26
|
-
id: string;
|
|
27
|
-
userId: string | null;
|
|
28
|
-
token: string;
|
|
29
|
-
type: string;
|
|
30
|
-
expiresAt: string | null;
|
|
31
|
-
createdAt: string;
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
// ---------------------------------------------------------------------------
|
|
35
|
-
// Device Code helpers
|
|
36
|
-
// ---------------------------------------------------------------------------
|
|
37
|
-
|
|
38
|
-
/**
|
|
39
|
-
* Persist a new device code for the OAuth device-authorization flow.
|
|
40
|
-
*/
|
|
41
|
-
export function saveDeviceCode(
|
|
42
|
-
deviceCode: string,
|
|
43
|
-
userCode: string,
|
|
44
|
-
expiresAt: Date,
|
|
45
|
-
clientId?: string,
|
|
46
|
-
scope?: string,
|
|
47
|
-
db?: Database
|
|
48
|
-
): void {
|
|
49
|
-
const d = db || getDb();
|
|
50
|
-
const stmt = d.prepare(`
|
|
51
|
-
INSERT INTO device_codes (device_code, user_code, client_id, scope, status, expires_at)
|
|
52
|
-
VALUES (?, ?, ?, ?, 'pending', ?)
|
|
53
|
-
`);
|
|
54
|
-
|
|
55
|
-
stmt.run(deviceCode, userCode, clientId || null, scope || null, expiresAt.toISOString());
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
/**
|
|
59
|
-
* Retrieve a device code record by its device_code value.
|
|
60
|
-
*/
|
|
61
|
-
export function getDeviceCode(deviceCode: string, db?: Database): DeviceCodeRecord | null {
|
|
62
|
-
const d = db || getDb();
|
|
63
|
-
const stmt = d.prepare('SELECT * FROM device_codes WHERE device_code = ?');
|
|
64
|
-
const row: any = stmt.get(deviceCode);
|
|
65
|
-
|
|
66
|
-
if (!row) {
|
|
67
|
-
return null;
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
return {
|
|
71
|
-
deviceCode: row.device_code,
|
|
72
|
-
userCode: row.user_code,
|
|
73
|
-
clientId: row.client_id,
|
|
74
|
-
scope: row.scope,
|
|
75
|
-
status: row.status,
|
|
76
|
-
token: row.token,
|
|
77
|
-
expiresAt: row.expires_at,
|
|
78
|
-
createdAt: row.created_at,
|
|
79
|
-
};
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
/**
|
|
83
|
-
* Update the status (and optionally the associated token) of a device code.
|
|
84
|
-
*/
|
|
85
|
-
export function updateDeviceCodeStatus(
|
|
86
|
-
deviceCode: string,
|
|
87
|
-
status: string,
|
|
88
|
-
token?: string,
|
|
89
|
-
db?: Database
|
|
90
|
-
): void {
|
|
91
|
-
const d = db || getDb();
|
|
92
|
-
const stmt = d.prepare(`
|
|
93
|
-
UPDATE device_codes
|
|
94
|
-
SET status = ?, token = COALESCE(?, token)
|
|
95
|
-
WHERE device_code = ?
|
|
96
|
-
`);
|
|
97
|
-
|
|
98
|
-
stmt.run(status, token || null, deviceCode);
|
|
99
|
-
}
|
|
100
|
-
|
|
101
|
-
// ---------------------------------------------------------------------------
|
|
102
|
-
// Token helpers
|
|
103
|
-
// ---------------------------------------------------------------------------
|
|
104
|
-
|
|
105
|
-
/**
|
|
106
|
-
* Persist an authentication token.
|
|
107
|
-
*/
|
|
108
|
-
export function saveToken(
|
|
109
|
-
id: string,
|
|
110
|
-
token: string,
|
|
111
|
-
type: string = 'access',
|
|
112
|
-
userId?: string,
|
|
113
|
-
expiresAt?: Date,
|
|
114
|
-
db?: Database
|
|
115
|
-
): void {
|
|
116
|
-
const d = db || getDb();
|
|
117
|
-
const stmt = d.prepare(`
|
|
118
|
-
INSERT INTO tokens (id, user_id, token, type, expires_at)
|
|
119
|
-
VALUES (?, ?, ?, ?, ?)
|
|
120
|
-
`);
|
|
121
|
-
|
|
122
|
-
stmt.run(id, userId || null, token, type, expiresAt ? expiresAt.toISOString() : null);
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
/**
|
|
126
|
-
* Retrieve a token record by its token string value.
|
|
127
|
-
*/
|
|
128
|
-
export function getToken(token: string, db?: Database): TokenRecord | null {
|
|
129
|
-
const d = db || getDb();
|
|
130
|
-
const stmt = d.prepare('SELECT * FROM tokens WHERE token = ?');
|
|
131
|
-
const row: any = stmt.get(token);
|
|
132
|
-
|
|
133
|
-
if (!row) {
|
|
134
|
-
return null;
|
|
135
|
-
}
|
|
136
|
-
|
|
137
|
-
return {
|
|
138
|
-
id: row.id,
|
|
139
|
-
userId: row.user_id,
|
|
140
|
-
token: row.token,
|
|
141
|
-
type: row.type,
|
|
142
|
-
expiresAt: row.expires_at,
|
|
143
|
-
createdAt: row.created_at,
|
|
144
|
-
};
|
|
145
|
-
}
|
|
146
|
-
|
|
147
|
-
/**
|
|
148
|
-
* Delete a token by its token string value.
|
|
149
|
-
*/
|
|
150
|
-
export function deleteToken(token: string, db?: Database): void {
|
|
151
|
-
const d = db || getDb();
|
|
152
|
-
const stmt = d.prepare('DELETE FROM tokens WHERE token = ?');
|
|
153
|
-
stmt.run(token);
|
|
154
|
-
}
|
package/src/state/db.ts
DELETED
|
@@ -1,58 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Database singleton for the Nimbus unified SQLite persistence layer.
|
|
3
|
-
*
|
|
4
|
-
* Provides a lazily-initialized, WAL-mode SQLite database stored at
|
|
5
|
-
* ~/.nimbus/nimbus.db (overridable via NIMBUS_DB_PATH). An in-memory
|
|
6
|
-
* variant is available for tests.
|
|
7
|
-
*/
|
|
8
|
-
|
|
9
|
-
import { Database } from '../compat/sqlite';
|
|
10
|
-
import * as path from 'path';
|
|
11
|
-
import * as os from 'os';
|
|
12
|
-
import * as fs from 'fs';
|
|
13
|
-
import { runMigrations } from './schema';
|
|
14
|
-
|
|
15
|
-
let db: Database | null = null;
|
|
16
|
-
|
|
17
|
-
/**
|
|
18
|
-
* Return the shared Database instance, creating it on first call.
|
|
19
|
-
* The database file lives at `~/.nimbus/nimbus.db` unless the
|
|
20
|
-
* `NIMBUS_DB_PATH` environment variable points elsewhere.
|
|
21
|
-
*/
|
|
22
|
-
export function getDb(): Database {
|
|
23
|
-
if (!db) {
|
|
24
|
-
const nimbusDir = path.join(os.homedir(), '.nimbus');
|
|
25
|
-
if (!fs.existsSync(nimbusDir)) {
|
|
26
|
-
fs.mkdirSync(nimbusDir, { recursive: true });
|
|
27
|
-
}
|
|
28
|
-
const dbPath = process.env.NIMBUS_DB_PATH || path.join(nimbusDir, 'nimbus.db');
|
|
29
|
-
db = new Database(dbPath);
|
|
30
|
-
db.exec('PRAGMA journal_mode=WAL');
|
|
31
|
-
db.exec('PRAGMA foreign_keys=ON');
|
|
32
|
-
runMigrations(db);
|
|
33
|
-
}
|
|
34
|
-
return db;
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
/**
|
|
38
|
-
* Create a throwaway in-memory database for unit / integration tests.
|
|
39
|
-
* Each call returns a fresh, fully-migrated instance.
|
|
40
|
-
*/
|
|
41
|
-
export function getTestDb(): Database {
|
|
42
|
-
const testDb = new Database(':memory:');
|
|
43
|
-
testDb.exec('PRAGMA journal_mode=WAL');
|
|
44
|
-
testDb.exec('PRAGMA foreign_keys=ON');
|
|
45
|
-
runMigrations(testDb);
|
|
46
|
-
return testDb;
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
/**
|
|
50
|
-
* Close the shared database connection and clear the singleton so that
|
|
51
|
-
* a subsequent `getDb()` call will re-open it.
|
|
52
|
-
*/
|
|
53
|
-
export function closeDb(): void {
|
|
54
|
-
if (db) {
|
|
55
|
-
db.close();
|
|
56
|
-
db = null;
|
|
57
|
-
}
|
|
58
|
-
}
|
package/src/state/index.ts
DELETED
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Nimbus unified SQLite persistence layer.
|
|
3
|
-
*
|
|
4
|
-
* Re-exports every public symbol from the individual domain modules so that
|
|
5
|
-
* consumers can do:
|
|
6
|
-
*
|
|
7
|
-
* import { getDb, saveOperation, setConfig, ... } from '../state';
|
|
8
|
-
*/
|
|
9
|
-
|
|
10
|
-
// Database lifecycle
|
|
11
|
-
export { getDb, getTestDb, closeDb } from './db';
|
|
12
|
-
|
|
13
|
-
// Schema / migrations
|
|
14
|
-
export { runMigrations } from './schema';
|
|
15
|
-
|
|
16
|
-
// Domain modules
|
|
17
|
-
export * from './sessions';
|
|
18
|
-
export * from './messages';
|
|
19
|
-
export * from './config';
|
|
20
|
-
export * from './artifacts';
|
|
21
|
-
export * from './audit';
|
|
22
|
-
export * from './credentials';
|
|
23
|
-
export * from './teams';
|
|
24
|
-
export * from './billing';
|
|
25
|
-
export * from './checkpoints';
|
|
26
|
-
export * from './projects';
|
package/src/state/messages.ts
DELETED
|
@@ -1,115 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Message / conversation CRUD helpers.
|
|
3
|
-
*
|
|
4
|
-
* Refactored from SQLiteAdapter.saveConversation, getConversation,
|
|
5
|
-
* listConversations, and deleteConversation.
|
|
6
|
-
*/
|
|
7
|
-
|
|
8
|
-
import type { Database } from '../compat/sqlite';
|
|
9
|
-
import { getDb } from './db';
|
|
10
|
-
|
|
11
|
-
/** Shape returned by conversation query helpers. */
|
|
12
|
-
export interface ConversationRecord {
|
|
13
|
-
id: string;
|
|
14
|
-
title: string;
|
|
15
|
-
messages: any[];
|
|
16
|
-
model: string | null;
|
|
17
|
-
createdAt: string;
|
|
18
|
-
updatedAt: string;
|
|
19
|
-
metadata: any | null;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
// ---------------------------------------------------------------------------
|
|
23
|
-
// Public API
|
|
24
|
-
// ---------------------------------------------------------------------------
|
|
25
|
-
|
|
26
|
-
/**
|
|
27
|
-
* Persist or update a conversation. Uses INSERT ... ON CONFLICT to upsert.
|
|
28
|
-
*/
|
|
29
|
-
export function saveConversation(
|
|
30
|
-
id: string,
|
|
31
|
-
title: string,
|
|
32
|
-
messages: any[],
|
|
33
|
-
model?: string,
|
|
34
|
-
metadata?: any,
|
|
35
|
-
db?: Database
|
|
36
|
-
): void {
|
|
37
|
-
const d = db || getDb();
|
|
38
|
-
const stmt = d.prepare(`
|
|
39
|
-
INSERT INTO conversations (id, title, messages, model, created_at, updated_at, metadata)
|
|
40
|
-
VALUES (?, ?, ?, ?, CURRENT_TIMESTAMP, CURRENT_TIMESTAMP, ?)
|
|
41
|
-
ON CONFLICT(id) DO UPDATE SET
|
|
42
|
-
title = excluded.title,
|
|
43
|
-
messages = excluded.messages,
|
|
44
|
-
model = excluded.model,
|
|
45
|
-
updated_at = CURRENT_TIMESTAMP,
|
|
46
|
-
metadata = excluded.metadata
|
|
47
|
-
`);
|
|
48
|
-
|
|
49
|
-
stmt.run(
|
|
50
|
-
id,
|
|
51
|
-
title,
|
|
52
|
-
JSON.stringify(messages),
|
|
53
|
-
model || null,
|
|
54
|
-
metadata ? JSON.stringify(metadata) : null
|
|
55
|
-
);
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
/**
|
|
59
|
-
* Retrieve a single conversation by id.
|
|
60
|
-
*/
|
|
61
|
-
export function getConversation(id: string, db?: Database): ConversationRecord | null {
|
|
62
|
-
const d = db || getDb();
|
|
63
|
-
const stmt = d.prepare('SELECT * FROM conversations WHERE id = ?');
|
|
64
|
-
const row: any = stmt.get(id);
|
|
65
|
-
|
|
66
|
-
if (!row) {
|
|
67
|
-
return null;
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
return {
|
|
71
|
-
id: row.id,
|
|
72
|
-
title: row.title,
|
|
73
|
-
messages: JSON.parse(row.messages),
|
|
74
|
-
model: row.model,
|
|
75
|
-
createdAt: row.created_at,
|
|
76
|
-
updatedAt: row.updated_at,
|
|
77
|
-
metadata: row.metadata ? JSON.parse(row.metadata) : null,
|
|
78
|
-
};
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
/**
|
|
82
|
-
* List conversations ordered by most-recently updated first.
|
|
83
|
-
*/
|
|
84
|
-
export function listConversations(
|
|
85
|
-
limit: number = 50,
|
|
86
|
-
offset: number = 0,
|
|
87
|
-
db?: Database
|
|
88
|
-
): ConversationRecord[] {
|
|
89
|
-
const d = db || getDb();
|
|
90
|
-
const stmt = d.prepare(`
|
|
91
|
-
SELECT * FROM conversations
|
|
92
|
-
ORDER BY updated_at DESC
|
|
93
|
-
LIMIT ? OFFSET ?
|
|
94
|
-
`);
|
|
95
|
-
|
|
96
|
-
const rows: any[] = stmt.all(limit, offset) as any[];
|
|
97
|
-
return rows.map(row => ({
|
|
98
|
-
id: row.id,
|
|
99
|
-
title: row.title,
|
|
100
|
-
messages: JSON.parse(row.messages),
|
|
101
|
-
model: row.model,
|
|
102
|
-
createdAt: row.created_at,
|
|
103
|
-
updatedAt: row.updated_at,
|
|
104
|
-
metadata: row.metadata ? JSON.parse(row.metadata) : null,
|
|
105
|
-
}));
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
/**
|
|
109
|
-
* Delete a conversation by id.
|
|
110
|
-
*/
|
|
111
|
-
export function deleteConversation(id: string, db?: Database): void {
|
|
112
|
-
const d = db || getDb();
|
|
113
|
-
const stmt = d.prepare('DELETE FROM conversations WHERE id = ?');
|
|
114
|
-
stmt.run(id);
|
|
115
|
-
}
|
package/src/state/projects.ts
DELETED
|
@@ -1,123 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Project CRUD helpers.
|
|
3
|
-
*
|
|
4
|
-
* Refactored from SQLiteAdapter.saveProject, getProject, getProjectByPath,
|
|
5
|
-
* listProjects, and deleteProject.
|
|
6
|
-
*/
|
|
7
|
-
|
|
8
|
-
import type { Database } from '../compat/sqlite';
|
|
9
|
-
import { getDb } from './db';
|
|
10
|
-
|
|
11
|
-
/** Shape returned by project query helpers. */
|
|
12
|
-
export interface ProjectRecord {
|
|
13
|
-
id: string;
|
|
14
|
-
name: string;
|
|
15
|
-
path: string;
|
|
16
|
-
config: any;
|
|
17
|
-
lastScanned: string | null;
|
|
18
|
-
createdAt: string;
|
|
19
|
-
updatedAt: string;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
// ---------------------------------------------------------------------------
|
|
23
|
-
// Public API
|
|
24
|
-
// ---------------------------------------------------------------------------
|
|
25
|
-
|
|
26
|
-
/**
|
|
27
|
-
* Persist or update a project. Uses INSERT ... ON CONFLICT to upsert.
|
|
28
|
-
*/
|
|
29
|
-
export function saveProject(
|
|
30
|
-
id: string,
|
|
31
|
-
name: string,
|
|
32
|
-
projectPath: string,
|
|
33
|
-
config: any,
|
|
34
|
-
db?: Database
|
|
35
|
-
): void {
|
|
36
|
-
const d = db || getDb();
|
|
37
|
-
const stmt = d.prepare(`
|
|
38
|
-
INSERT INTO projects (id, name, path, config, last_scanned, created_at, updated_at)
|
|
39
|
-
VALUES (?, ?, ?, ?, CURRENT_TIMESTAMP, CURRENT_TIMESTAMP, CURRENT_TIMESTAMP)
|
|
40
|
-
ON CONFLICT(id) DO UPDATE SET
|
|
41
|
-
name = excluded.name,
|
|
42
|
-
path = excluded.path,
|
|
43
|
-
config = excluded.config,
|
|
44
|
-
last_scanned = CURRENT_TIMESTAMP,
|
|
45
|
-
updated_at = CURRENT_TIMESTAMP
|
|
46
|
-
`);
|
|
47
|
-
|
|
48
|
-
stmt.run(id, name, projectPath, JSON.stringify(config));
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
/**
|
|
52
|
-
* Retrieve a project by id.
|
|
53
|
-
*/
|
|
54
|
-
export function getProject(id: string, db?: Database): ProjectRecord | null {
|
|
55
|
-
const d = db || getDb();
|
|
56
|
-
const stmt = d.prepare('SELECT * FROM projects WHERE id = ?');
|
|
57
|
-
const row: any = stmt.get(id);
|
|
58
|
-
|
|
59
|
-
if (!row) {
|
|
60
|
-
return null;
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
return {
|
|
64
|
-
id: row.id,
|
|
65
|
-
name: row.name,
|
|
66
|
-
path: row.path,
|
|
67
|
-
config: JSON.parse(row.config),
|
|
68
|
-
lastScanned: row.last_scanned,
|
|
69
|
-
createdAt: row.created_at,
|
|
70
|
-
updatedAt: row.updated_at,
|
|
71
|
-
};
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
/**
|
|
75
|
-
* Retrieve a project by its filesystem path.
|
|
76
|
-
*/
|
|
77
|
-
export function getProjectByPath(projectPath: string, db?: Database): ProjectRecord | null {
|
|
78
|
-
const d = db || getDb();
|
|
79
|
-
const stmt = d.prepare('SELECT * FROM projects WHERE path = ?');
|
|
80
|
-
const row: any = stmt.get(projectPath);
|
|
81
|
-
|
|
82
|
-
if (!row) {
|
|
83
|
-
return null;
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
return {
|
|
87
|
-
id: row.id,
|
|
88
|
-
name: row.name,
|
|
89
|
-
path: row.path,
|
|
90
|
-
config: JSON.parse(row.config),
|
|
91
|
-
lastScanned: row.last_scanned,
|
|
92
|
-
createdAt: row.created_at,
|
|
93
|
-
updatedAt: row.updated_at,
|
|
94
|
-
};
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
/**
|
|
98
|
-
* List all projects ordered by most-recently updated first.
|
|
99
|
-
*/
|
|
100
|
-
export function listProjects(db?: Database): ProjectRecord[] {
|
|
101
|
-
const d = db || getDb();
|
|
102
|
-
const stmt = d.prepare('SELECT * FROM projects ORDER BY updated_at DESC');
|
|
103
|
-
const rows: any[] = stmt.all() as any[];
|
|
104
|
-
|
|
105
|
-
return rows.map(row => ({
|
|
106
|
-
id: row.id,
|
|
107
|
-
name: row.name,
|
|
108
|
-
path: row.path,
|
|
109
|
-
config: JSON.parse(row.config),
|
|
110
|
-
lastScanned: row.last_scanned,
|
|
111
|
-
createdAt: row.created_at,
|
|
112
|
-
updatedAt: row.updated_at,
|
|
113
|
-
}));
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
/**
|
|
117
|
-
* Delete a project by id.
|
|
118
|
-
*/
|
|
119
|
-
export function deleteProject(id: string, db?: Database): void {
|
|
120
|
-
const d = db || getDb();
|
|
121
|
-
const stmt = d.prepare('DELETE FROM projects WHERE id = ?');
|
|
122
|
-
stmt.run(id);
|
|
123
|
-
}
|
package/src/state/schema.ts
DELETED
|
@@ -1,236 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Unified schema with all 16 tables for the Nimbus persistence layer.
|
|
3
|
-
*
|
|
4
|
-
* Tables cover: operations, config, templates, conversations, artifacts,
|
|
5
|
-
* projects, audit_logs, safety_checks, checkpoints, device_codes, tokens,
|
|
6
|
-
* teams, team_members, users, subscriptions, and usage.
|
|
7
|
-
*/
|
|
8
|
-
|
|
9
|
-
import type { Database } from '../compat/sqlite';
|
|
10
|
-
|
|
11
|
-
/**
|
|
12
|
-
* Run all CREATE TABLE / CREATE INDEX migrations against the given database.
|
|
13
|
-
* Every statement uses IF NOT EXISTS so the function is safe to call on an
|
|
14
|
-
* already-initialised database.
|
|
15
|
-
*/
|
|
16
|
-
export function runMigrations(db: Database): void {
|
|
17
|
-
db.exec(`
|
|
18
|
-
-- Operations / history
|
|
19
|
-
CREATE TABLE IF NOT EXISTS operations (
|
|
20
|
-
id TEXT PRIMARY KEY,
|
|
21
|
-
timestamp TEXT NOT NULL DEFAULT (datetime('now')),
|
|
22
|
-
type TEXT NOT NULL,
|
|
23
|
-
command TEXT NOT NULL,
|
|
24
|
-
input TEXT,
|
|
25
|
-
output TEXT,
|
|
26
|
-
status TEXT NOT NULL DEFAULT 'pending',
|
|
27
|
-
duration_ms INTEGER,
|
|
28
|
-
model TEXT,
|
|
29
|
-
tokens_used INTEGER,
|
|
30
|
-
cost_usd REAL,
|
|
31
|
-
metadata TEXT
|
|
32
|
-
);
|
|
33
|
-
|
|
34
|
-
-- Config key-value store
|
|
35
|
-
CREATE TABLE IF NOT EXISTS config (
|
|
36
|
-
key TEXT PRIMARY KEY,
|
|
37
|
-
value TEXT NOT NULL,
|
|
38
|
-
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
39
|
-
);
|
|
40
|
-
|
|
41
|
-
-- Templates
|
|
42
|
-
CREATE TABLE IF NOT EXISTS templates (
|
|
43
|
-
id TEXT PRIMARY KEY,
|
|
44
|
-
name TEXT NOT NULL,
|
|
45
|
-
type TEXT NOT NULL,
|
|
46
|
-
content TEXT NOT NULL,
|
|
47
|
-
variables TEXT,
|
|
48
|
-
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
49
|
-
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
50
|
-
);
|
|
51
|
-
|
|
52
|
-
-- Conversations
|
|
53
|
-
CREATE TABLE IF NOT EXISTS conversations (
|
|
54
|
-
id TEXT PRIMARY KEY,
|
|
55
|
-
title TEXT NOT NULL,
|
|
56
|
-
messages TEXT NOT NULL,
|
|
57
|
-
model TEXT,
|
|
58
|
-
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
59
|
-
updated_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
60
|
-
metadata TEXT
|
|
61
|
-
);
|
|
62
|
-
|
|
63
|
-
-- Artifacts
|
|
64
|
-
CREATE TABLE IF NOT EXISTS artifacts (
|
|
65
|
-
id TEXT PRIMARY KEY,
|
|
66
|
-
conversation_id TEXT,
|
|
67
|
-
name TEXT NOT NULL,
|
|
68
|
-
type TEXT NOT NULL,
|
|
69
|
-
content TEXT NOT NULL,
|
|
70
|
-
language TEXT,
|
|
71
|
-
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
72
|
-
updated_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
73
|
-
metadata TEXT
|
|
74
|
-
);
|
|
75
|
-
|
|
76
|
-
-- Projects
|
|
77
|
-
CREATE TABLE IF NOT EXISTS projects (
|
|
78
|
-
id TEXT PRIMARY KEY,
|
|
79
|
-
name TEXT NOT NULL,
|
|
80
|
-
path TEXT NOT NULL UNIQUE,
|
|
81
|
-
config TEXT NOT NULL DEFAULT '{}',
|
|
82
|
-
last_scanned TEXT,
|
|
83
|
-
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
84
|
-
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
85
|
-
);
|
|
86
|
-
|
|
87
|
-
-- Audit logs
|
|
88
|
-
CREATE TABLE IF NOT EXISTS audit_logs (
|
|
89
|
-
id TEXT PRIMARY KEY,
|
|
90
|
-
timestamp TEXT NOT NULL DEFAULT (datetime('now')),
|
|
91
|
-
user_id TEXT,
|
|
92
|
-
action TEXT NOT NULL,
|
|
93
|
-
resource_type TEXT,
|
|
94
|
-
resource_id TEXT,
|
|
95
|
-
input TEXT,
|
|
96
|
-
output TEXT,
|
|
97
|
-
status TEXT NOT NULL,
|
|
98
|
-
duration_ms INTEGER,
|
|
99
|
-
metadata TEXT
|
|
100
|
-
);
|
|
101
|
-
|
|
102
|
-
-- Safety checks
|
|
103
|
-
CREATE TABLE IF NOT EXISTS safety_checks (
|
|
104
|
-
id TEXT PRIMARY KEY,
|
|
105
|
-
operation_id TEXT,
|
|
106
|
-
check_type TEXT NOT NULL,
|
|
107
|
-
check_name TEXT NOT NULL,
|
|
108
|
-
passed INTEGER NOT NULL DEFAULT 0,
|
|
109
|
-
severity TEXT,
|
|
110
|
-
message TEXT,
|
|
111
|
-
requires_approval INTEGER NOT NULL DEFAULT 0,
|
|
112
|
-
approved_by TEXT,
|
|
113
|
-
approved_at TEXT,
|
|
114
|
-
created_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
115
|
-
);
|
|
116
|
-
|
|
117
|
-
-- Checkpoints (resumable operations)
|
|
118
|
-
CREATE TABLE IF NOT EXISTS checkpoints (
|
|
119
|
-
id TEXT PRIMARY KEY,
|
|
120
|
-
operation_id TEXT NOT NULL,
|
|
121
|
-
step INTEGER NOT NULL,
|
|
122
|
-
state TEXT NOT NULL,
|
|
123
|
-
created_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
124
|
-
);
|
|
125
|
-
|
|
126
|
-
-- Device codes (auth)
|
|
127
|
-
CREATE TABLE IF NOT EXISTS device_codes (
|
|
128
|
-
device_code TEXT PRIMARY KEY,
|
|
129
|
-
user_code TEXT NOT NULL UNIQUE,
|
|
130
|
-
client_id TEXT,
|
|
131
|
-
scope TEXT,
|
|
132
|
-
status TEXT NOT NULL DEFAULT 'pending',
|
|
133
|
-
token TEXT,
|
|
134
|
-
expires_at TEXT NOT NULL,
|
|
135
|
-
created_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
136
|
-
);
|
|
137
|
-
|
|
138
|
-
-- Auth tokens
|
|
139
|
-
CREATE TABLE IF NOT EXISTS tokens (
|
|
140
|
-
id TEXT PRIMARY KEY,
|
|
141
|
-
user_id TEXT,
|
|
142
|
-
token TEXT NOT NULL UNIQUE,
|
|
143
|
-
type TEXT NOT NULL DEFAULT 'access',
|
|
144
|
-
expires_at TEXT,
|
|
145
|
-
created_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
146
|
-
);
|
|
147
|
-
|
|
148
|
-
-- Teams
|
|
149
|
-
CREATE TABLE IF NOT EXISTS teams (
|
|
150
|
-
id TEXT PRIMARY KEY,
|
|
151
|
-
name TEXT NOT NULL,
|
|
152
|
-
owner_id TEXT NOT NULL,
|
|
153
|
-
plan TEXT NOT NULL DEFAULT 'free',
|
|
154
|
-
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
155
|
-
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
156
|
-
);
|
|
157
|
-
|
|
158
|
-
-- Team members
|
|
159
|
-
CREATE TABLE IF NOT EXISTS team_members (
|
|
160
|
-
id TEXT PRIMARY KEY,
|
|
161
|
-
team_id TEXT NOT NULL,
|
|
162
|
-
user_id TEXT NOT NULL,
|
|
163
|
-
role TEXT NOT NULL DEFAULT 'member',
|
|
164
|
-
joined_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
165
|
-
FOREIGN KEY (team_id) REFERENCES teams(id) ON DELETE CASCADE
|
|
166
|
-
);
|
|
167
|
-
|
|
168
|
-
-- Users
|
|
169
|
-
CREATE TABLE IF NOT EXISTS users (
|
|
170
|
-
id TEXT PRIMARY KEY,
|
|
171
|
-
email TEXT UNIQUE,
|
|
172
|
-
name TEXT,
|
|
173
|
-
avatar_url TEXT,
|
|
174
|
-
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
175
|
-
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
176
|
-
);
|
|
177
|
-
|
|
178
|
-
-- Subscriptions (billing)
|
|
179
|
-
CREATE TABLE IF NOT EXISTS subscriptions (
|
|
180
|
-
id TEXT PRIMARY KEY,
|
|
181
|
-
team_id TEXT NOT NULL,
|
|
182
|
-
plan TEXT NOT NULL DEFAULT 'free',
|
|
183
|
-
status TEXT NOT NULL DEFAULT 'active',
|
|
184
|
-
current_period_start TEXT,
|
|
185
|
-
current_period_end TEXT,
|
|
186
|
-
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
187
|
-
updated_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
188
|
-
FOREIGN KEY (team_id) REFERENCES teams(id) ON DELETE CASCADE
|
|
189
|
-
);
|
|
190
|
-
|
|
191
|
-
-- Usage tracking (billing)
|
|
192
|
-
CREATE TABLE IF NOT EXISTS usage (
|
|
193
|
-
id TEXT PRIMARY KEY,
|
|
194
|
-
team_id TEXT,
|
|
195
|
-
user_id TEXT,
|
|
196
|
-
type TEXT NOT NULL,
|
|
197
|
-
quantity REAL NOT NULL DEFAULT 0,
|
|
198
|
-
unit TEXT NOT NULL DEFAULT 'tokens',
|
|
199
|
-
cost_usd REAL DEFAULT 0,
|
|
200
|
-
metadata TEXT,
|
|
201
|
-
created_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
202
|
-
);
|
|
203
|
-
|
|
204
|
-
-- Shared sessions
|
|
205
|
-
CREATE TABLE IF NOT EXISTS shares (
|
|
206
|
-
id TEXT PRIMARY KEY,
|
|
207
|
-
session_id TEXT NOT NULL,
|
|
208
|
-
name TEXT NOT NULL,
|
|
209
|
-
messages TEXT NOT NULL,
|
|
210
|
-
model TEXT,
|
|
211
|
-
mode TEXT,
|
|
212
|
-
cost_usd REAL DEFAULT 0,
|
|
213
|
-
token_count INTEGER DEFAULT 0,
|
|
214
|
-
is_live INTEGER NOT NULL DEFAULT 0,
|
|
215
|
-
write_token TEXT,
|
|
216
|
-
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
217
|
-
expires_at TEXT NOT NULL
|
|
218
|
-
);
|
|
219
|
-
|
|
220
|
-
-- Indexes
|
|
221
|
-
CREATE INDEX IF NOT EXISTS idx_operations_timestamp ON operations(timestamp);
|
|
222
|
-
CREATE INDEX IF NOT EXISTS idx_operations_type ON operations(type);
|
|
223
|
-
CREATE INDEX IF NOT EXISTS idx_conversations_updated ON conversations(updated_at);
|
|
224
|
-
CREATE INDEX IF NOT EXISTS idx_artifacts_type ON artifacts(type);
|
|
225
|
-
CREATE INDEX IF NOT EXISTS idx_artifacts_conversation ON artifacts(conversation_id);
|
|
226
|
-
CREATE INDEX IF NOT EXISTS idx_audit_logs_timestamp ON audit_logs(timestamp);
|
|
227
|
-
CREATE INDEX IF NOT EXISTS idx_audit_logs_user ON audit_logs(user_id);
|
|
228
|
-
CREATE INDEX IF NOT EXISTS idx_audit_logs_action ON audit_logs(action);
|
|
229
|
-
CREATE INDEX IF NOT EXISTS idx_checkpoints_operation ON checkpoints(operation_id);
|
|
230
|
-
CREATE INDEX IF NOT EXISTS idx_team_members_team ON team_members(team_id);
|
|
231
|
-
CREATE INDEX IF NOT EXISTS idx_usage_team ON usage(team_id);
|
|
232
|
-
CREATE INDEX IF NOT EXISTS idx_usage_created ON usage(created_at);
|
|
233
|
-
CREATE INDEX IF NOT EXISTS idx_shares_session ON shares(session_id);
|
|
234
|
-
CREATE INDEX IF NOT EXISTS idx_shares_expires ON shares(expires_at);
|
|
235
|
-
`);
|
|
236
|
-
}
|