@zhixuan92/multi-model-agent-core 3.4.0 → 3.5.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.
Files changed (80) hide show
  1. package/dist/delegate-with-escalation.d.ts +0 -1
  2. package/dist/delegate-with-escalation.d.ts.map +1 -1
  3. package/dist/delegate-with-escalation.js +7 -52
  4. package/dist/delegate-with-escalation.js.map +1 -1
  5. package/dist/diagnostics/disconnect-log.d.ts +48 -0
  6. package/dist/diagnostics/disconnect-log.d.ts.map +1 -1
  7. package/dist/diagnostics/disconnect-log.js +24 -0
  8. package/dist/diagnostics/disconnect-log.js.map +1 -1
  9. package/dist/diagnostics/verbose-line.d.ts +1 -0
  10. package/dist/diagnostics/verbose-line.d.ts.map +1 -1
  11. package/dist/diagnostics/verbose-line.js +19 -0
  12. package/dist/diagnostics/verbose-line.js.map +1 -1
  13. package/dist/escalation/fallback.d.ts +65 -0
  14. package/dist/escalation/fallback.d.ts.map +1 -0
  15. package/dist/escalation/fallback.js +195 -0
  16. package/dist/escalation/fallback.js.map +1 -0
  17. package/dist/escalation/policy.d.ts +37 -0
  18. package/dist/escalation/policy.d.ts.map +1 -0
  19. package/dist/escalation/policy.js +67 -0
  20. package/dist/escalation/policy.js.map +1 -0
  21. package/dist/executors/debug.d.ts.map +1 -1
  22. package/dist/executors/debug.js +0 -1
  23. package/dist/executors/debug.js.map +1 -1
  24. package/dist/executors/execute-plan.js +1 -1
  25. package/dist/executors/execute-plan.js.map +1 -1
  26. package/dist/heartbeat.d.ts +4 -4
  27. package/dist/heartbeat.d.ts.map +1 -1
  28. package/dist/heartbeat.js +17 -17
  29. package/dist/heartbeat.js.map +1 -1
  30. package/dist/intake/compilers/execute-plan.d.ts.map +1 -1
  31. package/dist/intake/compilers/execute-plan.js +1 -0
  32. package/dist/intake/compilers/execute-plan.js.map +1 -1
  33. package/dist/intake/resolve.d.ts.map +1 -1
  34. package/dist/intake/resolve.js +1 -2
  35. package/dist/intake/resolve.js.map +1 -1
  36. package/dist/reporting/compose-terminal-headline.d.ts +5 -0
  37. package/dist/reporting/compose-terminal-headline.d.ts.map +1 -1
  38. package/dist/reporting/compose-terminal-headline.js +23 -6
  39. package/dist/reporting/compose-terminal-headline.js.map +1 -1
  40. package/dist/review/aggregate-result.d.ts +3 -1
  41. package/dist/review/aggregate-result.d.ts.map +1 -1
  42. package/dist/review/aggregate-result.js.map +1 -1
  43. package/dist/review/diff-review.d.ts +11 -0
  44. package/dist/review/diff-review.d.ts.map +1 -1
  45. package/dist/review/diff-review.js +5 -2
  46. package/dist/review/diff-review.js.map +1 -1
  47. package/dist/review/quality-reviewer.d.ts +11 -2
  48. package/dist/review/quality-reviewer.d.ts.map +1 -1
  49. package/dist/review/quality-reviewer.js +3 -0
  50. package/dist/review/quality-reviewer.js.map +1 -1
  51. package/dist/review/skipped-result.d.ts +8 -0
  52. package/dist/review/skipped-result.d.ts.map +1 -0
  53. package/dist/review/skipped-result.js +4 -0
  54. package/dist/review/skipped-result.js.map +1 -0
  55. package/dist/review/spec-reviewer.d.ts +4 -1
  56. package/dist/review/spec-reviewer.d.ts.map +1 -1
  57. package/dist/review/spec-reviewer.js +3 -0
  58. package/dist/review/spec-reviewer.js.map +1 -1
  59. package/dist/run-tasks/metadata-repair.d.ts.map +1 -1
  60. package/dist/run-tasks/metadata-repair.js +0 -1
  61. package/dist/run-tasks/metadata-repair.js.map +1 -1
  62. package/dist/run-tasks/reviewed-lifecycle.d.ts.map +1 -1
  63. package/dist/run-tasks/reviewed-lifecycle.js +360 -188
  64. package/dist/run-tasks/reviewed-lifecycle.js.map +1 -1
  65. package/dist/runners/base/result-builders.d.ts +1 -1
  66. package/dist/runners/base/result-builders.d.ts.map +1 -1
  67. package/dist/runners/types.d.ts +2 -2
  68. package/dist/runners/types.d.ts.map +1 -1
  69. package/dist/tool-schemas/delegate.d.ts +0 -1
  70. package/dist/tool-schemas/delegate.d.ts.map +1 -1
  71. package/dist/tool-schemas/delegate.js +0 -1
  72. package/dist/tool-schemas/delegate.js.map +1 -1
  73. package/dist/tool-schemas/execute-plan.d.ts +0 -5
  74. package/dist/tool-schemas/execute-plan.d.ts.map +1 -1
  75. package/dist/tool-schemas/execute-plan.js +0 -4
  76. package/dist/tool-schemas/execute-plan.js.map +1 -1
  77. package/dist/types.d.ts +15 -2
  78. package/dist/types.d.ts.map +1 -1
  79. package/dist/types.js.map +1 -1
  80. package/package.json +1 -1
