@covibes/zeroshot 5.2.0 → 5.3.0
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 +178 -186
- package/README.md +199 -248
- package/cli/commands/providers.js +150 -0
- package/cli/index.js +214 -58
- package/cli/lib/first-run.js +40 -3
- package/cluster-templates/base-templates/debug-workflow.json +24 -78
- package/cluster-templates/base-templates/full-workflow.json +44 -145
- package/cluster-templates/base-templates/single-worker.json +23 -15
- package/cluster-templates/base-templates/worker-validator.json +47 -34
- package/cluster-templates/conductor-bootstrap.json +7 -5
- package/lib/docker-config.js +6 -1
- package/lib/provider-detection.js +59 -0
- package/lib/provider-names.js +56 -0
- package/lib/settings.js +191 -6
- package/lib/stream-json-parser.js +4 -238
- package/package.json +21 -5
- package/scripts/validate-templates.js +100 -0
- package/src/agent/agent-config.js +37 -13
- package/src/agent/agent-context-builder.js +64 -2
- package/src/agent/agent-hook-executor.js +82 -9
- package/src/agent/agent-lifecycle.js +53 -14
- package/src/agent/agent-task-executor.js +196 -194
- package/src/agent/output-extraction.js +200 -0
- package/src/agent/output-reformatter.js +175 -0
- package/src/agent/schema-utils.js +111 -0
- package/src/agent-wrapper.js +102 -30
- package/src/agents/git-pusher-agent.json +2 -2
- package/src/claude-task-runner.js +80 -30
- package/src/config-router.js +13 -13
- package/src/config-validator.js +231 -10
- package/src/github.js +36 -0
- package/src/isolation-manager.js +243 -154
- package/src/ledger.js +28 -6
- package/src/orchestrator.js +391 -96
- package/src/preflight.js +85 -82
- package/src/providers/anthropic/cli-builder.js +45 -0
- package/src/providers/anthropic/index.js +134 -0
- package/src/providers/anthropic/models.js +23 -0
- package/src/providers/anthropic/output-parser.js +159 -0
- package/src/providers/base-provider.js +181 -0
- package/src/providers/capabilities.js +51 -0
- package/src/providers/google/cli-builder.js +55 -0
- package/src/providers/google/index.js +116 -0
- package/src/providers/google/models.js +24 -0
- package/src/providers/google/output-parser.js +92 -0
- package/src/providers/index.js +75 -0
- package/src/providers/openai/cli-builder.js +122 -0
- package/src/providers/openai/index.js +135 -0
- package/src/providers/openai/models.js +21 -0
- package/src/providers/openai/output-parser.js +129 -0
- package/src/sub-cluster-wrapper.js +18 -3
- package/src/task-runner.js +8 -6
- package/src/tui/layout.js +20 -3
- package/task-lib/attachable-watcher.js +80 -78
- package/task-lib/claude-recovery.js +119 -0
- package/task-lib/commands/list.js +1 -1
- package/task-lib/commands/resume.js +3 -2
- package/task-lib/commands/run.js +12 -3
- package/task-lib/runner.js +59 -38
- package/task-lib/scheduler.js +2 -2
- package/task-lib/store.js +43 -30
- package/task-lib/watcher.js +81 -62
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
const readline = require('readline');
|
|
2
|
+
const { loadSettings, saveSettings } = require('../../lib/settings');
|
|
3
|
+
const { VALID_PROVIDERS, normalizeProviderName } = require('../../lib/provider-names');
|
|
4
|
+
const { detectProviders, getProvider } = require('../../src/providers');
|
|
5
|
+
|
|
6
|
+
function question(rl, prompt) {
|
|
7
|
+
return new Promise((resolve) => {
|
|
8
|
+
rl.question(prompt, (answer) => resolve(answer.trim()));
|
|
9
|
+
});
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
async function providersCommand() {
|
|
13
|
+
const detected = await detectProviders();
|
|
14
|
+
const settings = loadSettings();
|
|
15
|
+
|
|
16
|
+
console.log('\nProvider Status Default Level Model CLI Path');
|
|
17
|
+
console.log('─'.repeat(70));
|
|
18
|
+
|
|
19
|
+
for (const [name, status] of Object.entries(detected)) {
|
|
20
|
+
const provider = getProvider(name);
|
|
21
|
+
const statusIcon = status.available ? '✓ found' : '✗ not found';
|
|
22
|
+
const providerSettings = settings.providerSettings?.[name] || {};
|
|
23
|
+
const defaultLevel = providerSettings.defaultLevel || provider.getDefaultLevel();
|
|
24
|
+
const levelOverrides = providerSettings.levelOverrides || {};
|
|
25
|
+
const modelSpec = provider.resolveModelSpec(defaultLevel, levelOverrides);
|
|
26
|
+
const modelLabel = modelSpec?.model || '-';
|
|
27
|
+
const cliPath = status.available ? await provider.getCliPath() : '-';
|
|
28
|
+
const isDefault = settings.defaultProvider === name ? ' (default)' : '';
|
|
29
|
+
|
|
30
|
+
console.log(
|
|
31
|
+
`${provider.displayName.padEnd(12)} ${statusIcon.padEnd(12)} ${defaultLevel.padEnd(
|
|
32
|
+
14
|
|
33
|
+
)} ${modelLabel.padEnd(16)} ${cliPath}${isDefault}`
|
|
34
|
+
);
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
console.log('\nCommands:');
|
|
38
|
+
console.log(' zeroshot providers set-default <provider> Set default provider');
|
|
39
|
+
console.log(' zeroshot providers setup <provider> Configure a provider');
|
|
40
|
+
console.log(
|
|
41
|
+
'\nNote: Authentication is managed by each CLI; zeroshot does not validate login or API keys.'
|
|
42
|
+
);
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
function setDefaultCommand(args) {
|
|
46
|
+
const provider = normalizeProviderName(args[0]);
|
|
47
|
+
if (!VALID_PROVIDERS.includes(provider)) {
|
|
48
|
+
console.error(`Invalid provider: ${args[0]}`);
|
|
49
|
+
process.exit(1);
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
const settings = loadSettings();
|
|
53
|
+
settings.defaultProvider = provider;
|
|
54
|
+
saveSettings(settings);
|
|
55
|
+
|
|
56
|
+
console.log(`Default provider set to: ${provider}`);
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
async function setupCommand(args) {
|
|
60
|
+
const provider = normalizeProviderName(args[0]);
|
|
61
|
+
if (!provider) {
|
|
62
|
+
console.error('Provider is required (claude, codex, gemini)');
|
|
63
|
+
process.exit(1);
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
const providerModule = getProvider(provider);
|
|
67
|
+
|
|
68
|
+
console.log(`\n${providerModule.displayName} Setup\n`);
|
|
69
|
+
|
|
70
|
+
const available = await providerModule.isAvailable();
|
|
71
|
+
if (!available) {
|
|
72
|
+
console.log(`✗ ${providerModule.cliCommand} CLI not found`);
|
|
73
|
+
console.log('\nInstall with:');
|
|
74
|
+
console.log(providerModule.getInstallInstructions());
|
|
75
|
+
return;
|
|
76
|
+
}
|
|
77
|
+
console.log(`✓ ${providerModule.cliCommand} CLI found`);
|
|
78
|
+
|
|
79
|
+
console.log('\nAuth is user-managed; run the CLI login flow if needed:');
|
|
80
|
+
console.log(providerModule.getAuthInstructions());
|
|
81
|
+
|
|
82
|
+
const rl = readline.createInterface({ input: process.stdin, output: process.stdout });
|
|
83
|
+
|
|
84
|
+
try {
|
|
85
|
+
const levels = providerModule.getLevelMapping();
|
|
86
|
+
const levelKeys = Object.keys(levels).sort((a, b) => levels[a].rank - levels[b].rank);
|
|
87
|
+
|
|
88
|
+
console.log('\nAvailable levels (cheapest to most capable):');
|
|
89
|
+
levelKeys.forEach((level, i) => {
|
|
90
|
+
const spec = levels[level];
|
|
91
|
+
const reasoning = spec.reasoningEffort ? ` (reasoning: ${spec.reasoningEffort})` : '';
|
|
92
|
+
console.log(` ${i + 1}) ${level} -> ${spec.model}${reasoning}`);
|
|
93
|
+
});
|
|
94
|
+
|
|
95
|
+
const maxIdxRaw = await question(rl, `\nMax level (cost ceiling) [${levelKeys.length}]: `);
|
|
96
|
+
const minIdxRaw = await question(rl, 'Min level (floor) [1]: ');
|
|
97
|
+
const maxIdxNum = Math.min(
|
|
98
|
+
levelKeys.length,
|
|
99
|
+
Math.max(1, parseInt(maxIdxRaw) || levelKeys.length)
|
|
100
|
+
);
|
|
101
|
+
const minIdxNum = Math.min(levelKeys.length, Math.max(1, parseInt(minIdxRaw) || 1));
|
|
102
|
+
const minIdx = Math.min(minIdxNum, maxIdxNum);
|
|
103
|
+
const maxIdx = Math.max(minIdxNum, maxIdxNum);
|
|
104
|
+
|
|
105
|
+
const defaultIdxRaw = await question(
|
|
106
|
+
rl,
|
|
107
|
+
`Default level (between ${minIdx}-${maxIdx}) [${maxIdx}]: `
|
|
108
|
+
);
|
|
109
|
+
const defaultIdxNum = Math.min(maxIdx, Math.max(minIdx, parseInt(defaultIdxRaw) || maxIdx));
|
|
110
|
+
|
|
111
|
+
const levelOverrides = {};
|
|
112
|
+
const wantsOverrides = await question(rl, 'Override models per level? [y/N]: ');
|
|
113
|
+
if (wantsOverrides.toLowerCase() === 'y') {
|
|
114
|
+
const catalog = Object.keys(providerModule.getModelCatalog());
|
|
115
|
+
for (const level of levelKeys) {
|
|
116
|
+
const modelChoice = await question(rl, `Model for ${level} (${catalog.join(', ')}): `);
|
|
117
|
+
if (modelChoice) levelOverrides[level] = { model: modelChoice };
|
|
118
|
+
if (provider === 'codex') {
|
|
119
|
+
const reasoning = await question(rl, `Reasoning for ${level} (low|medium|high|xhigh): `);
|
|
120
|
+
if (reasoning) {
|
|
121
|
+
levelOverrides[level] = {
|
|
122
|
+
...(levelOverrides[level] || {}),
|
|
123
|
+
reasoningEffort: reasoning,
|
|
124
|
+
};
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
const settings = loadSettings();
|
|
131
|
+
settings.providerSettings = settings.providerSettings || {};
|
|
132
|
+
settings.providerSettings[provider] = {
|
|
133
|
+
maxLevel: levelKeys[maxIdx - 1],
|
|
134
|
+
minLevel: levelKeys[minIdx - 1],
|
|
135
|
+
defaultLevel: levelKeys[defaultIdxNum - 1],
|
|
136
|
+
levelOverrides,
|
|
137
|
+
};
|
|
138
|
+
saveSettings(settings);
|
|
139
|
+
|
|
140
|
+
console.log(`\n✓ ${providerModule.displayName} configured successfully`);
|
|
141
|
+
} finally {
|
|
142
|
+
rl.close();
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
module.exports = {
|
|
147
|
+
providersCommand,
|
|
148
|
+
setDefaultCommand,
|
|
149
|
+
setupCommand,
|
|
150
|
+
};
|