@growthub/cli 0.5.1 → 0.6.1
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/__tests__/agent-jwt-env.test.d.ts +2 -0
- package/dist/__tests__/agent-jwt-env.test.d.ts.map +1 -0
- package/dist/__tests__/agent-jwt-env.test.js +57 -0
- package/dist/__tests__/agent-jwt-env.test.js.map +1 -0
- package/dist/__tests__/allowed-hostname.test.d.ts +2 -0
- package/dist/__tests__/allowed-hostname.test.d.ts.map +1 -0
- package/dist/__tests__/allowed-hostname.test.js +75 -0
- package/dist/__tests__/allowed-hostname.test.js.map +1 -0
- package/dist/__tests__/auth-login-flow.test.d.ts +2 -0
- package/dist/__tests__/auth-login-flow.test.d.ts.map +1 -0
- package/dist/__tests__/auth-login-flow.test.js +62 -0
- package/dist/__tests__/auth-login-flow.test.js.map +1 -0
- package/dist/__tests__/auth-session.test.d.ts +2 -0
- package/dist/__tests__/auth-session.test.d.ts.map +1 -0
- package/dist/__tests__/auth-session.test.js +128 -0
- package/dist/__tests__/auth-session.test.js.map +1 -0
- package/dist/__tests__/common.test.d.ts +2 -0
- package/dist/__tests__/common.test.d.ts.map +1 -0
- package/dist/__tests__/common.test.js +73 -0
- package/dist/__tests__/common.test.js.map +1 -0
- package/dist/__tests__/company-delete.test.d.ts +2 -0
- package/dist/__tests__/company-delete.test.d.ts.map +1 -0
- package/dist/__tests__/company-delete.test.js +78 -0
- package/dist/__tests__/company-delete.test.js.map +1 -0
- package/dist/__tests__/context.test.d.ts +2 -0
- package/dist/__tests__/context.test.d.ts.map +1 -0
- package/dist/__tests__/context.test.js +50 -0
- package/dist/__tests__/context.test.js.map +1 -0
- package/dist/__tests__/create-growthub-local-installer.test.d.ts +21 -0
- package/dist/__tests__/create-growthub-local-installer.test.d.ts.map +1 -0
- package/dist/__tests__/create-growthub-local-installer.test.js +205 -0
- package/dist/__tests__/create-growthub-local-installer.test.js.map +1 -0
- package/dist/__tests__/data-dir.test.d.ts +2 -0
- package/dist/__tests__/data-dir.test.d.ts.map +1 -0
- package/dist/__tests__/data-dir.test.js +61 -0
- package/dist/__tests__/data-dir.test.js.map +1 -0
- package/dist/__tests__/doctor.test.d.ts +2 -0
- package/dist/__tests__/doctor.test.d.ts.map +1 -0
- package/dist/__tests__/doctor.test.js +93 -0
- package/dist/__tests__/doctor.test.js.map +1 -0
- package/dist/__tests__/effective-profile.test.d.ts +2 -0
- package/dist/__tests__/effective-profile.test.d.ts.map +1 -0
- package/dist/__tests__/effective-profile.test.js +91 -0
- package/dist/__tests__/effective-profile.test.js.map +1 -0
- package/dist/__tests__/execute-hosted-pipeline.test.d.ts +2 -0
- package/dist/__tests__/execute-hosted-pipeline.test.d.ts.map +1 -0
- package/dist/__tests__/execute-hosted-pipeline.test.js +131 -0
- package/dist/__tests__/execute-hosted-pipeline.test.js.map +1 -0
- package/dist/__tests__/fork-policy.test.d.ts +12 -0
- package/dist/__tests__/fork-policy.test.d.ts.map +1 -0
- package/dist/__tests__/fork-policy.test.js +132 -0
- package/dist/__tests__/fork-policy.test.js.map +1 -0
- package/dist/__tests__/fork-trace.test.d.ts +12 -0
- package/dist/__tests__/fork-trace.test.d.ts.map +1 -0
- package/dist/__tests__/fork-trace.test.js +90 -0
- package/dist/__tests__/fork-trace.test.js.map +1 -0
- package/dist/__tests__/home-paths.test.d.ts +2 -0
- package/dist/__tests__/home-paths.test.d.ts.map +1 -0
- package/dist/__tests__/home-paths.test.js +32 -0
- package/dist/__tests__/home-paths.test.js.map +1 -0
- package/dist/__tests__/hosted-execution-client.test.d.ts +2 -0
- package/dist/__tests__/hosted-execution-client.test.d.ts.map +1 -0
- package/dist/__tests__/hosted-execution-client.test.js +100 -0
- package/dist/__tests__/hosted-execution-client.test.js.map +1 -0
- package/dist/__tests__/http.test.d.ts +2 -0
- package/dist/__tests__/http.test.d.ts.map +1 -0
- package/dist/__tests__/http.test.js +42 -0
- package/dist/__tests__/http.test.js.map +1 -0
- package/dist/__tests__/integrations-github-resolver.test.d.ts +14 -0
- package/dist/__tests__/integrations-github-resolver.test.d.ts.map +1 -0
- package/dist/__tests__/integrations-github-resolver.test.js +103 -0
- package/dist/__tests__/integrations-github-resolver.test.js.map +1 -0
- package/dist/__tests__/kit-command.test.d.ts +2 -0
- package/dist/__tests__/kit-command.test.d.ts.map +1 -0
- package/dist/__tests__/kit-command.test.js +134 -0
- package/dist/__tests__/kit-command.test.js.map +1 -0
- package/dist/__tests__/kit-core.test.d.ts +17 -0
- package/dist/__tests__/kit-core.test.d.ts.map +1 -0
- package/dist/__tests__/kit-core.test.js +403 -0
- package/dist/__tests__/kit-core.test.js.map +1 -0
- package/dist/__tests__/kit-fork-command.test.d.ts +11 -0
- package/dist/__tests__/kit-fork-command.test.d.ts.map +1 -0
- package/dist/__tests__/kit-fork-command.test.js +183 -0
- package/dist/__tests__/kit-fork-command.test.js.map +1 -0
- package/dist/__tests__/kit-fork-phase-1.test.d.ts +13 -0
- package/dist/__tests__/kit-fork-phase-1.test.d.ts.map +1 -0
- package/dist/__tests__/kit-fork-phase-1.test.js +220 -0
- package/dist/__tests__/kit-fork-phase-1.test.js.map +1 -0
- package/dist/__tests__/kit-fork-registry.test.d.ts +8 -0
- package/dist/__tests__/kit-fork-registry.test.d.ts.map +1 -0
- package/dist/__tests__/kit-fork-registry.test.js +183 -0
- package/dist/__tests__/kit-fork-registry.test.js.map +1 -0
- package/dist/__tests__/kit-fork-sync-agent.test.d.ts +13 -0
- package/dist/__tests__/kit-fork-sync-agent.test.d.ts.map +1 -0
- package/dist/__tests__/kit-fork-sync-agent.test.js +262 -0
- package/dist/__tests__/kit-fork-sync-agent.test.js.map +1 -0
- package/dist/__tests__/kit-fork-sync.test.d.ts +12 -0
- package/dist/__tests__/kit-fork-sync.test.d.ts.map +1 -0
- package/dist/__tests__/kit-fork-sync.test.js +455 -0
- package/dist/__tests__/kit-fork-sync.test.js.map +1 -0
- package/dist/__tests__/kit-zernio-social.test.d.ts +16 -0
- package/dist/__tests__/kit-zernio-social.test.d.ts.map +1 -0
- package/dist/__tests__/kit-zernio-social.test.js +528 -0
- package/dist/__tests__/kit-zernio-social.test.js.map +1 -0
- package/dist/__tests__/kit.test.d.ts +2 -0
- package/dist/__tests__/kit.test.d.ts.map +1 -0
- package/dist/__tests__/kit.test.js +359 -0
- package/dist/__tests__/kit.test.js.map +1 -0
- package/dist/__tests__/native-intelligence-normalizer.test.d.ts +2 -0
- package/dist/__tests__/native-intelligence-normalizer.test.d.ts.map +1 -0
- package/dist/__tests__/native-intelligence-normalizer.test.js +200 -0
- package/dist/__tests__/native-intelligence-normalizer.test.js.map +1 -0
- package/dist/__tests__/native-intelligence-planner.test.d.ts +2 -0
- package/dist/__tests__/native-intelligence-planner.test.d.ts.map +1 -0
- package/dist/__tests__/native-intelligence-planner.test.js +208 -0
- package/dist/__tests__/native-intelligence-planner.test.js.map +1 -0
- package/dist/__tests__/native-intelligence-recommender.test.d.ts +2 -0
- package/dist/__tests__/native-intelligence-recommender.test.d.ts.map +1 -0
- package/dist/__tests__/native-intelligence-recommender.test.js +212 -0
- package/dist/__tests__/native-intelligence-recommender.test.js.map +1 -0
- package/dist/__tests__/native-intelligence-summarizer.test.d.ts +2 -0
- package/dist/__tests__/native-intelligence-summarizer.test.d.ts.map +1 -0
- package/dist/__tests__/native-intelligence-summarizer.test.js +195 -0
- package/dist/__tests__/native-intelligence-summarizer.test.js.map +1 -0
- package/dist/__tests__/open-agents.test.d.ts +2 -0
- package/dist/__tests__/open-agents.test.d.ts.map +1 -0
- package/dist/__tests__/open-agents.test.js +174 -0
- package/dist/__tests__/open-agents.test.js.map +1 -0
- package/dist/__tests__/progress.test.d.ts +5 -0
- package/dist/__tests__/progress.test.d.ts.map +1 -0
- package/dist/__tests__/progress.test.js +55 -0
- package/dist/__tests__/progress.test.js.map +1 -0
- package/dist/__tests__/qwen-code.test.d.ts +2 -0
- package/dist/__tests__/qwen-code.test.d.ts.map +1 -0
- package/dist/__tests__/qwen-code.test.js +125 -0
- package/dist/__tests__/qwen-code.test.js.map +1 -0
- package/dist/__tests__/source-import-agent.test.d.ts +9 -0
- package/dist/__tests__/source-import-agent.test.d.ts.map +1 -0
- package/dist/__tests__/source-import-agent.test.js +124 -0
- package/dist/__tests__/source-import-agent.test.js.map +1 -0
- package/dist/__tests__/source-import-detect.test.d.ts +8 -0
- package/dist/__tests__/source-import-detect.test.d.ts.map +1 -0
- package/dist/__tests__/source-import-detect.test.js +91 -0
- package/dist/__tests__/source-import-detect.test.js.map +1 -0
- package/dist/__tests__/source-import-plan.test.d.ts +8 -0
- package/dist/__tests__/source-import-plan.test.d.ts.map +1 -0
- package/dist/__tests__/source-import-plan.test.js +170 -0
- package/dist/__tests__/source-import-plan.test.js.map +1 -0
- package/dist/__tests__/source-import-security.test.d.ts +8 -0
- package/dist/__tests__/source-import-security.test.d.ts.map +1 -0
- package/dist/__tests__/source-import-security.test.js +111 -0
- package/dist/__tests__/source-import-security.test.js.map +1 -0
- package/dist/__tests__/source-import-skills-source.test.d.ts +11 -0
- package/dist/__tests__/source-import-skills-source.test.d.ts.map +1 -0
- package/dist/__tests__/source-import-skills-source.test.js +181 -0
- package/dist/__tests__/source-import-skills-source.test.js.map +1 -0
- package/dist/__tests__/table-renderer.test.d.ts +12 -0
- package/dist/__tests__/table-renderer.test.d.ts.map +1 -0
- package/dist/__tests__/table-renderer.test.js +86 -0
- package/dist/__tests__/table-renderer.test.js.map +1 -0
- package/dist/__tests__/worktree.test.d.ts +2 -0
- package/dist/__tests__/worktree.test.d.ts.map +1 -0
- package/dist/__tests__/worktree.test.js +399 -0
- package/dist/__tests__/worktree.test.js.map +1 -0
- package/dist/adapters/http/format-event.d.ts +2 -0
- package/dist/adapters/http/format-event.d.ts.map +1 -0
- package/dist/adapters/http/format-event.js +6 -0
- package/dist/adapters/http/format-event.js.map +1 -0
- package/dist/adapters/http/index.d.ts +3 -0
- package/dist/adapters/http/index.d.ts.map +1 -0
- package/dist/adapters/http/index.js +6 -0
- package/dist/adapters/http/index.js.map +1 -0
- package/dist/adapters/index.d.ts +3 -0
- package/dist/adapters/index.d.ts.map +1 -0
- package/dist/adapters/index.js +2 -0
- package/dist/adapters/index.js.map +1 -0
- package/dist/adapters/open-agents/format-event.d.ts +2 -0
- package/dist/adapters/open-agents/format-event.d.ts.map +1 -0
- package/dist/adapters/open-agents/format-event.js +39 -0
- package/dist/adapters/open-agents/format-event.js.map +1 -0
- package/dist/adapters/open-agents/index.d.ts +3 -0
- package/dist/adapters/open-agents/index.d.ts.map +1 -0
- package/dist/adapters/open-agents/index.js +6 -0
- package/dist/adapters/open-agents/index.js.map +1 -0
- package/dist/adapters/process/format-event.d.ts +2 -0
- package/dist/adapters/process/format-event.d.ts.map +1 -0
- package/dist/adapters/process/format-event.js +6 -0
- package/dist/adapters/process/format-event.js.map +1 -0
- package/dist/adapters/process/index.d.ts +3 -0
- package/dist/adapters/process/index.d.ts.map +1 -0
- package/dist/adapters/process/index.js +6 -0
- package/dist/adapters/process/index.js.map +1 -0
- package/dist/adapters/qwen/format-event.d.ts +8 -0
- package/dist/adapters/qwen/format-event.d.ts.map +1 -0
- package/dist/adapters/qwen/format-event.js +28 -0
- package/dist/adapters/qwen/format-event.js.map +1 -0
- package/dist/adapters/qwen/index.d.ts +3 -0
- package/dist/adapters/qwen/index.d.ts.map +1 -0
- package/dist/adapters/qwen/index.js +6 -0
- package/dist/adapters/qwen/index.js.map +1 -0
- package/dist/adapters/registry.d.ts +3 -0
- package/dist/adapters/registry.d.ts.map +1 -0
- package/dist/adapters/registry.js +56 -0
- package/dist/adapters/registry.js.map +1 -0
- package/dist/auth/effective-profile.d.ts +61 -0
- package/dist/auth/effective-profile.d.ts.map +1 -0
- package/dist/auth/effective-profile.js +127 -0
- package/dist/auth/effective-profile.js.map +1 -0
- package/dist/auth/hosted-client.d.ts +107 -0
- package/dist/auth/hosted-client.d.ts.map +1 -0
- package/dist/auth/hosted-client.js +140 -0
- package/dist/auth/hosted-client.js.map +1 -0
- package/dist/auth/hosted-integrations.d.ts +33 -0
- package/dist/auth/hosted-integrations.d.ts.map +1 -0
- package/dist/auth/hosted-integrations.js +51 -0
- package/dist/auth/hosted-integrations.js.map +1 -0
- package/dist/auth/login-flow.d.ts +27 -0
- package/dist/auth/login-flow.d.ts.map +1 -0
- package/dist/auth/login-flow.js +212 -0
- package/dist/auth/login-flow.js.map +1 -0
- package/dist/auth/overlay-store.d.ts +52 -0
- package/dist/auth/overlay-store.d.ts.map +1 -0
- package/dist/auth/overlay-store.js +123 -0
- package/dist/auth/overlay-store.js.map +1 -0
- package/dist/auth/paths.d.ts +15 -0
- package/dist/auth/paths.d.ts.map +1 -0
- package/dist/auth/paths.js +27 -0
- package/dist/auth/paths.js.map +1 -0
- package/dist/auth/session-store.d.ts +35 -0
- package/dist/auth/session-store.d.ts.map +1 -0
- package/dist/auth/session-store.js +73 -0
- package/dist/auth/session-store.js.map +1 -0
- package/dist/auth/workflow-access.d.ts +7 -0
- package/dist/auth/workflow-access.d.ts.map +1 -0
- package/dist/auth/workflow-access.js +27 -0
- package/dist/auth/workflow-access.js.map +1 -0
- package/dist/checks/agent-jwt-secret-check.d.ts +3 -0
- package/dist/checks/agent-jwt-secret-check.d.ts.map +1 -0
- package/dist/checks/agent-jwt-secret-check.js +31 -0
- package/dist/checks/agent-jwt-secret-check.js.map +1 -0
- package/dist/checks/config-check.d.ts +3 -0
- package/dist/checks/config-check.d.ts.map +1 -0
- package/dist/checks/config-check.js +31 -0
- package/dist/checks/config-check.js.map +1 -0
- package/dist/checks/database-check.d.ts +4 -0
- package/dist/checks/database-check.d.ts.map +1 -0
- package/dist/checks/database-check.js +54 -0
- package/dist/checks/database-check.js.map +1 -0
- package/dist/checks/deployment-auth-check.d.ts +4 -0
- package/dist/checks/deployment-auth-check.d.ts.map +1 -0
- package/dist/checks/deployment-auth-check.js +83 -0
- package/dist/checks/deployment-auth-check.js.map +1 -0
- package/dist/checks/index.d.ts +18 -0
- package/dist/checks/index.d.ts.map +1 -0
- package/dist/checks/index.js +10 -0
- package/dist/checks/index.js.map +1 -0
- package/dist/checks/llm-check.d.ts +4 -0
- package/dist/checks/llm-check.d.ts.map +1 -0
- package/dist/checks/llm-check.js +80 -0
- package/dist/checks/llm-check.js.map +1 -0
- package/dist/checks/log-check.d.ts +4 -0
- package/dist/checks/log-check.d.ts.map +1 -0
- package/dist/checks/log-check.js +27 -0
- package/dist/checks/log-check.js.map +1 -0
- package/dist/checks/path-resolver.d.ts +2 -0
- package/dist/checks/path-resolver.d.ts.map +1 -0
- package/dist/checks/path-resolver.js +2 -0
- package/dist/checks/path-resolver.js.map +1 -0
- package/dist/checks/port-check.d.ts +4 -0
- package/dist/checks/port-check.d.ts.map +1 -0
- package/dist/checks/port-check.js +20 -0
- package/dist/checks/port-check.js.map +1 -0
- package/dist/checks/secrets-check.d.ts +4 -0
- package/dist/checks/secrets-check.d.ts.map +1 -0
- package/dist/checks/secrets-check.js +123 -0
- package/dist/checks/secrets-check.js.map +1 -0
- package/dist/checks/storage-check.d.ts +4 -0
- package/dist/checks/storage-check.d.ts.map +1 -0
- package/dist/checks/storage-check.js +46 -0
- package/dist/checks/storage-check.js.map +1 -0
- package/dist/client/context.d.ts +21 -0
- package/dist/client/context.d.ts.map +1 -0
- package/dist/client/context.js +136 -0
- package/dist/client/context.js.map +1 -0
- package/dist/client/http.d.ts +29 -0
- package/dist/client/http.d.ts.map +1 -0
- package/dist/client/http.js +120 -0
- package/dist/client/http.js.map +1 -0
- package/dist/commands/allowed-hostname.d.ts +4 -0
- package/dist/commands/allowed-hostname.d.ts.map +1 -0
- package/dist/commands/allowed-hostname.js +31 -0
- package/dist/commands/allowed-hostname.js.map +1 -0
- package/dist/commands/artifact.d.ts +12 -0
- package/dist/commands/artifact.d.ts.map +1 -0
- package/dist/commands/artifact.js +167 -0
- package/dist/commands/artifact.js.map +1 -0
- package/dist/commands/auth-bootstrap-ceo.d.ts +8 -0
- package/dist/commands/auth-bootstrap-ceo.d.ts.map +1 -0
- package/dist/commands/auth-bootstrap-ceo.js +108 -0
- package/dist/commands/auth-bootstrap-ceo.js.map +1 -0
- package/dist/commands/auth-login.d.ts +24 -0
- package/dist/commands/auth-login.d.ts.map +1 -0
- package/dist/commands/auth-login.js +270 -0
- package/dist/commands/auth-login.js.map +1 -0
- package/dist/commands/capability.d.ts +15 -0
- package/dist/commands/capability.d.ts.map +1 -0
- package/dist/commands/capability.js +366 -0
- package/dist/commands/capability.js.map +1 -0
- package/dist/commands/client/activity.d.ts +3 -0
- package/dist/commands/client/activity.d.ts.map +1 -0
- package/dist/commands/client/activity.js +49 -0
- package/dist/commands/client/activity.js.map +1 -0
- package/dist/commands/client/agent.d.ts +3 -0
- package/dist/commands/client/agent.d.ts.map +1 -0
- package/dist/commands/client/agent.js +224 -0
- package/dist/commands/client/agent.js.map +1 -0
- package/dist/commands/client/approval.d.ts +3 -0
- package/dist/commands/client/approval.d.ts.map +1 -0
- package/dist/commands/client/approval.js +193 -0
- package/dist/commands/client/approval.js.map +1 -0
- package/dist/commands/client/common.d.ts +33 -0
- package/dist/commands/client/common.d.ts.map +1 -0
- package/dist/commands/client/common.js +140 -0
- package/dist/commands/client/common.js.map +1 -0
- package/dist/commands/client/company.d.ts +14 -0
- package/dist/commands/client/company.d.ts.map +1 -0
- package/dist/commands/client/company.js +346 -0
- package/dist/commands/client/company.js.map +1 -0
- package/dist/commands/client/context.d.ts +3 -0
- package/dist/commands/client/context.d.ts.map +1 -0
- package/dist/commands/client/context.js +92 -0
- package/dist/commands/client/context.js.map +1 -0
- package/dist/commands/client/dashboard.d.ts +3 -0
- package/dist/commands/client/dashboard.d.ts.map +1 -0
- package/dist/commands/client/dashboard.js +19 -0
- package/dist/commands/client/dashboard.js.map +1 -0
- package/dist/commands/client/issue.d.ts +3 -0
- package/dist/commands/client/issue.d.ts.map +1 -0
- package/dist/commands/client/issue.js +229 -0
- package/dist/commands/client/issue.js.map +1 -0
- package/dist/commands/client/plugin.d.ts +3 -0
- package/dist/commands/client/plugin.d.ts.map +1 -0
- package/dist/commands/client/plugin.js +252 -0
- package/dist/commands/client/plugin.js.map +1 -0
- package/dist/commands/configure.d.ts +5 -0
- package/dist/commands/configure.d.ts.map +1 -0
- package/dist/commands/configure.js +167 -0
- package/dist/commands/configure.js.map +1 -0
- package/dist/commands/db-backup.d.ts +10 -0
- package/dist/commands/db-backup.d.ts.map +1 -0
- package/dist/commands/db-backup.js +74 -0
- package/dist/commands/db-backup.js.map +1 -0
- package/dist/commands/doctor.d.ts +10 -0
- package/dist/commands/doctor.d.ts.map +1 -0
- package/dist/commands/doctor.js +154 -0
- package/dist/commands/doctor.js.map +1 -0
- package/dist/commands/env.d.ts +4 -0
- package/dist/commands/env.d.ts.map +1 -0
- package/dist/commands/env.js +355 -0
- package/dist/commands/env.js.map +1 -0
- package/dist/commands/fleet.d.ts +39 -0
- package/dist/commands/fleet.d.ts.map +1 -0
- package/dist/commands/fleet.js +281 -0
- package/dist/commands/fleet.js.map +1 -0
- package/dist/commands/github.d.ts +29 -0
- package/dist/commands/github.d.ts.map +1 -0
- package/dist/commands/github.js +205 -0
- package/dist/commands/github.js.map +1 -0
- package/dist/commands/gtm.d.ts +3 -0
- package/dist/commands/gtm.d.ts.map +1 -0
- package/dist/commands/gtm.js +134 -0
- package/dist/commands/gtm.js.map +1 -0
- package/dist/commands/heartbeat-run.d.ts +16 -0
- package/dist/commands/heartbeat-run.d.ts.map +1 -0
- package/dist/commands/heartbeat-run.js +294 -0
- package/dist/commands/heartbeat-run.js.map +1 -0
- package/dist/commands/integrations.d.ts +20 -0
- package/dist/commands/integrations.d.ts.map +1 -0
- package/dist/commands/integrations.js +98 -0
- package/dist/commands/integrations.js.map +1 -0
- package/dist/commands/kit-fork-remote.d.ts +46 -0
- package/dist/commands/kit-fork-remote.d.ts.map +1 -0
- package/dist/commands/kit-fork-remote.js +489 -0
- package/dist/commands/kit-fork-remote.js.map +1 -0
- package/dist/commands/kit-fork.d.ts +39 -0
- package/dist/commands/kit-fork.d.ts.map +1 -0
- package/dist/commands/kit-fork.js +1338 -0
- package/dist/commands/kit-fork.js.map +1 -0
- package/dist/commands/kit.d.ts +7 -0
- package/dist/commands/kit.d.ts.map +1 -0
- package/dist/commands/kit.js +585 -0
- package/dist/commands/kit.js.map +1 -0
- package/dist/commands/onboard.d.ts +9 -0
- package/dist/commands/onboard.d.ts.map +1 -0
- package/dist/commands/onboard.js +425 -0
- package/dist/commands/onboard.js.map +1 -0
- package/dist/commands/open-agents.d.ts +19 -0
- package/dist/commands/open-agents.d.ts.map +1 -0
- package/dist/commands/open-agents.js +689 -0
- package/dist/commands/open-agents.js.map +1 -0
- package/dist/commands/pipeline.d.ts +20 -0
- package/dist/commands/pipeline.d.ts.map +1 -0
- package/dist/commands/pipeline.js +863 -0
- package/dist/commands/pipeline.js.map +1 -0
- package/dist/commands/profile.d.ts +3 -0
- package/dist/commands/profile.d.ts.map +1 -0
- package/dist/commands/profile.js +282 -0
- package/dist/commands/profile.js.map +1 -0
- package/dist/commands/qwen-code.d.ts +19 -0
- package/dist/commands/qwen-code.d.ts.map +1 -0
- package/dist/commands/qwen-code.js +286 -0
- package/dist/commands/qwen-code.js.map +1 -0
- package/dist/commands/run.d.ts +9 -0
- package/dist/commands/run.d.ts.map +1 -0
- package/dist/commands/run.js +156 -0
- package/dist/commands/run.js.map +1 -0
- package/dist/commands/source-import-discovery.d.ts +28 -0
- package/dist/commands/source-import-discovery.d.ts.map +1 -0
- package/dist/commands/source-import-discovery.js +327 -0
- package/dist/commands/source-import-discovery.js.map +1 -0
- package/dist/commands/starter.d.ts +27 -0
- package/dist/commands/starter.d.ts.map +1 -0
- package/dist/commands/starter.js +358 -0
- package/dist/commands/starter.js.map +1 -0
- package/dist/commands/status.d.ts +18 -0
- package/dist/commands/status.d.ts.map +1 -0
- package/dist/commands/status.js +84 -0
- package/dist/commands/status.js.map +1 -0
- package/dist/commands/template.d.ts +18 -0
- package/dist/commands/template.d.ts.map +1 -0
- package/dist/commands/template.js +341 -0
- package/dist/commands/template.js.map +1 -0
- package/dist/commands/workflow.d.ts +24 -0
- package/dist/commands/workflow.d.ts.map +1 -0
- package/dist/commands/workflow.js +1350 -0
- package/dist/commands/workflow.js.map +1 -0
- package/dist/commands/worktree-lib.d.ts +49 -0
- package/dist/commands/worktree-lib.d.ts.map +1 -0
- package/dist/commands/worktree-lib.js +220 -0
- package/dist/commands/worktree-lib.js.map +1 -0
- package/dist/commands/worktree.d.ts +60 -0
- package/dist/commands/worktree.d.ts.map +1 -0
- package/dist/commands/worktree.js +874 -0
- package/dist/commands/worktree.js.map +1 -0
- package/dist/config/data-dir.d.ts +12 -0
- package/dist/config/data-dir.d.ts.map +1 -0
- package/dist/config/data-dir.js +25 -0
- package/dist/config/data-dir.js.map +1 -0
- package/dist/config/env.d.ts +15 -0
- package/dist/config/env.d.ts.map +1 -0
- package/dist/config/env.js +105 -0
- package/dist/config/env.js.map +1 -0
- package/dist/config/github-home.d.ts +17 -0
- package/dist/config/github-home.d.ts.map +1 -0
- package/dist/config/github-home.js +29 -0
- package/dist/config/github-home.js.map +1 -0
- package/dist/config/home.d.ts +23 -0
- package/dist/config/home.d.ts.map +1 -0
- package/dist/config/home.js +65 -0
- package/dist/config/home.js.map +1 -0
- package/dist/config/hostnames.d.ts +3 -0
- package/dist/config/hostnames.d.ts.map +1 -0
- package/dist/config/hostnames.js +27 -0
- package/dist/config/hostnames.js.map +1 -0
- package/dist/config/kit-forks-home.d.ts +26 -0
- package/dist/config/kit-forks-home.d.ts.map +1 -0
- package/dist/config/kit-forks-home.js +44 -0
- package/dist/config/kit-forks-home.js.map +1 -0
- package/dist/config/schema.d.ts +2 -0
- package/dist/config/schema.d.ts.map +1 -0
- package/dist/config/schema.js +2 -0
- package/dist/config/schema.js.map +1 -0
- package/dist/config/secrets-key.d.ts +16 -0
- package/dist/config/secrets-key.d.ts.map +1 -0
- package/dist/config/secrets-key.js +34 -0
- package/dist/config/secrets-key.js.map +1 -0
- package/dist/config/store.d.ts +6 -0
- package/dist/config/store.d.ts.map +1 -0
- package/dist/config/store.js +102 -0
- package/dist/config/store.js.map +1 -0
- package/dist/fleet/agent-plan.d.ts +20 -0
- package/dist/fleet/agent-plan.d.ts.map +1 -0
- package/dist/fleet/agent-plan.js +61 -0
- package/dist/fleet/agent-plan.js.map +1 -0
- package/dist/fleet/approvals.d.ts +10 -0
- package/dist/fleet/approvals.d.ts.map +1 -0
- package/dist/fleet/approvals.js +33 -0
- package/dist/fleet/approvals.js.map +1 -0
- package/dist/fleet/drift-summary.d.ts +13 -0
- package/dist/fleet/drift-summary.d.ts.map +1 -0
- package/dist/fleet/drift-summary.js +120 -0
- package/dist/fleet/drift-summary.js.map +1 -0
- package/dist/fleet/summary.d.ts +9 -0
- package/dist/fleet/summary.d.ts.map +1 -0
- package/dist/fleet/summary.js +161 -0
- package/dist/fleet/summary.js.map +1 -0
- package/dist/fleet/types.d.ts +149 -0
- package/dist/fleet/types.d.ts.map +1 -0
- package/dist/fleet/types.js +12 -0
- package/dist/fleet/types.js.map +1 -0
- package/dist/github/client.d.ts +42 -0
- package/dist/github/client.d.ts.map +1 -0
- package/dist/github/client.js +174 -0
- package/dist/github/client.js.map +1 -0
- package/dist/github/token-store.d.ts +11 -0
- package/dist/github/token-store.d.ts.map +1 -0
- package/dist/github/token-store.js +74 -0
- package/dist/github/token-store.js.map +1 -0
- package/dist/github/types.d.ts +69 -0
- package/dist/github/types.d.ts.map +1 -0
- package/dist/github/types.js +8 -0
- package/dist/github/types.js.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +1100 -27800
- package/dist/index.js.map +1 -0
- package/dist/integrations/bridge.d.ts +43 -0
- package/dist/integrations/bridge.d.ts.map +1 -0
- package/dist/integrations/bridge.js +148 -0
- package/dist/integrations/bridge.js.map +1 -0
- package/dist/integrations/github-resolver.d.ts +31 -0
- package/dist/integrations/github-resolver.d.ts.map +1 -0
- package/dist/integrations/github-resolver.js +44 -0
- package/dist/integrations/github-resolver.js.map +1 -0
- package/dist/integrations/types.d.ts +46 -0
- package/dist/integrations/types.d.ts.map +1 -0
- package/dist/integrations/types.js +11 -0
- package/dist/integrations/types.js.map +1 -0
- package/dist/kits/catalog.d.ts +12 -0
- package/dist/kits/catalog.d.ts.map +1 -0
- package/dist/kits/catalog.js +93 -0
- package/dist/kits/catalog.js.map +1 -0
- package/dist/kits/contract.d.ts +153 -0
- package/dist/kits/contract.d.ts.map +1 -0
- package/dist/kits/contract.js +89 -0
- package/dist/kits/contract.js.map +1 -0
- package/dist/kits/core/adapter-core/contracts.d.ts +108 -0
- package/dist/kits/core/adapter-core/contracts.d.ts.map +1 -0
- package/dist/kits/core/adapter-core/contracts.js +17 -0
- package/dist/kits/core/adapter-core/contracts.js.map +1 -0
- package/dist/kits/core/adapter-core/env-gate.d.ts +29 -0
- package/dist/kits/core/adapter-core/env-gate.d.ts.map +1 -0
- package/dist/kits/core/adapter-core/env-gate.js +143 -0
- package/dist/kits/core/adapter-core/env-gate.js.map +1 -0
- package/dist/kits/core/adapter-core/fork-inspector.d.ts +42 -0
- package/dist/kits/core/adapter-core/fork-inspector.d.ts.map +1 -0
- package/dist/kits/core/adapter-core/fork-inspector.js +141 -0
- package/dist/kits/core/adapter-core/fork-inspector.js.map +1 -0
- package/dist/kits/core/adapter-core/index.d.ts +20 -0
- package/dist/kits/core/adapter-core/index.d.ts.map +1 -0
- package/dist/kits/core/adapter-core/index.js +13 -0
- package/dist/kits/core/adapter-core/index.js.map +1 -0
- package/dist/kits/core/adapter-core/output-contract.d.ts +25 -0
- package/dist/kits/core/adapter-core/output-contract.d.ts.map +1 -0
- package/dist/kits/core/adapter-core/output-contract.js +114 -0
- package/dist/kits/core/adapter-core/output-contract.js.map +1 -0
- package/dist/kits/core/adapter-core/provider-adapter.d.ts +26 -0
- package/dist/kits/core/adapter-core/provider-adapter.d.ts.map +1 -0
- package/dist/kits/core/adapter-core/provider-adapter.js +119 -0
- package/dist/kits/core/adapter-core/provider-adapter.js.map +1 -0
- package/dist/kits/core/adapter-core/runtime-surface.d.ts +25 -0
- package/dist/kits/core/adapter-core/runtime-surface.d.ts.map +1 -0
- package/dist/kits/core/adapter-core/runtime-surface.js +100 -0
- package/dist/kits/core/adapter-core/runtime-surface.js.map +1 -0
- package/dist/kits/core/adapter-core/setup-validation.d.ts +28 -0
- package/dist/kits/core/adapter-core/setup-validation.d.ts.map +1 -0
- package/dist/kits/core/adapter-core/setup-validation.js +145 -0
- package/dist/kits/core/adapter-core/setup-validation.js.map +1 -0
- package/dist/kits/core/factory/index.d.ts +25 -0
- package/dist/kits/core/factory/index.d.ts.map +1 -0
- package/dist/kits/core/factory/index.js +21 -0
- package/dist/kits/core/factory/index.js.map +1 -0
- package/dist/kits/core/factory/operator-kit.d.ts +50 -0
- package/dist/kits/core/factory/operator-kit.d.ts.map +1 -0
- package/dist/kits/core/factory/operator-kit.js +88 -0
- package/dist/kits/core/factory/operator-kit.js.map +1 -0
- package/dist/kits/core/factory/ops-kit.d.ts +57 -0
- package/dist/kits/core/factory/ops-kit.d.ts.map +1 -0
- package/dist/kits/core/factory/ops-kit.js +115 -0
- package/dist/kits/core/factory/ops-kit.js.map +1 -0
- package/dist/kits/core/factory/studio-kit.d.ts +39 -0
- package/dist/kits/core/factory/studio-kit.d.ts.map +1 -0
- package/dist/kits/core/factory/studio-kit.js +96 -0
- package/dist/kits/core/factory/studio-kit.js.map +1 -0
- package/dist/kits/core/factory/workflow-kit.d.ts +57 -0
- package/dist/kits/core/factory/workflow-kit.d.ts.map +1 -0
- package/dist/kits/core/factory/workflow-kit.js +107 -0
- package/dist/kits/core/factory/workflow-kit.js.map +1 -0
- package/dist/kits/core/index.d.ts +25 -0
- package/dist/kits/core/index.d.ts.map +1 -0
- package/dist/kits/core/index.js +111 -0
- package/dist/kits/core/index.js.map +1 -0
- package/dist/kits/core/types/index.d.ts +65 -0
- package/dist/kits/core/types/index.d.ts.map +1 -0
- package/dist/kits/core/types/index.js +49 -0
- package/dist/kits/core/types/index.js.map +1 -0
- package/dist/kits/core/validation/index.d.ts +42 -0
- package/dist/kits/core/validation/index.d.ts.map +1 -0
- package/dist/kits/core/validation/index.js +128 -0
- package/dist/kits/core/validation/index.js.map +1 -0
- package/dist/kits/fork-policy.d.ts +78 -0
- package/dist/kits/fork-policy.d.ts.map +1 -0
- package/dist/kits/fork-policy.js +92 -0
- package/dist/kits/fork-policy.js.map +1 -0
- package/dist/kits/fork-registry.d.ts +54 -0
- package/dist/kits/fork-registry.d.ts.map +1 -0
- package/dist/kits/fork-registry.js +201 -0
- package/dist/kits/fork-registry.js.map +1 -0
- package/dist/kits/fork-remote.d.ts +52 -0
- package/dist/kits/fork-remote.d.ts.map +1 -0
- package/dist/kits/fork-remote.js +116 -0
- package/dist/kits/fork-remote.js.map +1 -0
- package/dist/kits/fork-sync-agent.d.ts +51 -0
- package/dist/kits/fork-sync-agent.d.ts.map +1 -0
- package/dist/kits/fork-sync-agent.js +435 -0
- package/dist/kits/fork-sync-agent.js.map +1 -0
- package/dist/kits/fork-sync.d.ts +32 -0
- package/dist/kits/fork-sync.d.ts.map +1 -0
- package/dist/kits/fork-sync.js +590 -0
- package/dist/kits/fork-sync.js.map +1 -0
- package/dist/kits/fork-trace.d.ts +29 -0
- package/dist/kits/fork-trace.d.ts.map +1 -0
- package/dist/kits/fork-trace.js +54 -0
- package/dist/kits/fork-trace.js.map +1 -0
- package/dist/kits/fork-types.d.ts +198 -0
- package/dist/kits/fork-types.d.ts.map +1 -0
- package/dist/kits/fork-types.js +16 -0
- package/dist/kits/fork-types.js.map +1 -0
- package/dist/kits/service.d.ts +63 -0
- package/dist/kits/service.d.ts.map +1 -0
- package/dist/kits/service.js +630 -0
- package/dist/kits/service.js.map +1 -0
- package/dist/prompts/database.d.ts +3 -0
- package/dist/prompts/database.d.ts.map +1 -0
- package/dist/prompts/database.js +144 -0
- package/dist/prompts/database.js.map +1 -0
- package/dist/prompts/llm.d.ts +3 -0
- package/dist/prompts/llm.d.ts.map +1 -0
- package/dist/prompts/llm.js +37 -0
- package/dist/prompts/llm.js.map +1 -0
- package/dist/prompts/logging.d.ts +3 -0
- package/dist/prompts/logging.d.ts.map +1 -0
- package/dist/prompts/logging.js +31 -0
- package/dist/prompts/logging.js.map +1 -0
- package/dist/prompts/secrets.d.ts +4 -0
- package/dist/prompts/secrets.d.ts.map +1 -0
- package/dist/prompts/secrets.js +85 -0
- package/dist/prompts/secrets.js.map +1 -0
- package/dist/prompts/server.d.ts +9 -0
- package/dist/prompts/server.d.ts.map +1 -0
- package/dist/prompts/server.js +154 -0
- package/dist/prompts/server.js.map +1 -0
- package/dist/prompts/storage.d.ts +4 -0
- package/dist/prompts/storage.d.ts.map +1 -0
- package/dist/prompts/storage.js +129 -0
- package/dist/prompts/storage.js.map +1 -0
- package/dist/runtime/agent-harness/auth-store.d.ts +8 -0
- package/dist/runtime/agent-harness/auth-store.d.ts.map +1 -0
- package/dist/runtime/agent-harness/auth-store.js +92 -0
- package/dist/runtime/agent-harness/auth-store.js.map +1 -0
- package/dist/runtime/artifact-contracts/index.d.ts +47 -0
- package/dist/runtime/artifact-contracts/index.d.ts.map +1 -0
- package/dist/runtime/artifact-contracts/index.js +153 -0
- package/dist/runtime/artifact-contracts/index.js.map +1 -0
- package/dist/runtime/artifact-contracts/types.d.ts +82 -0
- package/dist/runtime/artifact-contracts/types.d.ts.map +1 -0
- package/dist/runtime/artifact-contracts/types.js +16 -0
- package/dist/runtime/artifact-contracts/types.js.map +1 -0
- package/dist/runtime/cms-capability-registry/index.d.ts +30 -0
- package/dist/runtime/cms-capability-registry/index.d.ts.map +1 -0
- package/dist/runtime/cms-capability-registry/index.js +183 -0
- package/dist/runtime/cms-capability-registry/index.js.map +1 -0
- package/dist/runtime/cms-capability-registry/types.d.ts +109 -0
- package/dist/runtime/cms-capability-registry/types.d.ts.map +1 -0
- package/dist/runtime/cms-capability-registry/types.js +19 -0
- package/dist/runtime/cms-capability-registry/types.js.map +1 -0
- package/dist/runtime/cms-node-contracts/compile.d.ts +6 -0
- package/dist/runtime/cms-node-contracts/compile.d.ts.map +1 -0
- package/dist/runtime/cms-node-contracts/compile.js +57 -0
- package/dist/runtime/cms-node-contracts/compile.js.map +1 -0
- package/dist/runtime/cms-node-contracts/index.d.ts +6 -0
- package/dist/runtime/cms-node-contracts/index.d.ts.map +1 -0
- package/dist/runtime/cms-node-contracts/index.js +5 -0
- package/dist/runtime/cms-node-contracts/index.js.map +1 -0
- package/dist/runtime/cms-node-contracts/introspect.d.ts +5 -0
- package/dist/runtime/cms-node-contracts/introspect.d.ts.map +1 -0
- package/dist/runtime/cms-node-contracts/introspect.js +61 -0
- package/dist/runtime/cms-node-contracts/introspect.js.map +1 -0
- package/dist/runtime/cms-node-contracts/normalize.d.ts +5 -0
- package/dist/runtime/cms-node-contracts/normalize.d.ts.map +1 -0
- package/dist/runtime/cms-node-contracts/normalize.js +112 -0
- package/dist/runtime/cms-node-contracts/normalize.js.map +1 -0
- package/dist/runtime/cms-node-contracts/presenter.d.ts +9 -0
- package/dist/runtime/cms-node-contracts/presenter.d.ts.map +1 -0
- package/dist/runtime/cms-node-contracts/presenter.js +117 -0
- package/dist/runtime/cms-node-contracts/presenter.js.map +1 -0
- package/dist/runtime/cms-node-contracts/types.d.ts +76 -0
- package/dist/runtime/cms-node-contracts/types.d.ts.map +1 -0
- package/dist/runtime/cms-node-contracts/types.js +2 -0
- package/dist/runtime/cms-node-contracts/types.js.map +1 -0
- package/dist/runtime/dynamic-registry-pipeline/index.d.ts +41 -0
- package/dist/runtime/dynamic-registry-pipeline/index.d.ts.map +1 -0
- package/dist/runtime/dynamic-registry-pipeline/index.js +224 -0
- package/dist/runtime/dynamic-registry-pipeline/index.js.map +1 -0
- package/dist/runtime/dynamic-registry-pipeline/types.d.ts +61 -0
- package/dist/runtime/dynamic-registry-pipeline/types.d.ts.map +1 -0
- package/dist/runtime/dynamic-registry-pipeline/types.js +14 -0
- package/dist/runtime/dynamic-registry-pipeline/types.js.map +1 -0
- package/dist/runtime/hosted-execution-client/index.d.ts +45 -0
- package/dist/runtime/hosted-execution-client/index.d.ts.map +1 -0
- package/dist/runtime/hosted-execution-client/index.js +527 -0
- package/dist/runtime/hosted-execution-client/index.js.map +1 -0
- package/dist/runtime/hosted-execution-client/types.d.ts +125 -0
- package/dist/runtime/hosted-execution-client/types.d.ts.map +1 -0
- package/dist/runtime/hosted-execution-client/types.js +9 -0
- package/dist/runtime/hosted-execution-client/types.js.map +1 -0
- package/dist/runtime/index.d.ts +24 -0
- package/dist/runtime/index.d.ts.map +1 -0
- package/dist/runtime/index.js +24 -0
- package/dist/runtime/index.js.map +1 -0
- package/dist/runtime/machine-capability-resolver/index.d.ts +32 -0
- package/dist/runtime/machine-capability-resolver/index.d.ts.map +1 -0
- package/dist/runtime/machine-capability-resolver/index.js +131 -0
- package/dist/runtime/machine-capability-resolver/index.js.map +1 -0
- package/dist/runtime/machine-capability-resolver/types.d.ts +46 -0
- package/dist/runtime/machine-capability-resolver/types.d.ts.map +1 -0
- package/dist/runtime/machine-capability-resolver/types.js +13 -0
- package/dist/runtime/machine-capability-resolver/types.js.map +1 -0
- package/dist/runtime/native-intelligence/contract.d.ts +174 -0
- package/dist/runtime/native-intelligence/contract.d.ts.map +1 -0
- package/dist/runtime/native-intelligence/contract.js +23 -0
- package/dist/runtime/native-intelligence/contract.js.map +1 -0
- package/dist/runtime/native-intelligence/index.d.ts +38 -0
- package/dist/runtime/native-intelligence/index.d.ts.map +1 -0
- package/dist/runtime/native-intelligence/index.js +121 -0
- package/dist/runtime/native-intelligence/index.js.map +1 -0
- package/dist/runtime/native-intelligence/normalizer.d.ts +22 -0
- package/dist/runtime/native-intelligence/normalizer.d.ts.map +1 -0
- package/dist/runtime/native-intelligence/normalizer.js +307 -0
- package/dist/runtime/native-intelligence/normalizer.js.map +1 -0
- package/dist/runtime/native-intelligence/planner.d.ts +22 -0
- package/dist/runtime/native-intelligence/planner.d.ts.map +1 -0
- package/dist/runtime/native-intelligence/planner.js +312 -0
- package/dist/runtime/native-intelligence/planner.js.map +1 -0
- package/dist/runtime/native-intelligence/provider.d.ts +27 -0
- package/dist/runtime/native-intelligence/provider.d.ts.map +1 -0
- package/dist/runtime/native-intelligence/provider.js +221 -0
- package/dist/runtime/native-intelligence/provider.js.map +1 -0
- package/dist/runtime/native-intelligence/recommender.d.ts +23 -0
- package/dist/runtime/native-intelligence/recommender.d.ts.map +1 -0
- package/dist/runtime/native-intelligence/recommender.js +299 -0
- package/dist/runtime/native-intelligence/recommender.js.map +1 -0
- package/dist/runtime/native-intelligence/summarizer.d.ts +22 -0
- package/dist/runtime/native-intelligence/summarizer.d.ts.map +1 -0
- package/dist/runtime/native-intelligence/summarizer.js +228 -0
- package/dist/runtime/native-intelligence/summarizer.js.map +1 -0
- package/dist/runtime/open-agents/contract.d.ts +58 -0
- package/dist/runtime/open-agents/contract.d.ts.map +1 -0
- package/dist/runtime/open-agents/contract.js +26 -0
- package/dist/runtime/open-agents/contract.js.map +1 -0
- package/dist/runtime/open-agents/index.d.ts +15 -0
- package/dist/runtime/open-agents/index.d.ts.map +1 -0
- package/dist/runtime/open-agents/index.js +72 -0
- package/dist/runtime/open-agents/index.js.map +1 -0
- package/dist/runtime/open-agents/provider.d.ts +32 -0
- package/dist/runtime/open-agents/provider.d.ts.map +1 -0
- package/dist/runtime/open-agents/provider.js +190 -0
- package/dist/runtime/open-agents/provider.js.map +1 -0
- package/dist/runtime/qwen-code/contract.d.ts +79 -0
- package/dist/runtime/qwen-code/contract.d.ts.map +1 -0
- package/dist/runtime/qwen-code/contract.js +40 -0
- package/dist/runtime/qwen-code/contract.js.map +1 -0
- package/dist/runtime/qwen-code/health.d.ts +11 -0
- package/dist/runtime/qwen-code/health.d.ts.map +1 -0
- package/dist/runtime/qwen-code/health.js +111 -0
- package/dist/runtime/qwen-code/health.js.map +1 -0
- package/dist/runtime/qwen-code/index.d.ts +26 -0
- package/dist/runtime/qwen-code/index.d.ts.map +1 -0
- package/dist/runtime/qwen-code/index.js +93 -0
- package/dist/runtime/qwen-code/index.js.map +1 -0
- package/dist/runtime/qwen-code/provider.d.ts +23 -0
- package/dist/runtime/qwen-code/provider.d.ts.map +1 -0
- package/dist/runtime/qwen-code/provider.js +134 -0
- package/dist/runtime/qwen-code/provider.js.map +1 -0
- package/dist/runtime/workflow-hygiene/index.d.ts +4 -0
- package/dist/runtime/workflow-hygiene/index.d.ts.map +1 -0
- package/dist/runtime/workflow-hygiene/index.js +3 -0
- package/dist/runtime/workflow-hygiene/index.js.map +1 -0
- package/dist/runtime/workflow-hygiene/labels.d.ts +4 -0
- package/dist/runtime/workflow-hygiene/labels.d.ts.map +1 -0
- package/dist/runtime/workflow-hygiene/labels.js +64 -0
- package/dist/runtime/workflow-hygiene/labels.js.map +1 -0
- package/dist/runtime/workflow-hygiene/summaries.d.ts +11 -0
- package/dist/runtime/workflow-hygiene/summaries.d.ts.map +1 -0
- package/dist/runtime/workflow-hygiene/summaries.js +17 -0
- package/dist/runtime/workflow-hygiene/summaries.js.map +1 -0
- package/dist/runtime/workflow-hygiene/types.d.ts +12 -0
- package/dist/runtime/workflow-hygiene/types.d.ts.map +1 -0
- package/dist/runtime/workflow-hygiene/types.js +2 -0
- package/dist/runtime/workflow-hygiene/types.js.map +1 -0
- package/dist/starter/init.d.ts +18 -0
- package/dist/starter/init.d.ts.map +1 -0
- package/dist/starter/init.js +108 -0
- package/dist/starter/init.js.map +1 -0
- package/dist/starter/source-import/agent.d.ts +60 -0
- package/dist/starter/source-import/agent.d.ts.map +1 -0
- package/dist/starter/source-import/agent.js +302 -0
- package/dist/starter/source-import/agent.js.map +1 -0
- package/dist/starter/source-import/detect.d.ts +20 -0
- package/dist/starter/source-import/detect.d.ts.map +1 -0
- package/dist/starter/source-import/detect.js +197 -0
- package/dist/starter/source-import/detect.js.map +1 -0
- package/dist/starter/source-import/github-source.d.ts +66 -0
- package/dist/starter/source-import/github-source.d.ts.map +1 -0
- package/dist/starter/source-import/github-source.js +233 -0
- package/dist/starter/source-import/github-source.js.map +1 -0
- package/dist/starter/source-import/index.d.ts +31 -0
- package/dist/starter/source-import/index.d.ts.map +1 -0
- package/dist/starter/source-import/index.js +31 -0
- package/dist/starter/source-import/index.js.map +1 -0
- package/dist/starter/source-import/materialize.d.ts +61 -0
- package/dist/starter/source-import/materialize.d.ts.map +1 -0
- package/dist/starter/source-import/materialize.js +260 -0
- package/dist/starter/source-import/materialize.js.map +1 -0
- package/dist/starter/source-import/plan.d.ts +39 -0
- package/dist/starter/source-import/plan.d.ts.map +1 -0
- package/dist/starter/source-import/plan.js +158 -0
- package/dist/starter/source-import/plan.js.map +1 -0
- package/dist/starter/source-import/security.d.ts +42 -0
- package/dist/starter/source-import/security.d.ts.map +1 -0
- package/dist/starter/source-import/security.js +323 -0
- package/dist/starter/source-import/security.js.map +1 -0
- package/dist/starter/source-import/skills-source.d.ts +28 -0
- package/dist/starter/source-import/skills-source.d.ts.map +1 -0
- package/dist/starter/source-import/skills-source.js +419 -0
- package/dist/starter/source-import/skills-source.js.map +1 -0
- package/dist/starter/source-import/summarize.d.ts +25 -0
- package/dist/starter/source-import/summarize.d.ts.map +1 -0
- package/dist/starter/source-import/summarize.js +107 -0
- package/dist/starter/source-import/summarize.js.map +1 -0
- package/dist/starter/source-import/types.d.ts +357 -0
- package/dist/starter/source-import/types.d.ts.map +1 -0
- package/dist/starter/source-import/types.js +28 -0
- package/dist/starter/source-import/types.js.map +1 -0
- package/dist/starter/types.d.ts +46 -0
- package/dist/starter/types.d.ts.map +1 -0
- package/dist/starter/types.js +11 -0
- package/dist/starter/types.js.map +1 -0
- package/dist/status/probes.d.ts +25 -0
- package/dist/status/probes.d.ts.map +1 -0
- package/dist/status/probes.js +297 -0
- package/dist/status/probes.js.map +1 -0
- package/dist/status/runner.d.ts +18 -0
- package/dist/status/runner.d.ts.map +1 -0
- package/dist/status/runner.js +185 -0
- package/dist/status/runner.js.map +1 -0
- package/dist/status/types.d.ts +60 -0
- package/dist/status/types.d.ts.map +1 -0
- package/dist/status/types.js +13 -0
- package/dist/status/types.js.map +1 -0
- package/dist/templates/catalog.d.ts +12 -0
- package/dist/templates/catalog.d.ts.map +1 -0
- package/dist/templates/catalog.js +226 -0
- package/dist/templates/catalog.js.map +1 -0
- package/dist/templates/contract.d.ts +62 -0
- package/dist/templates/contract.d.ts.map +1 -0
- package/dist/templates/contract.js +12 -0
- package/dist/templates/contract.js.map +1 -0
- package/dist/templates/index.d.ts +5 -0
- package/dist/templates/index.d.ts.map +1 -0
- package/dist/templates/index.js +2 -0
- package/dist/templates/index.js.map +1 -0
- package/dist/templates/service.d.ts +19 -0
- package/dist/templates/service.d.ts.map +1 -0
- package/dist/templates/service.js +132 -0
- package/dist/templates/service.js.map +1 -0
- package/dist/utils/banner.d.ts +2 -0
- package/dist/utils/banner.d.ts.map +1 -0
- package/dist/utils/banner.js.map +1 -0
- package/dist/utils/net.d.ts +5 -0
- package/dist/utils/net.d.ts.map +1 -0
- package/dist/utils/net.js +19 -0
- package/dist/utils/net.js.map +1 -0
- package/dist/utils/path-resolver.d.ts +2 -0
- package/dist/utils/path-resolver.d.ts.map +1 -0
- package/dist/utils/path-resolver.js +22 -0
- package/dist/utils/path-resolver.js.map +1 -0
- package/dist/utils/progress.d.ts +24 -0
- package/dist/utils/progress.d.ts.map +1 -0
- package/dist/utils/progress.js +57 -0
- package/dist/utils/progress.js.map +1 -0
- package/dist/utils/table-renderer.d.ts +28 -0
- package/dist/utils/table-renderer.d.ts.map +1 -0
- package/dist/utils/table-renderer.js +83 -0
- package/dist/utils/table-renderer.js.map +1 -0
- package/package.json +1 -1
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export { agentJwtSecretCheck } from "./agent-jwt-secret-check.js";
|
|
2
|
+
export { configCheck } from "./config-check.js";
|
|
3
|
+
export { deploymentAuthCheck } from "./deployment-auth-check.js";
|
|
4
|
+
export { databaseCheck } from "./database-check.js";
|
|
5
|
+
export { llmCheck } from "./llm-check.js";
|
|
6
|
+
export { logCheck } from "./log-check.js";
|
|
7
|
+
export { portCheck } from "./port-check.js";
|
|
8
|
+
export { secretsCheck } from "./secrets-check.js";
|
|
9
|
+
export { storageCheck } from "./storage-check.js";
|
|
10
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/checks/index.ts"],"names":[],"mappings":"AASA,OAAO,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAC;AAClE,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;AACjE,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAC1C,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAC1C,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"llm-check.d.ts","sourceRoot":"","sources":["../../src/checks/llm-check.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAC3D,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAE9C,wBAAsB,QAAQ,CAAC,MAAM,EAAE,eAAe,GAAG,OAAO,CAAC,WAAW,CAAC,CA8E5E"}
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
export async function llmCheck(config) {
|
|
2
|
+
if (!config.llm) {
|
|
3
|
+
return {
|
|
4
|
+
name: "LLM provider",
|
|
5
|
+
status: "pass",
|
|
6
|
+
message: "No LLM provider configured (optional)",
|
|
7
|
+
};
|
|
8
|
+
}
|
|
9
|
+
if (!config.llm.apiKey) {
|
|
10
|
+
return {
|
|
11
|
+
name: "LLM provider",
|
|
12
|
+
status: "pass",
|
|
13
|
+
message: `${config.llm.provider} configured but no API key set (optional)`,
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
try {
|
|
17
|
+
if (config.llm.provider === "claude") {
|
|
18
|
+
const res = await fetch("https://api.anthropic.com/v1/messages", {
|
|
19
|
+
method: "POST",
|
|
20
|
+
headers: {
|
|
21
|
+
"x-api-key": config.llm.apiKey,
|
|
22
|
+
"anthropic-version": "2023-06-01",
|
|
23
|
+
"content-type": "application/json",
|
|
24
|
+
},
|
|
25
|
+
body: JSON.stringify({
|
|
26
|
+
model: "claude-sonnet-4-5-20250929",
|
|
27
|
+
max_tokens: 1,
|
|
28
|
+
messages: [{ role: "user", content: "hi" }],
|
|
29
|
+
}),
|
|
30
|
+
});
|
|
31
|
+
if (res.ok || res.status === 400) {
|
|
32
|
+
return { name: "LLM provider", status: "pass", message: "Claude API key is valid" };
|
|
33
|
+
}
|
|
34
|
+
if (res.status === 401) {
|
|
35
|
+
return {
|
|
36
|
+
name: "LLM provider",
|
|
37
|
+
status: "fail",
|
|
38
|
+
message: "Claude API key is invalid (401)",
|
|
39
|
+
canRepair: false,
|
|
40
|
+
repairHint: "Run `paperclipai configure --section llm`",
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
return {
|
|
44
|
+
name: "LLM provider",
|
|
45
|
+
status: "warn",
|
|
46
|
+
message: `Claude API returned status ${res.status}`,
|
|
47
|
+
};
|
|
48
|
+
}
|
|
49
|
+
else {
|
|
50
|
+
const res = await fetch("https://api.openai.com/v1/models", {
|
|
51
|
+
headers: { Authorization: `Bearer ${config.llm.apiKey}` },
|
|
52
|
+
});
|
|
53
|
+
if (res.ok) {
|
|
54
|
+
return { name: "LLM provider", status: "pass", message: "OpenAI API key is valid" };
|
|
55
|
+
}
|
|
56
|
+
if (res.status === 401) {
|
|
57
|
+
return {
|
|
58
|
+
name: "LLM provider",
|
|
59
|
+
status: "fail",
|
|
60
|
+
message: "OpenAI API key is invalid (401)",
|
|
61
|
+
canRepair: false,
|
|
62
|
+
repairHint: "Run `paperclipai configure --section llm`",
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
return {
|
|
66
|
+
name: "LLM provider",
|
|
67
|
+
status: "warn",
|
|
68
|
+
message: `OpenAI API returned status ${res.status}`,
|
|
69
|
+
};
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
catch {
|
|
73
|
+
return {
|
|
74
|
+
name: "LLM provider",
|
|
75
|
+
status: "warn",
|
|
76
|
+
message: "Could not reach API to validate key",
|
|
77
|
+
};
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
//# sourceMappingURL=llm-check.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"llm-check.js","sourceRoot":"","sources":["../../src/checks/llm-check.ts"],"names":[],"mappings":"AAGA,MAAM,CAAC,KAAK,UAAU,QAAQ,CAAC,MAAuB;IACpD,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC;QAChB,OAAO;YACL,IAAI,EAAE,cAAc;YACpB,MAAM,EAAE,MAAM;YACd,OAAO,EAAE,uCAAuC;SACjD,CAAC;IACJ,CAAC;IAED,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC;QACvB,OAAO;YACL,IAAI,EAAE,cAAc;YACpB,MAAM,EAAE,MAAM;YACd,OAAO,EAAE,GAAG,MAAM,CAAC,GAAG,CAAC,QAAQ,2CAA2C;SAC3E,CAAC;IACJ,CAAC;IAED,IAAI,CAAC;QACH,IAAI,MAAM,CAAC,GAAG,CAAC,QAAQ,KAAK,QAAQ,EAAE,CAAC;YACrC,MAAM,GAAG,GAAG,MAAM,KAAK,CAAC,uCAAuC,EAAE;gBAC/D,MAAM,EAAE,MAAM;gBACd,OAAO,EAAE;oBACP,WAAW,EAAE,MAAM,CAAC,GAAG,CAAC,MAAM;oBAC9B,mBAAmB,EAAE,YAAY;oBACjC,cAAc,EAAE,kBAAkB;iBACnC;gBACD,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC;oBACnB,KAAK,EAAE,4BAA4B;oBACnC,UAAU,EAAE,CAAC;oBACb,QAAQ,EAAE,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;iBAC5C,CAAC;aACH,CAAC,CAAC;YACH,IAAI,GAAG,CAAC,EAAE,IAAI,GAAG,CAAC,MAAM,KAAK,GAAG,EAAE,CAAC;gBACjC,OAAO,EAAE,IAAI,EAAE,cAAc,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,yBAAyB,EAAE,CAAC;YACtF,CAAC;YACD,IAAI,GAAG,CAAC,MAAM,KAAK,GAAG,EAAE,CAAC;gBACvB,OAAO;oBACL,IAAI,EAAE,cAAc;oBACpB,MAAM,EAAE,MAAM;oBACd,OAAO,EAAE,iCAAiC;oBAC1C,SAAS,EAAE,KAAK;oBAChB,UAAU,EAAE,2CAA2C;iBACxD,CAAC;YACJ,CAAC;YACD,OAAO;gBACL,IAAI,EAAE,cAAc;gBACpB,MAAM,EAAE,MAAM;gBACd,OAAO,EAAE,8BAA8B,GAAG,CAAC,MAAM,EAAE;aACpD,CAAC;QACJ,CAAC;aAAM,CAAC;YACN,MAAM,GAAG,GAAG,MAAM,KAAK,CAAC,kCAAkC,EAAE;gBAC1D,OAAO,EAAE,EAAE,aAAa,EAAE,UAAU,MAAM,CAAC,GAAG,CAAC,MAAM,EAAE,EAAE;aAC1D,CAAC,CAAC;YACH,IAAI,GAAG,CAAC,EAAE,EAAE,CAAC;gBACX,OAAO,EAAE,IAAI,EAAE,cAAc,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,yBAAyB,EAAE,CAAC;YACtF,CAAC;YACD,IAAI,GAAG,CAAC,MAAM,KAAK,GAAG,EAAE,CAAC;gBACvB,OAAO;oBACL,IAAI,EAAE,cAAc;oBACpB,MAAM,EAAE,MAAM;oBACd,OAAO,EAAE,iCAAiC;oBAC1C,SAAS,EAAE,KAAK;oBAChB,UAAU,EAAE,2CAA2C;iBACxD,CAAC;YACJ,CAAC;YACD,OAAO;gBACL,IAAI,EAAE,cAAc;gBACpB,MAAM,EAAE,MAAM;gBACd,OAAO,EAAE,8BAA8B,GAAG,CAAC,MAAM,EAAE;aACpD,CAAC;QACJ,CAAC;IACH,CAAC;IAAC,MAAM,CAAC;QACP,OAAO;YACL,IAAI,EAAE,cAAc;YACpB,MAAM,EAAE,MAAM;YACd,OAAO,EAAE,qCAAqC;SAC/C,CAAC;IACJ,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"log-check.d.ts","sourceRoot":"","sources":["../../src/checks/log-check.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAC3D,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAG9C,wBAAgB,QAAQ,CAAC,MAAM,EAAE,eAAe,EAAE,UAAU,CAAC,EAAE,MAAM,GAAG,WAAW,CAwBlF"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import fs from "node:fs";
|
|
2
|
+
import { resolveRuntimeLikePath } from "./path-resolver.js";
|
|
3
|
+
export function logCheck(config, configPath) {
|
|
4
|
+
const logDir = resolveRuntimeLikePath(config.logging.logDir, configPath);
|
|
5
|
+
const reportedDir = logDir;
|
|
6
|
+
if (!fs.existsSync(logDir)) {
|
|
7
|
+
fs.mkdirSync(reportedDir, { recursive: true });
|
|
8
|
+
}
|
|
9
|
+
try {
|
|
10
|
+
fs.accessSync(reportedDir, fs.constants.W_OK);
|
|
11
|
+
return {
|
|
12
|
+
name: "Log directory",
|
|
13
|
+
status: "pass",
|
|
14
|
+
message: `Log directory is writable: ${reportedDir}`,
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
catch {
|
|
18
|
+
return {
|
|
19
|
+
name: "Log directory",
|
|
20
|
+
status: "fail",
|
|
21
|
+
message: `Log directory is not writable: ${logDir}`,
|
|
22
|
+
canRepair: false,
|
|
23
|
+
repairHint: "Check file permissions on the log directory",
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
//# sourceMappingURL=log-check.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"log-check.js","sourceRoot":"","sources":["../../src/checks/log-check.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,SAAS,CAAC;AAGzB,OAAO,EAAE,sBAAsB,EAAE,MAAM,oBAAoB,CAAC;AAE5D,MAAM,UAAU,QAAQ,CAAC,MAAuB,EAAE,UAAmB;IACnE,MAAM,MAAM,GAAG,sBAAsB,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;IACzE,MAAM,WAAW,GAAG,MAAM,CAAC;IAE3B,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC;QAC3B,EAAE,CAAC,SAAS,CAAC,WAAW,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IACjD,CAAC;IAED,IAAI,CAAC;QACH,EAAE,CAAC,UAAU,CAAC,WAAW,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAC9C,OAAO;YACL,IAAI,EAAE,eAAe;YACrB,MAAM,EAAE,MAAM;YACd,OAAO,EAAE,8BAA8B,WAAW,EAAE;SACrD,CAAC;IACJ,CAAC;IAAC,MAAM,CAAC;QACP,OAAO;YACL,IAAI,EAAE,eAAe;YACrB,MAAM,EAAE,MAAM;YACd,OAAO,EAAE,kCAAkC,MAAM,EAAE;YACnD,SAAS,EAAE,KAAK;YAChB,UAAU,EAAE,6CAA6C;SAC1D,CAAC;IACJ,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"path-resolver.d.ts","sourceRoot":"","sources":["../../src/checks/path-resolver.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,MAAM,2BAA2B,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"path-resolver.js","sourceRoot":"","sources":["../../src/checks/path-resolver.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,MAAM,2BAA2B,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"port-check.d.ts","sourceRoot":"","sources":["../../src/checks/port-check.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAE3D,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAE9C,wBAAsB,SAAS,CAAC,MAAM,EAAE,eAAe,GAAG,OAAO,CAAC,WAAW,CAAC,CAmB7E"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { checkPort } from "../utils/net.js";
|
|
2
|
+
export async function portCheck(config) {
|
|
3
|
+
const port = config.server.port;
|
|
4
|
+
const result = await checkPort(port);
|
|
5
|
+
if (result.available) {
|
|
6
|
+
return {
|
|
7
|
+
name: "Server port",
|
|
8
|
+
status: "pass",
|
|
9
|
+
message: `Port ${port} is available`,
|
|
10
|
+
};
|
|
11
|
+
}
|
|
12
|
+
return {
|
|
13
|
+
name: "Server port",
|
|
14
|
+
status: "warn",
|
|
15
|
+
message: result.error ?? `Port ${port} is not available`,
|
|
16
|
+
canRepair: false,
|
|
17
|
+
repairHint: `Check what's using port ${port} with: lsof -i :${port}`,
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=port-check.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"port-check.js","sourceRoot":"","sources":["../../src/checks/port-check.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAG5C,MAAM,CAAC,KAAK,UAAU,SAAS,CAAC,MAAuB;IACrD,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC;IAChC,MAAM,MAAM,GAAG,MAAM,SAAS,CAAC,IAAI,CAAC,CAAC;IAErC,IAAI,MAAM,CAAC,SAAS,EAAE,CAAC;QACrB,OAAO;YACL,IAAI,EAAE,aAAa;YACnB,MAAM,EAAE,MAAM;YACd,OAAO,EAAE,QAAQ,IAAI,eAAe;SACrC,CAAC;IACJ,CAAC;IAED,OAAO;QACL,IAAI,EAAE,aAAa;QACnB,MAAM,EAAE,MAAM;QACd,OAAO,EAAE,MAAM,CAAC,KAAK,IAAI,QAAQ,IAAI,mBAAmB;QACxD,SAAS,EAAE,KAAK;QAChB,UAAU,EAAE,2BAA2B,IAAI,mBAAmB,IAAI,EAAE;KACrE,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"secrets-check.d.ts","sourceRoot":"","sources":["../../src/checks/secrets-check.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAC3D,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AA2C9C,wBAAgB,YAAY,CAAC,MAAM,EAAE,eAAe,EAAE,UAAU,CAAC,EAAE,MAAM,GAAG,WAAW,CAkGtF"}
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
import { randomBytes } from "node:crypto";
|
|
2
|
+
import fs from "node:fs";
|
|
3
|
+
import path from "node:path";
|
|
4
|
+
import { resolveRuntimeLikePath } from "./path-resolver.js";
|
|
5
|
+
function decodeMasterKey(raw) {
|
|
6
|
+
const trimmed = raw.trim();
|
|
7
|
+
if (!trimmed)
|
|
8
|
+
return null;
|
|
9
|
+
if (/^[A-Fa-f0-9]{64}$/.test(trimmed)) {
|
|
10
|
+
return Buffer.from(trimmed, "hex");
|
|
11
|
+
}
|
|
12
|
+
try {
|
|
13
|
+
const decoded = Buffer.from(trimmed, "base64");
|
|
14
|
+
if (decoded.length === 32)
|
|
15
|
+
return decoded;
|
|
16
|
+
}
|
|
17
|
+
catch {
|
|
18
|
+
// ignored
|
|
19
|
+
}
|
|
20
|
+
if (Buffer.byteLength(trimmed, "utf8") === 32) {
|
|
21
|
+
return Buffer.from(trimmed, "utf8");
|
|
22
|
+
}
|
|
23
|
+
return null;
|
|
24
|
+
}
|
|
25
|
+
function withStrictModeNote(base, config) {
|
|
26
|
+
const strictModeDisabledInDeployedSetup = config.database.mode === "postgres" && config.secrets.strictMode === false;
|
|
27
|
+
if (!strictModeDisabledInDeployedSetup)
|
|
28
|
+
return base;
|
|
29
|
+
if (base.status === "fail")
|
|
30
|
+
return base;
|
|
31
|
+
return {
|
|
32
|
+
...base,
|
|
33
|
+
status: "warn",
|
|
34
|
+
message: `${base.message}; strict secret mode is disabled for postgres deployment`,
|
|
35
|
+
repairHint: base.repairHint
|
|
36
|
+
? `${base.repairHint}. Consider enabling secrets.strictMode`
|
|
37
|
+
: "Consider enabling secrets.strictMode",
|
|
38
|
+
};
|
|
39
|
+
}
|
|
40
|
+
export function secretsCheck(config, configPath) {
|
|
41
|
+
const provider = config.secrets.provider;
|
|
42
|
+
if (provider !== "local_encrypted") {
|
|
43
|
+
return {
|
|
44
|
+
name: "Secrets adapter",
|
|
45
|
+
status: "fail",
|
|
46
|
+
message: `${provider} is configured, but this build only supports local_encrypted`,
|
|
47
|
+
canRepair: false,
|
|
48
|
+
repairHint: "Run `paperclipai configure --section secrets` and set provider to local_encrypted",
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
const envMasterKey = process.env.PAPERCLIP_SECRETS_MASTER_KEY;
|
|
52
|
+
if (envMasterKey && envMasterKey.trim().length > 0) {
|
|
53
|
+
if (!decodeMasterKey(envMasterKey)) {
|
|
54
|
+
return {
|
|
55
|
+
name: "Secrets adapter",
|
|
56
|
+
status: "fail",
|
|
57
|
+
message: "PAPERCLIP_SECRETS_MASTER_KEY is invalid (expected 32-byte base64, 64-char hex, or raw 32-char string)",
|
|
58
|
+
canRepair: false,
|
|
59
|
+
repairHint: "Set PAPERCLIP_SECRETS_MASTER_KEY to a valid key or unset it to use a key file",
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
return withStrictModeNote({
|
|
63
|
+
name: "Secrets adapter",
|
|
64
|
+
status: "pass",
|
|
65
|
+
message: "Local encrypted provider configured via PAPERCLIP_SECRETS_MASTER_KEY",
|
|
66
|
+
}, config);
|
|
67
|
+
}
|
|
68
|
+
const keyFileOverride = process.env.PAPERCLIP_SECRETS_MASTER_KEY_FILE;
|
|
69
|
+
const configuredPath = keyFileOverride && keyFileOverride.trim().length > 0
|
|
70
|
+
? keyFileOverride.trim()
|
|
71
|
+
: config.secrets.localEncrypted.keyFilePath;
|
|
72
|
+
const keyFilePath = resolveRuntimeLikePath(configuredPath, configPath);
|
|
73
|
+
if (!fs.existsSync(keyFilePath)) {
|
|
74
|
+
return withStrictModeNote({
|
|
75
|
+
name: "Secrets adapter",
|
|
76
|
+
status: "warn",
|
|
77
|
+
message: `Secrets key file does not exist yet: ${keyFilePath}`,
|
|
78
|
+
canRepair: true,
|
|
79
|
+
repair: () => {
|
|
80
|
+
fs.mkdirSync(path.dirname(keyFilePath), { recursive: true });
|
|
81
|
+
fs.writeFileSync(keyFilePath, randomBytes(32).toString("base64"), {
|
|
82
|
+
encoding: "utf8",
|
|
83
|
+
mode: 0o600,
|
|
84
|
+
});
|
|
85
|
+
try {
|
|
86
|
+
fs.chmodSync(keyFilePath, 0o600);
|
|
87
|
+
}
|
|
88
|
+
catch {
|
|
89
|
+
// best effort
|
|
90
|
+
}
|
|
91
|
+
},
|
|
92
|
+
repairHint: "Run with --repair to create a local encrypted secrets key file",
|
|
93
|
+
}, config);
|
|
94
|
+
}
|
|
95
|
+
let raw;
|
|
96
|
+
try {
|
|
97
|
+
raw = fs.readFileSync(keyFilePath, "utf8");
|
|
98
|
+
}
|
|
99
|
+
catch (err) {
|
|
100
|
+
return {
|
|
101
|
+
name: "Secrets adapter",
|
|
102
|
+
status: "fail",
|
|
103
|
+
message: `Could not read secrets key file: ${err instanceof Error ? err.message : String(err)}`,
|
|
104
|
+
canRepair: false,
|
|
105
|
+
repairHint: "Check file permissions or set PAPERCLIP_SECRETS_MASTER_KEY",
|
|
106
|
+
};
|
|
107
|
+
}
|
|
108
|
+
if (!decodeMasterKey(raw)) {
|
|
109
|
+
return {
|
|
110
|
+
name: "Secrets adapter",
|
|
111
|
+
status: "fail",
|
|
112
|
+
message: `Invalid key material in ${keyFilePath}`,
|
|
113
|
+
canRepair: false,
|
|
114
|
+
repairHint: "Replace with valid key material or delete it and run doctor --repair",
|
|
115
|
+
};
|
|
116
|
+
}
|
|
117
|
+
return withStrictModeNote({
|
|
118
|
+
name: "Secrets adapter",
|
|
119
|
+
status: "pass",
|
|
120
|
+
message: `Local encrypted provider configured with key file ${keyFilePath}`,
|
|
121
|
+
}, config);
|
|
122
|
+
}
|
|
123
|
+
//# sourceMappingURL=secrets-check.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"secrets-check.js","sourceRoot":"","sources":["../../src/checks/secrets-check.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"storage-check.d.ts","sourceRoot":"","sources":["../../src/checks/storage-check.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAC3D,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAG9C,wBAAgB,YAAY,CAAC,MAAM,EAAE,eAAe,EAAE,UAAU,CAAC,EAAE,MAAM,GAAG,WAAW,CA4CtF"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import fs from "node:fs";
|
|
2
|
+
import { resolveRuntimeLikePath } from "./path-resolver.js";
|
|
3
|
+
export function storageCheck(config, configPath) {
|
|
4
|
+
if (config.storage.provider === "local_disk") {
|
|
5
|
+
const baseDir = resolveRuntimeLikePath(config.storage.localDisk.baseDir, configPath);
|
|
6
|
+
if (!fs.existsSync(baseDir)) {
|
|
7
|
+
fs.mkdirSync(baseDir, { recursive: true });
|
|
8
|
+
}
|
|
9
|
+
try {
|
|
10
|
+
fs.accessSync(baseDir, fs.constants.W_OK);
|
|
11
|
+
return {
|
|
12
|
+
name: "Storage",
|
|
13
|
+
status: "pass",
|
|
14
|
+
message: `Local disk storage is writable: ${baseDir}`,
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
catch {
|
|
18
|
+
return {
|
|
19
|
+
name: "Storage",
|
|
20
|
+
status: "fail",
|
|
21
|
+
message: `Local storage directory is not writable: ${baseDir}`,
|
|
22
|
+
canRepair: false,
|
|
23
|
+
repairHint: "Check file permissions for storage.localDisk.baseDir",
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
const bucket = config.storage.s3.bucket.trim();
|
|
28
|
+
const region = config.storage.s3.region.trim();
|
|
29
|
+
if (!bucket || !region) {
|
|
30
|
+
return {
|
|
31
|
+
name: "Storage",
|
|
32
|
+
status: "fail",
|
|
33
|
+
message: "S3 storage requires non-empty bucket and region",
|
|
34
|
+
canRepair: false,
|
|
35
|
+
repairHint: "Run `paperclipai configure --section storage`",
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
return {
|
|
39
|
+
name: "Storage",
|
|
40
|
+
status: "warn",
|
|
41
|
+
message: `S3 storage configured (bucket=${bucket}, region=${region}). Reachability check is skipped in doctor.`,
|
|
42
|
+
canRepair: false,
|
|
43
|
+
repairHint: "Verify credentials and endpoint in deployment environment",
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
//# sourceMappingURL=storage-check.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"storage-check.js","sourceRoot":"","sources":["../../src/checks/storage-check.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,SAAS,CAAC;AAGzB,OAAO,EAAE,sBAAsB,EAAE,MAAM,oBAAoB,CAAC;AAE5D,MAAM,UAAU,YAAY,CAAC,MAAuB,EAAE,UAAmB;IACvE,IAAI,MAAM,CAAC,OAAO,CAAC,QAAQ,KAAK,YAAY,EAAE,CAAC;QAC7C,MAAM,OAAO,GAAG,sBAAsB,CAAC,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC;QACrF,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE,CAAC;YAC5B,EAAE,CAAC,SAAS,CAAC,OAAO,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;QAC7C,CAAC;QAED,IAAI,CAAC;YACH,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;YAC1C,OAAO;gBACL,IAAI,EAAE,SAAS;gBACf,MAAM,EAAE,MAAM;gBACd,OAAO,EAAE,mCAAmC,OAAO,EAAE;aACtD,CAAC;QACJ,CAAC;QAAC,MAAM,CAAC;YACP,OAAO;gBACL,IAAI,EAAE,SAAS;gBACf,MAAM,EAAE,MAAM;gBACd,OAAO,EAAE,4CAA4C,OAAO,EAAE;gBAC9D,SAAS,EAAE,KAAK;gBAChB,UAAU,EAAE,sDAAsD;aACnE,CAAC;QACJ,CAAC;IACH,CAAC;IAED,MAAM,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;IAC/C,MAAM,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;IAC/C,IAAI,CAAC,MAAM,IAAI,CAAC,MAAM,EAAE,CAAC;QACvB,OAAO;YACL,IAAI,EAAE,SAAS;YACf,MAAM,EAAE,MAAM;YACd,OAAO,EAAE,iDAAiD;YAC1D,SAAS,EAAE,KAAK;YAChB,UAAU,EAAE,+CAA+C;SAC5D,CAAC;IACJ,CAAC;IAED,OAAO;QACL,IAAI,EAAE,SAAS;QACf,MAAM,EAAE,MAAM;QACd,OAAO,EAAE,iCAAiC,MAAM,YAAY,MAAM,6CAA6C;QAC/G,SAAS,EAAE,KAAK;QAChB,UAAU,EAAE,2DAA2D;KACxE,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
export interface ClientContextProfile {
|
|
2
|
+
apiBase?: string;
|
|
3
|
+
companyId?: string;
|
|
4
|
+
apiKeyEnvVarName?: string;
|
|
5
|
+
}
|
|
6
|
+
export interface ClientContext {
|
|
7
|
+
version: 1;
|
|
8
|
+
currentProfile: string;
|
|
9
|
+
profiles: Record<string, ClientContextProfile>;
|
|
10
|
+
}
|
|
11
|
+
export declare function resolveContextPath(overridePath?: string): string;
|
|
12
|
+
export declare function defaultClientContext(): ClientContext;
|
|
13
|
+
export declare function readContext(contextPath?: string): ClientContext;
|
|
14
|
+
export declare function writeContext(context: ClientContext, contextPath?: string): void;
|
|
15
|
+
export declare function upsertProfile(profileName: string, patch: Partial<ClientContextProfile>, contextPath?: string): ClientContext;
|
|
16
|
+
export declare function setCurrentProfile(profileName: string, contextPath?: string): ClientContext;
|
|
17
|
+
export declare function resolveProfile(context: ClientContext, profileName?: string): {
|
|
18
|
+
name: string;
|
|
19
|
+
profile: ClientContextProfile;
|
|
20
|
+
};
|
|
21
|
+
//# sourceMappingURL=context.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"context.d.ts","sourceRoot":"","sources":["../../src/client/context.ts"],"names":[],"mappings":"AAOA,MAAM,WAAW,oBAAoB;IACnC,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,gBAAgB,CAAC,EAAE,MAAM,CAAC;CAC3B;AAED,MAAM,WAAW,aAAa;IAC5B,OAAO,EAAE,CAAC,CAAC;IACX,cAAc,EAAE,MAAM,CAAC;IACvB,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,oBAAoB,CAAC,CAAC;CAChD;AAoBD,wBAAgB,kBAAkB,CAAC,YAAY,CAAC,EAAE,MAAM,GAAG,MAAM,CAIhE;AAED,wBAAgB,oBAAoB,IAAI,aAAa,CAQpD;AA2DD,wBAAgB,WAAW,CAAC,WAAW,CAAC,EAAE,MAAM,GAAG,aAAa,CAQ/D;AAED,wBAAgB,YAAY,CAAC,OAAO,EAAE,aAAa,EAAE,WAAW,CAAC,EAAE,MAAM,GAAG,IAAI,CAO/E;AAED,wBAAgB,aAAa,CAC3B,WAAW,EAAE,MAAM,EACnB,KAAK,EAAE,OAAO,CAAC,oBAAoB,CAAC,EACpC,WAAW,CAAC,EAAE,MAAM,GACnB,aAAa,CAsBf;AAED,wBAAgB,iBAAiB,CAAC,WAAW,EAAE,MAAM,EAAE,WAAW,CAAC,EAAE,MAAM,GAAG,aAAa,CAQ1F;AAED,wBAAgB,cAAc,CAC5B,OAAO,EAAE,aAAa,EACtB,WAAW,CAAC,EAAE,MAAM,GACnB;IAAE,IAAI,EAAE,MAAM,CAAC;IAAC,OAAO,EAAE,oBAAoB,CAAA;CAAE,CAIjD"}
|
|
@@ -0,0 +1,136 @@
|
|
|
1
|
+
import fs from "node:fs";
|
|
2
|
+
import path from "node:path";
|
|
3
|
+
import { resolveDefaultContextPath } from "../config/home.js";
|
|
4
|
+
const DEFAULT_CONTEXT_BASENAME = "context.json";
|
|
5
|
+
const DEFAULT_PROFILE = "default";
|
|
6
|
+
function findContextFileFromAncestors(startDir) {
|
|
7
|
+
const absoluteStartDir = path.resolve(startDir);
|
|
8
|
+
let currentDir = absoluteStartDir;
|
|
9
|
+
while (true) {
|
|
10
|
+
const candidate = path.resolve(currentDir, ".paperclip", DEFAULT_CONTEXT_BASENAME);
|
|
11
|
+
if (fs.existsSync(candidate)) {
|
|
12
|
+
return candidate;
|
|
13
|
+
}
|
|
14
|
+
const nextDir = path.resolve(currentDir, "..");
|
|
15
|
+
if (nextDir === currentDir)
|
|
16
|
+
break;
|
|
17
|
+
currentDir = nextDir;
|
|
18
|
+
}
|
|
19
|
+
return null;
|
|
20
|
+
}
|
|
21
|
+
export function resolveContextPath(overridePath) {
|
|
22
|
+
if (overridePath)
|
|
23
|
+
return path.resolve(overridePath);
|
|
24
|
+
if (process.env.PAPERCLIP_CONTEXT)
|
|
25
|
+
return path.resolve(process.env.PAPERCLIP_CONTEXT);
|
|
26
|
+
return findContextFileFromAncestors(process.cwd()) ?? resolveDefaultContextPath();
|
|
27
|
+
}
|
|
28
|
+
export function defaultClientContext() {
|
|
29
|
+
return {
|
|
30
|
+
version: 1,
|
|
31
|
+
currentProfile: DEFAULT_PROFILE,
|
|
32
|
+
profiles: {
|
|
33
|
+
[DEFAULT_PROFILE]: {},
|
|
34
|
+
},
|
|
35
|
+
};
|
|
36
|
+
}
|
|
37
|
+
function parseJson(filePath) {
|
|
38
|
+
try {
|
|
39
|
+
return JSON.parse(fs.readFileSync(filePath, "utf-8"));
|
|
40
|
+
}
|
|
41
|
+
catch (err) {
|
|
42
|
+
throw new Error(`Failed to parse JSON at ${filePath}: ${err instanceof Error ? err.message : String(err)}`);
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
function toStringOrUndefined(value) {
|
|
46
|
+
return typeof value === "string" && value.trim().length > 0 ? value.trim() : undefined;
|
|
47
|
+
}
|
|
48
|
+
function normalizeProfile(value) {
|
|
49
|
+
if (typeof value !== "object" || value === null || Array.isArray(value))
|
|
50
|
+
return {};
|
|
51
|
+
const profile = value;
|
|
52
|
+
return {
|
|
53
|
+
apiBase: toStringOrUndefined(profile.apiBase),
|
|
54
|
+
companyId: toStringOrUndefined(profile.companyId),
|
|
55
|
+
apiKeyEnvVarName: toStringOrUndefined(profile.apiKeyEnvVarName),
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
function normalizeContext(raw) {
|
|
59
|
+
if (typeof raw !== "object" || raw === null || Array.isArray(raw)) {
|
|
60
|
+
return defaultClientContext();
|
|
61
|
+
}
|
|
62
|
+
const record = raw;
|
|
63
|
+
const version = record.version === 1 ? 1 : 1;
|
|
64
|
+
const currentProfile = toStringOrUndefined(record.currentProfile) ?? DEFAULT_PROFILE;
|
|
65
|
+
const rawProfiles = record.profiles;
|
|
66
|
+
const profiles = {};
|
|
67
|
+
if (typeof rawProfiles === "object" && rawProfiles !== null && !Array.isArray(rawProfiles)) {
|
|
68
|
+
for (const [name, profile] of Object.entries(rawProfiles)) {
|
|
69
|
+
if (!name.trim())
|
|
70
|
+
continue;
|
|
71
|
+
profiles[name] = normalizeProfile(profile);
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
if (!profiles[currentProfile]) {
|
|
75
|
+
profiles[currentProfile] = {};
|
|
76
|
+
}
|
|
77
|
+
if (Object.keys(profiles).length === 0) {
|
|
78
|
+
profiles[DEFAULT_PROFILE] = {};
|
|
79
|
+
}
|
|
80
|
+
return {
|
|
81
|
+
version,
|
|
82
|
+
currentProfile,
|
|
83
|
+
profiles,
|
|
84
|
+
};
|
|
85
|
+
}
|
|
86
|
+
export function readContext(contextPath) {
|
|
87
|
+
const filePath = resolveContextPath(contextPath);
|
|
88
|
+
if (!fs.existsSync(filePath)) {
|
|
89
|
+
return defaultClientContext();
|
|
90
|
+
}
|
|
91
|
+
const raw = parseJson(filePath);
|
|
92
|
+
return normalizeContext(raw);
|
|
93
|
+
}
|
|
94
|
+
export function writeContext(context, contextPath) {
|
|
95
|
+
const filePath = resolveContextPath(contextPath);
|
|
96
|
+
const dir = path.dirname(filePath);
|
|
97
|
+
fs.mkdirSync(dir, { recursive: true });
|
|
98
|
+
const normalized = normalizeContext(context);
|
|
99
|
+
fs.writeFileSync(filePath, `${JSON.stringify(normalized, null, 2)}\n`, { mode: 0o600 });
|
|
100
|
+
}
|
|
101
|
+
export function upsertProfile(profileName, patch, contextPath) {
|
|
102
|
+
const context = readContext(contextPath);
|
|
103
|
+
const existing = context.profiles[profileName] ?? {};
|
|
104
|
+
const merged = {
|
|
105
|
+
...existing,
|
|
106
|
+
...patch,
|
|
107
|
+
};
|
|
108
|
+
if (patch.apiBase !== undefined && patch.apiBase.trim().length === 0) {
|
|
109
|
+
delete merged.apiBase;
|
|
110
|
+
}
|
|
111
|
+
if (patch.companyId !== undefined && patch.companyId.trim().length === 0) {
|
|
112
|
+
delete merged.companyId;
|
|
113
|
+
}
|
|
114
|
+
if (patch.apiKeyEnvVarName !== undefined && patch.apiKeyEnvVarName.trim().length === 0) {
|
|
115
|
+
delete merged.apiKeyEnvVarName;
|
|
116
|
+
}
|
|
117
|
+
context.profiles[profileName] = merged;
|
|
118
|
+
context.currentProfile = context.currentProfile || profileName;
|
|
119
|
+
writeContext(context, contextPath);
|
|
120
|
+
return context;
|
|
121
|
+
}
|
|
122
|
+
export function setCurrentProfile(profileName, contextPath) {
|
|
123
|
+
const context = readContext(contextPath);
|
|
124
|
+
if (!context.profiles[profileName]) {
|
|
125
|
+
context.profiles[profileName] = {};
|
|
126
|
+
}
|
|
127
|
+
context.currentProfile = profileName;
|
|
128
|
+
writeContext(context, contextPath);
|
|
129
|
+
return context;
|
|
130
|
+
}
|
|
131
|
+
export function resolveProfile(context, profileName) {
|
|
132
|
+
const name = profileName?.trim() || context.currentProfile || DEFAULT_PROFILE;
|
|
133
|
+
const profile = context.profiles[name] ?? {};
|
|
134
|
+
return { name, profile };
|
|
135
|
+
}
|
|
136
|
+
//# sourceMappingURL=context.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"context.js","sourceRoot":"","sources":["../../src/client/context.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
export declare class ApiRequestError extends Error {
|
|
2
|
+
status: number;
|
|
3
|
+
details?: unknown;
|
|
4
|
+
body?: unknown;
|
|
5
|
+
constructor(status: number, message: string, details?: unknown, body?: unknown);
|
|
6
|
+
}
|
|
7
|
+
interface RequestOptions {
|
|
8
|
+
ignoreNotFound?: boolean;
|
|
9
|
+
}
|
|
10
|
+
interface ApiClientOptions {
|
|
11
|
+
apiBase: string;
|
|
12
|
+
apiKey?: string;
|
|
13
|
+
runId?: string;
|
|
14
|
+
userId?: string;
|
|
15
|
+
}
|
|
16
|
+
export declare class PaperclipApiClient {
|
|
17
|
+
readonly apiBase: string;
|
|
18
|
+
readonly apiKey?: string;
|
|
19
|
+
readonly runId?: string;
|
|
20
|
+
readonly userId?: string;
|
|
21
|
+
constructor(opts: ApiClientOptions);
|
|
22
|
+
get<T>(path: string, opts?: RequestOptions): Promise<T | null>;
|
|
23
|
+
post<T>(path: string, body?: unknown, opts?: RequestOptions): Promise<T | null>;
|
|
24
|
+
patch<T>(path: string, body?: unknown, opts?: RequestOptions): Promise<T | null>;
|
|
25
|
+
delete<T>(path: string, opts?: RequestOptions): Promise<T | null>;
|
|
26
|
+
private request;
|
|
27
|
+
}
|
|
28
|
+
export {};
|
|
29
|
+
//# sourceMappingURL=http.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"http.d.ts","sourceRoot":"","sources":["../../src/client/http.ts"],"names":[],"mappings":"AAEA,qBAAa,eAAgB,SAAQ,KAAK;IACxC,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,IAAI,CAAC,EAAE,OAAO,CAAC;gBAEH,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,EAAE,OAAO;CAM/E;AAED,UAAU,cAAc;IACtB,cAAc,CAAC,EAAE,OAAO,CAAC;CAC1B;AAED,UAAU,gBAAgB;IACxB,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,qBAAa,kBAAkB;IAC7B,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAC;IACzB,QAAQ,CAAC,MAAM,CAAC,EAAE,MAAM,CAAC;IACzB,QAAQ,CAAC,KAAK,CAAC,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,MAAM,CAAC,EAAE,MAAM,CAAC;gBAEb,IAAI,EAAE,gBAAgB;IAOlC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,cAAc,GAAG,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC;IAI9D,IAAI,CAAC,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,EAAE,cAAc,GAAG,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC;IAO/E,KAAK,CAAC,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,EAAE,cAAc,GAAG,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC;IAOhF,MAAM,CAAC,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,cAAc,GAAG,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC;YAInD,OAAO;CAgDtB"}
|