@@ -3,7 +3,6 @@ import type { InternalRunnerEvent } from './runners/types.js';
3
3
  export interface DelegateOptions {
4
4
  explicitlyPinned?: boolean;
5
5
  onProgress?: (event: InternalRunnerEvent) => void;
6
- escalateToProvider?: Provider;
7
6
  }
8
7
  export declare function delegateWithEscalation(task: TaskSpec, chain: Provider[], options?: DelegateOptions): Promise<RunResult>;
9
8
  //# sourceMappingURL=delegate-with-escalation.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"delegate-with-escalation.d.ts","sourceRoot":"","sources":["../src/delegate-with-escalation.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAChE,OAAO,KAAK,EAEV,mBAAmB,EAGpB,MAAM,oBAAoB,CAAC;AAW5B,MAAM,WAAW,eAAe;IAC9B,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,UAAU,CAAC,EAAE,CAAC,KAAK,EAAE,mBAAmB,KAAK,IAAI,CAAC;IAClD,kBAAkB,CAAC,EAAE,QAAQ,CAAC;CAC/B;AAiBD,wBAAsB,sBAAsB,CAC1C,IAAI,EAAE,QAAQ,EACd,KAAK,EAAE,QAAQ,EAAE,EACjB,OAAO,GAAE,eAAoB,GAC5B,OAAO,CAAC,SAAS,CAAC,CA4MpB"}
1
+ {"version":3,"file":"delegate-with-escalation.d.ts","sourceRoot":"","sources":["../src/delegate-with-escalation.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAChE,OAAO,KAAK,EAEV,mBAAmB,EAGpB,MAAM,oBAAoB,CAAC;AAY5B,MAAM,WAAW,eAAe;IAC9B,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,UAAU,CAAC,EAAE,CAAC,KAAK,EAAE,mBAAmB,KAAK,IAAI,CAAC;CACnD;AAiBD,wBAAsB,sBAAsB,CAC1C,IAAI,EAAE,QAAQ,EACd,KAAK,EAAE,QAAQ,EAAE,EACjB,OAAO,GAAE,eAAoB,GAC5B,OAAO,CAAC,SAAS,CAAC,CAkJpB"}
@@ -1,3 +1,8 @@
1
+ // NOTE: Despite the name "delegateWithEscalation", this function NO LONGER
2
+ // performs status-level tier escalation as of 3.5.0. Escalation policy is
3
+ // owned by reviewed-lifecycle.ts via runWithFallback (escalation/policy.ts).
4
+ // This function only handles transient retries (api_error / network_error).
5
+ // Rename to delegateWithRetries deferred to 3.6.0.
1
6
  import { retryableFor } from './error-codes.js';
2
7
  import { hasCompletedWork, extractToolName } from './runners/supervision.js';
3
8
  function deriveCause(status, errorCode) {
@@ -7,6 +12,8 @@ function deriveCause(status, errorCode) {
7
12
  return 'finished';
8
13
  if (status === 'incomplete')
9
14
  return 'incomplete';
15
+ if (status === 'unavailable')
16
+ return 'error';
10
17
  return status;
11
18
  }
12
19
  const TRANSIENT_STATUSES = new Set(['api_error', 'network_error']);
@@ -111,58 +118,6 @@ export async function delegateWithEscalation(task, chain, options = {}) {
111
118
  };
112
119
  }
113
120
  }
