@skaile/workspaces 0.9.1 → 0.10.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/CHANGELOG.md +38 -0
- package/README.md +2 -2
- package/dist/asset-manager/index.js +2 -2
- package/dist/asset-manager/scaffold.js +1 -1
- package/dist/base-assets/connectors/deploy.js +1 -1
- package/dist/base-assets/connectors/devserver.js +1 -1
- package/dist/base-assets/connectors/flow/adapter.js +1 -1
- package/dist/base-assets/connectors/flow/run-flow.js +2 -2
- package/dist/base-assets/connectors/flow.js +1 -1
- package/dist/base-assets/connectors/git.js +1 -1
- package/dist/base-assets/connectors/gmail.js +1 -1
- package/dist/base-assets/connectors/local.js +1 -1
- package/dist/base-assets/connectors/mattermost.js +1 -1
- package/dist/base-assets/connectors/memory.js +1 -1
- package/dist/base-assets/connectors/minio.js +1 -1
- package/dist/base-assets/connectors/postgres.js +1 -1
- package/dist/base-assets/connectors/redis.js +1 -1
- package/dist/base-assets/connectors/s3.js +1 -1
- package/dist/base-assets/connectors/sharepoint.js +1 -1
- package/dist/base-assets/connectors/sqlite.js +1 -1
- package/dist/base-assets/connectors/static-server.js +1 -1
- package/dist/base-assets/connectors/tunnel.js +1 -1
- package/dist/base-assets/connectors/webdav.js +1 -1
- package/dist/base-assets/connectors/xstate-store.js +1 -1
- package/dist/base-assets/connectors/xstate.js +1 -1
- package/dist/base-assets/connectors/yjs.js +1 -1
- package/dist/bridge/drivers/claude-sdk.js +53 -3
- package/dist/bridge/drivers/claude-sdk.js.map +1 -1
- package/dist/bridge/drivers/codex.js +1 -1
- package/dist/bridge/drivers/echo.js +1 -1
- package/dist/bridge/drivers/omp.js +1 -1
- package/dist/bridge/index.js +2 -2
- package/dist/bridge/src/drivers/claude-sdk.d.ts +23 -0
- package/dist/bridge/src/drivers/claude-sdk.d.ts.map +1 -1
- package/dist/{chunk-5IC6CJL4.js → chunk-BTKNSMLK.js} +2 -2
- package/dist/{chunk-5IC6CJL4.js.map → chunk-BTKNSMLK.js.map} +1 -1
- package/dist/{chunk-TODD4VNR.js → chunk-D3VO6WNC.js} +85 -3
- package/dist/chunk-D3VO6WNC.js.map +1 -0
- package/dist/{chunk-I3S4BAAR.js → chunk-FEBLE7QX.js} +2 -2
- package/dist/{chunk-I3S4BAAR.js.map → chunk-FEBLE7QX.js.map} +1 -1
- package/dist/{chunk-DTL7S57T.js → chunk-IFRUVHOQ.js} +3 -3
- package/dist/{chunk-DTL7S57T.js.map → chunk-IFRUVHOQ.js.map} +1 -1
- package/dist/{chunk-XIVOEUAF.js → chunk-OQIBHB4F.js} +2 -2
- package/dist/{chunk-XIVOEUAF.js.map → chunk-OQIBHB4F.js.map} +1 -1
- package/dist/{chunk-K3TMZI6D.js → chunk-OSJH4SPO.js} +3 -3
- package/dist/{chunk-K3TMZI6D.js.map → chunk-OSJH4SPO.js.map} +1 -1
- package/dist/{chunk-QZ6PY73K.js → chunk-OVM36NYF.js} +18 -23
- package/dist/chunk-OVM36NYF.js.map +1 -0
- package/dist/{chunk-AE6GCXGL.js → chunk-S7RACIZI.js} +2 -2
- package/dist/{chunk-AE6GCXGL.js.map → chunk-S7RACIZI.js.map} +1 -1
- package/dist/{chunk-O5AE4QDX.js → chunk-TDSRLMDB.js} +4 -4
- package/dist/chunk-TDSRLMDB.js.map +1 -0
- package/dist/{chunk-EPGHAOEU.js → chunk-UHSC75L7.js} +19 -3
- package/dist/chunk-UHSC75L7.js.map +1 -0
- package/dist/chunk-W3UDISS2.js +31 -0
- package/dist/chunk-W3UDISS2.js.map +1 -0
- package/dist/cli/index.js +11 -10
- package/dist/cli/index.js.map +1 -1
- package/dist/connectors/index.js +1 -1
- package/dist/connectors/src/connector-manager.d.ts +7 -0
- package/dist/connectors/src/connector-manager.d.ts.map +1 -1
- package/dist/runner/index.js +7 -6
- package/dist/runner/prompt-assembly.js +4 -0
- package/dist/runner/prompt-assembly.js.map +1 -0
- package/dist/runner/src/capability-registry.d.ts.map +1 -1
- package/dist/runner/src/capability-roundtrip.d.ts +18 -0
- package/dist/runner/src/capability-roundtrip.d.ts.map +1 -1
- package/dist/runner/src/define-capability.d.ts +7 -0
- package/dist/runner/src/define-capability.d.ts.map +1 -1
- package/dist/runner/src/prompt-assembly.d.ts +39 -0
- package/dist/runner/src/prompt-assembly.d.ts.map +1 -1
- package/dist/runner/src/serve.d.ts.map +1 -1
- package/dist/sdk/asset-manager.js +2 -2
- package/dist/sdk/bridge.js +2 -2
- package/dist/sdk/index.js +7 -6
- package/dist/sdk/index.js.map +1 -1
- package/dist/sdk/runner.js +7 -6
- package/dist/sdk/session.js +2 -2
- package/dist/sdk/types.js +1 -1
- package/dist/session/index.js +2 -2
- package/dist/session/src/dispatcher.d.ts +57 -0
- package/dist/session/src/dispatcher.d.ts.map +1 -1
- package/dist/{setup-PHFPBDBI.js → setup-QIEPIYH2.js} +4 -4
- package/dist/{setup-PHFPBDBI.js.map → setup-QIEPIYH2.js.map} +1 -1
- package/dist/tui/index.js +7 -6
- package/dist/tui/index.js.map +1 -1
- package/dist/types/index.js +1 -1
- package/dist/types/src/capabilities.d.ts +13 -0
- package/dist/types/src/capabilities.d.ts.map +1 -1
- package/dist/types/src/events.d.ts +29 -1
- package/dist/types/src/events.d.ts.map +1 -1
- package/dist/types/src/index.d.ts +1 -1
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/version.d.ts +19 -1
- package/dist/types/src/version.d.ts.map +1 -1
- package/dist/workspace-plugin/adapters/mcp.js +2 -2
- package/dist/workspace-plugin/index.js +1 -1
- package/package.json +7 -1
- package/dist/chunk-EPGHAOEU.js.map +0 -1
- package/dist/chunk-O5AE4QDX.js.map +0 -1
- package/dist/chunk-QZ6PY73K.js.map +0 -1
- package/dist/chunk-TODD4VNR.js.map +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../cli/src/setup.ts"],"names":["p","isCancel","result"],"mappings":"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","file":"setup-PHFPBDBI.js","sourcesContent":["/**\n * skaile setup — Interactive provider setup wizard\n *\n * Discovers existing config, lets the user pick providers, enter/validate API keys,\n * choose where to store them, and set defaults.\n */\n\nimport fs from \"node:fs\";\nimport os from \"node:os\";\nimport path from \"node:path\";\nimport * as p from \"@clack/prompts\";\nimport { getModels, validateApiKey } from \"@skaile/workspaces/bridge\";\nimport {\n ALL_PROVIDERS,\n detectEnvApiKeys,\n loadSettings,\n maskApiKey,\n projectSettingsPath,\n providerEnvKey,\n resolveSettings,\n type SkaileSettings,\n saveSettings,\n WorkspaceYamlEditor,\n} from \"@skaile/workspaces/core\";\n\n// ---------------------------------------------------------------------------\n// Provider metadata\n// ---------------------------------------------------------------------------\n\n/** LLM providers only (excludes voice providers) */\nconst LLM_PROVIDERS = ALL_PROVIDERS.filter((p) => p !== \"deepgram\" && p !== \"elevenlabs\");\n\nconst PROVIDER_LABELS: Record<string, string> = {\n anthropic: \"Anthropic (Claude)\",\n openai: \"OpenAI (GPT)\",\n google: \"Google (Gemini)\",\n mistral: \"Mistral AI\",\n groq: \"Groq (fast inference)\",\n openrouter: \"OpenRouter (multi-provider gateway)\",\n deepseek: \"DeepSeek\",\n xai: \"xAI (Grok)\",\n together: \"Together AI\",\n fireworks: \"Fireworks AI\",\n};\n\nconst PROVIDER_KEY_URLS: Record<string, string> = {\n anthropic: \"https://console.anthropic.com/settings/keys\",\n openai: \"https://platform.openai.com/api-keys\",\n google: \"https://aistudio.google.com/apikey\",\n mistral: \"https://console.mistral.ai/api-keys\",\n groq: \"https://console.groq.com/keys\",\n openrouter: \"https://openrouter.ai/settings/keys\",\n deepseek: \"https://platform.deepseek.com/api_keys\",\n xai: \"https://console.x.ai/\",\n together: \"https://api.together.ai/settings/api-keys\",\n fireworks: \"https://fireworks.ai/api-keys\",\n};\n\n// ---------------------------------------------------------------------------\n// Types\n// ---------------------------------------------------------------------------\n\ntype StorageTarget = \"settings\" | \"env-project\" | \"env-global\" | \"skip\";\ntype DefaultsTarget = \"project\" | \"personal\";\n\ninterface SetupPlan {\n providers: string[];\n newKeys: Record<string, string>;\n storageTarget: StorageTarget;\n defaultsTarget: DefaultsTarget;\n defaultProvider: string;\n defaultModel: string;\n defaultDriver: string;\n}\n\n// ---------------------------------------------------------------------------\n// Helpers\n// ---------------------------------------------------------------------------\n\nfunction isCancel(value: unknown): value is symbol {\n return p.isCancel(value);\n}\n\nfunction exitOnCancel<T>(value: T): asserts value is Exclude<T, symbol> {\n if (isCancel(value)) {\n p.cancel(\"Setup cancelled.\");\n process.exit(0);\n }\n}\n\n/** Load .env files from common locations and parse key=value pairs */\nfunction loadDotenvKeys(): Record<string, string> {\n const locations = [path.join(process.cwd(), \".env\"), path.join(os.homedir(), \".env\")];\n const result: Record<string, string> = {};\n for (const loc of locations) {\n try {\n const content = fs.readFileSync(loc, \"utf-8\");\n for (const line of content.split(\"\\n\")) {\n const trimmed = line.trim();\n if (!trimmed || trimmed.startsWith(\"#\")) continue;\n const eq = trimmed.indexOf(\"=\");\n if (eq === -1) continue;\n const key = trimmed.slice(0, eq).trim();\n let val = trimmed.slice(eq + 1).trim();\n // Strip surrounding quotes\n if (\n (val.startsWith('\"') && val.endsWith('\"')) ||\n (val.startsWith(\"'\") && val.endsWith(\"'\"))\n ) {\n val = val.slice(1, -1);\n }\n result[key] = val;\n }\n } catch {\n // file doesn't exist, skip\n }\n }\n return result;\n}\n\n/** Append key=value entries to a .env file without overwriting existing keys */\nfunction appendEnvFile(filePath: string, entries: Record<string, string>): void {\n let existing = \"\";\n try {\n existing = fs.readFileSync(filePath, \"utf-8\");\n } catch {\n // file doesn't exist yet\n }\n\n const existingKeys = new Set<string>();\n for (const line of existing.split(\"\\n\")) {\n const trimmed = line.trim();\n if (!trimmed || trimmed.startsWith(\"#\")) continue;\n const eq = trimmed.indexOf(\"=\");\n if (eq !== -1) existingKeys.add(trimmed.slice(0, eq).trim());\n }\n\n const lines: string[] = [];\n for (const [key, value] of Object.entries(entries)) {\n if (existingKeys.has(key)) {\n p.log.warn(` ${key} already exists in ${filePath} — skipping`);\n continue;\n }\n lines.push(`${key}=${value}`);\n }\n\n if (lines.length === 0) return;\n\n const separator = existing.endsWith(\"\\n\") || existing === \"\" ? \"\" : \"\\n\";\n const content = `${separator + lines.join(\"\\n\")}\\n`;\n fs.mkdirSync(path.dirname(filePath), { recursive: true });\n fs.appendFileSync(filePath, content, \"utf-8\");\n}\n\n// ---------------------------------------------------------------------------\n// Wizard steps\n// ---------------------------------------------------------------------------\n\nasync function showCurrentState(\n settings: SkaileSettings,\n envKeys: Record<string, string>,\n): Promise<void> {\n const apiKeys = settings.apiKeys ?? {};\n const lines: string[] = [\"Provider keys:\"];\n for (const provider of LLM_PROVIDERS) {\n const envVal = envKeys[provider];\n const storedVal = apiKeys[provider];\n if (envVal) {\n lines.push(` ${provider.padEnd(12)} [env] ${maskApiKey(envVal)}`);\n } else if (storedVal) {\n lines.push(` ${provider.padEnd(12)} [stored] ${maskApiKey(storedVal)}`);\n } else {\n lines.push(` ${provider.padEnd(12)} (not configured)`);\n }\n }\n lines.push(\"\");\n lines.push(\"Current defaults:\");\n lines.push(` Provider: ${settings.provider ?? \"(not set)\"}`);\n lines.push(` Model: ${settings.model ?? \"(not set)\"}`);\n lines.push(` Driver: ${settings.driver ?? \"(not set)\"}`);\n\n p.note(lines.join(\"\\n\"), \"Current configuration\");\n}\n\nasync function selectProviders(\n envKeys: Record<string, string>,\n storedKeys: Record<string, string>,\n): Promise<string[]> {\n const result = await p.multiselect({\n message: \"Which providers do you want to configure?\",\n options: LLM_PROVIDERS.map((id) => ({\n value: id,\n label: PROVIDER_LABELS[id] ?? id,\n hint: envKeys[id]\n ? `env: ${maskApiKey(envKeys[id])}`\n : storedKeys[id]\n ? `stored: ${maskApiKey(storedKeys[id])}`\n : undefined,\n })),\n initialValues: LLM_PROVIDERS.filter((id) => envKeys[id] || storedKeys[id]),\n required: true,\n });\n exitOnCancel(result);\n return result as string[];\n}\n\nasync function collectApiKeys(\n providers: string[],\n envKeys: Record<string, string>,\n storedKeys: Record<string, string>,\n): Promise<Record<string, string>> {\n const newKeys: Record<string, string> = {};\n\n for (const provider of providers) {\n const envVar = providerEnvKey(provider);\n\n if (envKeys[provider]) {\n p.log.info(`${PROVIDER_LABELS[provider] ?? provider}: already set via ${envVar}`);\n continue;\n }\n\n if (storedKeys[provider]) {\n const update = await p.confirm({\n message: `${PROVIDER_LABELS[provider] ?? provider}: key already stored (${maskApiKey(storedKeys[provider])}). Update it?`,\n initialValue: false,\n });\n exitOnCancel(update);\n if (!update) continue;\n }\n\n const keyUrl = PROVIDER_KEY_URLS[provider];\n const key = await p.password({\n message: `${PROVIDER_LABELS[provider] ?? provider} API key${keyUrl ? ` (get one at ${keyUrl})` : \"\"}:`,\n });\n exitOnCancel(key);\n\n if (!key) continue;\n\n // Optional validation\n const shouldValidate = await p.confirm({\n message: \"Validate this key?\",\n initialValue: true,\n });\n exitOnCancel(shouldValidate);\n\n if (shouldValidate) {\n const s = p.spinner();\n s.start(`Validating ${provider} key...`);\n const result = await validateApiKey(provider, key);\n if (result.ok) {\n s.stop(`${provider} key is valid`);\n } else {\n s.stop(`${provider} validation failed: ${result.error}`);\n const retry = await p.confirm({\n message: \"Use this key anyway?\",\n initialValue: false,\n });\n exitOnCancel(retry);\n if (!retry) continue;\n }\n }\n\n newKeys[provider] = key;\n }\n\n return newKeys;\n}\n\nasync function selectStorageTarget(): Promise<StorageTarget> {\n const result = await p.select({\n message: \"Where should API keys be stored?\",\n options: [\n { value: \"settings\" as const, label: \".skaile/settings.json (project-local, gitignored)\" },\n { value: \"env-project\" as const, label: `${process.cwd()}/.env (project-level)` },\n { value: \"env-global\" as const, label: `${os.homedir()}/.env (global)` },\n { value: \"skip\" as const, label: \"Skip — I'll set env vars myself\" },\n ],\n });\n exitOnCancel(result);\n return result as StorageTarget;\n}\n\nasync function selectDefaultProvider(providers: string[], current?: string): Promise<string> {\n const result = await p.select({\n message: \"Default LLM provider:\",\n options: providers.map((id) => ({\n value: id,\n label: PROVIDER_LABELS[id] ?? id,\n })),\n initialValue: current && providers.includes(current) ? current : providers[0],\n });\n exitOnCancel(result);\n return result as string;\n}\n\nasync function selectDefaultModel(\n provider: string,\n current?: string,\n apiKey?: string,\n): Promise<string> {\n // Try live model list from provider API, fall back to static catalog\n const s = apiKey ? p.spinner() : undefined;\n if (s) s.start(`Fetching models from ${provider}...`);\n\n const fetchResult = await getModels(provider, apiKey);\n\n if (s) {\n if (fetchResult.source === \"api\") {\n s.stop(`Loaded ${fetchResult.models.length} models from ${provider} API`);\n } else if (fetchResult.error) {\n s.stop(`Could not fetch live models (${fetchResult.error}) — using built-in catalog`);\n } else {\n s.stop(`Using built-in model catalog`);\n }\n }\n\n const models = fetchResult.models;\n if (models.length === 0) {\n p.log.warn(`No models found for ${provider} — enter a model ID manually`);\n const result = await p.text({\n message: \"Model ID:\",\n initialValue: current ?? \"\",\n });\n exitOnCancel(result);\n return result as string;\n }\n\n const result = await p.select({\n message: `Default model (${provider}):`,\n options: models.map((m) => ({\n value: m.id,\n label: `${m.name} (${m.id})`,\n })),\n initialValue: current && models.some((m) => m.id === current) ? current : models[0].id,\n });\n exitOnCancel(result);\n return result as string;\n}\n\nasync function selectDriver(current?: string): Promise<string> {\n const result = await p.select({\n message: \"Default agent driver:\",\n options: [\n { value: \"omp\", label: \"omp (oh-my-pi — multi-provider, recommended)\" },\n { value: \"claude-sdk\", label: \"claude-sdk (Anthropic Agent SDK, Claude only)\" },\n { value: \"codex\", label: \"codex (OpenAI Codex SDK, OpenAI only)\" },\n ],\n initialValue: current ?? \"omp\",\n });\n exitOnCancel(result);\n return result as string;\n}\n\nasync function selectDefaultsTarget(projectDir: string): Promise<DefaultsTarget> {\n const yamlPath = path.join(projectDir, \"skaile.yaml\");\n const hasYaml = fs.existsSync(yamlPath);\n\n if (!hasYaml) {\n // No skaile.yaml — can only save personally\n return \"personal\";\n }\n\n const result = await p.select({\n message: \"Where should driver, provider, and model defaults be saved?\",\n options: [\n {\n value: \"project\" as const,\n label: \"skaile.yaml (project-wide, shared with team)\",\n hint: \"recommended\",\n },\n {\n value: \"personal\" as const,\n label: \".skaile/settings.json (personal only, gitignored)\",\n },\n ],\n initialValue: \"project\" as const,\n });\n exitOnCancel(result);\n return result as DefaultsTarget;\n}\n\nasync function reviewAndSave(plan: SetupPlan, projectDir: string): Promise<void> {\n const settingsFile = projectSettingsPath(projectDir);\n\n // Build summary\n const lines: string[] = [];\n\n if (Object.keys(plan.newKeys).length > 0) {\n lines.push(\"New API keys:\");\n for (const [provider, key] of Object.entries(plan.newKeys)) {\n lines.push(` ${provider.padEnd(12)} ${maskApiKey(key)}`);\n }\n const targetLabels: Record<StorageTarget, string> = {\n settings: `.skaile/settings.json (${settingsFile})`,\n \"env-project\": `${process.cwd()}/.env`,\n \"env-global\": `${os.homedir()}/.env`,\n skip: \"not saved (set env vars manually)\",\n };\n lines.push(` Storage: ${targetLabels[plan.storageTarget]}`);\n lines.push(\"\");\n }\n\n const defaultsLabel =\n plan.defaultsTarget === \"project\"\n ? \"skaile.yaml (project-wide)\"\n : \".skaile/settings.json (personal)\";\n lines.push(\"Defaults:\");\n lines.push(` Provider: ${plan.defaultProvider}`);\n lines.push(` Model: ${plan.defaultModel}`);\n lines.push(` Driver: ${plan.defaultDriver}`);\n lines.push(` Saved to: ${defaultsLabel}`);\n\n p.note(lines.join(\"\\n\"), \"Summary\");\n\n const confirmed = await p.confirm({\n message: \"Apply these settings?\",\n initialValue: true,\n });\n exitOnCancel(confirmed);\n\n if (!confirmed) {\n p.cancel(\"Setup cancelled — no changes were made.\");\n process.exit(0);\n }\n\n // Load existing project settings (or empty)\n const existing = await loadSettings(settingsFile);\n\n // Save defaults to skaile.yaml or settings.json depending on user choice\n if (plan.defaultsTarget === \"project\") {\n const yamlPath = path.join(projectDir, \"skaile.yaml\");\n const editor = WorkspaceYamlEditor.load(yamlPath);\n editor.setAgentConfig(\"default\", {\n provider: plan.defaultProvider,\n model: plan.defaultModel,\n driver: plan.defaultDriver,\n });\n editor.save();\n p.log.success(`Saved defaults to ${yamlPath}`);\n }\n\n // Personal settings: only include defaults if saving personally, always include API keys.\n // When saving to project (skaile.yaml), strip driver/provider/model from settings.json\n // so they don't shadow the project-wide values.\n const merged: SkaileSettings = { ...existing };\n if (plan.defaultsTarget === \"personal\") {\n merged.provider = plan.defaultProvider;\n merged.model = plan.defaultModel;\n merged.driver = plan.defaultDriver;\n } else {\n delete merged.provider;\n delete merged.model;\n delete merged.driver;\n }\n\n // Save keys\n const hasNewKeys = Object.keys(plan.newKeys).length > 0;\n\n if (hasNewKeys && plan.storageTarget === \"settings\") {\n const apiKeys = { ...(merged.apiKeys ?? {}) };\n for (const [provider, key] of Object.entries(plan.newKeys)) {\n apiKeys[provider] = key;\n }\n merged.apiKeys = apiKeys;\n } else if (hasNewKeys && plan.storageTarget === \"env-project\") {\n const envEntries: Record<string, string> = {};\n for (const [provider, key] of Object.entries(plan.newKeys)) {\n envEntries[providerEnvKey(provider)] = key;\n }\n appendEnvFile(path.join(process.cwd(), \".env\"), envEntries);\n p.log.success(`Appended keys to ${process.cwd()}/.env`);\n } else if (hasNewKeys && plan.storageTarget === \"env-global\") {\n const envEntries: Record<string, string> = {};\n for (const [provider, key] of Object.entries(plan.newKeys)) {\n envEntries[providerEnvKey(provider)] = key;\n }\n appendEnvFile(path.join(os.homedir(), \".env\"), envEntries);\n p.log.success(`Appended keys to ${os.homedir()}/.env`);\n }\n\n // Write unified settings file\n await saveSettings(merged, settingsFile);\n p.log.success(`Saved settings to ${settingsFile}`);\n}\n\n// ---------------------------------------------------------------------------\n// Main entry\n// ---------------------------------------------------------------------------\n\n/** Check whether Claude Code OAuth credentials exist on disk */\nfunction hasClaudeCodeCredentials(): boolean {\n const credPath = path.join(os.homedir(), \".claude\", \".credentials.json\");\n try {\n const content = fs.readFileSync(credPath, \"utf-8\");\n const parsed = JSON.parse(content);\n // Check that it has at least one non-empty field\n return parsed && (parsed.accessToken || parsed.refreshToken || parsed.oauthToken);\n } catch {\n return false;\n }\n}\n\n/**\n * Interactive provider setup wizard: discovers existing config, prompts for\n * provider/model/driver preferences and API keys, then writes the results to\n * `skaile.yaml` or `.skaile/settings.json` depending on the user's choice.\n *\n * @param _args - Unused positional args (reserved for future use).\n * @param opts - Options including an optional `projectDir` override.\n * @docLink cli/dev-guide#setup\n */\nexport async function cmdSetup(_args: string[], opts: { projectDir?: string }): Promise<void> {\n p.intro(\"skaile setup\");\n\n const projectDir = opts.projectDir ?? process.cwd();\n\n // 1. Detect existing state via layered resolution\n const dotenvKeys = loadDotenvKeys();\n const envKeys = detectEnvApiKeys(dotenvKeys);\n const settings = await resolveSettings(projectDir);\n\n // 2. Show current state\n await showCurrentState(settings, envKeys);\n\n // 3. Select driver FIRST — it determines which providers/models are relevant\n const defaultDriver = await selectDriver(settings.driver);\n\n const apiKeys = settings.apiKeys ?? {};\n let providers: string[];\n let newKeys: Record<string, string>;\n let storageTarget: StorageTarget = \"skip\";\n let defaultProvider: string;\n let defaultModel: string;\n\n if (defaultDriver === \"claude-sdk\") {\n // -----------------------------------------------------------------------\n // Claude SDK path: Anthropic only\n // -----------------------------------------------------------------------\n defaultProvider = \"anthropic\";\n\n // Check for existing auth: API key or Claude Code OAuth credentials\n const hasEnvKey = !!envKeys.anthropic;\n const hasStoredKey = !!apiKeys.anthropic;\n const hasOAuth = hasClaudeCodeCredentials();\n\n if (hasEnvKey) {\n p.log.info(`Anthropic API key found in environment (${maskApiKey(envKeys.anthropic)})`);\n providers = [\"anthropic\"];\n newKeys = {};\n } else if (hasStoredKey) {\n p.log.info(`Anthropic API key found in settings (${maskApiKey(apiKeys.anthropic)})`);\n providers = [\"anthropic\"];\n newKeys = {};\n } else if (hasOAuth) {\n p.log.info(\"Claude Code subscription detected (OAuth credentials found)\");\n p.log.info(\"The Claude SDK will use your Claude Code login — no API key needed.\");\n providers = [\"anthropic\"];\n newKeys = {};\n } else {\n // No auth found — prompt for Anthropic API key\n p.log.warn(\"No Anthropic API key or Claude Code subscription found.\");\n p.log.info(\"You can either:\");\n p.log.info(\" 1. Enter an Anthropic API key now\");\n p.log.info(\" 2. Run `claude login` to authenticate with Claude Code\");\n\n const wantsKey = await p.confirm({\n message: \"Enter an Anthropic API key?\",\n initialValue: true,\n });\n exitOnCancel(wantsKey);\n\n providers = [\"anthropic\"];\n if (wantsKey) {\n newKeys = await collectApiKeys([\"anthropic\"], envKeys, apiKeys);\n } else {\n newKeys = {};\n }\n }\n\n // Storage target (only ask if there are new keys)\n if (Object.keys(newKeys).length > 0) {\n storageTarget = await selectStorageTarget();\n }\n\n // Model selection — only Anthropic models (try live fetch with available key)\n const anthropicKey = newKeys.anthropic ?? envKeys.anthropic ?? apiKeys.anthropic;\n defaultModel = await selectDefaultModel(\"anthropic\", settings.model, anthropicKey);\n } else if (defaultDriver === \"codex\") {\n // -----------------------------------------------------------------------\n // Codex path: OpenAI only\n // -----------------------------------------------------------------------\n defaultProvider = \"openai\";\n\n const hasEnvKey = !!envKeys.openai;\n const hasStoredKey = !!apiKeys.openai;\n\n if (hasEnvKey) {\n p.log.info(`OpenAI API key found in environment (${maskApiKey(envKeys.openai)})`);\n providers = [\"openai\"];\n newKeys = {};\n } else if (hasStoredKey) {\n p.log.info(`OpenAI API key found in settings (${maskApiKey(apiKeys.openai)})`);\n providers = [\"openai\"];\n newKeys = {};\n } else {\n p.log.warn(\"No OpenAI API key found.\");\n newKeys = await collectApiKeys([\"openai\"], envKeys, apiKeys);\n providers = [\"openai\"];\n }\n\n if (Object.keys(newKeys).length > 0) {\n storageTarget = await selectStorageTarget();\n }\n\n const openaiKey = newKeys.openai ?? envKeys.openai ?? apiKeys.openai;\n defaultModel = await selectDefaultModel(\"openai\", settings.model, openaiKey);\n } else {\n // -----------------------------------------------------------------------\n // omp / pi path: multi-provider flow (existing behavior)\n // -----------------------------------------------------------------------\n\n // 4. Select providers\n providers = await selectProviders(envKeys, apiKeys);\n\n // 5. Collect API keys\n newKeys = await collectApiKeys(providers, envKeys, apiKeys);\n\n // 6. Storage target (only ask if there are new keys)\n if (Object.keys(newKeys).length > 0) {\n storageTarget = await selectStorageTarget();\n }\n\n // 7. Default provider (from selected providers + any already configured)\n const allConfigured = [\n ...new Set([\n ...providers,\n ...Object.keys(envKeys),\n ...Object.keys(apiKeys).filter((k) => apiKeys[k]),\n ]),\n ].filter((p) => LLM_PROVIDERS.includes(p as any));\n defaultProvider = await selectDefaultProvider(\n allConfigured.length > 0 ? allConfigured : providers,\n settings.provider,\n );\n\n // 8. Default model (try live fetch with available key)\n const providerKey =\n newKeys[defaultProvider] ?? envKeys[defaultProvider] ?? apiKeys[defaultProvider];\n defaultModel = await selectDefaultModel(defaultProvider, settings.model, providerKey);\n }\n\n // 9. Choose where to save defaults (project-wide vs personal)\n const defaultsTarget = await selectDefaultsTarget(projectDir);\n\n // 10. Review and save\n await reviewAndSave(\n {\n providers,\n newKeys,\n storageTarget,\n defaultsTarget,\n defaultProvider,\n defaultModel,\n defaultDriver,\n },\n projectDir,\n );\n\n p.outro(\"Setup complete!\");\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["../cli/src/setup.ts"],"names":["p","isCancel","result"],"mappings":"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","file":"setup-QIEPIYH2.js","sourcesContent":["/**\n * skaile setup — Interactive provider setup wizard\n *\n * Discovers existing config, lets the user pick providers, enter/validate API keys,\n * choose where to store them, and set defaults.\n */\n\nimport fs from \"node:fs\";\nimport os from \"node:os\";\nimport path from \"node:path\";\nimport * as p from \"@clack/prompts\";\nimport { getModels, validateApiKey } from \"@skaile/workspaces/bridge\";\nimport {\n ALL_PROVIDERS,\n detectEnvApiKeys,\n loadSettings,\n maskApiKey,\n projectSettingsPath,\n providerEnvKey,\n resolveSettings,\n type SkaileSettings,\n saveSettings,\n WorkspaceYamlEditor,\n} from \"@skaile/workspaces/core\";\n\n// ---------------------------------------------------------------------------\n// Provider metadata\n// ---------------------------------------------------------------------------\n\n/** LLM providers only (excludes voice providers) */\nconst LLM_PROVIDERS = ALL_PROVIDERS.filter((p) => p !== \"deepgram\" && p !== \"elevenlabs\");\n\nconst PROVIDER_LABELS: Record<string, string> = {\n anthropic: \"Anthropic (Claude)\",\n openai: \"OpenAI (GPT)\",\n google: \"Google (Gemini)\",\n mistral: \"Mistral AI\",\n groq: \"Groq (fast inference)\",\n openrouter: \"OpenRouter (multi-provider gateway)\",\n deepseek: \"DeepSeek\",\n xai: \"xAI (Grok)\",\n together: \"Together AI\",\n fireworks: \"Fireworks AI\",\n};\n\nconst PROVIDER_KEY_URLS: Record<string, string> = {\n anthropic: \"https://console.anthropic.com/settings/keys\",\n openai: \"https://platform.openai.com/api-keys\",\n google: \"https://aistudio.google.com/apikey\",\n mistral: \"https://console.mistral.ai/api-keys\",\n groq: \"https://console.groq.com/keys\",\n openrouter: \"https://openrouter.ai/settings/keys\",\n deepseek: \"https://platform.deepseek.com/api_keys\",\n xai: \"https://console.x.ai/\",\n together: \"https://api.together.ai/settings/api-keys\",\n fireworks: \"https://fireworks.ai/api-keys\",\n};\n\n// ---------------------------------------------------------------------------\n// Types\n// ---------------------------------------------------------------------------\n\ntype StorageTarget = \"settings\" | \"env-project\" | \"env-global\" | \"skip\";\ntype DefaultsTarget = \"project\" | \"personal\";\n\ninterface SetupPlan {\n providers: string[];\n newKeys: Record<string, string>;\n storageTarget: StorageTarget;\n defaultsTarget: DefaultsTarget;\n defaultProvider: string;\n defaultModel: string;\n defaultDriver: string;\n}\n\n// ---------------------------------------------------------------------------\n// Helpers\n// ---------------------------------------------------------------------------\n\nfunction isCancel(value: unknown): value is symbol {\n return p.isCancel(value);\n}\n\nfunction exitOnCancel<T>(value: T): asserts value is Exclude<T, symbol> {\n if (isCancel(value)) {\n p.cancel(\"Setup cancelled.\");\n process.exit(0);\n }\n}\n\n/** Load .env files from common locations and parse key=value pairs */\nfunction loadDotenvKeys(): Record<string, string> {\n const locations = [path.join(process.cwd(), \".env\"), path.join(os.homedir(), \".env\")];\n const result: Record<string, string> = {};\n for (const loc of locations) {\n try {\n const content = fs.readFileSync(loc, \"utf-8\");\n for (const line of content.split(\"\\n\")) {\n const trimmed = line.trim();\n if (!trimmed || trimmed.startsWith(\"#\")) continue;\n const eq = trimmed.indexOf(\"=\");\n if (eq === -1) continue;\n const key = trimmed.slice(0, eq).trim();\n let val = trimmed.slice(eq + 1).trim();\n // Strip surrounding quotes\n if (\n (val.startsWith('\"') && val.endsWith('\"')) ||\n (val.startsWith(\"'\") && val.endsWith(\"'\"))\n ) {\n val = val.slice(1, -1);\n }\n result[key] = val;\n }\n } catch {\n // file doesn't exist, skip\n }\n }\n return result;\n}\n\n/** Append key=value entries to a .env file without overwriting existing keys */\nfunction appendEnvFile(filePath: string, entries: Record<string, string>): void {\n let existing = \"\";\n try {\n existing = fs.readFileSync(filePath, \"utf-8\");\n } catch {\n // file doesn't exist yet\n }\n\n const existingKeys = new Set<string>();\n for (const line of existing.split(\"\\n\")) {\n const trimmed = line.trim();\n if (!trimmed || trimmed.startsWith(\"#\")) continue;\n const eq = trimmed.indexOf(\"=\");\n if (eq !== -1) existingKeys.add(trimmed.slice(0, eq).trim());\n }\n\n const lines: string[] = [];\n for (const [key, value] of Object.entries(entries)) {\n if (existingKeys.has(key)) {\n p.log.warn(` ${key} already exists in ${filePath} — skipping`);\n continue;\n }\n lines.push(`${key}=${value}`);\n }\n\n if (lines.length === 0) return;\n\n const separator = existing.endsWith(\"\\n\") || existing === \"\" ? \"\" : \"\\n\";\n const content = `${separator + lines.join(\"\\n\")}\\n`;\n fs.mkdirSync(path.dirname(filePath), { recursive: true });\n fs.appendFileSync(filePath, content, \"utf-8\");\n}\n\n// ---------------------------------------------------------------------------\n// Wizard steps\n// ---------------------------------------------------------------------------\n\nasync function showCurrentState(\n settings: SkaileSettings,\n envKeys: Record<string, string>,\n): Promise<void> {\n const apiKeys = settings.apiKeys ?? {};\n const lines: string[] = [\"Provider keys:\"];\n for (const provider of LLM_PROVIDERS) {\n const envVal = envKeys[provider];\n const storedVal = apiKeys[provider];\n if (envVal) {\n lines.push(` ${provider.padEnd(12)} [env] ${maskApiKey(envVal)}`);\n } else if (storedVal) {\n lines.push(` ${provider.padEnd(12)} [stored] ${maskApiKey(storedVal)}`);\n } else {\n lines.push(` ${provider.padEnd(12)} (not configured)`);\n }\n }\n lines.push(\"\");\n lines.push(\"Current defaults:\");\n lines.push(` Provider: ${settings.provider ?? \"(not set)\"}`);\n lines.push(` Model: ${settings.model ?? \"(not set)\"}`);\n lines.push(` Driver: ${settings.driver ?? \"(not set)\"}`);\n\n p.note(lines.join(\"\\n\"), \"Current configuration\");\n}\n\nasync function selectProviders(\n envKeys: Record<string, string>,\n storedKeys: Record<string, string>,\n): Promise<string[]> {\n const result = await p.multiselect({\n message: \"Which providers do you want to configure?\",\n options: LLM_PROVIDERS.map((id) => ({\n value: id,\n label: PROVIDER_LABELS[id] ?? id,\n hint: envKeys[id]\n ? `env: ${maskApiKey(envKeys[id])}`\n : storedKeys[id]\n ? `stored: ${maskApiKey(storedKeys[id])}`\n : undefined,\n })),\n initialValues: LLM_PROVIDERS.filter((id) => envKeys[id] || storedKeys[id]),\n required: true,\n });\n exitOnCancel(result);\n return result as string[];\n}\n\nasync function collectApiKeys(\n providers: string[],\n envKeys: Record<string, string>,\n storedKeys: Record<string, string>,\n): Promise<Record<string, string>> {\n const newKeys: Record<string, string> = {};\n\n for (const provider of providers) {\n const envVar = providerEnvKey(provider);\n\n if (envKeys[provider]) {\n p.log.info(`${PROVIDER_LABELS[provider] ?? provider}: already set via ${envVar}`);\n continue;\n }\n\n if (storedKeys[provider]) {\n const update = await p.confirm({\n message: `${PROVIDER_LABELS[provider] ?? provider}: key already stored (${maskApiKey(storedKeys[provider])}). Update it?`,\n initialValue: false,\n });\n exitOnCancel(update);\n if (!update) continue;\n }\n\n const keyUrl = PROVIDER_KEY_URLS[provider];\n const key = await p.password({\n message: `${PROVIDER_LABELS[provider] ?? provider} API key${keyUrl ? ` (get one at ${keyUrl})` : \"\"}:`,\n });\n exitOnCancel(key);\n\n if (!key) continue;\n\n // Optional validation\n const shouldValidate = await p.confirm({\n message: \"Validate this key?\",\n initialValue: true,\n });\n exitOnCancel(shouldValidate);\n\n if (shouldValidate) {\n const s = p.spinner();\n s.start(`Validating ${provider} key...`);\n const result = await validateApiKey(provider, key);\n if (result.ok) {\n s.stop(`${provider} key is valid`);\n } else {\n s.stop(`${provider} validation failed: ${result.error}`);\n const retry = await p.confirm({\n message: \"Use this key anyway?\",\n initialValue: false,\n });\n exitOnCancel(retry);\n if (!retry) continue;\n }\n }\n\n newKeys[provider] = key;\n }\n\n return newKeys;\n}\n\nasync function selectStorageTarget(): Promise<StorageTarget> {\n const result = await p.select({\n message: \"Where should API keys be stored?\",\n options: [\n { value: \"settings\" as const, label: \".skaile/settings.json (project-local, gitignored)\" },\n { value: \"env-project\" as const, label: `${process.cwd()}/.env (project-level)` },\n { value: \"env-global\" as const, label: `${os.homedir()}/.env (global)` },\n { value: \"skip\" as const, label: \"Skip — I'll set env vars myself\" },\n ],\n });\n exitOnCancel(result);\n return result as StorageTarget;\n}\n\nasync function selectDefaultProvider(providers: string[], current?: string): Promise<string> {\n const result = await p.select({\n message: \"Default LLM provider:\",\n options: providers.map((id) => ({\n value: id,\n label: PROVIDER_LABELS[id] ?? id,\n })),\n initialValue: current && providers.includes(current) ? current : providers[0],\n });\n exitOnCancel(result);\n return result as string;\n}\n\nasync function selectDefaultModel(\n provider: string,\n current?: string,\n apiKey?: string,\n): Promise<string> {\n // Try live model list from provider API, fall back to static catalog\n const s = apiKey ? p.spinner() : undefined;\n if (s) s.start(`Fetching models from ${provider}...`);\n\n const fetchResult = await getModels(provider, apiKey);\n\n if (s) {\n if (fetchResult.source === \"api\") {\n s.stop(`Loaded ${fetchResult.models.length} models from ${provider} API`);\n } else if (fetchResult.error) {\n s.stop(`Could not fetch live models (${fetchResult.error}) — using built-in catalog`);\n } else {\n s.stop(`Using built-in model catalog`);\n }\n }\n\n const models = fetchResult.models;\n if (models.length === 0) {\n p.log.warn(`No models found for ${provider} — enter a model ID manually`);\n const result = await p.text({\n message: \"Model ID:\",\n initialValue: current ?? \"\",\n });\n exitOnCancel(result);\n return result as string;\n }\n\n const result = await p.select({\n message: `Default model (${provider}):`,\n options: models.map((m) => ({\n value: m.id,\n label: `${m.name} (${m.id})`,\n })),\n initialValue: current && models.some((m) => m.id === current) ? current : models[0].id,\n });\n exitOnCancel(result);\n return result as string;\n}\n\nasync function selectDriver(current?: string): Promise<string> {\n const result = await p.select({\n message: \"Default agent driver:\",\n options: [\n { value: \"omp\", label: \"omp (oh-my-pi — multi-provider, recommended)\" },\n { value: \"claude-sdk\", label: \"claude-sdk (Anthropic Agent SDK, Claude only)\" },\n { value: \"codex\", label: \"codex (OpenAI Codex SDK, OpenAI only)\" },\n ],\n initialValue: current ?? \"omp\",\n });\n exitOnCancel(result);\n return result as string;\n}\n\nasync function selectDefaultsTarget(projectDir: string): Promise<DefaultsTarget> {\n const yamlPath = path.join(projectDir, \"skaile.yaml\");\n const hasYaml = fs.existsSync(yamlPath);\n\n if (!hasYaml) {\n // No skaile.yaml — can only save personally\n return \"personal\";\n }\n\n const result = await p.select({\n message: \"Where should driver, provider, and model defaults be saved?\",\n options: [\n {\n value: \"project\" as const,\n label: \"skaile.yaml (project-wide, shared with team)\",\n hint: \"recommended\",\n },\n {\n value: \"personal\" as const,\n label: \".skaile/settings.json (personal only, gitignored)\",\n },\n ],\n initialValue: \"project\" as const,\n });\n exitOnCancel(result);\n return result as DefaultsTarget;\n}\n\nasync function reviewAndSave(plan: SetupPlan, projectDir: string): Promise<void> {\n const settingsFile = projectSettingsPath(projectDir);\n\n // Build summary\n const lines: string[] = [];\n\n if (Object.keys(plan.newKeys).length > 0) {\n lines.push(\"New API keys:\");\n for (const [provider, key] of Object.entries(plan.newKeys)) {\n lines.push(` ${provider.padEnd(12)} ${maskApiKey(key)}`);\n }\n const targetLabels: Record<StorageTarget, string> = {\n settings: `.skaile/settings.json (${settingsFile})`,\n \"env-project\": `${process.cwd()}/.env`,\n \"env-global\": `${os.homedir()}/.env`,\n skip: \"not saved (set env vars manually)\",\n };\n lines.push(` Storage: ${targetLabels[plan.storageTarget]}`);\n lines.push(\"\");\n }\n\n const defaultsLabel =\n plan.defaultsTarget === \"project\"\n ? \"skaile.yaml (project-wide)\"\n : \".skaile/settings.json (personal)\";\n lines.push(\"Defaults:\");\n lines.push(` Provider: ${plan.defaultProvider}`);\n lines.push(` Model: ${plan.defaultModel}`);\n lines.push(` Driver: ${plan.defaultDriver}`);\n lines.push(` Saved to: ${defaultsLabel}`);\n\n p.note(lines.join(\"\\n\"), \"Summary\");\n\n const confirmed = await p.confirm({\n message: \"Apply these settings?\",\n initialValue: true,\n });\n exitOnCancel(confirmed);\n\n if (!confirmed) {\n p.cancel(\"Setup cancelled — no changes were made.\");\n process.exit(0);\n }\n\n // Load existing project settings (or empty)\n const existing = await loadSettings(settingsFile);\n\n // Save defaults to skaile.yaml or settings.json depending on user choice\n if (plan.defaultsTarget === \"project\") {\n const yamlPath = path.join(projectDir, \"skaile.yaml\");\n const editor = WorkspaceYamlEditor.load(yamlPath);\n editor.setAgentConfig(\"default\", {\n provider: plan.defaultProvider,\n model: plan.defaultModel,\n driver: plan.defaultDriver,\n });\n editor.save();\n p.log.success(`Saved defaults to ${yamlPath}`);\n }\n\n // Personal settings: only include defaults if saving personally, always include API keys.\n // When saving to project (skaile.yaml), strip driver/provider/model from settings.json\n // so they don't shadow the project-wide values.\n const merged: SkaileSettings = { ...existing };\n if (plan.defaultsTarget === \"personal\") {\n merged.provider = plan.defaultProvider;\n merged.model = plan.defaultModel;\n merged.driver = plan.defaultDriver;\n } else {\n delete merged.provider;\n delete merged.model;\n delete merged.driver;\n }\n\n // Save keys\n const hasNewKeys = Object.keys(plan.newKeys).length > 0;\n\n if (hasNewKeys && plan.storageTarget === \"settings\") {\n const apiKeys = { ...(merged.apiKeys ?? {}) };\n for (const [provider, key] of Object.entries(plan.newKeys)) {\n apiKeys[provider] = key;\n }\n merged.apiKeys = apiKeys;\n } else if (hasNewKeys && plan.storageTarget === \"env-project\") {\n const envEntries: Record<string, string> = {};\n for (const [provider, key] of Object.entries(plan.newKeys)) {\n envEntries[providerEnvKey(provider)] = key;\n }\n appendEnvFile(path.join(process.cwd(), \".env\"), envEntries);\n p.log.success(`Appended keys to ${process.cwd()}/.env`);\n } else if (hasNewKeys && plan.storageTarget === \"env-global\") {\n const envEntries: Record<string, string> = {};\n for (const [provider, key] of Object.entries(plan.newKeys)) {\n envEntries[providerEnvKey(provider)] = key;\n }\n appendEnvFile(path.join(os.homedir(), \".env\"), envEntries);\n p.log.success(`Appended keys to ${os.homedir()}/.env`);\n }\n\n // Write unified settings file\n await saveSettings(merged, settingsFile);\n p.log.success(`Saved settings to ${settingsFile}`);\n}\n\n// ---------------------------------------------------------------------------\n// Main entry\n// ---------------------------------------------------------------------------\n\n/** Check whether Claude Code OAuth credentials exist on disk */\nfunction hasClaudeCodeCredentials(): boolean {\n const credPath = path.join(os.homedir(), \".claude\", \".credentials.json\");\n try {\n const content = fs.readFileSync(credPath, \"utf-8\");\n const parsed = JSON.parse(content);\n // Check that it has at least one non-empty field\n return parsed && (parsed.accessToken || parsed.refreshToken || parsed.oauthToken);\n } catch {\n return false;\n }\n}\n\n/**\n * Interactive provider setup wizard: discovers existing config, prompts for\n * provider/model/driver preferences and API keys, then writes the results to\n * `skaile.yaml` or `.skaile/settings.json` depending on the user's choice.\n *\n * @param _args - Unused positional args (reserved for future use).\n * @param opts - Options including an optional `projectDir` override.\n * @docLink cli/dev-guide#setup\n */\nexport async function cmdSetup(_args: string[], opts: { projectDir?: string }): Promise<void> {\n p.intro(\"skaile setup\");\n\n const projectDir = opts.projectDir ?? process.cwd();\n\n // 1. Detect existing state via layered resolution\n const dotenvKeys = loadDotenvKeys();\n const envKeys = detectEnvApiKeys(dotenvKeys);\n const settings = await resolveSettings(projectDir);\n\n // 2. Show current state\n await showCurrentState(settings, envKeys);\n\n // 3. Select driver FIRST — it determines which providers/models are relevant\n const defaultDriver = await selectDriver(settings.driver);\n\n const apiKeys = settings.apiKeys ?? {};\n let providers: string[];\n let newKeys: Record<string, string>;\n let storageTarget: StorageTarget = \"skip\";\n let defaultProvider: string;\n let defaultModel: string;\n\n if (defaultDriver === \"claude-sdk\") {\n // -----------------------------------------------------------------------\n // Claude SDK path: Anthropic only\n // -----------------------------------------------------------------------\n defaultProvider = \"anthropic\";\n\n // Check for existing auth: API key or Claude Code OAuth credentials\n const hasEnvKey = !!envKeys.anthropic;\n const hasStoredKey = !!apiKeys.anthropic;\n const hasOAuth = hasClaudeCodeCredentials();\n\n if (hasEnvKey) {\n p.log.info(`Anthropic API key found in environment (${maskApiKey(envKeys.anthropic)})`);\n providers = [\"anthropic\"];\n newKeys = {};\n } else if (hasStoredKey) {\n p.log.info(`Anthropic API key found in settings (${maskApiKey(apiKeys.anthropic)})`);\n providers = [\"anthropic\"];\n newKeys = {};\n } else if (hasOAuth) {\n p.log.info(\"Claude Code subscription detected (OAuth credentials found)\");\n p.log.info(\"The Claude SDK will use your Claude Code login — no API key needed.\");\n providers = [\"anthropic\"];\n newKeys = {};\n } else {\n // No auth found — prompt for Anthropic API key\n p.log.warn(\"No Anthropic API key or Claude Code subscription found.\");\n p.log.info(\"You can either:\");\n p.log.info(\" 1. Enter an Anthropic API key now\");\n p.log.info(\" 2. Run `claude login` to authenticate with Claude Code\");\n\n const wantsKey = await p.confirm({\n message: \"Enter an Anthropic API key?\",\n initialValue: true,\n });\n exitOnCancel(wantsKey);\n\n providers = [\"anthropic\"];\n if (wantsKey) {\n newKeys = await collectApiKeys([\"anthropic\"], envKeys, apiKeys);\n } else {\n newKeys = {};\n }\n }\n\n // Storage target (only ask if there are new keys)\n if (Object.keys(newKeys).length > 0) {\n storageTarget = await selectStorageTarget();\n }\n\n // Model selection — only Anthropic models (try live fetch with available key)\n const anthropicKey = newKeys.anthropic ?? envKeys.anthropic ?? apiKeys.anthropic;\n defaultModel = await selectDefaultModel(\"anthropic\", settings.model, anthropicKey);\n } else if (defaultDriver === \"codex\") {\n // -----------------------------------------------------------------------\n // Codex path: OpenAI only\n // -----------------------------------------------------------------------\n defaultProvider = \"openai\";\n\n const hasEnvKey = !!envKeys.openai;\n const hasStoredKey = !!apiKeys.openai;\n\n if (hasEnvKey) {\n p.log.info(`OpenAI API key found in environment (${maskApiKey(envKeys.openai)})`);\n providers = [\"openai\"];\n newKeys = {};\n } else if (hasStoredKey) {\n p.log.info(`OpenAI API key found in settings (${maskApiKey(apiKeys.openai)})`);\n providers = [\"openai\"];\n newKeys = {};\n } else {\n p.log.warn(\"No OpenAI API key found.\");\n newKeys = await collectApiKeys([\"openai\"], envKeys, apiKeys);\n providers = [\"openai\"];\n }\n\n if (Object.keys(newKeys).length > 0) {\n storageTarget = await selectStorageTarget();\n }\n\n const openaiKey = newKeys.openai ?? envKeys.openai ?? apiKeys.openai;\n defaultModel = await selectDefaultModel(\"openai\", settings.model, openaiKey);\n } else {\n // -----------------------------------------------------------------------\n // omp / pi path: multi-provider flow (existing behavior)\n // -----------------------------------------------------------------------\n\n // 4. Select providers\n providers = await selectProviders(envKeys, apiKeys);\n\n // 5. Collect API keys\n newKeys = await collectApiKeys(providers, envKeys, apiKeys);\n\n // 6. Storage target (only ask if there are new keys)\n if (Object.keys(newKeys).length > 0) {\n storageTarget = await selectStorageTarget();\n }\n\n // 7. Default provider (from selected providers + any already configured)\n const allConfigured = [\n ...new Set([\n ...providers,\n ...Object.keys(envKeys),\n ...Object.keys(apiKeys).filter((k) => apiKeys[k]),\n ]),\n ].filter((p) => LLM_PROVIDERS.includes(p as any));\n defaultProvider = await selectDefaultProvider(\n allConfigured.length > 0 ? allConfigured : providers,\n settings.provider,\n );\n\n // 8. Default model (try live fetch with available key)\n const providerKey =\n newKeys[defaultProvider] ?? envKeys[defaultProvider] ?? apiKeys[defaultProvider];\n defaultModel = await selectDefaultModel(defaultProvider, settings.model, providerKey);\n }\n\n // 9. Choose where to save defaults (project-wide vs personal)\n const defaultsTarget = await selectDefaultsTarget(projectDir);\n\n // 10. Review and save\n await reviewAndSave(\n {\n providers,\n newKeys,\n storageTarget,\n defaultsTarget,\n defaultProvider,\n defaultModel,\n defaultDriver,\n },\n projectDir,\n );\n\n p.outro(\"Setup complete!\");\n}\n"]}
|
package/dist/tui/index.js
CHANGED
|
@@ -1,18 +1,19 @@
|
|
|
1
|
-
import { createAgentSession } from '../chunk-
|
|
2
|
-
import '../chunk-
|
|
1
|
+
import { createAgentSession } from '../chunk-OVM36NYF.js';
|
|
2
|
+
import '../chunk-BTKNSMLK.js';
|
|
3
3
|
import '../chunk-X5YPJV4N.js';
|
|
4
|
-
import '../chunk-O5AE4QDX.js';
|
|
5
4
|
import '../chunk-O7SG5PC2.js';
|
|
6
5
|
import '../chunk-W2O5LWYU.js';
|
|
7
6
|
import '../chunk-7PTP3SQJ.js';
|
|
8
7
|
import '../chunk-PBWMV5GM.js';
|
|
9
|
-
import '../chunk-
|
|
8
|
+
import '../chunk-W3UDISS2.js';
|
|
9
|
+
import '../chunk-TDSRLMDB.js';
|
|
10
|
+
import '../chunk-OSJH4SPO.js';
|
|
10
11
|
import '../chunk-EWP5HZBV.js';
|
|
11
12
|
import '../chunk-KOVLSBXK.js';
|
|
12
13
|
import '../chunk-RRVQAE5D.js';
|
|
13
|
-
import '../chunk-
|
|
14
|
+
import '../chunk-S7RACIZI.js';
|
|
14
15
|
import '../chunk-LV2HPH3C.js';
|
|
15
|
-
import '../chunk-
|
|
16
|
+
import '../chunk-UHSC75L7.js';
|
|
16
17
|
import { loadConnectorDeclarations } from '../chunk-W75ASXH4.js';
|
|
17
18
|
import '../chunk-EBMFCF4P.js';
|
|
18
19
|
import '../chunk-GCRKAFH7.js';
|
package/dist/tui/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../tui/src/telemetry.ts","../../tui/src/repl-renderer.ts","../../tui/src/repl-session.ts","../../tui/src/repl.ts"],"names":["text","pc","resolve"],"mappings":"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","file":"index.js","sourcesContent":["/**\n * Local telemetry sink that emits structured events to the TUI log panel.\n *\n * Implements `TelemetryProvider` so it can be injected into `createAgentSession`\n * without any HTTP or OpenTelemetry overhead. Instead of exporting spans over a\n * network, it converts each lifecycle event (trace start/end, span start/end,\n * generation, metric) into a {@link TelemetryLogEntry} and forwards it via the\n * `onEvent` callback. The REPL uses this to optionally display timing and token\n * cost inline when `--verbose` is active.\n *\n * @docLink packages/tui/concepts#tui-telemetry-provider\n */\n\nimport { randomUUID } from \"node:crypto\";\nimport type {\n Attributes,\n GenerationEvent,\n Span,\n SpanKind,\n SpanOptions,\n SpanResult,\n TelemetryProvider,\n Trace,\n TraceOptions,\n} from \"@skaile/workspaces/telemetry\";\n\n// ── Telemetry log entry types ────────────────────────────────────────────────\n\n/**\n * A structured telemetry event emitted by {@link TuiTelemetryProvider}.\n *\n * Discriminated union over `kind`. The TUI renders a subset of these (generation,\n * span_end for tool/turn, trace lifecycle) and suppresses the rest. Used as input\n * to {@link formatTelemetryEntry} and {@link renderLog}.\n *\n * @docLink packages/tui/concepts#tui-telemetry-provider\n */\nexport type TelemetryLogEntry =\n | { kind: \"trace_start\"; traceId: string; name: string; traceKind: string }\n | { kind: \"trace_end\"; traceId: string; status: string; durationMs: number }\n | { kind: \"span_start\"; spanId: string; name: string; spanKind: SpanKind }\n | {\n kind: \"span_end\";\n spanId: string;\n name: string;\n spanKind: SpanKind;\n status: string;\n durationMs: number;\n }\n | {\n kind: \"generation\";\n model: string;\n inputTokens: number;\n outputTokens: number;\n costUsd: number;\n durationMs: number;\n }\n | { kind: \"metric\"; name: string; value: number };\n\n// ── Internal span tracking ───────────────────────────────────────────────────\n\ninterface SpanRecord {\n spanId: string;\n traceId: string;\n name: string;\n spanKind: SpanKind;\n startTime: number;\n}\n\n// ── Provider ─────────────────────────────────────────────────────────────────\n\nexport class TuiTelemetryProvider implements TelemetryProvider {\n private readonly onEvent: (entry: TelemetryLogEntry) => void;\n private readonly spans = new Map<string, SpanRecord>();\n private readonly traces = new Map<string, { name: string; startTime: number }>();\n\n constructor(onEvent: (entry: TelemetryLogEntry) => void) {\n this.onEvent = onEvent;\n }\n\n startTrace(opts: TraceOptions): Trace {\n const traceId = randomUUID().replace(/-/g, \"\");\n const rootSpan: Span = { spanId: randomUUID().slice(0, 16), traceId };\n\n this.traces.set(traceId, { name: opts.name, startTime: Date.now() });\n this.onEvent({ kind: \"trace_start\", traceId, name: opts.name, traceKind: opts.kind });\n\n return { traceId, rootSpan };\n }\n\n endTrace(trace: Trace, result?: SpanResult): void {\n const record = this.traces.get(trace.traceId);\n if (record) {\n const durationMs = Date.now() - record.startTime;\n this.onEvent({\n kind: \"trace_end\",\n traceId: trace.traceId,\n status: result?.status ?? \"ok\",\n durationMs,\n });\n this.traces.delete(trace.traceId);\n }\n }\n\n startSpan(parent: Trace | Span, opts: SpanOptions): Span {\n const spanId = randomUUID().slice(0, 16);\n const traceId = parent.traceId;\n const span: Span = { spanId, traceId };\n\n this.spans.set(spanId, {\n spanId,\n traceId,\n name: opts.name,\n spanKind: opts.kind,\n startTime: Date.now(),\n });\n\n this.onEvent({ kind: \"span_start\", spanId, name: opts.name, spanKind: opts.kind });\n return span;\n }\n\n endSpan(span: Span, result?: SpanResult): void {\n const record = this.spans.get(span.spanId);\n if (record) {\n const durationMs = Date.now() - record.startTime;\n this.onEvent({\n kind: \"span_end\",\n spanId: span.spanId,\n name: record.name,\n spanKind: record.spanKind,\n status: result?.status ?? \"ok\",\n durationMs,\n });\n this.spans.delete(span.spanId);\n }\n }\n\n addEvent(_span: Span, _name: string, _attrs?: Attributes): void {\n // Silently ignored — events are not surfaced in TUI\n }\n\n logGeneration(_span: Span, generation: GenerationEvent): void {\n this.onEvent({\n kind: \"generation\",\n model: generation.model,\n inputTokens: generation.inputTokens ?? 0,\n outputTokens: generation.outputTokens ?? 0,\n costUsd: generation.costUsd ?? 0,\n durationMs: generation.durationMs,\n });\n }\n\n recordMetric(name: string, value: number, _tags?: Record<string, string>): void {\n this.onEvent({ kind: \"metric\", name, value });\n }\n\n async flush(): Promise<void> {}\n async shutdown(): Promise<void> {\n this.spans.clear();\n this.traces.clear();\n }\n}\n\n// ── Log formatting ───────────────────────────────────────────────────────────\n\n/**\n * Format a {@link TelemetryLogEntry} into a human-readable string for the log panel.\n *\n * Produces plain (no ANSI) strings suitable for structured logging or non-terminal\n * output. The format mirrors {@link renderLog} but without colour codes: generation\n * entries include model, token counts, cost, and duration; span_end entries for\n * `tool_call` and `agent_turn` kinds include name, status, and duration; trace\n * lifecycle entries include name and elapsed time. Returns `null` for entry kinds\n * that should not be displayed.\n *\n * @param entry - The structured telemetry event to format.\n * @returns Human-readable string, or `null` if the entry should be suppressed.\n *\n * @docLink packages/tui/concepts#tui-telemetry-provider\n */\nexport function formatTelemetryEntry(entry: TelemetryLogEntry): string | null {\n switch (entry.kind) {\n case \"generation\": {\n const tokens = `${entry.inputTokens}↑ ${entry.outputTokens}↓`;\n const cost = entry.costUsd > 0 ? ` $${entry.costUsd.toFixed(4)}` : \"\";\n const dur = entry.durationMs > 0 ? ` ${(entry.durationMs / 1000).toFixed(1)}s` : \"\";\n return `[gen] ${entry.model} ${tokens}${cost}${dur}`;\n }\n case \"span_end\":\n if (entry.spanKind === \"tool_call\") {\n return `[tool] ${entry.name} ${entry.status} ${entry.durationMs}ms`;\n }\n if (entry.spanKind === \"agent_turn\") {\n return `[turn] ${entry.name} ${(entry.durationMs / 1000).toFixed(1)}s`;\n }\n return null;\n case \"trace_start\":\n return `[trace] ${entry.name} started`;\n case \"trace_end\":\n return `[trace] done ${(entry.durationMs / 1000).toFixed(1)}s`;\n default:\n return null;\n }\n}\n","import pc from \"picocolors\";\nimport type { OutputLine } from \"@skaile/workspaces\";\nimport type { TelemetryLogEntry } from \"./telemetry.js\";\n\n/**\n * Render a single OutputLine to an ANSI-colored string for terminal display.\n *\n * Each `OutputLine` variant is mapped to a distinct colour: user input (cyan/bold),\n * agent text (plain), tool calls (blue italic), questions (yellow), errors (red),\n * status/system messages (dim italic), subagent lifecycle (blue/green italic), and\n * separator lines (dim dashes). Returns an empty string for unrecognised variants.\n *\n * @param line - The typed output line to render.\n * @returns ANSI-coloured string ready for terminal output.\n *\n * @docLink packages/tui/concepts#repl-renderer\n */\nexport function renderLine(line: OutputLine): string {\n switch (line.type) {\n case \"user\":\n return pc.cyan(pc.bold(`> ${line.content}`));\n case \"text\":\n return line.content;\n case \"tool\":\n return pc.blue(pc.italic(` Running: \\`${line.name}\\`...`));\n case \"question\":\n return pc.yellow(`?? ${line.text}\\n Reply below.`);\n case \"error\":\n return pc.red(`Error: ${line.message}`);\n case \"status\":\n return pc.dim(pc.italic(`${line.phase}...`));\n case \"system\":\n return pc.dim(pc.italic(line.message));\n case \"subagent\": {\n const icon = line.status === \"started\" ? \"▶\" : \"✓\";\n const color = line.status === \"started\" ? pc.blue : pc.green;\n return color(pc.italic(` ${icon} ${line.name}: ${line.description}`));\n }\n case \"separator\":\n return pc.dim(\"─\".repeat(60));\n default:\n return \"\";\n }\n}\n\n/**\n * Render a telemetry log entry to an ANSI string, or null to suppress.\n *\n * Formats `generation` entries with model name, token counts, cost, and duration;\n * `span_end` entries for `tool_call` and `agent_turn` kinds; and `trace_start` /\n * `trace_end` lifecycle entries. All output is styled dim for visual de-emphasis.\n * Returns `null` for entry kinds that should not appear in the log panel.\n *\n * @param entry - The structured telemetry event to render.\n * @returns Dim ANSI string, or `null` if the entry should be suppressed.\n *\n * @docLink packages/tui/concepts#repl-renderer\n */\nexport function renderLog(entry: TelemetryLogEntry): string | null {\n switch (entry.kind) {\n case \"generation\": {\n const tokens = `${entry.inputTokens}↑ ${entry.outputTokens}↓`;\n const cost = entry.costUsd > 0 ? ` $${entry.costUsd.toFixed(4)}` : \"\";\n const dur = entry.durationMs > 0 ? ` ${(entry.durationMs / 1000).toFixed(1)}s` : \"\";\n return pc.dim(`[gen] ${entry.model} ${tokens}${cost}${dur}`);\n }\n case \"span_end\":\n if (entry.spanKind === \"tool_call\") {\n return pc.dim(`[tool] ${entry.name} ${entry.status} ${entry.durationMs}ms`);\n }\n if (entry.spanKind === \"agent_turn\") {\n return pc.dim(`[turn] ${entry.name} ${(entry.durationMs / 1000).toFixed(1)}s`);\n }\n return null;\n case \"trace_start\":\n return pc.dim(`[trace] ${entry.name} started`);\n case \"trace_end\":\n return pc.dim(`[trace] done ${(entry.durationMs / 1000).toFixed(1)}s`);\n default:\n return null;\n }\n}\n","/**\n * Slim event bridge: maps AgentDriver events to rendered console lines.\n * No React, no ink, no UI state — just event → string → callback.\n */\n\nimport type { AgentEvent } from \"@skaile/workspaces/bridge\";\nimport type { AgentSession } from \"@skaile/workspaces/runner\";\nimport type { OutputLine, SessionState } from \"@skaile/workspaces\";\nimport { renderLine, renderLog } from \"./repl-renderer.js\";\nimport type { TelemetryLogEntry } from \"./telemetry.js\";\n\n/**\n * Handle returned by {@link createReplSession} for controlling an active REPL session.\n *\n * `state` reflects the current lifecycle state (`idle`, `active`, or `stopped`).\n * Call `send(text)` to forward a user message to the agent driver; the state\n * transitions to `active` until the driver emits `agent_end`. Call `stop()` to\n * terminate the driver and dispose of the underlying agent session.\n *\n * @docLink packages/tui/concepts#repl-session\n */\nexport interface ReplSessionHandle {\n readonly state: SessionState;\n send(text: string): void;\n stop(): void;\n}\n\n/**\n * Options for {@link createReplSession}.\n *\n * @param session - The agent session returned by `createAgentSession`.\n * @param onLine - Callback invoked with an ANSI-rendered string for each output line.\n * @param onLog - Callback invoked with a log string for each telemetry event (if verbose).\n * @param onStateChange - Callback invoked whenever the session state changes.\n *\n * @docLink packages/tui/concepts#repl-session\n */\nexport interface CreateReplSessionOpts {\n session: AgentSession;\n onLine?: (line: string) => void;\n onLog?: (line: string) => void;\n onStateChange?: (state: SessionState) => void;\n}\n\n/**\n * Create a slim event bridge that maps `AgentEvent` stream to rendered console lines.\n *\n * Subscribes to `agent-event` on the session driver and converts each event type\n * (`message_update`, `tool_call`, `error`, `agent_end`, `turn_end`, `subagent`) to\n * an `OutputLine`, renders it via {@link renderLine}, and forwards the string to\n * `opts.onLine`. Text content is buffered internally and flushed line-by-line as\n * newlines arrive. Returns a {@link ReplSessionHandle} for sending messages and\n * stopping the session.\n *\n * @param opts - Session, output callbacks, and state-change hook.\n * @returns Handle for sending messages and observing session state.\n *\n * @docLink packages/tui/concepts#repl-session\n */\nexport function createReplSession(opts: CreateReplSessionOpts): ReplSessionHandle {\n const { session, onLine, onLog, onStateChange } = opts;\n\n let state: SessionState = \"idle\";\n let textBuffer = \"\";\n\n function emit(outputLine: OutputLine) {\n const rendered = renderLine(outputLine);\n if (rendered) onLine?.(rendered);\n }\n\n function setState(s: SessionState) {\n state = s;\n onStateChange?.(s);\n }\n\n session.driver.on(\"agent-event\", (event: AgentEvent) => {\n switch (event.type) {\n case \"message_update\": {\n const delta = (event as any)._textDelta as string | undefined;\n if (delta) {\n textBuffer += delta;\n const lines = textBuffer.split(\"\\n\");\n if (lines.length > 1) {\n for (let i = 0; i < lines.length - 1; i++) {\n emit({ type: \"text\", content: lines[i]! });\n }\n textBuffer = lines[lines.length - 1]!;\n }\n }\n break;\n }\n\n case \"tool_call\": {\n const name = (event as any).tool?.name ?? (event as any).name ?? \"unknown\";\n emit({ type: \"tool\", name });\n break;\n }\n\n case \"error\": {\n const msg = (event as any).error ?? \"Unknown error\";\n emit({ type: \"error\", message: String(msg) });\n if ((event as any).fatal) setState(\"stopped\");\n break;\n }\n\n case \"agent_end\":\n case \"turn_end\": {\n if (textBuffer.trim()) {\n emit({ type: \"text\", content: textBuffer });\n }\n textBuffer = \"\";\n emit({ type: \"separator\" });\n if (event.type === \"agent_end\") setState(\"idle\");\n break;\n }\n\n case \"session_info\":\n break;\n\n default: {\n const raw = event as any;\n if (raw.type === \"subagent\") {\n const status = raw.status === \"finished\" ? \"finished\" : \"started\";\n emit({\n type: \"subagent\",\n name: raw.name ?? \"subagent\",\n status,\n description: raw.description ?? \"\",\n });\n }\n break;\n }\n }\n });\n\n return {\n get state() {\n return state;\n },\n\n send(text: string) {\n if (state === \"stopped\") return;\n setState(\"active\");\n textBuffer = \"\";\n session.driver.prompt(text).catch((err: Error) => {\n emit({ type: \"error\", message: err.message });\n setState(\"idle\");\n });\n },\n\n stop() {\n setState(\"stopped\");\n session.driver.kill();\n session.dispose();\n },\n };\n}\n\n/**\n * Create a telemetry sink that pipes {@link TelemetryLogEntry} events to the log callback.\n *\n * Wraps {@link renderLog} so that only displayable entries (generation, span_end for\n * tool/turn, trace lifecycle) are forwarded. Entries that `renderLog` returns `null`\n * for are silently suppressed. The returned function is used in `startRepl` to drain\n * buffered telemetry and to wire up live forwarding during the session.\n *\n * @param onLog - Callback invoked with an ANSI-rendered log string.\n * @returns A function that accepts a `TelemetryLogEntry` and routes it to `onLog`.\n *\n * @docLink packages/tui/concepts#repl-session\n */\nexport function createTelemetrySink(\n onLog: (line: string) => void,\n): (entry: TelemetryLogEntry) => void {\n return (entry) => {\n const text = renderLog(entry);\n if (text) onLog(text);\n };\n}\n","/**\n * Simple @clack-based agent REPL.\n * No React, no ink, no alt-screen — just a scrolling terminal.\n *\n * Design: clack's text() blocks until user submits, so agent output\n * flows naturally between prompts — no readline interleaving issues.\n * Loop: await text() → send → await idle → loop\n */\n\nimport * as p from \"@clack/prompts\";\nimport { resolve, join, basename, dirname, parse } from \"node:path\";\nimport { existsSync, readFileSync, statSync, readdirSync } from \"node:fs\";\nimport type { Dirent } from \"node:fs\";\nimport pc from \"picocolors\";\nimport { createAgentSession } from \"@skaile/workspaces/runner\";\nimport { resolveAgentDir, resolveSettings } from \"@skaile/workspaces/core\";\nimport { loadConnectorDeclarations } from \"@skaile/workspaces/connectors\";\nimport { TuiTelemetryProvider } from \"./telemetry.js\";\nimport type { TelemetryLogEntry } from \"./telemetry.js\";\nimport { createReplSession, createTelemetrySink } from \"./repl-session.js\";\n\nfunction findAiAssetsRoot(startDir: string): string | undefined {\n let current = resolve(startDir);\n const root = parse(current).root;\n while (current !== root) {\n const candidate = join(current, \"ai-assets\");\n try {\n if (statSync(candidate).isDirectory()) return candidate;\n } catch {}\n const parent = dirname(current);\n if (parent === current) break;\n current = parent;\n }\n return undefined;\n}\n\nfunction countSkills(projectDir: string): number {\n const aiAssetsRoot = findAiAssetsRoot(projectDir);\n if (!aiAssetsRoot) return 0;\n let count = 0;\n const walk = (dir: string) => {\n let entries: Dirent[];\n try {\n entries = readdirSync(dir, { withFileTypes: true });\n } catch {\n return;\n }\n if (entries.some((e) => e.isFile() && e.name === \"SKILL.md\")) {\n count++;\n return;\n }\n for (const e of entries) {\n if (e.isDirectory()) walk(join(dir, e.name));\n }\n };\n walk(aiAssetsRoot);\n return count;\n}\n\n/**\n * Options for {@link startRepl}.\n *\n * @param projectDir - Absolute path to the project root. Used to locate the agent dir, settings, and skill count.\n * @param cwd - Working directory passed to the agent process. Defaults to `projectDir`.\n * @param driver - Agent driver override (`\"omp\"` or `\"claude-sdk\"`). Falls back to settings resolution.\n * @param model - Model name passed to the agent driver.\n * @param provider - Provider name passed to the agent driver.\n * @param resume - When `true`, load the last session ID from `.skaile/last_session` and resume it.\n * @param resumeSessionId - Explicit session ID to resume. Takes precedence over `resume`.\n * @param verbose - When `true`, show telemetry log lines inline between prompts. Default: `false`.\n *\n * @docLink packages/tui/concepts#start-repl\n */\nexport interface ReplOptions {\n projectDir: string;\n cwd?: string;\n driver?: string;\n model?: string;\n provider?: string;\n resume?: boolean;\n resumeSessionId?: string;\n /** When true, show telemetry log lines inline. Default: false. */\n verbose?: boolean;\n}\n\n/**\n * Start the scrolling REPL for an interactive agent conversation.\n *\n * Initialises the agent session (including OMP extension injection when the driver is `omp`),\n * prints a banner with project metadata, then enters a `@clack/prompts` input loop.\n * Each iteration awaits user input, forwards it to the agent via {@link createReplSession},\n * and blocks until the agent signals `idle` or `stopped`. Slash commands (`/help`, `/log`,\n * `/quit`) are handled before the message reaches the agent.\n *\n * @param opts - Configuration for the REPL session.\n * @returns Resolves when the session ends (user quit or fatal error).\n *\n * @docLink packages/tui/concepts#start-repl\n */\nexport async function startRepl(opts: ReplOptions): Promise<void> {\n const projectDir = resolve(opts.projectDir);\n const agentCwd = opts.cwd ? resolve(opts.cwd) : projectDir;\n\n // ── OMP workspace extension injection ──────────────────────────────\n const settings = await resolveSettings(projectDir, { driver: opts.driver });\n const resolvedDriver = settings.driver ?? \"omp\";\n let ompCleanup: (() => void) | undefined;\n\n if (resolvedDriver === \"omp\") {\n const fsAsync = await import(\"node:fs/promises\");\n const pathMod = await import(\"node:path\");\n const { WorkspacePlugin } = await import(\"@skaile/workspaces/workspace-plugin\");\n\n const plugin = new WorkspacePlugin({ projectDir });\n const src = await plugin.buildOmpExtensionSource();\n const extPath = pathMod.default.join(agentCwd, \".omp\", \"extensions\", \"skaile.ts\");\n await fsAsync.default.mkdir(pathMod.default.dirname(extPath), { recursive: true });\n await fsAsync.default.writeFile(extPath, src);\n ompCleanup = () => {\n fsAsync.default.unlink(extPath).catch(() => {});\n };\n }\n\n // ── Session resume ─────────────────────────────────────────────────\n const SESSION_FILE = join(projectDir, \".skaile\", \"last_session\");\n let resumeSessionId = opts.resumeSessionId;\n if (!resumeSessionId && opts.resume) {\n try {\n if (existsSync(SESSION_FILE)) {\n resumeSessionId = readFileSync(SESSION_FILE, \"utf-8\").trim() || undefined;\n }\n } catch {}\n }\n\n // ── Telemetry ──────────────────────────────────────────────────────\n const telemetryBuffer: TelemetryLogEntry[] = [];\n const telemetry = new TuiTelemetryProvider((entry) => {\n telemetryBuffer.push(entry);\n });\n const trace = telemetry.startTrace({ name: \"skaile-repl\", kind: \"chat_session\" });\n\n // ── Create agent session ───────────────────────────────────────────\n const agentDir = resolveAgentDir(projectDir) ?? undefined;\n const session = await createAgentSession({\n projectDir,\n cwd: agentCwd !== projectDir ? agentCwd : undefined,\n agentDir,\n driver: opts.driver ?? resolvedDriver,\n model: opts.model,\n provider: opts.provider,\n resumeSessionId,\n telemetry,\n trace,\n onLog: () => {},\n });\n\n await session.driver.start();\n\n // ── Output + state tracking ────────────────────────────────────────\n let showLog = opts.verbose ?? false;\n let idleResolve: (() => void) | undefined;\n\n const write = (line: string) => {\n p.log.message(line);\n };\n\n const writeLog = (line: string) => {\n if (showLog) p.log.step(line);\n };\n\n // ── Create REPL session ────────────────────────────────────────────\n const replSession = createReplSession({\n session,\n onLine: write,\n onLog: writeLog,\n onStateChange: (state) => {\n if (state === \"idle\" || state === \"stopped\") {\n idleResolve?.();\n }\n },\n });\n\n // Drain buffered telemetry\n const sink = createTelemetrySink(writeLog);\n for (const entry of telemetryBuffer) sink(entry);\n telemetryBuffer.length = 0;\n\n // ── Banner ─────────────────────────────────────────────────────────\n const displayModel = session.model ?? opts.model ?? \"default\";\n const displayDriver = session.driverType ?? resolvedDriver;\n\n const skillCount = countSkills(projectDir);\n let connectorCount = 0;\n try {\n connectorCount = loadConnectorDeclarations(projectDir).length;\n } catch {}\n const agentName = agentDir ? basename(agentDir) : \"(none)\";\n\n p.intro(`${pc.bold(\"skaile repl\")} ${pc.dim(`— ${displayDriver} / ${displayModel}`)}`);\n p.log.info(pc.dim(`Project: ${projectDir}`));\n p.log.info(pc.dim(`Agent: ${agentName} · ${skillCount} skills · ${connectorCount} connectors`));\n if (resumeSessionId) p.log.info(pc.dim(`Resumed: ${resumeSessionId.slice(0, 12)}...`));\n p.log.info(pc.dim(\"Type /help for commands, Ctrl+C to quit.\"));\n\n // ── REPL loop ──────────────────────────────────────────────────────\n function shutdown() {\n replSession.stop();\n telemetry.endTrace(trace, { status: \"ok\" });\n void telemetry.shutdown();\n ompCleanup?.();\n p.outro(\"Bye.\");\n process.exit(0);\n }\n\n process.on(\"SIGINT\", shutdown);\n process.on(\"SIGTERM\", shutdown);\n\n while (replSession.state !== \"stopped\") {\n const input = await p.text({\n message: pc.gray(\">>>\"),\n placeholder: \"\",\n });\n\n if (p.isCancel(input)) {\n shutdown();\n return;\n }\n\n const trimmed = (input as string).trim();\n if (!trimmed) continue;\n\n if (trimmed === \"/quit\" || trimmed === \"/q\") {\n shutdown();\n return;\n }\n if (trimmed === \"/help\" || trimmed === \"/h\" || trimmed === \"/?\") {\n p.log.info(\n [\n \" /help, /h — this help\",\n \" /log — toggle verbose log output\",\n \" /quit, /q — exit\",\n \" Ctrl+C — exit\",\n ].join(\"\\n\"),\n );\n continue;\n }\n if (trimmed === \"/log\") {\n showLog = !showLog;\n p.log.info(`Log output: ${showLog ? \"on\" : \"off\"}`);\n continue;\n }\n\n const idlePromise = new Promise<void>((resolve) => {\n idleResolve = resolve;\n });\n replSession.send(trimmed);\n await idlePromise;\n }\n\n shutdown();\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["../../tui/src/telemetry.ts","../../tui/src/repl-renderer.ts","../../tui/src/repl-session.ts","../../tui/src/repl.ts"],"names":["text","pc","resolve"],"mappings":"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","file":"index.js","sourcesContent":["/**\n * Local telemetry sink that emits structured events to the TUI log panel.\n *\n * Implements `TelemetryProvider` so it can be injected into `createAgentSession`\n * without any HTTP or OpenTelemetry overhead. Instead of exporting spans over a\n * network, it converts each lifecycle event (trace start/end, span start/end,\n * generation, metric) into a {@link TelemetryLogEntry} and forwards it via the\n * `onEvent` callback. The REPL uses this to optionally display timing and token\n * cost inline when `--verbose` is active.\n *\n * @docLink packages/tui/concepts#tui-telemetry-provider\n */\n\nimport { randomUUID } from \"node:crypto\";\nimport type {\n Attributes,\n GenerationEvent,\n Span,\n SpanKind,\n SpanOptions,\n SpanResult,\n TelemetryProvider,\n Trace,\n TraceOptions,\n} from \"@skaile/workspaces/telemetry\";\n\n// ── Telemetry log entry types ────────────────────────────────────────────────\n\n/**\n * A structured telemetry event emitted by {@link TuiTelemetryProvider}.\n *\n * Discriminated union over `kind`. The TUI renders a subset of these (generation,\n * span_end for tool/turn, trace lifecycle) and suppresses the rest. Used as input\n * to {@link formatTelemetryEntry} and {@link renderLog}.\n *\n * @docLink packages/tui/concepts#tui-telemetry-provider\n */\nexport type TelemetryLogEntry =\n | { kind: \"trace_start\"; traceId: string; name: string; traceKind: string }\n | { kind: \"trace_end\"; traceId: string; status: string; durationMs: number }\n | { kind: \"span_start\"; spanId: string; name: string; spanKind: SpanKind }\n | {\n kind: \"span_end\";\n spanId: string;\n name: string;\n spanKind: SpanKind;\n status: string;\n durationMs: number;\n }\n | {\n kind: \"generation\";\n model: string;\n inputTokens: number;\n outputTokens: number;\n costUsd: number;\n durationMs: number;\n }\n | { kind: \"metric\"; name: string; value: number };\n\n// ── Internal span tracking ───────────────────────────────────────────────────\n\ninterface SpanRecord {\n spanId: string;\n traceId: string;\n name: string;\n spanKind: SpanKind;\n startTime: number;\n}\n\n// ── Provider ─────────────────────────────────────────────────────────────────\n\nexport class TuiTelemetryProvider implements TelemetryProvider {\n private readonly onEvent: (entry: TelemetryLogEntry) => void;\n private readonly spans = new Map<string, SpanRecord>();\n private readonly traces = new Map<string, { name: string; startTime: number }>();\n\n constructor(onEvent: (entry: TelemetryLogEntry) => void) {\n this.onEvent = onEvent;\n }\n\n startTrace(opts: TraceOptions): Trace {\n const traceId = randomUUID().replace(/-/g, \"\");\n const rootSpan: Span = { spanId: randomUUID().slice(0, 16), traceId };\n\n this.traces.set(traceId, { name: opts.name, startTime: Date.now() });\n this.onEvent({ kind: \"trace_start\", traceId, name: opts.name, traceKind: opts.kind });\n\n return { traceId, rootSpan };\n }\n\n endTrace(trace: Trace, result?: SpanResult): void {\n const record = this.traces.get(trace.traceId);\n if (record) {\n const durationMs = Date.now() - record.startTime;\n this.onEvent({\n kind: \"trace_end\",\n traceId: trace.traceId,\n status: result?.status ?? \"ok\",\n durationMs,\n });\n this.traces.delete(trace.traceId);\n }\n }\n\n startSpan(parent: Trace | Span, opts: SpanOptions): Span {\n const spanId = randomUUID().slice(0, 16);\n const traceId = parent.traceId;\n const span: Span = { spanId, traceId };\n\n this.spans.set(spanId, {\n spanId,\n traceId,\n name: opts.name,\n spanKind: opts.kind,\n startTime: Date.now(),\n });\n\n this.onEvent({ kind: \"span_start\", spanId, name: opts.name, spanKind: opts.kind });\n return span;\n }\n\n endSpan(span: Span, result?: SpanResult): void {\n const record = this.spans.get(span.spanId);\n if (record) {\n const durationMs = Date.now() - record.startTime;\n this.onEvent({\n kind: \"span_end\",\n spanId: span.spanId,\n name: record.name,\n spanKind: record.spanKind,\n status: result?.status ?? \"ok\",\n durationMs,\n });\n this.spans.delete(span.spanId);\n }\n }\n\n addEvent(_span: Span, _name: string, _attrs?: Attributes): void {\n // Silently ignored — events are not surfaced in TUI\n }\n\n logGeneration(_span: Span, generation: GenerationEvent): void {\n this.onEvent({\n kind: \"generation\",\n model: generation.model,\n inputTokens: generation.inputTokens ?? 0,\n outputTokens: generation.outputTokens ?? 0,\n costUsd: generation.costUsd ?? 0,\n durationMs: generation.durationMs,\n });\n }\n\n recordMetric(name: string, value: number, _tags?: Record<string, string>): void {\n this.onEvent({ kind: \"metric\", name, value });\n }\n\n async flush(): Promise<void> {}\n async shutdown(): Promise<void> {\n this.spans.clear();\n this.traces.clear();\n }\n}\n\n// ── Log formatting ───────────────────────────────────────────────────────────\n\n/**\n * Format a {@link TelemetryLogEntry} into a human-readable string for the log panel.\n *\n * Produces plain (no ANSI) strings suitable for structured logging or non-terminal\n * output. The format mirrors {@link renderLog} but without colour codes: generation\n * entries include model, token counts, cost, and duration; span_end entries for\n * `tool_call` and `agent_turn` kinds include name, status, and duration; trace\n * lifecycle entries include name and elapsed time. Returns `null` for entry kinds\n * that should not be displayed.\n *\n * @param entry - The structured telemetry event to format.\n * @returns Human-readable string, or `null` if the entry should be suppressed.\n *\n * @docLink packages/tui/concepts#tui-telemetry-provider\n */\nexport function formatTelemetryEntry(entry: TelemetryLogEntry): string | null {\n switch (entry.kind) {\n case \"generation\": {\n const tokens = `${entry.inputTokens}↑ ${entry.outputTokens}↓`;\n const cost = entry.costUsd > 0 ? ` $${entry.costUsd.toFixed(4)}` : \"\";\n const dur = entry.durationMs > 0 ? ` ${(entry.durationMs / 1000).toFixed(1)}s` : \"\";\n return `[gen] ${entry.model} ${tokens}${cost}${dur}`;\n }\n case \"span_end\":\n if (entry.spanKind === \"tool_call\") {\n return `[tool] ${entry.name} ${entry.status} ${entry.durationMs}ms`;\n }\n if (entry.spanKind === \"agent_turn\") {\n return `[turn] ${entry.name} ${(entry.durationMs / 1000).toFixed(1)}s`;\n }\n return null;\n case \"trace_start\":\n return `[trace] ${entry.name} started`;\n case \"trace_end\":\n return `[trace] done ${(entry.durationMs / 1000).toFixed(1)}s`;\n default:\n return null;\n }\n}\n","import pc from \"picocolors\";\nimport type { OutputLine } from \"@skaile/workspaces\";\nimport type { TelemetryLogEntry } from \"./telemetry.js\";\n\n/**\n * Render a single OutputLine to an ANSI-colored string for terminal display.\n *\n * Each `OutputLine` variant is mapped to a distinct colour: user input (cyan/bold),\n * agent text (plain), tool calls (blue italic), questions (yellow), errors (red),\n * status/system messages (dim italic), subagent lifecycle (blue/green italic), and\n * separator lines (dim dashes). Returns an empty string for unrecognised variants.\n *\n * @param line - The typed output line to render.\n * @returns ANSI-coloured string ready for terminal output.\n *\n * @docLink packages/tui/concepts#repl-renderer\n */\nexport function renderLine(line: OutputLine): string {\n switch (line.type) {\n case \"user\":\n return pc.cyan(pc.bold(`> ${line.content}`));\n case \"text\":\n return line.content;\n case \"tool\":\n return pc.blue(pc.italic(` Running: \\`${line.name}\\`...`));\n case \"question\":\n return pc.yellow(`?? ${line.text}\\n Reply below.`);\n case \"error\":\n return pc.red(`Error: ${line.message}`);\n case \"status\":\n return pc.dim(pc.italic(`${line.phase}...`));\n case \"system\":\n return pc.dim(pc.italic(line.message));\n case \"subagent\": {\n const icon = line.status === \"started\" ? \"▶\" : \"✓\";\n const color = line.status === \"started\" ? pc.blue : pc.green;\n return color(pc.italic(` ${icon} ${line.name}: ${line.description}`));\n }\n case \"separator\":\n return pc.dim(\"─\".repeat(60));\n default:\n return \"\";\n }\n}\n\n/**\n * Render a telemetry log entry to an ANSI string, or null to suppress.\n *\n * Formats `generation` entries with model name, token counts, cost, and duration;\n * `span_end` entries for `tool_call` and `agent_turn` kinds; and `trace_start` /\n * `trace_end` lifecycle entries. All output is styled dim for visual de-emphasis.\n * Returns `null` for entry kinds that should not appear in the log panel.\n *\n * @param entry - The structured telemetry event to render.\n * @returns Dim ANSI string, or `null` if the entry should be suppressed.\n *\n * @docLink packages/tui/concepts#repl-renderer\n */\nexport function renderLog(entry: TelemetryLogEntry): string | null {\n switch (entry.kind) {\n case \"generation\": {\n const tokens = `${entry.inputTokens}↑ ${entry.outputTokens}↓`;\n const cost = entry.costUsd > 0 ? ` $${entry.costUsd.toFixed(4)}` : \"\";\n const dur = entry.durationMs > 0 ? ` ${(entry.durationMs / 1000).toFixed(1)}s` : \"\";\n return pc.dim(`[gen] ${entry.model} ${tokens}${cost}${dur}`);\n }\n case \"span_end\":\n if (entry.spanKind === \"tool_call\") {\n return pc.dim(`[tool] ${entry.name} ${entry.status} ${entry.durationMs}ms`);\n }\n if (entry.spanKind === \"agent_turn\") {\n return pc.dim(`[turn] ${entry.name} ${(entry.durationMs / 1000).toFixed(1)}s`);\n }\n return null;\n case \"trace_start\":\n return pc.dim(`[trace] ${entry.name} started`);\n case \"trace_end\":\n return pc.dim(`[trace] done ${(entry.durationMs / 1000).toFixed(1)}s`);\n default:\n return null;\n }\n}\n","/**\n * Slim event bridge: maps AgentDriver events to rendered console lines.\n * No React, no ink, no UI state — just event → string → callback.\n */\n\nimport type { AgentEvent } from \"@skaile/workspaces/bridge\";\nimport type { AgentSession } from \"@skaile/workspaces/runner\";\nimport type { OutputLine, SessionState } from \"@skaile/workspaces\";\nimport { renderLine, renderLog } from \"./repl-renderer.js\";\nimport type { TelemetryLogEntry } from \"./telemetry.js\";\n\n/**\n * Handle returned by {@link createReplSession} for controlling an active REPL session.\n *\n * `state` reflects the current lifecycle state (`idle`, `active`, or `stopped`).\n * Call `send(text)` to forward a user message to the agent driver; the state\n * transitions to `active` until the driver emits `agent_end`. Call `stop()` to\n * terminate the driver and dispose of the underlying agent session.\n *\n * @docLink packages/tui/concepts#repl-session\n */\nexport interface ReplSessionHandle {\n readonly state: SessionState;\n send(text: string): void;\n stop(): void;\n}\n\n/**\n * Options for {@link createReplSession}.\n *\n * @param session - The agent session returned by `createAgentSession`.\n * @param onLine - Callback invoked with an ANSI-rendered string for each output line.\n * @param onLog - Callback invoked with a log string for each telemetry event (if verbose).\n * @param onStateChange - Callback invoked whenever the session state changes.\n *\n * @docLink packages/tui/concepts#repl-session\n */\nexport interface CreateReplSessionOpts {\n session: AgentSession;\n onLine?: (line: string) => void;\n onLog?: (line: string) => void;\n onStateChange?: (state: SessionState) => void;\n}\n\n/**\n * Create a slim event bridge that maps `AgentEvent` stream to rendered console lines.\n *\n * Subscribes to `agent-event` on the session driver and converts each event type\n * (`message_update`, `tool_call`, `error`, `agent_end`, `turn_end`, `subagent`) to\n * an `OutputLine`, renders it via {@link renderLine}, and forwards the string to\n * `opts.onLine`. Text content is buffered internally and flushed line-by-line as\n * newlines arrive. Returns a {@link ReplSessionHandle} for sending messages and\n * stopping the session.\n *\n * @param opts - Session, output callbacks, and state-change hook.\n * @returns Handle for sending messages and observing session state.\n *\n * @docLink packages/tui/concepts#repl-session\n */\nexport function createReplSession(opts: CreateReplSessionOpts): ReplSessionHandle {\n const { session, onLine, onLog, onStateChange } = opts;\n\n let state: SessionState = \"idle\";\n let textBuffer = \"\";\n\n function emit(outputLine: OutputLine) {\n const rendered = renderLine(outputLine);\n if (rendered) onLine?.(rendered);\n }\n\n function setState(s: SessionState) {\n state = s;\n onStateChange?.(s);\n }\n\n session.driver.on(\"agent-event\", (event: AgentEvent) => {\n switch (event.type) {\n case \"message_update\": {\n const delta = (event as any)._textDelta as string | undefined;\n if (delta) {\n textBuffer += delta;\n const lines = textBuffer.split(\"\\n\");\n if (lines.length > 1) {\n for (let i = 0; i < lines.length - 1; i++) {\n emit({ type: \"text\", content: lines[i]! });\n }\n textBuffer = lines[lines.length - 1]!;\n }\n }\n break;\n }\n\n case \"tool_call\": {\n const name = (event as any).tool?.name ?? (event as any).name ?? \"unknown\";\n emit({ type: \"tool\", name });\n break;\n }\n\n case \"error\": {\n const msg = (event as any).error ?? \"Unknown error\";\n emit({ type: \"error\", message: String(msg) });\n if ((event as any).fatal) setState(\"stopped\");\n break;\n }\n\n case \"agent_end\":\n case \"turn_end\": {\n if (textBuffer.trim()) {\n emit({ type: \"text\", content: textBuffer });\n }\n textBuffer = \"\";\n emit({ type: \"separator\" });\n if (event.type === \"agent_end\") setState(\"idle\");\n break;\n }\n\n case \"session_info\":\n break;\n\n default: {\n const raw = event as any;\n if (raw.type === \"subagent\") {\n const status = raw.status === \"finished\" ? \"finished\" : \"started\";\n emit({\n type: \"subagent\",\n name: raw.name ?? \"subagent\",\n status,\n description: raw.description ?? \"\",\n });\n }\n break;\n }\n }\n });\n\n return {\n get state() {\n return state;\n },\n\n send(text: string) {\n if (state === \"stopped\") return;\n setState(\"active\");\n textBuffer = \"\";\n session.driver.prompt(text).catch((err: Error) => {\n emit({ type: \"error\", message: err.message });\n setState(\"idle\");\n });\n },\n\n stop() {\n setState(\"stopped\");\n session.driver.kill();\n session.dispose();\n },\n };\n}\n\n/**\n * Create a telemetry sink that pipes {@link TelemetryLogEntry} events to the log callback.\n *\n * Wraps {@link renderLog} so that only displayable entries (generation, span_end for\n * tool/turn, trace lifecycle) are forwarded. Entries that `renderLog` returns `null`\n * for are silently suppressed. The returned function is used in `startRepl` to drain\n * buffered telemetry and to wire up live forwarding during the session.\n *\n * @param onLog - Callback invoked with an ANSI-rendered log string.\n * @returns A function that accepts a `TelemetryLogEntry` and routes it to `onLog`.\n *\n * @docLink packages/tui/concepts#repl-session\n */\nexport function createTelemetrySink(\n onLog: (line: string) => void,\n): (entry: TelemetryLogEntry) => void {\n return (entry) => {\n const text = renderLog(entry);\n if (text) onLog(text);\n };\n}\n","/**\n * Simple @clack-based agent REPL.\n * No React, no ink, no alt-screen — just a scrolling terminal.\n *\n * Design: clack's text() blocks until user submits, so agent output\n * flows naturally between prompts — no readline interleaving issues.\n * Loop: await text() → send → await idle → loop\n */\n\nimport * as p from \"@clack/prompts\";\nimport { resolve, join, basename, dirname, parse } from \"node:path\";\nimport { existsSync, readFileSync, statSync, readdirSync } from \"node:fs\";\nimport type { Dirent } from \"node:fs\";\nimport pc from \"picocolors\";\nimport { createAgentSession } from \"@skaile/workspaces/runner\";\nimport { resolveAgentDir, resolveSettings } from \"@skaile/workspaces/core\";\nimport { loadConnectorDeclarations } from \"@skaile/workspaces/connectors\";\nimport { TuiTelemetryProvider } from \"./telemetry.js\";\nimport type { TelemetryLogEntry } from \"./telemetry.js\";\nimport { createReplSession, createTelemetrySink } from \"./repl-session.js\";\n\nfunction findAiAssetsRoot(startDir: string): string | undefined {\n let current = resolve(startDir);\n const root = parse(current).root;\n while (current !== root) {\n const candidate = join(current, \"ai-assets\");\n try {\n if (statSync(candidate).isDirectory()) return candidate;\n } catch {}\n const parent = dirname(current);\n if (parent === current) break;\n current = parent;\n }\n return undefined;\n}\n\nfunction countSkills(projectDir: string): number {\n const aiAssetsRoot = findAiAssetsRoot(projectDir);\n if (!aiAssetsRoot) return 0;\n let count = 0;\n const walk = (dir: string) => {\n let entries: Dirent[];\n try {\n entries = readdirSync(dir, { withFileTypes: true });\n } catch {\n return;\n }\n if (entries.some((e) => e.isFile() && e.name === \"SKILL.md\")) {\n count++;\n return;\n }\n for (const e of entries) {\n if (e.isDirectory()) walk(join(dir, e.name));\n }\n };\n walk(aiAssetsRoot);\n return count;\n}\n\n/**\n * Options for {@link startRepl}.\n *\n * @param projectDir - Absolute path to the project root. Used to locate the agent dir, settings, and skill count.\n * @param cwd - Working directory passed to the agent process. Defaults to `projectDir`.\n * @param driver - Agent driver override (`\"omp\"` or `\"claude-sdk\"`). Falls back to settings resolution.\n * @param model - Model name passed to the agent driver.\n * @param provider - Provider name passed to the agent driver.\n * @param resume - When `true`, load the last session ID from `.skaile/last_session` and resume it.\n * @param resumeSessionId - Explicit session ID to resume. Takes precedence over `resume`.\n * @param verbose - When `true`, show telemetry log lines inline between prompts. Default: `false`.\n *\n * @docLink packages/tui/concepts#start-repl\n */\nexport interface ReplOptions {\n projectDir: string;\n cwd?: string;\n driver?: string;\n model?: string;\n provider?: string;\n resume?: boolean;\n resumeSessionId?: string;\n /** When true, show telemetry log lines inline. Default: false. */\n verbose?: boolean;\n}\n\n/**\n * Start the scrolling REPL for an interactive agent conversation.\n *\n * Initialises the agent session (including OMP extension injection when the driver is `omp`),\n * prints a banner with project metadata, then enters a `@clack/prompts` input loop.\n * Each iteration awaits user input, forwards it to the agent via {@link createReplSession},\n * and blocks until the agent signals `idle` or `stopped`. Slash commands (`/help`, `/log`,\n * `/quit`) are handled before the message reaches the agent.\n *\n * @param opts - Configuration for the REPL session.\n * @returns Resolves when the session ends (user quit or fatal error).\n *\n * @docLink packages/tui/concepts#start-repl\n */\nexport async function startRepl(opts: ReplOptions): Promise<void> {\n const projectDir = resolve(opts.projectDir);\n const agentCwd = opts.cwd ? resolve(opts.cwd) : projectDir;\n\n // ── OMP workspace extension injection ──────────────────────────────\n const settings = await resolveSettings(projectDir, { driver: opts.driver });\n const resolvedDriver = settings.driver ?? \"omp\";\n let ompCleanup: (() => void) | undefined;\n\n if (resolvedDriver === \"omp\") {\n const fsAsync = await import(\"node:fs/promises\");\n const pathMod = await import(\"node:path\");\n const { WorkspacePlugin } = await import(\"@skaile/workspaces/workspace-plugin\");\n\n const plugin = new WorkspacePlugin({ projectDir });\n const src = await plugin.buildOmpExtensionSource();\n const extPath = pathMod.default.join(agentCwd, \".omp\", \"extensions\", \"skaile.ts\");\n await fsAsync.default.mkdir(pathMod.default.dirname(extPath), { recursive: true });\n await fsAsync.default.writeFile(extPath, src);\n ompCleanup = () => {\n fsAsync.default.unlink(extPath).catch(() => {});\n };\n }\n\n // ── Session resume ─────────────────────────────────────────────────\n const SESSION_FILE = join(projectDir, \".skaile\", \"last_session\");\n let resumeSessionId = opts.resumeSessionId;\n if (!resumeSessionId && opts.resume) {\n try {\n if (existsSync(SESSION_FILE)) {\n resumeSessionId = readFileSync(SESSION_FILE, \"utf-8\").trim() || undefined;\n }\n } catch {}\n }\n\n // ── Telemetry ──────────────────────────────────────────────────────\n const telemetryBuffer: TelemetryLogEntry[] = [];\n const telemetry = new TuiTelemetryProvider((entry) => {\n telemetryBuffer.push(entry);\n });\n const trace = telemetry.startTrace({ name: \"skaile-repl\", kind: \"chat_session\" });\n\n // ── Create agent session ───────────────────────────────────────────\n const agentDir = resolveAgentDir(projectDir) ?? undefined;\n const session = await createAgentSession({\n projectDir,\n cwd: agentCwd !== projectDir ? agentCwd : undefined,\n agentDir,\n driver: opts.driver ?? resolvedDriver,\n model: opts.model,\n provider: opts.provider,\n resumeSessionId,\n telemetry,\n trace,\n onLog: () => {},\n });\n\n await session.driver.start();\n\n // ── Output + state tracking ────────────────────────────────────────\n let showLog = opts.verbose ?? false;\n let idleResolve: (() => void) | undefined;\n\n const write = (line: string) => {\n p.log.message(line);\n };\n\n const writeLog = (line: string) => {\n if (showLog) p.log.step(line);\n };\n\n // ── Create REPL session ────────────────────────────────────────────\n const replSession = createReplSession({\n session,\n onLine: write,\n onLog: writeLog,\n onStateChange: (state) => {\n if (state === \"idle\" || state === \"stopped\") {\n idleResolve?.();\n }\n },\n });\n\n // Drain buffered telemetry\n const sink = createTelemetrySink(writeLog);\n for (const entry of telemetryBuffer) sink(entry);\n telemetryBuffer.length = 0;\n\n // ── Banner ─────────────────────────────────────────────────────────\n const displayModel = session.model ?? opts.model ?? \"default\";\n const displayDriver = session.driverType ?? resolvedDriver;\n\n const skillCount = countSkills(projectDir);\n let connectorCount = 0;\n try {\n connectorCount = loadConnectorDeclarations(projectDir).length;\n } catch {}\n const agentName = agentDir ? basename(agentDir) : \"(none)\";\n\n p.intro(`${pc.bold(\"skaile repl\")} ${pc.dim(`— ${displayDriver} / ${displayModel}`)}`);\n p.log.info(pc.dim(`Project: ${projectDir}`));\n p.log.info(pc.dim(`Agent: ${agentName} · ${skillCount} skills · ${connectorCount} connectors`));\n if (resumeSessionId) p.log.info(pc.dim(`Resumed: ${resumeSessionId.slice(0, 12)}...`));\n p.log.info(pc.dim(\"Type /help for commands, Ctrl+C to quit.\"));\n\n // ── REPL loop ──────────────────────────────────────────────────────\n function shutdown() {\n replSession.stop();\n telemetry.endTrace(trace, { status: \"ok\" });\n void telemetry.shutdown();\n ompCleanup?.();\n p.outro(\"Bye.\");\n process.exit(0);\n }\n\n process.on(\"SIGINT\", shutdown);\n process.on(\"SIGTERM\", shutdown);\n\n while (replSession.state !== \"stopped\") {\n const input = await p.text({\n message: pc.gray(\">>>\"),\n placeholder: \"\",\n });\n\n if (p.isCancel(input)) {\n shutdown();\n return;\n }\n\n const trimmed = (input as string).trim();\n if (!trimmed) continue;\n\n if (trimmed === \"/quit\" || trimmed === \"/q\") {\n shutdown();\n return;\n }\n if (trimmed === \"/help\" || trimmed === \"/h\" || trimmed === \"/?\") {\n p.log.info(\n [\n \" /help, /h — this help\",\n \" /log — toggle verbose log output\",\n \" /quit, /q — exit\",\n \" Ctrl+C — exit\",\n ].join(\"\\n\"),\n );\n continue;\n }\n if (trimmed === \"/log\") {\n showLog = !showLog;\n p.log.info(`Log output: ${showLog ? \"on\" : \"off\"}`);\n continue;\n }\n\n const idlePromise = new Promise<void>((resolve) => {\n idleResolve = resolve;\n });\n replSession.send(trimmed);\n await idlePromise;\n }\n\n shutdown();\n}\n"]}
|
package/dist/types/index.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
export { MENTION_GROUPS, PROTOCOL_VERSION, PROTOCOL_VERSION_STRING, QUICK_REACTIONS, formatVersion, isRenderCapability, isUserInvokable, parseVersion } from '../chunk-
|
|
1
|
+
export { MENTION_GROUPS, PROTOCOL_VERSION, PROTOCOL_VERSION_STRING, QUICK_REACTIONS, formatVersion, isRenderCapability, isUserInvokable, parseVersion } from '../chunk-TDSRLMDB.js';
|
|
2
2
|
import '../chunk-NSBPE2FW.js';
|
|
3
3
|
//# sourceMappingURL=index.js.map
|
|
4
4
|
//# sourceMappingURL=index.js.map
|
|
@@ -196,6 +196,19 @@ export type Capability = {
|
|
|
196
196
|
audience?: CapabilityAudience[];
|
|
197
197
|
/** Appended to the system prompt's `<CAPABILITIES>` section. Use for usage hints the LLM should always see. */
|
|
198
198
|
promptFragment?: string;
|
|
199
|
+
/**
|
|
200
|
+
* Per-capability override for how long the runner waits on the
|
|
201
|
+
* `capability_result` round-trip before timing out. When omitted the
|
|
202
|
+
* runner applies its default (`DEFAULT_CAPABILITY_CALL_TIMEOUT_MS`, 60s).
|
|
203
|
+
*
|
|
204
|
+
* Set this for capabilities that legitimately block far longer than a
|
|
205
|
+
* normal tool call — e.g. `platform.ask_session` suspends the caller's
|
|
206
|
+
* turn until a peer session answers, which can take minutes.
|
|
207
|
+
*
|
|
208
|
+
* @category Capabilities
|
|
209
|
+
* @since 3.3.0
|
|
210
|
+
*/
|
|
211
|
+
callTimeoutMs?: number;
|
|
199
212
|
/** Present iff this is a render capability — see {@link RenderCapability}. */
|
|
200
213
|
render?: RenderSpec;
|
|
201
214
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"capabilities.d.ts","sourceRoot":"","sources":["../../../types/src/capabilities.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"capabilities.d.ts","sourceRoot":"","sources":["../../../types/src/capabilities.ts"],"names":[],"mappings":"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"}
|
|
@@ -17,7 +17,7 @@ import type { LogEntry } from "./logging.js";
|
|
|
17
17
|
*
|
|
18
18
|
* @docLink packages/types/events#agent-event
|
|
19
19
|
*/
|
|
20
|
-
export type AgentEvent = TextEvent | ToolCallEvent | ToolResultEvent | QuestionEvent | QuestionReplyEvent | ErrorEvent | StatusEvent | DevServerEvent | FileChangeEvent | SubagentEvent | FinishedEvent | StateChangedEvent | HandoffEvent | ConnectorResponseEvent | ConnectorQueryResponseEvent | ConnectorsAvailableEvent | LifecycleCompleteEvent | TypingEvent | UserMessageEvent | SyncStatusEvent | SecretsReadyEvent | ConfiguredEvent | MountMountedEvent | MountUnmountedEvent | MountChangedEvent | MountSyncStatusEvent | DebugResultEvent | LogEntryEvent | ValidationWarningEvent | SkillsChangedEvent | CommandsAvailableEvent | FlowBreadcrumbEvent | SessionInfoEvent | ReactionAddedEvent | ReactionRemovedEvent | ResourceStatusEvent | ConnectorStatusEvent | CustomMessageEvent | SnapshotEvent | CompactionAttemptEvent | ResumeAttemptedEvent | ResumeFailedEvent | CapabilityRegisterEvent | CapabilityDeregisterEvent | CapabilityInvokedEvent | RenderInvokedEvent | ProtocolInfoEvent | IncompatibleProtocolEvent | SessionInitAckEvent | SessionInitMismatchEvent | SystemPromptComposedEvent;
|
|
20
|
+
export type AgentEvent = TextEvent | ToolCallEvent | ToolResultEvent | QuestionEvent | QuestionReplyEvent | ErrorEvent | StatusEvent | DevServerEvent | FileChangeEvent | SubagentEvent | FinishedEvent | A2AMessageEvent | StateChangedEvent | HandoffEvent | ConnectorResponseEvent | ConnectorQueryResponseEvent | ConnectorsAvailableEvent | LifecycleCompleteEvent | TypingEvent | UserMessageEvent | SyncStatusEvent | SecretsReadyEvent | ConfiguredEvent | MountMountedEvent | MountUnmountedEvent | MountChangedEvent | MountSyncStatusEvent | DebugResultEvent | LogEntryEvent | ValidationWarningEvent | SkillsChangedEvent | CommandsAvailableEvent | FlowBreadcrumbEvent | SessionInfoEvent | ReactionAddedEvent | ReactionRemovedEvent | ResourceStatusEvent | ConnectorStatusEvent | CustomMessageEvent | SnapshotEvent | CompactionAttemptEvent | ResumeAttemptedEvent | ResumeFailedEvent | CapabilityRegisterEvent | CapabilityDeregisterEvent | CapabilityInvokedEvent | RenderInvokedEvent | ProtocolInfoEvent | IncompatibleProtocolEvent | SessionInitAckEvent | SessionInitMismatchEvent | SystemPromptComposedEvent;
|
|
21
21
|
/**
|
|
22
22
|
* A text message from the agent to the user.
|
|
23
23
|
*
|
|
@@ -268,6 +268,34 @@ export type FinishedEvent = {
|
|
|
268
268
|
/** Structured data for custom message types — used as component props. */
|
|
269
269
|
customData?: Record<string, unknown>;
|
|
270
270
|
};
|
|
271
|
+
/**
|
|
272
|
+
* An agent-to-agent (A2A) message exchanged between two linked sessions.
|
|
273
|
+
*
|
|
274
|
+
* Persisted as a `Message` row in BOTH the caller and target session
|
|
275
|
+
* conversations — each side stores its own copy with the matching
|
|
276
|
+
* `direction`. `inbound` is the copy in the receiving session's
|
|
277
|
+
* conversation; `outbound` is the copy in the initiating session's
|
|
278
|
+
* conversation. The two copies share the same `exchangeId`.
|
|
279
|
+
*
|
|
280
|
+
* Hosts (the Skaile platform) write this event into `Message.payload`
|
|
281
|
+
* alongside the dedicated `a2aExchangeId` / `peerSessionId` / `a2aDirection`
|
|
282
|
+
* columns. The chat UI's Network / All views render it as a badged A2A card.
|
|
283
|
+
*
|
|
284
|
+
* @docLink packages/types/events#a2a-message-event
|
|
285
|
+
*/
|
|
286
|
+
export type A2AMessageEvent = {
|
|
287
|
+
type: "a2a_message";
|
|
288
|
+
/** `inbound` = this session received it; `outbound` = this session sent it. */
|
|
289
|
+
direction: "inbound" | "outbound";
|
|
290
|
+
/** The other end of the exchange — the peer session's id. */
|
|
291
|
+
peerSessionId: string;
|
|
292
|
+
/** Human-readable name of the peer session, for UI display. */
|
|
293
|
+
peerName: string;
|
|
294
|
+
/** The A2A exchange this message belongs to (`A2AExchange.id`). */
|
|
295
|
+
exchangeId: string;
|
|
296
|
+
/** The message body — the question, answer, or async message text. */
|
|
297
|
+
text: string;
|
|
298
|
+
};
|
|
271
299
|
/**
|
|
272
300
|
* Emitted when a shared state store's snapshot changes.
|
|
273
301
|
*
|