@stamn/cli 0.1.0-alpha.1 → 0.1.0-alpha.2
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 +0 -9
- package/dist/bin.js +1 -1
- package/dist/{chunk-ECKKSWUQ.js → chunk-GNL7D4HS.js} +10 -13
- package/dist/chunk-GNL7D4HS.js.map +1 -0
- package/dist/index.js +1 -1
- package/package.json +1 -1
- package/dist/chunk-ECKKSWUQ.js.map +0 -1
package/README.md
CHANGED
|
@@ -8,15 +8,6 @@ Stamn CLI for managing agents.
|
|
|
8
8
|
npm install -g @stamn/cli
|
|
9
9
|
```
|
|
10
10
|
|
|
11
|
-
### From source
|
|
12
|
-
|
|
13
|
-
```bash
|
|
14
|
-
git clone https://github.com/stamnhq/sdk.git stamn-sdk
|
|
15
|
-
git clone https://github.com/stamnhq/cli.git stamn-cli
|
|
16
|
-
cd stamn-sdk && npm install && cd ..
|
|
17
|
-
cd stamn-cli && npm install && npm link
|
|
18
|
-
```
|
|
19
|
-
|
|
20
11
|
## Commands
|
|
21
12
|
|
|
22
13
|
### `stamn agent login`
|
package/dist/bin.js
CHANGED
|
@@ -41,7 +41,7 @@ ${label("Code:")} ${flow.userCode}`,
|
|
|
41
41
|
} catch (err) {
|
|
42
42
|
s.stop("Failed.");
|
|
43
43
|
cancel(`Login failed: ${err.message}`);
|
|
44
|
-
process.
|
|
44
|
+
process.exit(1);
|
|
45
45
|
}
|
|
46
46
|
}
|
|
47
47
|
|
|
@@ -53,8 +53,7 @@ async function handleAgentRegister(opts, adapter) {
|
|
|
53
53
|
const config = adapter.readConfig();
|
|
54
54
|
if (!config?.apiKey) {
|
|
55
55
|
cancel2("Not logged in. Run `stamn login` first.");
|
|
56
|
-
process.
|
|
57
|
-
return;
|
|
56
|
+
process.exit(1);
|
|
58
57
|
}
|
|
59
58
|
let name = opts.name;
|
|
60
59
|
if (!name) {
|
|
@@ -93,7 +92,7 @@ async function handleAgentRegister(opts, adapter) {
|
|
|
93
92
|
} catch (err) {
|
|
94
93
|
s.stop("Failed.");
|
|
95
94
|
cancel2(`Registration failed: ${err.message}`);
|
|
96
|
-
process.
|
|
95
|
+
process.exit(1);
|
|
97
96
|
}
|
|
98
97
|
}
|
|
99
98
|
|
|
@@ -105,8 +104,7 @@ async function handleAgentList(_opts, adapter) {
|
|
|
105
104
|
const config = adapter.readConfig();
|
|
106
105
|
if (!config?.apiKey) {
|
|
107
106
|
cancel3("Not logged in. Run `stamn login` first.");
|
|
108
|
-
process.
|
|
109
|
-
return;
|
|
107
|
+
process.exit(1);
|
|
110
108
|
}
|
|
111
109
|
const client = new StamnClient3({ apiKey: config.apiKey });
|
|
112
110
|
const s = spinner3();
|
|
@@ -125,7 +123,7 @@ async function handleAgentList(_opts, adapter) {
|
|
|
125
123
|
} catch (err) {
|
|
126
124
|
s.stop("Failed.");
|
|
127
125
|
cancel3(`Failed to list agents: ${err.message}`);
|
|
128
|
-
process.
|
|
126
|
+
process.exit(1);
|
|
129
127
|
}
|
|
130
128
|
}
|
|
131
129
|
|
|
@@ -137,8 +135,7 @@ async function handleAgentSelect(opts, adapter) {
|
|
|
137
135
|
const config = adapter.readConfig();
|
|
138
136
|
if (!config?.apiKey) {
|
|
139
137
|
cancel4("Not logged in. Run `stamn login` first.");
|
|
140
|
-
process.
|
|
141
|
-
return;
|
|
138
|
+
process.exit(1);
|
|
142
139
|
}
|
|
143
140
|
const client = new StamnClient4({ apiKey: config.apiKey });
|
|
144
141
|
const s = spinner4();
|
|
@@ -149,7 +146,7 @@ async function handleAgentSelect(opts, adapter) {
|
|
|
149
146
|
const match = agents.find((a) => a.id === opts.nameOrId || a.name === opts.nameOrId);
|
|
150
147
|
if (!match) {
|
|
151
148
|
cancel4(`Agent "${opts.nameOrId}" not found. Run \`stamn agent list\` to see available agents.`);
|
|
152
|
-
process.
|
|
149
|
+
process.exit(1);
|
|
153
150
|
return;
|
|
154
151
|
}
|
|
155
152
|
adapter.writeConfig({ agentId: match.id, agentName: match.name });
|
|
@@ -158,7 +155,7 @@ async function handleAgentSelect(opts, adapter) {
|
|
|
158
155
|
} catch (err) {
|
|
159
156
|
s.stop("Failed.");
|
|
160
157
|
cancel4(`Failed to select agent: ${err.message}`);
|
|
161
|
-
process.
|
|
158
|
+
process.exit(1);
|
|
162
159
|
}
|
|
163
160
|
}
|
|
164
161
|
|
|
@@ -278,7 +275,7 @@ async function handleUninstall(adapter) {
|
|
|
278
275
|
outro6("Stamn config removed.");
|
|
279
276
|
} catch (err) {
|
|
280
277
|
cancel6(`Failed to remove config: ${err.message}`);
|
|
281
|
-
process.
|
|
278
|
+
process.exit(1);
|
|
282
279
|
}
|
|
283
280
|
}
|
|
284
281
|
|
|
@@ -339,4 +336,4 @@ export {
|
|
|
339
336
|
writeJsonFile,
|
|
340
337
|
createDefaultAdapter
|
|
341
338
|
};
|
|
342
|
-
//# sourceMappingURL=chunk-
|
|
339
|
+
//# sourceMappingURL=chunk-GNL7D4HS.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/commands/login.ts","../src/commands/agent-register.ts","../src/commands/agent-list.ts","../src/commands/agent-select.ts","../src/commands/logout.ts","../src/commands/config.ts","../src/commands/status.ts","../src/commands/uninstall.ts","../src/config.ts"],"sourcesContent":["import { intro, outro, spinner, log, note, cancel } from '@clack/prompts';\nimport { StamnClient } from '@stamn/sdk';\nimport type { ConfigAdapter } from '@/types';\n\nexport async function handleLogin(_opts: Record<string, never>, adapter: ConfigAdapter): Promise<void> {\n intro('Stamn Login');\n\n const existing = adapter.readConfig();\n\n if (existing?.apiKey) {\n const s = spinner();\n s.start('Checking existing session...');\n try {\n const client = new StamnClient({ apiKey: existing.apiKey });\n await client.participants.list();\n s.stop('Session valid.');\n log.info('Already logged in.');\n outro('Run `stamn agent register` to create an agent, or `stamn agent list` to see existing ones.');\n return;\n } catch {\n s.stop('Session expired.');\n log.warn('Existing session is invalid. Re-authenticating...');\n }\n }\n\n const client = new StamnClient();\n const s = spinner();\n\n try {\n s.start(\"Initiating device flow...\");\n const flow = await client.auth.initiateDeviceFlow();\n s.stop(\"Device flow initiated.\");\n\n const label = (str: string) => str.padEnd(7);\n note(\n `${label(\"Open:\")} ${flow.verificationUri}\\n${label(\"Code:\")} ${flow.userCode}`,\n \"Authorize in your browser\",\n );\n\n s.start(\"Waiting for approval...\");\n const apiKey = await client.auth.pollForApproval(flow.deviceCode);\n s.stop(\"Approved!\");\n\n adapter.writeConfig({ apiKey });\n\n log.success('Logged in successfully.');\n log.info(`Config written to ${adapter.getConfigPath()}`);\n\n outro('Now run `stamn agent register` to create or reconnect an agent.');\n } catch (err) {\n s.stop(\"Failed.\");\n cancel(`Login failed: ${(err as Error).message}`);\n process.exit(1);\n }\n}\n","import { intro, outro, spinner, log, cancel, text } from '@clack/prompts';\nimport { StamnClient } from '@stamn/sdk';\nimport type { ConfigAdapter } from '@/types';\n\nexport async function handleAgentRegister(opts: { name?: string }, adapter: ConfigAdapter): Promise<void> {\n intro('Stamn Agent Register');\n\n const config = adapter.readConfig();\n if (!config?.apiKey) {\n cancel('Not logged in. Run `stamn login` first.');\n process.exit(1);\n }\n\n let name = opts.name;\n if (!name) {\n const input = await text({\n message: 'What should we call this agent?',\n placeholder: 'my-agent',\n validate: (value) => {\n if (!value?.trim()) return 'Name is required.';\n },\n });\n if (typeof input === 'symbol') {\n cancel('Cancelled.');\n return;\n }\n name = input;\n }\n\n const client = new StamnClient({ apiKey: config.apiKey });\n const s = spinner();\n\n try {\n s.start('Checking existing agents...');\n const agents = await client.participants.list();\n const match = agents.find((a) => a.name === name);\n\n if (match) {\n s.stop('Agent found.');\n adapter.writeConfig({ agentId: match.id, agentName: match.name });\n log.success(`Agent \"${match.name}\" (${match.id}) already exists. Selected as active.`);\n outro('Done!');\n return;\n }\n\n s.start('Registering agent...');\n const participant = await client.participants.create({ name });\n s.stop('Agent registered.');\n\n adapter.writeConfig({ agentId: participant.id, agentName: participant.name });\n\n log.success(`Agent \"${participant.name}\" (${participant.id})`);\n outro('Done!');\n } catch (err) {\n s.stop('Failed.');\n cancel(`Registration failed: ${(err as Error).message}`);\n process.exit(1);\n }\n}\n","import { intro, spinner, log, cancel } from '@clack/prompts';\nimport { StamnClient } from '@stamn/sdk';\nimport type { ConfigAdapter } from '@/types';\n\nexport async function handleAgentList(_opts: Record<string, never>, adapter: ConfigAdapter): Promise<void> {\n intro('Stamn Agents');\n\n const config = adapter.readConfig();\n if (!config?.apiKey) {\n cancel('Not logged in. Run `stamn login` first.');\n process.exit(1);\n }\n\n const client = new StamnClient({ apiKey: config.apiKey });\n const s = spinner();\n\n try {\n s.start('Fetching agents...');\n const agents = await client.participants.list();\n s.stop(`${agents.length} agent${agents.length === 1 ? '' : 's'} found.`);\n\n if (agents.length === 0) {\n log.info('No agents found. Run `stamn agent register` to create one.');\n return;\n }\n\n for (const agent of agents) {\n const active = agent.id === config.agentId ? ' (active)' : '';\n log.info(` ${agent.name} — ${agent.id}${active}`);\n }\n } catch (err) {\n s.stop('Failed.');\n cancel(`Failed to list agents: ${(err as Error).message}`);\n process.exit(1);\n }\n}\n","import { intro, outro, spinner, log, cancel } from '@clack/prompts';\nimport { StamnClient } from '@stamn/sdk';\nimport type { ConfigAdapter } from '@/types';\n\nexport async function handleAgentSelect(opts: { nameOrId: string }, adapter: ConfigAdapter): Promise<void> {\n intro('Stamn Agent Select');\n\n const config = adapter.readConfig();\n if (!config?.apiKey) {\n cancel('Not logged in. Run `stamn login` first.');\n process.exit(1);\n }\n\n const client = new StamnClient({ apiKey: config.apiKey });\n const s = spinner();\n\n try {\n s.start('Fetching agents...');\n const agents = await client.participants.list();\n s.stop(`${agents.length} agent${agents.length === 1 ? '' : 's'} found.`);\n\n const match = agents.find((a) => a.id === opts.nameOrId || a.name === opts.nameOrId);\n\n if (!match) {\n cancel(`Agent \"${opts.nameOrId}\" not found. Run \\`stamn agent list\\` to see available agents.`);\n process.exit(1);\n return;\n }\n\n adapter.writeConfig({ agentId: match.id, agentName: match.name });\n log.success(`Active agent set to \"${match.name}\" (${match.id})`);\n outro('Done!');\n } catch (err) {\n s.stop('Failed.');\n cancel(`Failed to select agent: ${(err as Error).message}`);\n process.exit(1);\n }\n}\n","import { intro, outro, log, cancel, confirm } from '@clack/prompts';\nimport type { ConfigAdapter } from '@/types';\n\nexport async function handleLogout(_opts: Record<string, never>, adapter: ConfigAdapter): Promise<void> {\n intro('Stamn Logout');\n\n const config = adapter.readConfig();\n if (!config?.apiKey) {\n log.info('Not logged in.');\n outro('Nothing to do.');\n return;\n }\n\n const shouldContinue = await confirm({\n message: 'This will clear your auth session. Your agents will not be deleted. Continue?',\n });\n\n if (!shouldContinue || typeof shouldContinue === 'symbol') {\n cancel('Cancelled.');\n return;\n }\n\n adapter.writeConfig({ apiKey: '', agentId: '', agentName: '' } as any);\n log.success('Logged out.');\n outro('Run `stamn login` to authenticate again.');\n}\n","import { execSync } from \"child_process\";\nimport { mkdirSync, readFileSync, writeFileSync, unlinkSync } from \"fs\";\nimport { join } from \"path\";\nimport { tmpdir } from \"os\";\nimport { log } from \"@clack/prompts\";\nimport type { ConfigAdapter } from \"@/types\";\n\nfunction openEditor(initial: string): string | null {\n const editor = process.env.EDITOR || process.env.VISUAL || \"vi\";\n const tmpFile = join(tmpdir(), `stamn-personality-${Date.now()}.md`);\n\n mkdirSync(tmpdir(), { recursive: true });\n writeFileSync(tmpFile, initial, \"utf-8\");\n\n try {\n execSync(`${editor} \"${tmpFile}\"`, { stdio: \"inherit\" });\n const result = readFileSync(tmpFile, \"utf-8\").trim();\n return result || null;\n } catch {\n return null;\n } finally {\n try {\n unlinkSync(tmpFile);\n } catch {}\n }\n}\n\nexport function handleConfig(\n opts: { name?: string; personality?: boolean },\n adapter: ConfigAdapter,\n): void {\n if (!opts.name && !opts.personality) {\n const config = adapter.readConfig();\n if (!config) {\n log.warn(\"No config found. Run `stamn login` first.\");\n return;\n }\n log.info(`Name: ${config.agentName ?? \"(not set)\"}`);\n log.info(`Personality: ${config.personality ? \"configured\" : \"(not set)\"}`);\n return;\n }\n\n if (opts.name) {\n adapter.writeConfig({ agentName: opts.name });\n log.success(`Name set: \"${opts.name}\"`);\n }\n\n if (opts.personality) {\n const existing = adapter.readConfig()?.personality ?? \"\";\n const text = openEditor(existing);\n if (!text) {\n log.warn(\"Editor closed without saving. Personality unchanged.\");\n return;\n }\n adapter.writeConfig({ personality: text });\n log.success(\"Personality updated.\");\n }\n}\n","import { intro, outro, log } from \"@clack/prompts\";\nimport { StamnClient } from \"@stamn/sdk\";\nimport type { StamnConfig, ConfigAdapter } from \"@/types\";\n\nexport async function handleStatus(adapter: ConfigAdapter): Promise<void> {\n const config = adapter.readConfig();\n const status = adapter.readStatusFile();\n const label = (str: string) => str.padEnd(14);\n\n intro(\"Stamn Status\");\n\n log.info(`${label(\"Agent ID:\")} ${config?.agentId || \"(not configured)\"}`);\n log.info(\n `${label(\"Agent Name:\")} ${config?.agentName || \"(not configured)\"}`,\n );\n log.info(`${label(\"Connected:\")} ${status?.connected ? \"yes\" : \"no\"}`);\n\n if (status?.connected && status.connectedAt) {\n log.info(\n `${label(\"Since:\")} ${new Date(status.connectedAt).toLocaleString()}`,\n );\n }\n\n if (config?.apiKey) {\n const client = new StamnClient({ apiKey: config.apiKey });\n const health = await client.health.check();\n log.info(`${label(\"Server:\")} ${health.ok ? \"healthy\" : \"unhealthy\"}`);\n }\n\n outro(\"\");\n}\n","import { intro, outro, confirm, log, cancel } from \"@clack/prompts\";\nimport type { ConfigAdapter } from \"@/types\";\n\nexport async function handleUninstall(adapter: ConfigAdapter): Promise<void> {\n intro(\"Stamn Uninstall\");\n\n const shouldContinue = await confirm({\n message: \"This will remove all Stamn config and data. Continue?\",\n });\n\n if (!shouldContinue || typeof shouldContinue === \"symbol\") {\n cancel(\"Uninstall cancelled.\");\n return;\n }\n\n try {\n adapter.uninstall?.();\n log.success(\"Removed Stamn config\");\n outro(\"Stamn config removed.\");\n } catch (err) {\n cancel(`Failed to remove config: ${(err as Error).message}`);\n process.exit(1);\n }\n}\n","import { existsSync, mkdirSync, readFileSync, rmSync, writeFileSync } from \"fs\";\nimport { dirname, join } from \"path\";\nimport { homedir } from \"os\";\nimport type { StamnConfig, StamnStatusFile, ConfigAdapter } from \"@/types\";\n\nexport function readJsonFile<T>(filePath: string): T | null {\n try {\n const raw = readFileSync(filePath, \"utf-8\");\n return JSON.parse(raw) as T;\n } catch {\n return null;\n }\n}\n\nexport function writeJsonFile(filePath: string, data: unknown): void {\n mkdirSync(dirname(filePath), { recursive: true });\n writeFileSync(filePath, JSON.stringify(data, null, 2) + \"\\n\", \"utf-8\");\n}\n\nexport function getConfigPath(): string {\n return join(homedir(), \".stamn\", \"config.json\");\n}\n\nexport function readConfig(): StamnConfig | null {\n return readJsonFile<StamnConfig>(getConfigPath());\n}\n\nexport function writeConfig(updates: Partial<StamnConfig>): void {\n const existing = readConfig() ?? {};\n writeJsonFile(getConfigPath(), { ...existing, ...updates });\n}\n\nexport function readStatusFile(): StamnStatusFile | null {\n return readJsonFile<StamnStatusFile>(join(homedir(), \".stamn\", \"status.json\"));\n}\n\nexport function createDefaultAdapter(): ConfigAdapter {\n return {\n readConfig,\n writeConfig,\n readStatusFile,\n getConfigPath,\n uninstall() {\n const configDir = dirname(getConfigPath());\n if (existsSync(configDir)) {\n rmSync(configDir, { recursive: true, force: true });\n }\n },\n };\n}\n"],"mappings":"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","names":["s","client","intro","outro","spinner","log","cancel","StamnClient","intro","spinner","log","cancel","StamnClient","intro","outro","spinner","log","cancel","StamnClient","intro","outro","log","cancel","log","text","intro","outro","log","StamnClient","intro","outro","confirm","log","cancel","mkdirSync","readFileSync","writeFileSync","join"]}
|
package/dist/index.js
CHANGED
package/package.json
CHANGED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/commands/login.ts","../src/commands/agent-register.ts","../src/commands/agent-list.ts","../src/commands/agent-select.ts","../src/commands/logout.ts","../src/commands/config.ts","../src/commands/status.ts","../src/commands/uninstall.ts","../src/config.ts"],"sourcesContent":["import { intro, outro, spinner, log, note, cancel } from '@clack/prompts';\nimport { StamnClient } from '@stamn/sdk';\nimport type { ConfigAdapter } from '@/types';\n\nexport async function handleLogin(_opts: Record<string, never>, adapter: ConfigAdapter): Promise<void> {\n intro('Stamn Login');\n\n const existing = adapter.readConfig();\n\n if (existing?.apiKey) {\n const s = spinner();\n s.start('Checking existing session...');\n try {\n const client = new StamnClient({ apiKey: existing.apiKey });\n await client.participants.list();\n s.stop('Session valid.');\n log.info('Already logged in.');\n outro('Run `stamn agent register` to create an agent, or `stamn agent list` to see existing ones.');\n return;\n } catch {\n s.stop('Session expired.');\n log.warn('Existing session is invalid. Re-authenticating...');\n }\n }\n\n const client = new StamnClient();\n const s = spinner();\n\n try {\n s.start(\"Initiating device flow...\");\n const flow = await client.auth.initiateDeviceFlow();\n s.stop(\"Device flow initiated.\");\n\n const label = (str: string) => str.padEnd(7);\n note(\n `${label(\"Open:\")} ${flow.verificationUri}\\n${label(\"Code:\")} ${flow.userCode}`,\n \"Authorize in your browser\",\n );\n\n s.start(\"Waiting for approval...\");\n const apiKey = await client.auth.pollForApproval(flow.deviceCode);\n s.stop(\"Approved!\");\n\n adapter.writeConfig({ apiKey });\n\n log.success('Logged in successfully.');\n log.info(`Config written to ${adapter.getConfigPath()}`);\n\n outro('Now run `stamn agent register` to create or reconnect an agent.');\n } catch (err) {\n s.stop(\"Failed.\");\n cancel(`Login failed: ${(err as Error).message}`);\n process.exitCode = 1;\n }\n}\n","import { intro, outro, spinner, log, cancel, text } from '@clack/prompts';\nimport { StamnClient } from '@stamn/sdk';\nimport type { ConfigAdapter } from '@/types';\n\nexport async function handleAgentRegister(opts: { name?: string }, adapter: ConfigAdapter): Promise<void> {\n intro('Stamn Agent Register');\n\n const config = adapter.readConfig();\n if (!config?.apiKey) {\n cancel('Not logged in. Run `stamn login` first.');\n process.exitCode = 1;\n return;\n }\n\n let name = opts.name;\n if (!name) {\n const input = await text({\n message: 'What should we call this agent?',\n placeholder: 'my-agent',\n validate: (value) => {\n if (!value?.trim()) return 'Name is required.';\n },\n });\n if (typeof input === 'symbol') {\n cancel('Cancelled.');\n return;\n }\n name = input;\n }\n\n const client = new StamnClient({ apiKey: config.apiKey });\n const s = spinner();\n\n try {\n s.start('Checking existing agents...');\n const agents = await client.participants.list();\n const match = agents.find((a) => a.name === name);\n\n if (match) {\n s.stop('Agent found.');\n adapter.writeConfig({ agentId: match.id, agentName: match.name });\n log.success(`Agent \"${match.name}\" (${match.id}) already exists. Selected as active.`);\n outro('Done!');\n return;\n }\n\n s.start('Registering agent...');\n const participant = await client.participants.create({ name });\n s.stop('Agent registered.');\n\n adapter.writeConfig({ agentId: participant.id, agentName: participant.name });\n\n log.success(`Agent \"${participant.name}\" (${participant.id})`);\n outro('Done!');\n } catch (err) {\n s.stop('Failed.');\n cancel(`Registration failed: ${(err as Error).message}`);\n process.exitCode = 1;\n }\n}\n","import { intro, spinner, log, cancel } from '@clack/prompts';\nimport { StamnClient } from '@stamn/sdk';\nimport type { ConfigAdapter } from '@/types';\n\nexport async function handleAgentList(_opts: Record<string, never>, adapter: ConfigAdapter): Promise<void> {\n intro('Stamn Agents');\n\n const config = adapter.readConfig();\n if (!config?.apiKey) {\n cancel('Not logged in. Run `stamn login` first.');\n process.exitCode = 1;\n return;\n }\n\n const client = new StamnClient({ apiKey: config.apiKey });\n const s = spinner();\n\n try {\n s.start('Fetching agents...');\n const agents = await client.participants.list();\n s.stop(`${agents.length} agent${agents.length === 1 ? '' : 's'} found.`);\n\n if (agents.length === 0) {\n log.info('No agents found. Run `stamn agent register` to create one.');\n return;\n }\n\n for (const agent of agents) {\n const active = agent.id === config.agentId ? ' (active)' : '';\n log.info(` ${agent.name} — ${agent.id}${active}`);\n }\n } catch (err) {\n s.stop('Failed.');\n cancel(`Failed to list agents: ${(err as Error).message}`);\n process.exitCode = 1;\n }\n}\n","import { intro, outro, spinner, log, cancel } from '@clack/prompts';\nimport { StamnClient } from '@stamn/sdk';\nimport type { ConfigAdapter } from '@/types';\n\nexport async function handleAgentSelect(opts: { nameOrId: string }, adapter: ConfigAdapter): Promise<void> {\n intro('Stamn Agent Select');\n\n const config = adapter.readConfig();\n if (!config?.apiKey) {\n cancel('Not logged in. Run `stamn login` first.');\n process.exitCode = 1;\n return;\n }\n\n const client = new StamnClient({ apiKey: config.apiKey });\n const s = spinner();\n\n try {\n s.start('Fetching agents...');\n const agents = await client.participants.list();\n s.stop(`${agents.length} agent${agents.length === 1 ? '' : 's'} found.`);\n\n const match = agents.find((a) => a.id === opts.nameOrId || a.name === opts.nameOrId);\n\n if (!match) {\n cancel(`Agent \"${opts.nameOrId}\" not found. Run \\`stamn agent list\\` to see available agents.`);\n process.exitCode = 1;\n return;\n }\n\n adapter.writeConfig({ agentId: match.id, agentName: match.name });\n log.success(`Active agent set to \"${match.name}\" (${match.id})`);\n outro('Done!');\n } catch (err) {\n s.stop('Failed.');\n cancel(`Failed to select agent: ${(err as Error).message}`);\n process.exitCode = 1;\n }\n}\n","import { intro, outro, log, cancel, confirm } from '@clack/prompts';\nimport type { ConfigAdapter } from '@/types';\n\nexport async function handleLogout(_opts: Record<string, never>, adapter: ConfigAdapter): Promise<void> {\n intro('Stamn Logout');\n\n const config = adapter.readConfig();\n if (!config?.apiKey) {\n log.info('Not logged in.');\n outro('Nothing to do.');\n return;\n }\n\n const shouldContinue = await confirm({\n message: 'This will clear your auth session. Your agents will not be deleted. Continue?',\n });\n\n if (!shouldContinue || typeof shouldContinue === 'symbol') {\n cancel('Cancelled.');\n return;\n }\n\n adapter.writeConfig({ apiKey: '', agentId: '', agentName: '' } as any);\n log.success('Logged out.');\n outro('Run `stamn login` to authenticate again.');\n}\n","import { execSync } from \"child_process\";\nimport { mkdirSync, readFileSync, writeFileSync, unlinkSync } from \"fs\";\nimport { join } from \"path\";\nimport { tmpdir } from \"os\";\nimport { log } from \"@clack/prompts\";\nimport type { ConfigAdapter } from \"@/types\";\n\nfunction openEditor(initial: string): string | null {\n const editor = process.env.EDITOR || process.env.VISUAL || \"vi\";\n const tmpFile = join(tmpdir(), `stamn-personality-${Date.now()}.md`);\n\n mkdirSync(tmpdir(), { recursive: true });\n writeFileSync(tmpFile, initial, \"utf-8\");\n\n try {\n execSync(`${editor} \"${tmpFile}\"`, { stdio: \"inherit\" });\n const result = readFileSync(tmpFile, \"utf-8\").trim();\n return result || null;\n } catch {\n return null;\n } finally {\n try {\n unlinkSync(tmpFile);\n } catch {}\n }\n}\n\nexport function handleConfig(\n opts: { name?: string; personality?: boolean },\n adapter: ConfigAdapter,\n): void {\n if (!opts.name && !opts.personality) {\n const config = adapter.readConfig();\n if (!config) {\n log.warn(\"No config found. Run `stamn login` first.\");\n return;\n }\n log.info(`Name: ${config.agentName ?? \"(not set)\"}`);\n log.info(`Personality: ${config.personality ? \"configured\" : \"(not set)\"}`);\n return;\n }\n\n if (opts.name) {\n adapter.writeConfig({ agentName: opts.name });\n log.success(`Name set: \"${opts.name}\"`);\n }\n\n if (opts.personality) {\n const existing = adapter.readConfig()?.personality ?? \"\";\n const text = openEditor(existing);\n if (!text) {\n log.warn(\"Editor closed without saving. Personality unchanged.\");\n return;\n }\n adapter.writeConfig({ personality: text });\n log.success(\"Personality updated.\");\n }\n}\n","import { intro, outro, log } from \"@clack/prompts\";\nimport { StamnClient } from \"@stamn/sdk\";\nimport type { StamnConfig, ConfigAdapter } from \"@/types\";\n\nexport async function handleStatus(adapter: ConfigAdapter): Promise<void> {\n const config = adapter.readConfig();\n const status = adapter.readStatusFile();\n const label = (str: string) => str.padEnd(14);\n\n intro(\"Stamn Status\");\n\n log.info(`${label(\"Agent ID:\")} ${config?.agentId || \"(not configured)\"}`);\n log.info(\n `${label(\"Agent Name:\")} ${config?.agentName || \"(not configured)\"}`,\n );\n log.info(`${label(\"Connected:\")} ${status?.connected ? \"yes\" : \"no\"}`);\n\n if (status?.connected && status.connectedAt) {\n log.info(\n `${label(\"Since:\")} ${new Date(status.connectedAt).toLocaleString()}`,\n );\n }\n\n if (config?.apiKey) {\n const client = new StamnClient({ apiKey: config.apiKey });\n const health = await client.health.check();\n log.info(`${label(\"Server:\")} ${health.ok ? \"healthy\" : \"unhealthy\"}`);\n }\n\n outro(\"\");\n}\n","import { intro, outro, confirm, log, cancel } from \"@clack/prompts\";\nimport type { ConfigAdapter } from \"@/types\";\n\nexport async function handleUninstall(adapter: ConfigAdapter): Promise<void> {\n intro(\"Stamn Uninstall\");\n\n const shouldContinue = await confirm({\n message: \"This will remove all Stamn config and data. Continue?\",\n });\n\n if (!shouldContinue || typeof shouldContinue === \"symbol\") {\n cancel(\"Uninstall cancelled.\");\n return;\n }\n\n try {\n adapter.uninstall?.();\n log.success(\"Removed Stamn config\");\n outro(\"Stamn config removed.\");\n } catch (err) {\n cancel(`Failed to remove config: ${(err as Error).message}`);\n process.exitCode = 1;\n }\n}\n","import { existsSync, mkdirSync, readFileSync, rmSync, writeFileSync } from \"fs\";\nimport { dirname, join } from \"path\";\nimport { homedir } from \"os\";\nimport type { StamnConfig, StamnStatusFile, ConfigAdapter } from \"@/types\";\n\nexport function readJsonFile<T>(filePath: string): T | null {\n try {\n const raw = readFileSync(filePath, \"utf-8\");\n return JSON.parse(raw) as T;\n } catch {\n return null;\n }\n}\n\nexport function writeJsonFile(filePath: string, data: unknown): void {\n mkdirSync(dirname(filePath), { recursive: true });\n writeFileSync(filePath, JSON.stringify(data, null, 2) + \"\\n\", \"utf-8\");\n}\n\nexport function getConfigPath(): string {\n return join(homedir(), \".stamn\", \"config.json\");\n}\n\nexport function readConfig(): StamnConfig | null {\n return readJsonFile<StamnConfig>(getConfigPath());\n}\n\nexport function writeConfig(updates: Partial<StamnConfig>): void {\n const existing = readConfig() ?? {};\n writeJsonFile(getConfigPath(), { ...existing, ...updates });\n}\n\nexport function readStatusFile(): StamnStatusFile | null {\n return readJsonFile<StamnStatusFile>(join(homedir(), \".stamn\", \"status.json\"));\n}\n\nexport function createDefaultAdapter(): ConfigAdapter {\n return {\n readConfig,\n writeConfig,\n readStatusFile,\n getConfigPath,\n uninstall() {\n const configDir = dirname(getConfigPath());\n if (existsSync(configDir)) {\n rmSync(configDir, { recursive: true, force: true });\n }\n },\n };\n}\n"],"mappings":"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","names":["s","client","intro","outro","spinner","log","cancel","StamnClient","intro","spinner","log","cancel","StamnClient","intro","outro","spinner","log","cancel","StamnClient","intro","outro","log","cancel","log","text","intro","outro","log","StamnClient","intro","outro","confirm","log","cancel","mkdirSync","readFileSync","writeFileSync","join"]}
|