114
- // Auto-escalation: if single-provider dispatch failed for escalation-eligible
115
- // reasons (degenerate_exhausted, api_error, network_error), retry with complex.
116
- const bestResult = attempts[attempts.length - 1].result;
117
- const cause = deriveCause(bestResult.status, bestResult.errorCode);
118
- const shouldEscalate = !options.explicitlyPinned &&
119
- chain.length === 1 &&
120
- options.escalateToProvider !== undefined &&
121
- (cause === 'degenerate_exhausted' ||
122
- cause === 'api_error' ||
123
- cause === 'network_error');
124
- if (shouldEscalate) {
125
- const escalationProvider = options.escalateToProvider;
126
- safeSink?.({
127
- kind: 'escalation_start',
128
- previousProvider: bestResult.status === 'ok' ? 'standard' : chain[0].name,
129
- previousReason: `cause=${cause}`,
130
- nextProvider: escalationProvider.name,
131
- });
132
- const escalationResult = await escalationProvider.run(task.prompt, {
133
- tools: task.tools,
134
- timeoutMs: task.timeoutMs,
135
- cwd: task.cwd,
136
- effort: task.effort,
137
- sandboxPolicy: task.sandboxPolicy,
138
- expectedCoverage: task.expectedCoverage,
139
- skipCompletionHeuristic: task.skipCompletionHeuristic,
140
- parentModel: task.parentModel,
141
- maxCostUSD: task.maxCostUSD,
142
- formatConstraints: task.formatConstraints,
143
- onProgress: safeSink,
144
- });
145
- const escalationRecord = {
146
- provider: escalationProvider.name,
147
- status: escalationResult.status,
148
- turns: escalationResult.turns,
149
- inputTokens: escalationResult.usage.inputTokens,
150
- outputTokens: escalationResult.usage.outputTokens,
151
- costUSD: escalationResult.usage.costUSD,
152
- initialPromptLengthChars: 0,
153
- initialPromptHash: '',
154
- reason: escalationResult.status === 'ok'
155
- ? undefined
156
- : (escalationResult.error || `status=${escalationResult.status}`),
157
- };
158
- if (escalationResult.status === 'ok') {
159
- return {
160
- ...escalationResult,
161
- escalationLog: [...attempts.map((a) => a.record), escalationRecord],
162
- };
163
- }
164
- attempts.push({ result: escalationResult, record: escalationRecord });
165
- }
166
121
  const realContentAttempts = attempts.filter((a) => !a.result.outputIsDiagnostic);
167
122
  const pool = realContentAttempts.length > 0 ? realContentAttempts : attempts;
168
123
  let best = pool[0].result;
