@agentuity/cli 0.1.8 → 0.1.10
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/README.md +2 -2
- package/bin/cli.ts +8 -0
- package/dist/cache/index.d.ts +2 -0
- package/dist/cache/index.d.ts.map +1 -0
- package/dist/cache/index.js +2 -0
- package/dist/cache/index.js.map +1 -0
- package/dist/cache/resource-region.d.ts +46 -0
- package/dist/cache/resource-region.d.ts.map +1 -0
- package/dist/cache/resource-region.js +115 -0
- package/dist/cache/resource-region.js.map +1 -0
- package/dist/cli.d.ts.map +1 -1
- package/dist/cli.js +44 -18
- package/dist/cli.js.map +1 -1
- package/dist/cmd/ai/capabilities/show.d.ts.map +1 -1
- package/dist/cmd/ai/capabilities/show.js +12 -15
- package/dist/cmd/ai/capabilities/show.js.map +1 -1
- package/dist/cmd/ai/prompt/llm.js +5 -5
- package/dist/cmd/ai/prompt/llm.js.map +1 -1
- package/dist/cmd/ai/skills/generator.d.ts.map +1 -1
- package/dist/cmd/ai/skills/generator.js +9 -1
- package/dist/cmd/ai/skills/generator.js.map +1 -1
- package/dist/cmd/auth/logout.d.ts.map +1 -1
- package/dist/cmd/auth/logout.js +5 -2
- package/dist/cmd/auth/logout.js.map +1 -1
- package/dist/cmd/build/ast.d.ts.map +1 -1
- package/dist/cmd/build/ast.js +87 -1
- package/dist/cmd/build/ast.js.map +1 -1
- package/dist/cmd/build/vite/metadata-generator.js +1 -1
- package/dist/cmd/build/vite/metadata-generator.js.map +1 -1
- package/dist/cmd/build/vite/vite-asset-server-config.d.ts.map +1 -1
- package/dist/cmd/build/vite/vite-asset-server-config.js +8 -3
- package/dist/cmd/build/vite/vite-asset-server-config.js.map +1 -1
- package/dist/cmd/build/vite/vite-asset-server.d.ts.map +1 -1
- package/dist/cmd/build/vite/vite-asset-server.js +5 -3
- package/dist/cmd/build/vite/vite-asset-server.js.map +1 -1
- package/dist/cmd/cloud/db/delete.d.ts.map +1 -1
- package/dist/cmd/cloud/db/delete.js +69 -11
- package/dist/cmd/cloud/db/delete.js.map +1 -1
- package/dist/cmd/cloud/db/get.d.ts.map +1 -1
- package/dist/cmd/cloud/db/get.js +23 -7
- package/dist/cmd/cloud/db/get.js.map +1 -1
- package/dist/cmd/cloud/db/list.d.ts.map +1 -1
- package/dist/cmd/cloud/db/list.js +15 -7
- package/dist/cmd/cloud/db/list.js.map +1 -1
- package/dist/cmd/cloud/db/logs.d.ts.map +1 -1
- package/dist/cmd/cloud/db/logs.js +24 -4
- package/dist/cmd/cloud/db/logs.js.map +1 -1
- package/dist/cmd/cloud/deploy.d.ts.map +1 -1
- package/dist/cmd/cloud/deploy.js +50 -1
- package/dist/cmd/cloud/deploy.js.map +1 -1
- package/dist/cmd/cloud/env/delete.d.ts.map +1 -1
- package/dist/cmd/cloud/env/delete.js +30 -13
- package/dist/cmd/cloud/env/delete.js.map +1 -1
- package/dist/cmd/cloud/env/get.d.ts.map +1 -1
- package/dist/cmd/cloud/env/get.js +27 -30
- package/dist/cmd/cloud/env/get.js.map +1 -1
- package/dist/cmd/cloud/env/import.d.ts.map +1 -1
- package/dist/cmd/cloud/env/import.js +41 -48
- package/dist/cmd/cloud/env/import.js.map +1 -1
- package/dist/cmd/cloud/env/index.d.ts.map +1 -1
- package/dist/cmd/cloud/env/index.js +6 -2
- package/dist/cmd/cloud/env/index.js.map +1 -1
- package/dist/cmd/cloud/env/list.d.ts.map +1 -1
- package/dist/cmd/cloud/env/list.js +51 -28
- package/dist/cmd/cloud/env/list.js.map +1 -1
- package/dist/cmd/cloud/env/pull.d.ts.map +1 -1
- package/dist/cmd/cloud/env/pull.js +3 -3
- package/dist/cmd/cloud/env/pull.js.map +1 -1
- package/dist/cmd/cloud/env/push.d.ts.map +1 -1
- package/dist/cmd/cloud/env/push.js +31 -11
- package/dist/cmd/cloud/env/push.js.map +1 -1
- package/dist/cmd/cloud/env/set.d.ts.map +1 -1
- package/dist/cmd/cloud/env/set.js +41 -26
- package/dist/cmd/cloud/env/set.js.map +1 -1
- package/dist/cmd/cloud/index.d.ts.map +1 -1
- package/dist/cmd/cloud/index.js +0 -2
- package/dist/cmd/cloud/index.js.map +1 -1
- package/dist/cmd/cloud/region-lookup.d.ts +18 -0
- package/dist/cmd/cloud/region-lookup.d.ts.map +1 -0
- package/dist/cmd/cloud/region-lookup.js +64 -0
- package/dist/cmd/cloud/region-lookup.js.map +1 -0
- package/dist/cmd/cloud/sandbox/cp.d.ts.map +1 -1
- package/dist/cmd/cloud/sandbox/cp.js +5 -3
- package/dist/cmd/cloud/sandbox/cp.js.map +1 -1
- package/dist/cmd/cloud/sandbox/create.d.ts.map +1 -1
- package/dist/cmd/cloud/sandbox/create.js +54 -2
- package/dist/cmd/cloud/sandbox/create.js.map +1 -1
- package/dist/cmd/cloud/sandbox/delete.d.ts.map +1 -1
- package/dist/cmd/cloud/sandbox/delete.js +5 -3
- package/dist/cmd/cloud/sandbox/delete.js.map +1 -1
- package/dist/cmd/cloud/sandbox/download.d.ts.map +1 -1
- package/dist/cmd/cloud/sandbox/download.js +4 -3
- package/dist/cmd/cloud/sandbox/download.js.map +1 -1
- package/dist/cmd/cloud/sandbox/env.d.ts.map +1 -1
- package/dist/cmd/cloud/sandbox/env.js +4 -3
- package/dist/cmd/cloud/sandbox/env.js.map +1 -1
- package/dist/cmd/cloud/sandbox/exec.d.ts.map +1 -1
- package/dist/cmd/cloud/sandbox/exec.js +4 -3
- package/dist/cmd/cloud/sandbox/exec.js.map +1 -1
- package/dist/cmd/cloud/sandbox/execution/get.js +4 -4
- package/dist/cmd/cloud/sandbox/execution/get.js.map +1 -1
- package/dist/cmd/cloud/sandbox/execution/index.js +1 -1
- package/dist/cmd/cloud/sandbox/execution/index.js.map +1 -1
- package/dist/cmd/cloud/sandbox/execution/list.d.ts.map +1 -1
- package/dist/cmd/cloud/sandbox/execution/list.js +4 -3
- package/dist/cmd/cloud/sandbox/execution/list.js.map +1 -1
- package/dist/cmd/cloud/sandbox/get.d.ts.map +1 -1
- package/dist/cmd/cloud/sandbox/get.js +26 -4
- package/dist/cmd/cloud/sandbox/get.js.map +1 -1
- package/dist/cmd/cloud/sandbox/index.d.ts.map +1 -1
- package/dist/cmd/cloud/sandbox/index.js +3 -1
- package/dist/cmd/cloud/sandbox/index.js.map +1 -1
- package/dist/cmd/cloud/sandbox/list.d.ts.map +1 -1
- package/dist/cmd/cloud/sandbox/list.js +16 -9
- package/dist/cmd/cloud/sandbox/list.js.map +1 -1
- package/dist/cmd/cloud/sandbox/ls.d.ts.map +1 -1
- package/dist/cmd/cloud/sandbox/ls.js +4 -3
- package/dist/cmd/cloud/sandbox/ls.js.map +1 -1
- package/dist/cmd/cloud/sandbox/mkdir.d.ts.map +1 -1
- package/dist/cmd/cloud/sandbox/mkdir.js +4 -3
- package/dist/cmd/cloud/sandbox/mkdir.js.map +1 -1
- package/dist/cmd/cloud/sandbox/rm.d.ts.map +1 -1
- package/dist/cmd/cloud/sandbox/rm.js +4 -3
- package/dist/cmd/cloud/sandbox/rm.js.map +1 -1
- package/dist/cmd/cloud/sandbox/rmdir.d.ts.map +1 -1
- package/dist/cmd/cloud/sandbox/rmdir.js +4 -3
- package/dist/cmd/cloud/sandbox/rmdir.js.map +1 -1
- package/dist/cmd/cloud/sandbox/run.d.ts.map +1 -1
- package/dist/cmd/cloud/sandbox/run.js +51 -2
- package/dist/cmd/cloud/sandbox/run.js.map +1 -1
- package/dist/cmd/cloud/sandbox/runtime/index.d.ts +3 -0
- package/dist/cmd/cloud/sandbox/runtime/index.d.ts.map +1 -0
- package/dist/cmd/cloud/sandbox/runtime/index.js +19 -0
- package/dist/cmd/cloud/sandbox/runtime/index.js.map +1 -0
- package/dist/cmd/cloud/sandbox/runtime/list.d.ts +3 -0
- package/dist/cmd/cloud/sandbox/runtime/list.d.ts.map +1 -0
- package/dist/cmd/cloud/sandbox/runtime/list.js +68 -0
- package/dist/cmd/cloud/sandbox/runtime/list.js.map +1 -0
- package/dist/cmd/cloud/sandbox/snapshot/create.d.ts.map +1 -1
- package/dist/cmd/cloud/sandbox/snapshot/create.js +41 -8
- package/dist/cmd/cloud/sandbox/snapshot/create.js.map +1 -1
- package/dist/cmd/cloud/sandbox/snapshot/delete.js +4 -4
- package/dist/cmd/cloud/sandbox/snapshot/delete.js.map +1 -1
- package/dist/cmd/cloud/sandbox/snapshot/get.js +5 -5
- package/dist/cmd/cloud/sandbox/snapshot/get.js.map +1 -1
- package/dist/cmd/cloud/sandbox/snapshot/index.js +1 -1
- package/dist/cmd/cloud/sandbox/snapshot/index.js.map +1 -1
- package/dist/cmd/cloud/sandbox/snapshot/list.d.ts.map +1 -1
- package/dist/cmd/cloud/sandbox/snapshot/list.js +8 -4
- package/dist/cmd/cloud/sandbox/snapshot/list.js.map +1 -1
- package/dist/cmd/cloud/sandbox/snapshot/tag.d.ts.map +1 -1
- package/dist/cmd/cloud/sandbox/snapshot/tag.js +14 -4
- package/dist/cmd/cloud/sandbox/snapshot/tag.js.map +1 -1
- package/dist/cmd/cloud/sandbox/upload.d.ts.map +1 -1
- package/dist/cmd/cloud/sandbox/upload.js +4 -3
- package/dist/cmd/cloud/sandbox/upload.js.map +1 -1
- package/dist/cmd/cloud/sandbox/util.d.ts +13 -0
- package/dist/cmd/cloud/sandbox/util.d.ts.map +1 -1
- package/dist/cmd/cloud/sandbox/util.js +40 -1
- package/dist/cmd/cloud/sandbox/util.js.map +1 -1
- package/dist/cmd/cloud/scp/download.d.ts.map +1 -1
- package/dist/cmd/cloud/scp/download.js +6 -2
- package/dist/cmd/cloud/scp/download.js.map +1 -1
- package/dist/cmd/cloud/scp/upload.d.ts.map +1 -1
- package/dist/cmd/cloud/scp/upload.js +6 -2
- package/dist/cmd/cloud/scp/upload.js.map +1 -1
- package/dist/cmd/cloud/session/get.js +4 -4
- package/dist/cmd/cloud/session/get.js.map +1 -1
- package/dist/cmd/cloud/session/list.js +4 -4
- package/dist/cmd/cloud/session/list.js.map +1 -1
- package/dist/cmd/cloud/ssh.d.ts.map +1 -1
- package/dist/cmd/cloud/ssh.js +7 -2
- package/dist/cmd/cloud/ssh.js.map +1 -1
- package/dist/cmd/cloud/storage/delete.d.ts.map +1 -1
- package/dist/cmd/cloud/storage/delete.js +46 -10
- package/dist/cmd/cloud/storage/delete.js.map +1 -1
- package/dist/cmd/cloud/storage/download.d.ts.map +1 -1
- package/dist/cmd/cloud/storage/download.js +19 -6
- package/dist/cmd/cloud/storage/download.js.map +1 -1
- package/dist/cmd/cloud/storage/get.d.ts.map +1 -1
- package/dist/cmd/cloud/storage/get.js +19 -6
- package/dist/cmd/cloud/storage/get.js.map +1 -1
- package/dist/cmd/cloud/storage/list.d.ts.map +1 -1
- package/dist/cmd/cloud/storage/list.js +17 -7
- package/dist/cmd/cloud/storage/list.js.map +1 -1
- package/dist/cmd/cloud/storage/upload.d.ts.map +1 -1
- package/dist/cmd/cloud/storage/upload.js +19 -6
- package/dist/cmd/cloud/storage/upload.js.map +1 -1
- package/dist/cmd/cloud/thread/delete.js +4 -4
- package/dist/cmd/cloud/thread/delete.js.map +1 -1
- package/dist/cmd/cloud/thread/get.js +4 -4
- package/dist/cmd/cloud/thread/get.js.map +1 -1
- package/dist/cmd/cloud/thread/list.js +4 -4
- package/dist/cmd/cloud/thread/list.js.map +1 -1
- package/dist/cmd/project/auth/init.d.ts.map +1 -1
- package/dist/cmd/project/auth/init.js +6 -3
- package/dist/cmd/project/auth/init.js.map +1 -1
- package/dist/cmd/project/auth/shared.d.ts +6 -2
- package/dist/cmd/project/auth/shared.d.ts.map +1 -1
- package/dist/cmd/project/auth/shared.js +40 -12
- package/dist/cmd/project/auth/shared.js.map +1 -1
- package/dist/config.d.ts +37 -0
- package/dist/config.d.ts.map +1 -1
- package/dist/config.js +61 -8
- package/dist/config.js.map +1 -1
- package/dist/env-util.d.ts +25 -2
- package/dist/env-util.d.ts.map +1 -1
- package/dist/env-util.js +44 -4
- package/dist/env-util.js.map +1 -1
- package/dist/utils/apt-validator.d.ts +20 -0
- package/dist/utils/apt-validator.d.ts.map +1 -0
- package/dist/utils/apt-validator.js +157 -0
- package/dist/utils/apt-validator.js.map +1 -0
- package/package.json +6 -6
- package/src/cache/index.ts +11 -0
- package/src/cache/resource-region.ts +183 -0
- package/src/cli.ts +51 -17
- package/src/cmd/ai/capabilities/show.ts +12 -15
- package/src/cmd/ai/prompt/llm.ts +5 -5
- package/src/cmd/ai/skills/generator.ts +9 -1
- package/src/cmd/auth/logout.ts +5 -2
- package/src/cmd/build/ast.ts +160 -1
- package/src/cmd/build/vite/metadata-generator.ts +1 -1
- package/src/cmd/build/vite/vite-asset-server-config.ts +7 -3
- package/src/cmd/build/vite/vite-asset-server.ts +6 -3
- package/src/cmd/cloud/db/delete.ts +83 -11
- package/src/cmd/cloud/db/get.ts +29 -7
- package/src/cmd/cloud/db/list.ts +16 -7
- package/src/cmd/cloud/db/logs.ts +33 -4
- package/src/cmd/cloud/deploy.ts +63 -0
- package/src/cmd/cloud/env/delete.ts +36 -12
- package/src/cmd/cloud/env/get.ts +28 -27
- package/src/cmd/cloud/env/import.ts +43 -56
- package/src/cmd/cloud/env/index.ts +6 -2
- package/src/cmd/cloud/env/list.ts +57 -30
- package/src/cmd/cloud/env/pull.ts +9 -3
- package/src/cmd/cloud/env/push.ts +44 -11
- package/src/cmd/cloud/env/set.ts +49 -30
- package/src/cmd/cloud/index.ts +0 -2
- package/src/cmd/cloud/region-lookup.ts +89 -0
- package/src/cmd/cloud/sandbox/cp.ts +5 -3
- package/src/cmd/cloud/sandbox/create.ts +61 -2
- package/src/cmd/cloud/sandbox/delete.ts +6 -3
- package/src/cmd/cloud/sandbox/download.ts +4 -3
- package/src/cmd/cloud/sandbox/env.ts +4 -3
- package/src/cmd/cloud/sandbox/exec.ts +4 -3
- package/src/cmd/cloud/sandbox/execution/get.ts +4 -4
- package/src/cmd/cloud/sandbox/execution/index.ts +1 -1
- package/src/cmd/cloud/sandbox/execution/list.ts +4 -3
- package/src/cmd/cloud/sandbox/get.ts +27 -4
- package/src/cmd/cloud/sandbox/index.ts +3 -1
- package/src/cmd/cloud/sandbox/list.ts +16 -9
- package/src/cmd/cloud/sandbox/ls.ts +4 -3
- package/src/cmd/cloud/sandbox/mkdir.ts +4 -3
- package/src/cmd/cloud/sandbox/rm.ts +4 -3
- package/src/cmd/cloud/sandbox/rmdir.ts +4 -3
- package/src/cmd/cloud/sandbox/run.ts +58 -2
- package/src/cmd/cloud/sandbox/runtime/index.ts +20 -0
- package/src/cmd/cloud/sandbox/runtime/list.ts +75 -0
- package/src/cmd/cloud/sandbox/snapshot/create.ts +53 -8
- package/src/cmd/cloud/sandbox/snapshot/delete.ts +4 -4
- package/src/cmd/cloud/sandbox/snapshot/get.ts +5 -5
- package/src/cmd/cloud/sandbox/snapshot/index.ts +1 -1
- package/src/cmd/cloud/sandbox/snapshot/list.ts +8 -4
- package/src/cmd/cloud/sandbox/snapshot/tag.ts +20 -4
- package/src/cmd/cloud/sandbox/upload.ts +4 -3
- package/src/cmd/cloud/sandbox/util.ts +60 -1
- package/src/cmd/cloud/scp/download.ts +14 -2
- package/src/cmd/cloud/scp/upload.ts +14 -2
- package/src/cmd/cloud/session/get.ts +4 -4
- package/src/cmd/cloud/session/list.ts +4 -4
- package/src/cmd/cloud/ssh.ts +15 -2
- package/src/cmd/cloud/storage/delete.ts +61 -10
- package/src/cmd/cloud/storage/download.ts +31 -6
- package/src/cmd/cloud/storage/get.ts +31 -6
- package/src/cmd/cloud/storage/list.ts +18 -7
- package/src/cmd/cloud/storage/upload.ts +31 -6
- package/src/cmd/cloud/thread/delete.ts +4 -4
- package/src/cmd/cloud/thread/get.ts +4 -4
- package/src/cmd/cloud/thread/list.ts +4 -4
- package/src/cmd/project/auth/init.ts +7 -3
- package/src/cmd/project/auth/shared.ts +52 -13
- package/src/config.ts +74 -8
- package/src/env-util.ts +50 -5
- package/src/utils/apt-validator.ts +215 -0
- package/dist/cmd/cloud/secret/delete.d.ts +0 -2
- package/dist/cmd/cloud/secret/delete.d.ts.map +0 -1
- package/dist/cmd/cloud/secret/delete.js +0 -53
- package/dist/cmd/cloud/secret/delete.js.map +0 -1
- package/dist/cmd/cloud/secret/get.d.ts +0 -2
- package/dist/cmd/cloud/secret/get.d.ts.map +0 -1
- package/dist/cmd/cloud/secret/get.js +0 -73
- package/dist/cmd/cloud/secret/get.js.map +0 -1
- package/dist/cmd/cloud/secret/import.d.ts +0 -2
- package/dist/cmd/cloud/secret/import.d.ts.map +0 -1
- package/dist/cmd/cloud/secret/import.js +0 -91
- package/dist/cmd/cloud/secret/import.js.map +0 -1
- package/dist/cmd/cloud/secret/index.d.ts +0 -3
- package/dist/cmd/cloud/secret/index.d.ts.map +0 -1
- package/dist/cmd/cloud/secret/index.js +0 -33
- package/dist/cmd/cloud/secret/index.js.map +0 -1
- package/dist/cmd/cloud/secret/list.d.ts +0 -2
- package/dist/cmd/cloud/secret/list.d.ts.map +0 -1
- package/dist/cmd/cloud/secret/list.js +0 -65
- package/dist/cmd/cloud/secret/list.js.map +0 -1
- package/dist/cmd/cloud/secret/pull.d.ts +0 -2
- package/dist/cmd/cloud/secret/pull.d.ts.map +0 -1
- package/dist/cmd/cloud/secret/pull.js +0 -82
- package/dist/cmd/cloud/secret/pull.js.map +0 -1
- package/dist/cmd/cloud/secret/push.d.ts +0 -2
- package/dist/cmd/cloud/secret/push.d.ts.map +0 -1
- package/dist/cmd/cloud/secret/push.js +0 -61
- package/dist/cmd/cloud/secret/push.js.map +0 -1
- package/dist/cmd/cloud/secret/set.d.ts +0 -2
- package/dist/cmd/cloud/secret/set.d.ts.map +0 -1
- package/dist/cmd/cloud/secret/set.js +0 -63
- package/dist/cmd/cloud/secret/set.js.map +0 -1
- package/src/cmd/cloud/secret/delete.ts +0 -65
- package/src/cmd/cloud/secret/get.ts +0 -77
- package/src/cmd/cloud/secret/import.ts +0 -110
- package/src/cmd/cloud/secret/index.ts +0 -33
- package/src/cmd/cloud/secret/list.ts +0 -70
- package/src/cmd/cloud/secret/pull.ts +0 -92
- package/src/cmd/cloud/secret/push.ts +0 -69
- package/src/cmd/cloud/secret/set.ts +0 -76
|
@@ -1,82 +0,0 @@
|
|
|
1
|
-
import { z } from 'zod';
|
|
2
|
-
import { join } from 'node:path';
|
|
3
|
-
import { createSubcommand } from '../../../types';
|
|
4
|
-
import * as tui from '../../../tui';
|
|
5
|
-
import { projectGet } from '@agentuity/server';
|
|
6
|
-
import { findExistingEnvFile, readEnvFile, writeEnvFile, mergeEnvVars } from '../../../env-util';
|
|
7
|
-
import { getCommand } from '../../../command-prefix';
|
|
8
|
-
const SecretPullResponseSchema = z.object({
|
|
9
|
-
success: z.boolean().describe('Whether pull succeeded'),
|
|
10
|
-
pulled: z.number().describe('Number of items pulled'),
|
|
11
|
-
path: z.string().describe('Local file path where secrets were saved'),
|
|
12
|
-
force: z.boolean().describe('Whether force mode was used'),
|
|
13
|
-
});
|
|
14
|
-
export const pullSubcommand = createSubcommand({
|
|
15
|
-
name: 'pull',
|
|
16
|
-
description: 'Pull secrets from cloud to local .env file',
|
|
17
|
-
tags: ['slow', 'requires-auth', 'requires-project'],
|
|
18
|
-
idempotent: true,
|
|
19
|
-
examples: [
|
|
20
|
-
{ command: getCommand('secret pull'), description: 'Run pull command' },
|
|
21
|
-
{ command: getCommand('secret pull --force'), description: 'Use force option' },
|
|
22
|
-
],
|
|
23
|
-
requires: { auth: true, project: true, apiClient: true },
|
|
24
|
-
prerequisites: ['cloud deploy'],
|
|
25
|
-
schema: {
|
|
26
|
-
options: z.object({
|
|
27
|
-
force: z.boolean().default(false).describe('overwrite local values with cloud values'),
|
|
28
|
-
}),
|
|
29
|
-
response: SecretPullResponseSchema,
|
|
30
|
-
},
|
|
31
|
-
async handler(ctx) {
|
|
32
|
-
const { opts, apiClient, project, projectDir } = ctx;
|
|
33
|
-
// Fetch project with unmasked secrets
|
|
34
|
-
const projectData = await tui.spinner('Pulling secrets from cloud', () => {
|
|
35
|
-
return projectGet(apiClient, { id: project.projectId, mask: false });
|
|
36
|
-
});
|
|
37
|
-
const cloudSecrets = { ...projectData.env, ...projectData.secrets }; // secret pull with actually do both secrets and env since thats likely what the user would want
|
|
38
|
-
// Target file is always .env
|
|
39
|
-
const targetEnvPath = await findExistingEnvFile(projectDir);
|
|
40
|
-
const localEnv = await readEnvFile(targetEnvPath);
|
|
41
|
-
// Merge: cloud values override local if force=true, otherwise keep local
|
|
42
|
-
let mergedEnv;
|
|
43
|
-
if (opts?.force) {
|
|
44
|
-
// Cloud values take priority
|
|
45
|
-
mergedEnv = mergeEnvVars(localEnv, cloudSecrets);
|
|
46
|
-
}
|
|
47
|
-
else {
|
|
48
|
-
// Local values take priority (only add new keys from cloud)
|
|
49
|
-
mergedEnv = mergeEnvVars(cloudSecrets, localEnv);
|
|
50
|
-
}
|
|
51
|
-
// Write to .env (skip AGENTUITY_ keys)
|
|
52
|
-
await writeEnvFile(targetEnvPath, mergedEnv, {
|
|
53
|
-
skipKeys: Object.keys(mergedEnv).filter((k) => k.startsWith('AGENTUITY_')),
|
|
54
|
-
});
|
|
55
|
-
// Write AGENTUITY_SDK_KEY to .env if present and missing locally
|
|
56
|
-
if (projectData.api_key) {
|
|
57
|
-
const dotEnvPath = join(projectDir, '.env');
|
|
58
|
-
const dotEnv = await readEnvFile(dotEnvPath);
|
|
59
|
-
if (!dotEnv.AGENTUITY_SDK_KEY) {
|
|
60
|
-
dotEnv.AGENTUITY_SDK_KEY = projectData.api_key;
|
|
61
|
-
await writeEnvFile(dotEnvPath, dotEnv, {
|
|
62
|
-
addComment: (key) => {
|
|
63
|
-
if (key === 'AGENTUITY_SDK_KEY') {
|
|
64
|
-
return 'AGENTUITY_SDK_KEY is a sensitive value and should not be committed to version control.';
|
|
65
|
-
}
|
|
66
|
-
return null;
|
|
67
|
-
},
|
|
68
|
-
});
|
|
69
|
-
tui.info(`Wrote AGENTUITY_SDK_KEY to ${dotEnvPath}`);
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
const count = Object.keys(cloudSecrets).length;
|
|
73
|
-
tui.success(`Pulled ${count} secret${count !== 1 ? 's' : ''} to ${targetEnvPath}`);
|
|
74
|
-
return {
|
|
75
|
-
success: true,
|
|
76
|
-
pulled: count,
|
|
77
|
-
path: targetEnvPath,
|
|
78
|
-
force: opts?.force ?? false,
|
|
79
|
-
};
|
|
80
|
-
},
|
|
81
|
-
});
|
|
82
|
-
//# sourceMappingURL=pull.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"pull.js","sourceRoot":"","sources":["../../../../src/cmd/cloud/secret/pull.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAClD,OAAO,KAAK,GAAG,MAAM,cAAc,CAAC;AACpC,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAC/C,OAAO,EAAE,mBAAmB,EAAE,WAAW,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjG,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AAErD,MAAM,wBAAwB,GAAG,CAAC,CAAC,MAAM,CAAC;IACzC,OAAO,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,QAAQ,CAAC,wBAAwB,CAAC;IACvD,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,wBAAwB,CAAC;IACrD,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,0CAA0C,CAAC;IACrE,KAAK,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,QAAQ,CAAC,6BAA6B,CAAC;CAC1D,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,cAAc,GAAG,gBAAgB,CAAC;IAC9C,IAAI,EAAE,MAAM;IACZ,WAAW,EAAE,4CAA4C;IACzD,IAAI,EAAE,CAAC,MAAM,EAAE,eAAe,EAAE,kBAAkB,CAAC;IACnD,UAAU,EAAE,IAAI;IAChB,QAAQ,EAAE;QACT,EAAE,OAAO,EAAE,UAAU,CAAC,aAAa,CAAC,EAAE,WAAW,EAAE,kBAAkB,EAAE;QACvE,EAAE,OAAO,EAAE,UAAU,CAAC,qBAAqB,CAAC,EAAE,WAAW,EAAE,kBAAkB,EAAE;KAC/E;IACD,QAAQ,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE;IACxD,aAAa,EAAE,CAAC,cAAc,CAAC;IAC/B,MAAM,EAAE;QACP,OAAO,EAAE,CAAC,CAAC,MAAM,CAAC;YACjB,KAAK,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC,0CAA0C,CAAC;SACtF,CAAC;QACF,QAAQ,EAAE,wBAAwB;KAClC;IAED,KAAK,CAAC,OAAO,CAAC,GAAG;QAChB,MAAM,EAAE,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,UAAU,EAAE,GAAG,GAAG,CAAC;QAErD,sCAAsC;QACtC,MAAM,WAAW,GAAG,MAAM,GAAG,CAAC,OAAO,CAAC,4BAA4B,EAAE,GAAG,EAAE;YACxE,OAAO,UAAU,CAAC,SAAS,EAAE,EAAE,EAAE,EAAE,OAAO,CAAC,SAAS,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC;QACtE,CAAC,CAAC,CAAC;QAEH,MAAM,YAAY,GAAG,EAAE,GAAG,WAAW,CAAC,GAAG,EAAE,GAAG,WAAW,CAAC,OAAO,EAAE,CAAC,CAAC,gGAAgG;QAErK,6BAA6B;QAC7B,MAAM,aAAa,GAAG,MAAM,mBAAmB,CAAC,UAAU,CAAC,CAAC;QAC5D,MAAM,QAAQ,GAAG,MAAM,WAAW,CAAC,aAAa,CAAC,CAAC;QAElD,yEAAyE;QACzE,IAAI,SAAiC,CAAC;QACtC,IAAI,IAAI,EAAE,KAAK,EAAE,CAAC;YACjB,6BAA6B;YAC7B,SAAS,GAAG,YAAY,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAC;QAClD,CAAC;aAAM,CAAC;YACP,4DAA4D;YAC5D,SAAS,GAAG,YAAY,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;QAClD,CAAC;QAED,uCAAuC;QACvC,MAAM,YAAY,CAAC,aAAa,EAAE,SAAS,EAAE;YAC5C,QAAQ,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC;SAC1E,CAAC,CAAC;QAEH,iEAAiE;QACjE,IAAI,WAAW,CAAC,OAAO,EAAE,CAAC;YACzB,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC;YAC5C,MAAM,MAAM,GAAG,MAAM,WAAW,CAAC,UAAU,CAAC,CAAC;YAE7C,IAAI,CAAC,MAAM,CAAC,iBAAiB,EAAE,CAAC;gBAC/B,MAAM,CAAC,iBAAiB,GAAG,WAAW,CAAC,OAAO,CAAC;gBAC/C,MAAM,YAAY,CAAC,UAAU,EAAE,MAAM,EAAE;oBACtC,UAAU,EAAE,CAAC,GAAG,EAAE,EAAE;wBACnB,IAAI,GAAG,KAAK,mBAAmB,EAAE,CAAC;4BACjC,OAAO,wFAAwF,CAAC;wBACjG,CAAC;wBACD,OAAO,IAAI,CAAC;oBACb,CAAC;iBACD,CAAC,CAAC;gBACH,GAAG,CAAC,IAAI,CAAC,8BAA8B,UAAU,EAAE,CAAC,CAAC;YACtD,CAAC;QACF,CAAC;QAED,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC;QAC/C,GAAG,CAAC,OAAO,CAAC,UAAU,KAAK,UAAU,KAAK,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,OAAO,aAAa,EAAE,CAAC,CAAC;QAEnF,OAAO;YACN,OAAO,EAAE,IAAI;YACb,MAAM,EAAE,KAAK;YACb,IAAI,EAAE,aAAa;YACnB,KAAK,EAAE,IAAI,EAAE,KAAK,IAAI,KAAK;SAC3B,CAAC;IACH,CAAC;CACD,CAAC,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"push.d.ts","sourceRoot":"","sources":["../../../../src/cmd/cloud/secret/push.ts"],"names":[],"mappings":"AAaA,eAAO,MAAM,cAAc,yCAuDzB,CAAC"}
|
|
@@ -1,61 +0,0 @@
|
|
|
1
|
-
import { z } from 'zod';
|
|
2
|
-
import { createSubcommand } from '../../../types';
|
|
3
|
-
import * as tui from '../../../tui';
|
|
4
|
-
import { projectEnvUpdate } from '@agentuity/server';
|
|
5
|
-
import { findExistingEnvFile, readEnvFile, filterAgentuitySdkKeys } from '../../../env-util';
|
|
6
|
-
import { getCommand } from '../../../command-prefix';
|
|
7
|
-
const SecretPushResponseSchema = z.object({
|
|
8
|
-
success: z.boolean().describe('Whether push succeeded'),
|
|
9
|
-
pushed: z.number().describe('Number of items pushed'),
|
|
10
|
-
source: z.string().describe('Source file path'),
|
|
11
|
-
});
|
|
12
|
-
export const pushSubcommand = createSubcommand({
|
|
13
|
-
name: 'push',
|
|
14
|
-
description: 'Push secrets from local .env file to cloud',
|
|
15
|
-
tags: [
|
|
16
|
-
'mutating',
|
|
17
|
-
'updates-resource',
|
|
18
|
-
'slow',
|
|
19
|
-
'api-intensive',
|
|
20
|
-
'requires-auth',
|
|
21
|
-
'requires-project',
|
|
22
|
-
],
|
|
23
|
-
idempotent: true,
|
|
24
|
-
examples: [{ command: getCommand('secret push'), description: 'Run push command' }],
|
|
25
|
-
requires: { auth: true, project: true, apiClient: true },
|
|
26
|
-
prerequisites: ['secret set'],
|
|
27
|
-
schema: {
|
|
28
|
-
response: SecretPushResponseSchema,
|
|
29
|
-
},
|
|
30
|
-
async handler(ctx) {
|
|
31
|
-
const { apiClient, project, projectDir } = ctx;
|
|
32
|
-
// Read local env file
|
|
33
|
-
const envFilePath = await findExistingEnvFile(projectDir);
|
|
34
|
-
const localEnv = await readEnvFile(envFilePath);
|
|
35
|
-
// Filter out AGENTUITY_ prefixed keys (don't push SDK keys)
|
|
36
|
-
const filteredSecrets = filterAgentuitySdkKeys(localEnv);
|
|
37
|
-
if (Object.keys(filteredSecrets).length === 0) {
|
|
38
|
-
tui.warning('No secrets to push');
|
|
39
|
-
return {
|
|
40
|
-
success: false,
|
|
41
|
-
pushed: 0,
|
|
42
|
-
source: envFilePath,
|
|
43
|
-
};
|
|
44
|
-
}
|
|
45
|
-
// Push to cloud (using secrets field)
|
|
46
|
-
await tui.spinner('Pushing secrets to cloud', () => {
|
|
47
|
-
return projectEnvUpdate(apiClient, {
|
|
48
|
-
id: project.projectId,
|
|
49
|
-
secrets: filteredSecrets,
|
|
50
|
-
});
|
|
51
|
-
});
|
|
52
|
-
const count = Object.keys(filteredSecrets).length;
|
|
53
|
-
tui.success(`Pushed ${count} secret${count !== 1 ? 's' : ''} to cloud`);
|
|
54
|
-
return {
|
|
55
|
-
success: true,
|
|
56
|
-
pushed: count,
|
|
57
|
-
source: envFilePath,
|
|
58
|
-
};
|
|
59
|
-
},
|
|
60
|
-
});
|
|
61
|
-
//# sourceMappingURL=push.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"push.js","sourceRoot":"","sources":["../../../../src/cmd/cloud/secret/push.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAClD,OAAO,KAAK,GAAG,MAAM,cAAc,CAAC;AACpC,OAAO,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AACrD,OAAO,EAAE,mBAAmB,EAAE,WAAW,EAAE,sBAAsB,EAAE,MAAM,mBAAmB,CAAC;AAC7F,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AAErD,MAAM,wBAAwB,GAAG,CAAC,CAAC,MAAM,CAAC;IACzC,OAAO,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,QAAQ,CAAC,wBAAwB,CAAC;IACvD,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,wBAAwB,CAAC;IACrD,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,kBAAkB,CAAC;CAC/C,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,cAAc,GAAG,gBAAgB,CAAC;IAC9C,IAAI,EAAE,MAAM;IACZ,WAAW,EAAE,4CAA4C;IACzD,IAAI,EAAE;QACL,UAAU;QACV,kBAAkB;QAClB,MAAM;QACN,eAAe;QACf,eAAe;QACf,kBAAkB;KAClB;IACD,UAAU,EAAE,IAAI;IAChB,QAAQ,EAAE,CAAC,EAAE,OAAO,EAAE,UAAU,CAAC,aAAa,CAAC,EAAE,WAAW,EAAE,kBAAkB,EAAE,CAAC;IACnF,QAAQ,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE;IACxD,aAAa,EAAE,CAAC,YAAY,CAAC;IAC7B,MAAM,EAAE;QACP,QAAQ,EAAE,wBAAwB;KAClC;IAED,KAAK,CAAC,OAAO,CAAC,GAAG;QAChB,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,UAAU,EAAE,GAAG,GAAG,CAAC;QAE/C,sBAAsB;QACtB,MAAM,WAAW,GAAG,MAAM,mBAAmB,CAAC,UAAU,CAAC,CAAC;QAC1D,MAAM,QAAQ,GAAG,MAAM,WAAW,CAAC,WAAW,CAAC,CAAC;QAEhD,4DAA4D;QAC5D,MAAM,eAAe,GAAG,sBAAsB,CAAC,QAAQ,CAAC,CAAC;QAEzD,IAAI,MAAM,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC/C,GAAG,CAAC,OAAO,CAAC,oBAAoB,CAAC,CAAC;YAClC,OAAO;gBACN,OAAO,EAAE,KAAK;gBACd,MAAM,EAAE,CAAC;gBACT,MAAM,EAAE,WAAW;aACnB,CAAC;QACH,CAAC;QAED,sCAAsC;QACtC,MAAM,GAAG,CAAC,OAAO,CAAC,0BAA0B,EAAE,GAAG,EAAE;YAClD,OAAO,gBAAgB,CAAC,SAAS,EAAE;gBAClC,EAAE,EAAE,OAAO,CAAC,SAAS;gBACrB,OAAO,EAAE,eAAe;aACxB,CAAC,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,MAAM,CAAC;QAClD,GAAG,CAAC,OAAO,CAAC,UAAU,KAAK,UAAU,KAAK,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,WAAW,CAAC,CAAC;QAExE,OAAO;YACN,OAAO,EAAE,IAAI;YACb,MAAM,EAAE,KAAK;YACb,MAAM,EAAE,WAAW;SACnB,CAAC;IACH,CAAC;CACD,CAAC,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"set.d.ts","sourceRoot":"","sources":["../../../../src/cmd/cloud/secret/set.ts"],"names":[],"mappings":"AAkBA,eAAO,MAAM,aAAa,yCAyDxB,CAAC"}
|
|
@@ -1,63 +0,0 @@
|
|
|
1
|
-
import { z } from 'zod';
|
|
2
|
-
import { createSubcommand } from '../../../types';
|
|
3
|
-
import * as tui from '../../../tui';
|
|
4
|
-
import { projectEnvUpdate } from '@agentuity/server';
|
|
5
|
-
import { findExistingEnvFile, readEnvFile, writeEnvFile, filterAgentuitySdkKeys, } from '../../../env-util';
|
|
6
|
-
import { getCommand } from '../../../command-prefix';
|
|
7
|
-
const SecretSetResponseSchema = z.object({
|
|
8
|
-
success: z.boolean().describe('Whether the operation succeeded'),
|
|
9
|
-
key: z.string().describe('Secret key name'),
|
|
10
|
-
path: z.string().describe('Local file path where secret was saved'),
|
|
11
|
-
});
|
|
12
|
-
export const setSubcommand = createSubcommand({
|
|
13
|
-
name: 'set',
|
|
14
|
-
description: 'Set a secret',
|
|
15
|
-
tags: ['mutating', 'updates-resource', 'slow', 'requires-auth', 'requires-project'],
|
|
16
|
-
idempotent: true,
|
|
17
|
-
examples: [
|
|
18
|
-
{
|
|
19
|
-
command: getCommand('secret set DATABASE_URL "postgres://user:pass@host:5432/db"'),
|
|
20
|
-
description: 'Set the DATABASE_URL environment secret',
|
|
21
|
-
},
|
|
22
|
-
{
|
|
23
|
-
command: getCommand('secret set STRIPE_SECRET_KEY "sk_live_..."'),
|
|
24
|
-
description: 'Set the STRIPE_SECRET_KEY environment secret',
|
|
25
|
-
},
|
|
26
|
-
],
|
|
27
|
-
requires: { auth: true, project: true, apiClient: true },
|
|
28
|
-
schema: {
|
|
29
|
-
args: z.object({
|
|
30
|
-
key: z.string().min(1, 'key must not be empty').describe('the secret key'),
|
|
31
|
-
value: z.string().min(1, 'value must not be empty').describe('the secret value'),
|
|
32
|
-
}),
|
|
33
|
-
response: SecretSetResponseSchema,
|
|
34
|
-
},
|
|
35
|
-
async handler(ctx) {
|
|
36
|
-
const { args, apiClient, project, projectDir } = ctx;
|
|
37
|
-
// Validate key doesn't start with AGENTUITY_
|
|
38
|
-
if (args.key.startsWith('AGENTUITY_')) {
|
|
39
|
-
tui.fatal('Cannot set AGENTUITY_ prefixed variables. These are reserved for system use.');
|
|
40
|
-
}
|
|
41
|
-
// Set in cloud (using secrets field)
|
|
42
|
-
await tui.spinner('Setting secret in cloud', () => {
|
|
43
|
-
return projectEnvUpdate(apiClient, {
|
|
44
|
-
id: project.projectId,
|
|
45
|
-
secrets: { [args.key]: args.value },
|
|
46
|
-
});
|
|
47
|
-
});
|
|
48
|
-
// Update local .env file
|
|
49
|
-
const envFilePath = await findExistingEnvFile(projectDir);
|
|
50
|
-
const currentEnv = await readEnvFile(envFilePath);
|
|
51
|
-
currentEnv[args.key] = args.value;
|
|
52
|
-
// Filter out AGENTUITY_ keys before writing
|
|
53
|
-
const filteredEnv = filterAgentuitySdkKeys(currentEnv);
|
|
54
|
-
await writeEnvFile(envFilePath, filteredEnv);
|
|
55
|
-
tui.success(`Secret '${args.key}' set successfully (cloud + ${envFilePath})`);
|
|
56
|
-
return {
|
|
57
|
-
success: true,
|
|
58
|
-
key: args.key,
|
|
59
|
-
path: envFilePath,
|
|
60
|
-
};
|
|
61
|
-
},
|
|
62
|
-
});
|
|
63
|
-
//# sourceMappingURL=set.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"set.js","sourceRoot":"","sources":["../../../../src/cmd/cloud/secret/set.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,65 +0,0 @@
|
|
|
1
|
-
import { z } from 'zod';
|
|
2
|
-
import { createSubcommand } from '../../../types';
|
|
3
|
-
import * as tui from '../../../tui';
|
|
4
|
-
import { projectEnvDelete } from '@agentuity/server';
|
|
5
|
-
import {
|
|
6
|
-
findExistingEnvFile,
|
|
7
|
-
readEnvFile,
|
|
8
|
-
writeEnvFile,
|
|
9
|
-
filterAgentuitySdkKeys,
|
|
10
|
-
} from '../../../env-util';
|
|
11
|
-
import { getCommand } from '../../../command-prefix';
|
|
12
|
-
|
|
13
|
-
const SecretDeleteResponseSchema = z.object({
|
|
14
|
-
success: z.boolean().describe('Whether the operation succeeded'),
|
|
15
|
-
key: z.string().describe('Secret key name that was deleted'),
|
|
16
|
-
path: z.string().describe('Local file path where secret was removed'),
|
|
17
|
-
});
|
|
18
|
-
|
|
19
|
-
export const deleteSubcommand = createSubcommand({
|
|
20
|
-
name: 'delete',
|
|
21
|
-
aliases: ['del', 'remove', 'rm'],
|
|
22
|
-
description: 'Delete a secret',
|
|
23
|
-
tags: ['destructive', 'deletes-resource', 'slow', 'requires-auth', 'requires-project'],
|
|
24
|
-
idempotent: true,
|
|
25
|
-
examples: [
|
|
26
|
-
{ command: getCommand('secret delete OLD_API_KEY'), description: 'Delete item' },
|
|
27
|
-
{ command: getCommand('secret rm DATABASE_URL'), description: 'Delete item' },
|
|
28
|
-
],
|
|
29
|
-
requires: { auth: true, project: true, apiClient: true },
|
|
30
|
-
schema: {
|
|
31
|
-
args: z.object({
|
|
32
|
-
key: z.string().describe('the secret key to delete'),
|
|
33
|
-
}),
|
|
34
|
-
response: SecretDeleteResponseSchema,
|
|
35
|
-
},
|
|
36
|
-
|
|
37
|
-
async handler(ctx) {
|
|
38
|
-
const { args, apiClient, project, projectDir } = ctx;
|
|
39
|
-
|
|
40
|
-
// Delete from cloud (using secrets field)
|
|
41
|
-
await tui.spinner('Deleting secret from cloud', () => {
|
|
42
|
-
return projectEnvDelete(apiClient, {
|
|
43
|
-
id: project.projectId,
|
|
44
|
-
secrets: [args.key],
|
|
45
|
-
});
|
|
46
|
-
});
|
|
47
|
-
|
|
48
|
-
// Update local .env file
|
|
49
|
-
const envFilePath = await findExistingEnvFile(projectDir);
|
|
50
|
-
const currentEnv = await readEnvFile(envFilePath);
|
|
51
|
-
delete currentEnv[args.key];
|
|
52
|
-
|
|
53
|
-
// Filter out AGENTUITY_ keys before writing
|
|
54
|
-
const filteredEnv = filterAgentuitySdkKeys(currentEnv);
|
|
55
|
-
await writeEnvFile(envFilePath, filteredEnv);
|
|
56
|
-
|
|
57
|
-
tui.success(`Secret '${args.key}' deleted successfully (cloud + ${envFilePath})`);
|
|
58
|
-
|
|
59
|
-
return {
|
|
60
|
-
success: true,
|
|
61
|
-
key: args.key,
|
|
62
|
-
path: envFilePath,
|
|
63
|
-
};
|
|
64
|
-
},
|
|
65
|
-
});
|
|
@@ -1,77 +0,0 @@
|
|
|
1
|
-
import { z } from 'zod';
|
|
2
|
-
import { createSubcommand } from '../../../types';
|
|
3
|
-
import * as tui from '../../../tui';
|
|
4
|
-
import { projectGet } from '@agentuity/server';
|
|
5
|
-
import { getCommand } from '../../../command-prefix';
|
|
6
|
-
import { ErrorCode } from '../../../errors';
|
|
7
|
-
|
|
8
|
-
const SecretGetResponseSchema = z.object({
|
|
9
|
-
key: z.string().describe('Secret key name'),
|
|
10
|
-
value: z.string().describe('Secret value'),
|
|
11
|
-
});
|
|
12
|
-
|
|
13
|
-
export const getSubcommand = createSubcommand({
|
|
14
|
-
name: 'get',
|
|
15
|
-
description: 'Get a secret value',
|
|
16
|
-
tags: ['read-only', 'fast', 'requires-auth', 'requires-project'],
|
|
17
|
-
examples: [
|
|
18
|
-
{ command: getCommand('secret get DATABASE_URL'), description: 'Get item details' },
|
|
19
|
-
{
|
|
20
|
-
command: getCommand('secret get STRIPE_SECRET_KEY --no-mask'),
|
|
21
|
-
description: 'Use no mask option',
|
|
22
|
-
},
|
|
23
|
-
],
|
|
24
|
-
requires: { auth: true, project: true, apiClient: true },
|
|
25
|
-
schema: {
|
|
26
|
-
args: z.object({
|
|
27
|
-
key: z.string().describe('the secret key'),
|
|
28
|
-
}),
|
|
29
|
-
options: z.object({
|
|
30
|
-
mask: z
|
|
31
|
-
.boolean()
|
|
32
|
-
.default(!!process.stdout.isTTY)
|
|
33
|
-
.describe('mask the value in output (default: true in TTY, false otherwise)'),
|
|
34
|
-
}),
|
|
35
|
-
response: SecretGetResponseSchema,
|
|
36
|
-
},
|
|
37
|
-
idempotent: true,
|
|
38
|
-
|
|
39
|
-
async handler(ctx) {
|
|
40
|
-
const { args, opts, apiClient, project, options } = ctx;
|
|
41
|
-
|
|
42
|
-
// Fetch project with unmasked secrets
|
|
43
|
-
const projectData = await tui.spinner('Fetching secrets', () => {
|
|
44
|
-
return projectGet(apiClient, { id: project.projectId, mask: false });
|
|
45
|
-
});
|
|
46
|
-
|
|
47
|
-
// Look for the key in secrets
|
|
48
|
-
const value = projectData.secrets?.[args.key];
|
|
49
|
-
|
|
50
|
-
if (value === undefined) {
|
|
51
|
-
tui.fatal(`Secret '${args.key}' not found`, ErrorCode.RESOURCE_NOT_FOUND);
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
if (!options.json) {
|
|
55
|
-
if (process.stdout.isTTY) {
|
|
56
|
-
// Display the value, masked by default
|
|
57
|
-
if (opts?.mask) {
|
|
58
|
-
tui.success(`${args.key}=${tui.maskSecret(value)}`);
|
|
59
|
-
} else {
|
|
60
|
-
tui.success(`${args.key}=${value}`);
|
|
61
|
-
}
|
|
62
|
-
} else {
|
|
63
|
-
// Display the value, masked by default
|
|
64
|
-
if (opts?.mask) {
|
|
65
|
-
console.log(`${args.key}=${tui.maskSecret(value)}`);
|
|
66
|
-
} else {
|
|
67
|
-
console.log(`${args.key}=${value}`);
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
return {
|
|
73
|
-
key: args.key,
|
|
74
|
-
value,
|
|
75
|
-
};
|
|
76
|
-
},
|
|
77
|
-
});
|
|
@@ -1,110 +0,0 @@
|
|
|
1
|
-
import { z } from 'zod';
|
|
2
|
-
import { createSubcommand } from '../../../types';
|
|
3
|
-
import * as tui from '../../../tui';
|
|
4
|
-
import { projectEnvUpdate } from '@agentuity/server';
|
|
5
|
-
import {
|
|
6
|
-
findExistingEnvFile,
|
|
7
|
-
readEnvFile,
|
|
8
|
-
writeEnvFile,
|
|
9
|
-
filterAgentuitySdkKeys,
|
|
10
|
-
mergeEnvVars,
|
|
11
|
-
} from '../../../env-util';
|
|
12
|
-
import { getCommand } from '../../../command-prefix';
|
|
13
|
-
|
|
14
|
-
const SecretImportResponseSchema = z.object({
|
|
15
|
-
success: z.boolean().describe('Whether import succeeded'),
|
|
16
|
-
imported: z.number().describe('Number of items imported'),
|
|
17
|
-
skipped: z.number().describe('Number of items skipped'),
|
|
18
|
-
path: z.string().describe('Local file path where secrets were saved'),
|
|
19
|
-
file: z.string().describe('Source file path'),
|
|
20
|
-
});
|
|
21
|
-
|
|
22
|
-
export const importSubcommand = createSubcommand({
|
|
23
|
-
name: 'import',
|
|
24
|
-
description: 'Import secrets from a file to cloud and local .env',
|
|
25
|
-
tags: [
|
|
26
|
-
'mutating',
|
|
27
|
-
'creates-resource',
|
|
28
|
-
'slow',
|
|
29
|
-
'api-intensive',
|
|
30
|
-
'requires-auth',
|
|
31
|
-
'requires-project',
|
|
32
|
-
],
|
|
33
|
-
examples: [
|
|
34
|
-
{ command: getCommand('secret import .env.local'), description: 'Run .env.local command' },
|
|
35
|
-
{
|
|
36
|
-
command: getCommand('secret import .env.backup'),
|
|
37
|
-
description: 'Run .env.backup command',
|
|
38
|
-
},
|
|
39
|
-
],
|
|
40
|
-
idempotent: false,
|
|
41
|
-
requires: { auth: true, project: true, apiClient: true },
|
|
42
|
-
schema: {
|
|
43
|
-
args: z.object({
|
|
44
|
-
file: z.string().describe('path to the .env file to import'),
|
|
45
|
-
}),
|
|
46
|
-
response: SecretImportResponseSchema,
|
|
47
|
-
},
|
|
48
|
-
|
|
49
|
-
async handler(ctx) {
|
|
50
|
-
const { args, apiClient, project, projectDir } = ctx;
|
|
51
|
-
|
|
52
|
-
// Read the import file
|
|
53
|
-
const importedSecrets = await readEnvFile(args.file);
|
|
54
|
-
|
|
55
|
-
if (Object.keys(importedSecrets).length === 0) {
|
|
56
|
-
tui.warning(`No secrets found in ${args.file}`);
|
|
57
|
-
return {
|
|
58
|
-
success: false,
|
|
59
|
-
imported: 0,
|
|
60
|
-
skipped: 0,
|
|
61
|
-
path: '',
|
|
62
|
-
file: args.file,
|
|
63
|
-
};
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
// Filter out AGENTUITY_ prefixed keys
|
|
67
|
-
const filteredSecrets = filterAgentuitySdkKeys(importedSecrets);
|
|
68
|
-
|
|
69
|
-
if (Object.keys(filteredSecrets).length === 0) {
|
|
70
|
-
tui.warning('No valid secrets to import (all were AGENTUITY_ prefixed)');
|
|
71
|
-
return {
|
|
72
|
-
success: false,
|
|
73
|
-
imported: 0,
|
|
74
|
-
skipped: Object.keys(importedSecrets).length,
|
|
75
|
-
path: '',
|
|
76
|
-
file: args.file,
|
|
77
|
-
};
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
// Push to cloud (using secrets field)
|
|
81
|
-
await tui.spinner('Importing secrets to cloud', () => {
|
|
82
|
-
return projectEnvUpdate(apiClient, {
|
|
83
|
-
id: project.projectId,
|
|
84
|
-
secrets: filteredSecrets,
|
|
85
|
-
});
|
|
86
|
-
});
|
|
87
|
-
|
|
88
|
-
// Merge with local .env file
|
|
89
|
-
const localEnvPath = await findExistingEnvFile(projectDir);
|
|
90
|
-
const localEnv = await readEnvFile(localEnvPath);
|
|
91
|
-
const mergedEnv = mergeEnvVars(localEnv, filteredSecrets);
|
|
92
|
-
|
|
93
|
-
await writeEnvFile(localEnvPath, mergedEnv, {
|
|
94
|
-
skipKeys: Object.keys(mergedEnv).filter((k) => k.startsWith('AGENTUITY_')),
|
|
95
|
-
});
|
|
96
|
-
|
|
97
|
-
const count = Object.keys(filteredSecrets).length;
|
|
98
|
-
tui.success(
|
|
99
|
-
`Imported ${count} secret${count !== 1 ? 's' : ''} from ${args.file} to cloud and ${localEnvPath}`
|
|
100
|
-
);
|
|
101
|
-
|
|
102
|
-
return {
|
|
103
|
-
success: true,
|
|
104
|
-
imported: count,
|
|
105
|
-
skipped: Object.keys(importedSecrets).length - count,
|
|
106
|
-
path: localEnvPath,
|
|
107
|
-
file: args.file,
|
|
108
|
-
};
|
|
109
|
-
},
|
|
110
|
-
});
|
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
import { createCommand } from '../../../types';
|
|
2
|
-
import { pullSubcommand } from './pull';
|
|
3
|
-
import { pushSubcommand } from './push';
|
|
4
|
-
import { setSubcommand } from './set';
|
|
5
|
-
import { getSubcommand } from './get';
|
|
6
|
-
import { deleteSubcommand } from './delete';
|
|
7
|
-
import { importSubcommand } from './import';
|
|
8
|
-
import { listSubcommand } from './list';
|
|
9
|
-
import { getCommand } from '../../../command-prefix';
|
|
10
|
-
|
|
11
|
-
export const command = createCommand({
|
|
12
|
-
name: 'secret',
|
|
13
|
-
aliases: ['secrets'],
|
|
14
|
-
description: 'Manage secrets for your project',
|
|
15
|
-
tags: ['fast', 'requires-auth', 'requires-project'],
|
|
16
|
-
examples: [
|
|
17
|
-
{ command: getCommand('cloud secret list'), description: 'List all secrets' },
|
|
18
|
-
{
|
|
19
|
-
command: getCommand('cloud secret set API_KEY "sk_..."'),
|
|
20
|
-
description: 'Set a secret value',
|
|
21
|
-
},
|
|
22
|
-
],
|
|
23
|
-
subcommands: [
|
|
24
|
-
listSubcommand,
|
|
25
|
-
pullSubcommand,
|
|
26
|
-
pushSubcommand,
|
|
27
|
-
setSubcommand,
|
|
28
|
-
getSubcommand,
|
|
29
|
-
deleteSubcommand,
|
|
30
|
-
importSubcommand,
|
|
31
|
-
],
|
|
32
|
-
});
|
|
33
|
-
export default command;
|
|
@@ -1,70 +0,0 @@
|
|
|
1
|
-
import { z } from 'zod';
|
|
2
|
-
import { createSubcommand } from '../../../types';
|
|
3
|
-
import * as tui from '../../../tui';
|
|
4
|
-
import { projectGet } from '@agentuity/server';
|
|
5
|
-
import { getCommand } from '../../../command-prefix';
|
|
6
|
-
|
|
7
|
-
const SecretListResponseSchema = z.record(z.string(), z.string().describe('Secret value'));
|
|
8
|
-
|
|
9
|
-
export const listSubcommand = createSubcommand({
|
|
10
|
-
name: 'list',
|
|
11
|
-
aliases: ['ls'],
|
|
12
|
-
description: 'List all secrets',
|
|
13
|
-
tags: ['read-only', 'fast', 'requires-auth', 'requires-project'],
|
|
14
|
-
examples: [
|
|
15
|
-
{ command: getCommand('secret list'), description: 'List items' },
|
|
16
|
-
{ command: getCommand('secret list --no-mask'), description: 'Use no mask option' },
|
|
17
|
-
],
|
|
18
|
-
requires: { auth: true, project: true, apiClient: true },
|
|
19
|
-
idempotent: true,
|
|
20
|
-
schema: {
|
|
21
|
-
options: z.object({
|
|
22
|
-
mask: z
|
|
23
|
-
.boolean()
|
|
24
|
-
.default(!!process.stdout.isTTY)
|
|
25
|
-
.describe('mask the values in output (default: true in TTY for secrets)'),
|
|
26
|
-
}),
|
|
27
|
-
response: SecretListResponseSchema,
|
|
28
|
-
},
|
|
29
|
-
webUrl: (ctx) => `/projects/${encodeURIComponent(ctx.project.projectId)}/settings`,
|
|
30
|
-
|
|
31
|
-
async handler(ctx) {
|
|
32
|
-
const { opts, apiClient, project, options } = ctx;
|
|
33
|
-
|
|
34
|
-
// Fetch project with unmasked secrets
|
|
35
|
-
const projectData = await tui.spinner('Fetching secrets', () => {
|
|
36
|
-
return projectGet(apiClient, { id: project.projectId, mask: false });
|
|
37
|
-
});
|
|
38
|
-
|
|
39
|
-
const secrets = projectData.secrets || {};
|
|
40
|
-
|
|
41
|
-
// Skip TUI output in JSON mode
|
|
42
|
-
if (!options.json) {
|
|
43
|
-
if (Object.keys(secrets).length === 0) {
|
|
44
|
-
tui.info('No secrets found');
|
|
45
|
-
} else {
|
|
46
|
-
// Display the secrets
|
|
47
|
-
if (process.stdout.isTTY) {
|
|
48
|
-
tui.newline();
|
|
49
|
-
tui.success(`Secrets (${Object.keys(secrets).length}):`);
|
|
50
|
-
tui.newline();
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
const sortedKeys = Object.keys(secrets).sort();
|
|
54
|
-
// For secrets, masking is enabled by default in TTY (can be disabled with --no-mask)
|
|
55
|
-
const shouldMask = opts?.mask !== false;
|
|
56
|
-
for (const key of sortedKeys) {
|
|
57
|
-
const value = secrets[key];
|
|
58
|
-
const displayValue = shouldMask ? tui.maskSecret(value) : value;
|
|
59
|
-
if (process.stdout.isTTY) {
|
|
60
|
-
console.log(`${tui.bold(key)}=${displayValue}`);
|
|
61
|
-
} else {
|
|
62
|
-
console.log(`${key}=${displayValue}`);
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
return secrets;
|
|
69
|
-
},
|
|
70
|
-
});
|