@@ -1 +1 @@
1
- {"version":3,"file":"delegate-with-escalation.js","sourceRoot":"","sources":["../src/delegate-with-escalation.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"delegate-with-escalation.js","sourceRoot":"","sources":["../src/delegate-with-escalation.ts"],"names":[],"mappings":"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"}
@@ -1,3 +1,5 @@
1
+ import type { RunStatus } from '../runners/types.js';
2
+ import type { AgentType } from '../types.js';
1
3
  export type ShutdownCause = 'stdin_end' | 'stdout_epipe' | 'stdout_other_error' | 'uncaughtException' | 'unhandledRejection' | 'SIGTERM' | 'SIGINT' | 'SIGPIPE' | 'SIGHUP' | 'SIGABRT' | 'event_loop_empty' | 'SIGTERM_drain_timeout';
2
4
  export type SessionCloseReason = 'client_closed' | 'transport_error' | 'session_expired' | 'daemon_shutdown' | 'handshake_failed';
3
5
  export type EventPrimitive = string | number | boolean | null;
@@ -7,6 +9,9 @@ export interface TaskEvent {
7
9
  taskIndex: number;
8
10
  [key: string]: EventPrimitive | undefined;
9
11
  }
12
+ export type DiagLoop = 'spec' | 'quality' | 'diff';
13
+ export type DiagRole = 'implementer' | 'specReviewer' | 'qualityReviewer' | 'diffReviewer';
14
+ export type DiagReason = 'transport_failure' | 'not_configured';
10
15
  export interface DiagnosticLogger {
11
16
  startup(version: string, extras?: {
12
17
  transport?: 'stdio' | 'http';
@@ -77,7 +82,50 @@ export interface DiagnosticLogger {
77
82
  errorCode: string;
78
83
  errorMessage: string;
79
84
  }): void;
85
+ escalation(params: {
86
+ batchId: string;
87
+ taskIndex: number;
88
+ loop: DiagLoop;
89
+ attempt: number;
90
+ baseTier: AgentType;
91
+ implTier: AgentType;
92
+ reviewerTier: AgentType;
93
+ }): void;
94
+ escalationUnavailable(params: {
95
+ batchId: string;
96
+ taskIndex: number;
97
+ loop: DiagLoop;
98
+ attempt: number;
99
+ role: DiagRole;
100
+ wantedTier: AgentType;
101
+ reason: DiagReason;
102
+ }): void;
103
+ fallback(params: {
104
+ batchId: string;
105
+ taskIndex: number;
106
+ loop: DiagLoop;
107
+ attempt: number;
108
+ role: DiagRole;
109
+ assignedTier: AgentType;
110
+ usedTier: AgentType;
111
+ reason: DiagReason;
112
+ triggeringStatus?: RunStatus;
113
+ violatesSeparation: boolean;
114
+ }): void;
115
+ fallbackUnavailable(params: {
116
+ batchId: string;
117
+ taskIndex: number;
118
+ loop: DiagLoop;
119
+ attempt: number;
120
+ role: DiagRole;
121
+ assignedTier: AgentType;
122
+ reason: DiagReason;
123
+ }): void;
80
124
  }
125
+ export type EscalationEventParams = Parameters<DiagnosticLogger['escalation']>[0];
126
+ export type EscalationUnavailableEventParams = Parameters<DiagnosticLogger['escalationUnavailable']>[0];
127
+ export type FallbackEventParams = Parameters<DiagnosticLogger['fallback']>[0];
128
+ export type FallbackUnavailableEventParams = Parameters<DiagnosticLogger['fallbackUnavailable']>[0];
81
129
  export interface CreateDiagnosticLoggerOptions {
82
130
  enabled: boolean;
83
131
  logDir?: string;
@@ -1 +1 @@
1
- {"version":3,"file":"disconnect-log.d.ts","sourceRoot":"","sources":["../../src/diagnostics/disconnect-log.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"disconnect-log.d.ts","sourceRoot":"","sources":["../../src/diagnostics/disconnect-log.ts"],"names":[],"mappings":"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"}
@@ -70,6 +70,10 @@ export function createDiagnosticLogger(options) {
70
70
  emit: () => { },
71
71
  batchCompleted: () => { },
72
72
  batchFailed: () => { },
73
+ escalation: () => { },
74
+ escalationUnavailable: () => { },
75
+ fallback: () => { },
76
+ fallbackUnavailable: () => { },
73
77
  };
74
78
  }
75
79
  const processStartTime = now().getTime();
@@ -345,6 +349,26 @@ export function createDiagnosticLogger(options) {
345
349
  errorMessage,
346
350
  });
347
351
  },
352
+ escalation: (params) => {
353
+ if (state.inert)
354
+ return;
355
+ writeLine({ event: 'escalation', ts: now().toISOString(), ...params });
356
+ },
357
+ escalationUnavailable: (params) => {
358
+ if (state.inert)
359
+ return;
360
+ writeLine({ event: 'escalation_unavailable', ts: now().toISOString(), ...params });
361
+ },
362
+ fallback: (params) => {
363
+ if (state.inert)
364
+ return;
365
+ writeLine({ event: 'fallback', ts: now().toISOString(), ...params });
366
+ },
367
+ fallbackUnavailable: (params) => {
368
+ if (state.inert)
369
+ return;
370
+ writeLine({ event: 'fallback_unavailable', ts: now().toISOString(), ...params });
371
+ },
348
372
  };
349
373
  }
350
374
  //# sourceMappingURL=disconnect-log.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"disconnect-log.js","sourceRoot":"","sources":["../../src/diagnostics/disconnect-log.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"disconnect-log.js","sourceRoot":"","sources":["../../src/diagnostics/disconnect-log.ts"],"names":[],"mappings":"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"}
@@ -7,6 +7,7 @@ export interface VerboseLineFields {
7
7
  preview?: string;
8
8
  [key: string]: Primitive | undefined;
9
9
  }
10
+ export declare function toVerboseFields(fields: Record<string, Primitive | undefined>): Record<string, Primitive | undefined>;
10
11
  export declare function composeVerboseLine(fields: VerboseLineFields): string;
11
12
  export {};
12
13
  //# sourceMappingURL=verbose-line.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"verbose-line.d.ts","sourceRoot":"","sources":["../../src/diagnostics/verbose-line.ts"],"names":[],"mappings":"AAAA,KAAK,SAAS,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,IAAI,CAAC;AAElD,MAAM,WAAW,iBAAiB;IAChC,KAAK,EAAE,MAAM,CAAC;IACd,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,CAAC,GAAG,EAAE,MAAM,GAAG,SAAS,GAAG,SAAS,CAAC;CACtC;AA2CD,wBAAgB,kBAAkB,CAAC,MAAM,EAAE,iBAAiB,GAAG,MAAM,CAiCpE"}
1
+ {"version":3,"file":"verbose-line.d.ts","sourceRoot":"","sources":["../../src/diagnostics/verbose-line.ts"],"names":[],"mappings":"AAAA,KAAK,SAAS,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,IAAI,CAAC;AAElD,MAAM,WAAW,iBAAiB;IAChC,KAAK,EAAE,MAAM,CAAC;IACd,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,CAAC,GAAG,EAAE,MAAM,GAAG,SAAS,GAAG,SAAS,CAAC;CACtC;AAmDD,wBAAgB,eAAe,CAC7B,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,SAAS,GAAG,SAAS,CAAC,GAC5C,MAAM,CAAC,MAAM,EAAE,SAAS,GAAG,SAAS,CAAC,CASvC;AAED,wBAAgB,kBAAkB,CAAC,MAAM,EAAE,iBAAiB,GAAG,MAAM,CAiCpE"}
@@ -44,6 +44,25 @@ function assertPrimitiveValue(key, val) {
44
44
  throw new Error(`verbose-line: non-primitive value (key=${key})`);
45
45
  }
46
46
  }
47
+ // Keys already emitted on every verbose line as `batch` / `task` (see
48
+ // reviewed-lifecycle.ts:114). Drop them when forwarding event params so we
49
+ // don't produce both `batch=` and `batch_id=` on the same line.
50
+ const VERBOSE_DROP_KEYS = new Set(['batchId', 'taskIndex']);
51
+ // Convert event-param fields (typed in camelCase per the JSONL DiagnosticLogger
52
+ // contract) into the snake_case shape `composeVerboseLine` requires. Used at
53
+ // the verbose-stream branch only — the JSONL path keeps camelCase.
54
+ export function toVerboseFields(fields) {
55
+ const out = {};
56
+ for (const [key, value] of Object.entries(fields)) {
57
+ if (value === undefined)
58
+ continue;
59
+ if (VERBOSE_DROP_KEYS.has(key))
60
+ continue;
61
+ const snake = key.replace(/([a-z0-9])([A-Z])/g, '$1_$2').toLowerCase();
62
+ out[snake] = value;
63
+ }
64
+ return out;
65
+ }
47
66
  export function composeVerboseLine(fields) {
48
67
  const { event, ts, ...rest } = fields;
49
68
  if (!event)
@@ -1 +1 @@
1
- {"version":3,"file":"verbose-line.js","sourceRoot":"","sources":["../../src/diagnostics/verbose-line.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"verbose-line.js","sourceRoot":"","sources":["../../src/diagnostics/verbose-line.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,65 @@
1
+ import type { Provider, AgentType, RunResult } from '../types.js';
2
+ import type { RunStatus } from '../runners/types.js';
3
+ export declare const TRANSPORT_FAILURES: ReadonlySet<RunStatus>;
4
+ export type FallbackReason = 'transport_failure' | 'not_configured';
5
+ export type UnavailableMap = Map<AgentType, FallbackReason>;
6
+ /** First-write-wins. Preserves root cause across the loop. */
7
+ export declare function markUnavailable(map: UnavailableMap, tier: AgentType, reason: FallbackReason): void;
8
+ export declare function otherTier(t: AgentType): AgentType;
9
+ /** Two providers are "identical" iff they resolve to the same effective backend
10
+ * (type + model + baseUrl + apiKey wiring). When an operator points both tiers
11
+ * at the same backend (one-provider deployment), cross-tier fallback is
12
+ * structurally pointless — alt would just hit the same place. Comparing the
13
+ * serialized config catches this without a new operator-facing flag. */
14
+ export declare function providersIdentical(a: Provider, b: Provider): boolean;
15
+ export interface RunWithFallbackInput<T> {
16
+ assigned: AgentType;
17
+ providerFor: (tier: AgentType) => Provider | undefined;
18
+ unavailableTiers: UnavailableMap;
19
+ isTransportFailure: (result: T) => boolean;
20
+ /** Caller-supplied status extractor. Replaces unsafe `(result as any).status` casts.
21
+ * Returns undefined for results that don't carry a status field (custom T types). */
22
+ getStatus?: (result: T) => RunStatus | undefined;
23
+ makeSyntheticFailure: (assigned: AgentType) => T;
24
+ call: (provider: Provider) => Promise<T>;
25
+ }
26
+ export interface RunWithFallbackResult<T> {
27
+ result: T;
28
+ usedTier: AgentType | 'none';
29
+ /** True iff an alternate tier was actually USED for a provider call (not just considered).
30
+ * False when both tiers were unavailable up-front (no provider call made).
31
+ * Used by lifecycle to decide whether to emit a `fallback` event (yes iff fallbackFired).
32
+ * Distinct from `bothUnavailable` (which means "no usable result"). */
33
+ fallbackFired: boolean;
34
+ /** Why the substitution was attempted. Present iff fallbackFired or assignedUnavailableReason set. */
35
+ fallbackReason?: FallbackReason;
36
+ /** Status of the call that triggered the substitution (assigned-tier failure). Present iff
37
+ * fallbackReason === 'transport_failure' AND a real call occurred. */
38
+ fallbackTriggeringStatus?: RunStatus;
39
+ /** True iff the wrapper could not produce a usable result. */
40
+ bothUnavailable: boolean;
41
+ /** Why the FINAL tier (alt or assigned) was unavailable. Present iff bothUnavailable. */
42
+ unavailableReason?: FallbackReason;
43
+ /** Status of the alt-tier failure that produced bothUnavailable mid-call. Present iff
44
+ * bothUnavailable AND mid-call double-failure path AND alt was actually called. */
45
+ unavailableTriggeringStatus?: RunStatus;
46
+ /** Why the assigned tier was unavailable up-front (sticky or not-configured). Present iff
47
+ * fallbackReason set without calling assigned. Distinct from `fallbackReason` so callers
48
+ * can tell "we substituted at the start" vs "we substituted because the assigned call failed". */
49
+ assignedUnavailableReason?: FallbackReason;
50
+ }
51
+ export declare function runWithFallback<T>(input: RunWithFallbackInput<T>): Promise<RunWithFallbackResult<T>>;
52
+ /** Lifecycle helper: builds the synthetic RunResult expected when both tiers are
53
+ * unavailable. Status is the new 'unavailable' value (NOT 'api_error') so
54
+ * re-passing the synthetic into runWithFallback's isTransportFailure cannot
55
+ * retrigger fallback.
56
+ *
57
+ * IMPORTANT: This shape MUST satisfy `RunResult` (see types.ts). Confirmed
58
+ * required fields: output, status, usage, turns, filesRead, filesWritten,
59
+ * toolCalls, outputIsDiagnostic, escalationLog. All other RunResult fields
60
+ * are optional. */
61
+ export declare function makeSyntheticRunResult(assigned: AgentType, errorCode: string): RunResult;
62
+ export declare function isReviewTransportFailure(r: {
63
+ status?: string;
64
+ }): boolean;
65
+ //# sourceMappingURL=fallback.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fallback.d.ts","sourceRoot":"","sources":["../../src/escalation/fallback.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAClE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAErD,eAAO,MAAM,kBAAkB,EAAE,WAAW,CAAC,SAAS,CAIpD,CAAC;AAEH,MAAM,MAAM,cAAc,GAAG,mBAAmB,GAAG,gBAAgB,CAAC;AACpE,MAAM,MAAM,cAAc,GAAG,GAAG,CAAC,SAAS,EAAE,cAAc,CAAC,CAAC;AAE5D,8DAA8D;AAC9D,wBAAgB,eAAe,CAC7B,GAAG,EAAE,cAAc,EACnB,IAAI,EAAE,SAAS,EACf,MAAM,EAAE,cAAc,GACrB,IAAI,CAEN;AAED,wBAAgB,SAAS,CAAC,CAAC,EAAE,SAAS,GAAG,SAAS,CAEjD;AAED;;;;yEAIyE;AACzE,wBAAgB,kBAAkB,CAAC,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,QAAQ,GAAG,OAAO,CAEpE;AAED,MAAM,WAAW,oBAAoB,CAAC,CAAC;IACrC,QAAQ,EAAE,SAAS,CAAC;IACpB,WAAW,EAAE,CAAC,IAAI,EAAE,SAAS,KAAK,QAAQ,GAAG,SAAS,CAAC;IACvD,gBAAgB,EAAE,cAAc,CAAC;IACjC,kBAAkB,EAAE,CAAC,MAAM,EAAE,CAAC,KAAK,OAAO,CAAC;IAC3C;0FACsF;IACtF,SAAS,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,KAAK,SAAS,GAAG,SAAS,CAAC;IACjD,oBAAoB,EAAE,CAAC,QAAQ,EAAE,SAAS,KAAK,CAAC,CAAC;IACjD,IAAI,EAAE,CAAC,QAAQ,EAAE,QAAQ,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC;CAC1C;AAED,MAAM,WAAW,qBAAqB,CAAC,CAAC;IACtC,MAAM,EAAE,CAAC,CAAC;IACV,QAAQ,EAAE,SAAS,GAAG,MAAM,CAAC;IAE7B;;;4EAGwE;IACxE,aAAa,EAAE,OAAO,CAAC;IACvB,sGAAsG;IACtG,cAAc,CAAC,EAAE,cAAc,CAAC;IAChC;2EACuE;IACvE,wBAAwB,CAAC,EAAE,SAAS,CAAC;IAErC,8DAA8D;IAC9D,eAAe,EAAE,OAAO,CAAC;IACzB,yFAAyF;IACzF,iBAAiB,CAAC,EAAE,cAAc,CAAC;IACnC;wFACoF;IACpF,2BAA2B,CAAC,EAAE,SAAS,CAAC;IAExC;;uGAEmG;IACnG,yBAAyB,CAAC,EAAE,cAAc,CAAC;CAC5C;AAED,wBAAsB,eAAe,CAAC,CAAC,EACrC,KAAK,EAAE,oBAAoB,CAAC,CAAC,CAAC,GAC7B,OAAO,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC,CA0JnC;AAED;;;;;;;;oBAQoB;AACpB,wBAAgB,sBAAsB,CAAC,QAAQ,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,GAAG,SAAS,CAexF;AAED,wBAAgB,wBAAwB,CACtC,CAAC,EAAE;IAAE,MAAM,CAAC,EAAE,MAAM,CAAA;CAAE,GACrB,OAAO,CAET"}
@@ -0,0 +1,195 @@
1
+ export const TRANSPORT_FAILURES = new Set([
2
+ 'api_error',
3
+ 'network_error',
4
+ 'timeout',
5
+ ]);
6
+ /** First-write-wins. Preserves root cause across the loop. */
7
+ export function markUnavailable(map, tier, reason) {
8
+ if (!map.has(tier))
9
+ map.set(tier, reason);
10
+ }
11
+ export function otherTier(t) {
12
+ return t === 'standard' ? 'complex' : 'standard';
13
+ }
14
+ /** Two providers are "identical" iff they resolve to the same effective backend
15
+ * (type + model + baseUrl + apiKey wiring). When an operator points both tiers
16
+ * at the same backend (one-provider deployment), cross-tier fallback is
17
+ * structurally pointless — alt would just hit the same place. Comparing the
18
+ * serialized config catches this without a new operator-facing flag. */
19
+ export function providersIdentical(a, b) {
20
+ return JSON.stringify(a.config) === JSON.stringify(b.config);
21
+ }
22
+ export async function runWithFallback(input) {
23
+ const { assigned, providerFor, unavailableTiers, isTransportFailure, makeSyntheticFailure, call } = input;
24
+ const getStatus = input.getStatus ?? (() => undefined);
25
+ // ── Step 1: resolve assigned tier (sticky check first, then not-configured) ──
26
+ let usedTier = assigned;
27
+ let fallbackFired = false;
28
+ let fallbackReason;
29
+ let assignedUnavailableReason;
30
+ if (unavailableTiers.has(assigned)) {
31
+ assignedUnavailableReason = unavailableTiers.get(assigned);
32
+ fallbackReason = assignedUnavailableReason;
33
+ }
34
+ else if (providerFor(assigned) === undefined) {
35
+ markUnavailable(unavailableTiers, assigned, 'not_configured');
36
+ assignedUnavailableReason = 'not_configured';
37
+ fallbackReason = 'not_configured';
38
+ }
39
+ if (fallbackReason !== undefined) {
40
+ // Assigned is unavailable up-front. Try the alt tier.
41
+ const alt = otherTier(assigned);
42
+ let altUnavailableReason;
43
+ if (unavailableTiers.has(alt)) {
44
+ altUnavailableReason = unavailableTiers.get(alt);
45
+ }
46
+ else if (providerFor(alt) === undefined) {
47
+ markUnavailable(unavailableTiers, alt, 'not_configured');
48
+ altUnavailableReason = 'not_configured';
49
+ }
50
+ if (altUnavailableReason !== undefined) {
51
+ // Both unavailable up-front. Report the BLOCKING tier's reason (the alt's, since
52
+ // the alt is what we actually tried to use — round-1 audit C4 fix).
53
+ return {
54
+ result: makeSyntheticFailure(assigned),
55
+ usedTier: 'none',
56
+ fallbackFired: false,
57
+ bothUnavailable: true,
58
+ fallbackReason,
59
+ assignedUnavailableReason,
60
+ unavailableReason: altUnavailableReason,
61
+ };
62
+ }
63
+ usedTier = alt;
64
+ fallbackFired = true;
65
+ }
66
+ // ── Step 4: call the chosen provider ──
67
+ const provider = providerFor(usedTier);
68
+ const result = await call(provider);
69
+ if (!isTransportFailure(result)) {
70
+ // Success (or non-transport failure passed through) — return current state.
71
+ return {
72
+ result,
73
+ usedTier,
74
+ fallbackFired,
75
+ fallbackReason,
76
+ assignedUnavailableReason,
77
+ bothUnavailable: false,
78
+ };
79
+ }
80
+ // Transport failure on the called tier. Capture the original triggering status.
81
+ const calledStatus = getStatus(result);
82
+ markUnavailable(unavailableTiers, usedTier, 'transport_failure');
83
+ // If the called tier WAS the alt (i.e. we already substituted before calling),
84
+ // there's no further alt to try; we've burned both options.
85
+ if (fallbackFired) {
86
+ return {
87
+ result,
88
+ usedTier,
89
+ fallbackFired: true,
90
+ fallbackReason,
91
+ fallbackTriggeringStatus: calledStatus,
92
+ assignedUnavailableReason,
93
+ bothUnavailable: true,
94
+ unavailableReason: 'transport_failure',
95
+ unavailableTriggeringStatus: calledStatus,
96
+ };
97
+ }
98
+ // The assigned tier just failed in this call. Promote to fallback path.
99
+ fallbackReason = 'transport_failure';
100
+ const fallbackTriggeringStatus = calledStatus;
101
+ const altOfUsed = otherTier(usedTier);
102
+ // Same-provider short-circuit: if alt resolves to a provider with the same
103
+ // effective config as the assigned tier (operator pointing both tiers at one
104
+ // backend), fallback would just hit the same backend. Skip the doomed call
105
+ // and return the assigned-tier failure as the terminal result. We do NOT
106
+ // mark alt unavailable here — the failure may be transient, and a future
107
+ // rework attempt should still be allowed to try.
108
+ const altProviderForSameCheck = providerFor(altOfUsed);
109
+ if (altProviderForSameCheck !== undefined && providersIdentical(provider, altProviderForSameCheck)) {
110
+ return {
111
+ result,
112
+ usedTier,
113
+ fallbackFired: false,
114
+ bothUnavailable: false,
115
+ };
116
+ }
117
+ // Check alt availability (sticky first, then not-configured)
118
+ let altUnavailableReason;
119
+ if (unavailableTiers.has(altOfUsed)) {
120
+ altUnavailableReason = unavailableTiers.get(altOfUsed);
121
+ }
122
+ else if (providerFor(altOfUsed) === undefined) {
123
+ markUnavailable(unavailableTiers, altOfUsed, 'not_configured');
124
+ altUnavailableReason = 'not_configured';
125
+ }
126
+ if (altUnavailableReason !== undefined) {
127
+ // Both unavailable mid-call — assigned called and failed; alt unreachable.
128
+ // Return the actual failed result (not synthetic) per Spec Section D step 4b.
129
+ return {
130
+ result,
131
+ usedTier,
132
+ fallbackFired: true,
133
+ fallbackReason,
134
+ fallbackTriggeringStatus,
135
+ bothUnavailable: true,
136
+ unavailableReason: altUnavailableReason,
137
+ };
138
+ }
139
+ // Try alt.
140
+ const altProvider = providerFor(altOfUsed);
141
+ const altResult = await call(altProvider);
142
+ const altStatus = getStatus(altResult);
143
+ if (isTransportFailure(altResult)) {
144
+ // Both transport-failed mid-call — preserve BOTH triggering statuses.
145
+ markUnavailable(unavailableTiers, altOfUsed, 'transport_failure');
146
+ return {
147
+ result: altResult,
148
+ usedTier: altOfUsed,
149
+ fallbackFired: true,
150
+ fallbackReason,
151
+ fallbackTriggeringStatus, // assigned's failure status (root cause)
152
+ bothUnavailable: true,
153
+ unavailableReason: 'transport_failure',
154
+ unavailableTriggeringStatus: altStatus, // alt's failure status (final state)
155
+ };
156
+ }
157
+ // Alt succeeded.
158
+ return {
159
+ result: altResult,
160
+ usedTier: altOfUsed,
161
+ fallbackFired: true,
162
+ fallbackReason,
163
+ fallbackTriggeringStatus, // assigned's failure status (root cause)
164
+ bothUnavailable: false,
165
+ };
166
+ }
167
+ /** Lifecycle helper: builds the synthetic RunResult expected when both tiers are
168
+ * unavailable. Status is the new 'unavailable' value (NOT 'api_error') so
169
+ * re-passing the synthetic into runWithFallback's isTransportFailure cannot
170
+ * retrigger fallback.
171
+ *
172
+ * IMPORTANT: This shape MUST satisfy `RunResult` (see types.ts). Confirmed
173
+ * required fields: output, status, usage, turns, filesRead, filesWritten,
174
+ * toolCalls, outputIsDiagnostic, escalationLog. All other RunResult fields
175
+ * are optional. */
176
+ export function makeSyntheticRunResult(assigned, errorCode) {
177
+ return {
178
+ status: 'unavailable',
179
+ output: '',
180
+ outputIsDiagnostic: true,
181
+ error: `runWithFallback: both tiers unavailable (assigned=${assigned})`,
182
+ errorCode,
183
+ retryable: false,
184
+ turns: 0,
185
+ usage: { inputTokens: 0, outputTokens: 0, totalTokens: 0, costUSD: 0, savedCostUSD: 0 },
186
+ filesRead: [],
187
+ filesWritten: [],
188
+ toolCalls: [],
189
+ escalationLog: [],
190
+ };
191
+ }
192
+ export function isReviewTransportFailure(r) {
193
+ return r.status === 'api_error' || r.status === 'network_error' || r.status === 'timeout';
194
+ }
195
+ //# sourceMappingURL=fallback.js.map