@cleocode/contracts 2026.5.65 → 2026.5.67
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/dist/index.d.ts +6 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js.map +1 -1
- package/dist/llm/failover-reason.d.ts +76 -0
- package/dist/llm/failover-reason.d.ts.map +1 -0
- package/dist/llm/failover-reason.js +2 -0
- package/dist/llm/failover-reason.js.map +1 -0
- package/dist/llm/interfaces.d.ts +476 -0
- package/dist/llm/interfaces.d.ts.map +1 -0
- package/dist/llm/interfaces.js +24 -0
- package/dist/llm/interfaces.js.map +1 -0
- package/dist/llm/normalized-response.d.ts +304 -0
- package/dist/llm/normalized-response.d.ts.map +1 -0
- package/dist/llm/normalized-response.js +19 -0
- package/dist/llm/normalized-response.js.map +1 -0
- package/dist/llm/provider-id.d.ts +47 -0
- package/dist/llm/provider-id.d.ts.map +1 -0
- package/dist/llm/provider-id.js +13 -0
- package/dist/llm/provider-id.js.map +1 -0
- package/dist/llm/provider-profile.d.ts +166 -0
- package/dist/llm/provider-profile.d.ts.map +1 -0
- package/dist/llm/provider-profile.js +13 -0
- package/dist/llm/provider-profile.js.map +1 -0
- package/dist/llm/resolved-credential.d.ts +61 -0
- package/dist/llm/resolved-credential.d.ts.map +1 -0
- package/dist/llm/resolved-credential.js +14 -0
- package/dist/llm/resolved-credential.js.map +1 -0
- package/dist/operations/llm.d.ts +14 -2
- package/dist/operations/llm.d.ts.map +1 -1
- package/dist/operations/llm.js +4 -0
- package/dist/operations/llm.js.map +1 -1
- package/package.json +10 -2
- package/src/index.ts +43 -0
- package/src/llm/failover-reason.ts +86 -0
- package/src/llm/interfaces.ts +538 -0
- package/src/llm/normalized-response.ts +313 -0
- package/src/llm/provider-id.ts +63 -0
- package/src/llm/provider-profile.ts +191 -0
- package/src/llm/resolved-credential.ts +62 -0
- package/src/operations/llm.ts +20 -2
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Fully-resolved credential type for the unified LLM provider architecture.
|
|
3
|
+
*
|
|
4
|
+
* This type replaces the partial `CredentialResultWire` at the runtime level.
|
|
5
|
+
* `CredentialResultWire` is retained solely as a wire diagnostic type for
|
|
6
|
+
* `cleo llm whoami` CLI output.
|
|
7
|
+
*
|
|
8
|
+
* @module llm/resolved-credential
|
|
9
|
+
* @task T9281
|
|
10
|
+
* @epic T9261 T-LLM-CRED-CENTRALIZATION
|
|
11
|
+
* @see ADR-072 §Type lock-in
|
|
12
|
+
*/
|
|
13
|
+
export {};
|
|
14
|
+
//# sourceMappingURL=resolved-credential.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resolved-credential.js","sourceRoot":"","sources":["../../src/llm/resolved-credential.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG"}
|
package/dist/operations/llm.d.ts
CHANGED
|
@@ -8,8 +8,20 @@
|
|
|
8
8
|
* @task T1399 (T1386-W13)
|
|
9
9
|
* @epic T1386
|
|
10
10
|
*/
|
|
11
|
-
|
|
12
|
-
|
|
11
|
+
import type { BuiltinProviderId, ProviderId } from '../llm/provider-id.js';
|
|
12
|
+
/**
|
|
13
|
+
* @deprecated since Phase 4 (ADR-072). Use {@link ProviderId} from
|
|
14
|
+
* `@cleocode/contracts/llm/provider-id.js` for new code. This alias remains
|
|
15
|
+
* for one release cycle to ease migration of legacy callers, then is removed.
|
|
16
|
+
*
|
|
17
|
+
* The alias resolves to {@link BuiltinProviderId} — a superset of the previous
|
|
18
|
+
* closed literal union (`'anthropic' | 'openai' | 'gemini' | 'moonshot'`).
|
|
19
|
+
* All existing consumers that pattern-match on the previous four values continue
|
|
20
|
+
* to compile without changes.
|
|
21
|
+
*
|
|
22
|
+
* @see ADR-072 §Type lock-in — ModelTransport deprecation cycle
|
|
23
|
+
*/
|
|
24
|
+
export type ModelTransport = Extract<ProviderId, BuiltinProviderId>;
|
|
13
25
|
/** Cache policy mode for prompt prefix caching. */
|
|
14
26
|
export type PromptCachePolicyMode = 'gemini_cached_content';
|
|
15
27
|
/** Prompt caching policy descriptor. */
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"llm.d.ts","sourceRoot":"","sources":["../../src/operations/llm.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAEH,
|
|
1
|
+
{"version":3,"file":"llm.d.ts","sourceRoot":"","sources":["../../src/operations/llm.ts"],"names":[],"mappings":"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"}
|
package/dist/operations/llm.js
CHANGED
|
@@ -9,4 +9,8 @@
|
|
|
9
9
|
* @epic T1386
|
|
10
10
|
*/
|
|
11
11
|
export {};
|
|
12
|
+
// ProviderProfile interface lives in ./llm/provider-profile.ts (T9262).
|
|
13
|
+
// The generated catalog (packages/core/src/llm/generated/provider-profiles.ts)
|
|
14
|
+
// imports the canonical type from the contracts package and emits each
|
|
15
|
+
// generated entry as a plain ProviderProfile literal.
|
|
12
16
|
//# sourceMappingURL=llm.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"llm.js","sourceRoot":"","sources":["../../src/operations/llm.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG"}
|
|
1
|
+
{"version":3,"file":"llm.js","sourceRoot":"","sources":["../../src/operations/llm.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;;AA6iBH,wEAAwE;AACxE,+EAA+E;AAC/E,uEAAuE;AACvE,sDAAsD"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@cleocode/contracts",
|
|
3
|
-
"version": "2026.5.
|
|
3
|
+
"version": "2026.5.67",
|
|
4
4
|
"description": "Domain types, interfaces, and contracts for the CLEO ecosystem",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"main": "./dist/index.js",
|
|
@@ -57,6 +57,14 @@
|
|
|
57
57
|
"./operations/*.js": {
|
|
58
58
|
"types": "./dist/operations/*.d.ts",
|
|
59
59
|
"import": "./dist/operations/*.js"
|
|
60
|
+
},
|
|
61
|
+
"./llm/*": {
|
|
62
|
+
"types": "./dist/llm/*.d.ts",
|
|
63
|
+
"import": "./dist/llm/*.js"
|
|
64
|
+
},
|
|
65
|
+
"./llm/*.js": {
|
|
66
|
+
"types": "./dist/llm/*.d.ts",
|
|
67
|
+
"import": "./dist/llm/*.js"
|
|
60
68
|
}
|
|
61
69
|
},
|
|
62
70
|
"engines": {
|
|
@@ -82,7 +90,7 @@
|
|
|
82
90
|
"dependencies": {
|
|
83
91
|
"zod": "^4.3.6",
|
|
84
92
|
"zod-to-json-schema": "^3.25.2",
|
|
85
|
-
"@cleocode/lafs": "2026.5.
|
|
93
|
+
"@cleocode/lafs": "2026.5.67"
|
|
86
94
|
},
|
|
87
95
|
"scripts": {
|
|
88
96
|
"build": "tsc -b --force && node scripts/emit-schemas.mjs",
|
package/src/index.ts
CHANGED
|
@@ -426,6 +426,49 @@ export {
|
|
|
426
426
|
isLafsError,
|
|
427
427
|
isLafsSuccess,
|
|
428
428
|
} from './lafs.js';
|
|
429
|
+
// === LLM Error Taxonomy (T9270 — Hermes FailoverReason port) ===
|
|
430
|
+
export type { ClassifiedError, FailoverReason } from './llm/failover-reason.js';
|
|
431
|
+
// === Phase 4 Unified Architecture (T9281 / ADR-072) — Session + Executor interfaces ===
|
|
432
|
+
export type {
|
|
433
|
+
AggregatedUsage,
|
|
434
|
+
ExecutionEvent,
|
|
435
|
+
ExecutionRequest,
|
|
436
|
+
ExecutorFactoryOptions,
|
|
437
|
+
LlmExecutor,
|
|
438
|
+
LlmExecutorFactory,
|
|
439
|
+
LlmSession,
|
|
440
|
+
LlmSessionFactory,
|
|
441
|
+
NormalizedDelta,
|
|
442
|
+
RetryPolicy,
|
|
443
|
+
SendOptions,
|
|
444
|
+
SessionFactoryOptions,
|
|
445
|
+
ToolCall,
|
|
446
|
+
TransportContext,
|
|
447
|
+
} from './llm/interfaces.js';
|
|
448
|
+
// === Normalized LLM Transport Types (T9263 — Phase 3 T-LLM-CRED) ===
|
|
449
|
+
// Note: LlmTransport (the interface) is intentionally NOT re-exported at the
|
|
450
|
+
// top level here because `config.ts` already exports `LlmTransport` as a type
|
|
451
|
+
// alias for `ModelTransport`. Consumers that need the transport interface
|
|
452
|
+
// should import the LlmTransport interface from the llm/normalized-response.js
|
|
453
|
+
// subpath rather than the package root.
|
|
454
|
+
export type {
|
|
455
|
+
NormalizedResponse,
|
|
456
|
+
NormalizedToolCall,
|
|
457
|
+
NormalizedUsage,
|
|
458
|
+
TransportMessage,
|
|
459
|
+
TransportRequest,
|
|
460
|
+
TransportTool,
|
|
461
|
+
} from './llm/normalized-response.js';
|
|
462
|
+
// === Phase 4 Unified Architecture (T9281 / ADR-072) — Provider identity ===
|
|
463
|
+
export type { ApiMode, BuiltinProviderId, ProviderId } from './llm/provider-id.js';
|
|
464
|
+
// === Provider Profile + Plugin Contracts (T9262 — Phase 3 T-LLM-CRED) ===
|
|
465
|
+
export type {
|
|
466
|
+
ProviderPlugin,
|
|
467
|
+
ProviderPluginApi,
|
|
468
|
+
ProviderProfile,
|
|
469
|
+
} from './llm/provider-profile.js';
|
|
470
|
+
// === Phase 4 Unified Architecture (T9281 / ADR-072) — Resolved credential ===
|
|
471
|
+
export type { ResolvedCredential } from './llm/resolved-credential.js';
|
|
429
472
|
export type {
|
|
430
473
|
BridgeDecision,
|
|
431
474
|
BridgeLearning,
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Structured taxonomy of LLM failure modes — mirrors Hermes' FailoverReason enum.
|
|
3
|
+
*
|
|
4
|
+
* Consumers (CredentialPool, auxiliary-router, CLI error envelopes) use this
|
|
5
|
+
* to drive deterministic recovery actions instead of ad-hoc status-code
|
|
6
|
+
* inspection.
|
|
7
|
+
*
|
|
8
|
+
* Adding new values is BC-safe. Removing or renaming values is BREAKING.
|
|
9
|
+
*
|
|
10
|
+
* @task T9270 (Phase 3 T-LLM-CRED)
|
|
11
|
+
*/
|
|
12
|
+
export type FailoverReason =
|
|
13
|
+
// --- Authentication / authorization ---
|
|
14
|
+
/** 401/403 — transient; refresh or rotate credential */
|
|
15
|
+
| 'auth'
|
|
16
|
+
/** Auth failed AFTER refresh — abort, do not retry */
|
|
17
|
+
| 'auth_permanent'
|
|
18
|
+
// --- Billing / quota ---
|
|
19
|
+
/** 402 or credit exhaustion — rotate immediately to next credential */
|
|
20
|
+
| 'billing'
|
|
21
|
+
/** 429 — backoff then rotate */
|
|
22
|
+
| 'rate_limit'
|
|
23
|
+
// --- Server-side ---
|
|
24
|
+
/** 503/529 — provider overloaded; retry with backoff */
|
|
25
|
+
| 'overloaded'
|
|
26
|
+
/** 500/502 — internal error; retry */
|
|
27
|
+
| 'server_error'
|
|
28
|
+
// --- Transport ---
|
|
29
|
+
/** Connection or read timeout — rebuild client + retry */
|
|
30
|
+
| 'timeout'
|
|
31
|
+
// --- Context / payload ---
|
|
32
|
+
/** Context too large — invoke compression engine */
|
|
33
|
+
| 'context_overflow'
|
|
34
|
+
/** 413 — compress payload */
|
|
35
|
+
| 'payload_too_large'
|
|
36
|
+
/** Per-image limit hit — shrink and retry */
|
|
37
|
+
| 'image_too_large'
|
|
38
|
+
// --- Model / provider ---
|
|
39
|
+
/** 404 — fall back to a different model */
|
|
40
|
+
| 'model_not_found'
|
|
41
|
+
/** Aggregator policy block (OpenRouter, etc.) */
|
|
42
|
+
| 'provider_policy_blocked'
|
|
43
|
+
// --- Request format ---
|
|
44
|
+
/** 400 — abort or strip + retry */
|
|
45
|
+
| 'format_error'
|
|
46
|
+
// --- Provider-specific (hooks for future deep classification) ---
|
|
47
|
+
/** Anthropic thinking-block signature invalid */
|
|
48
|
+
| 'thinking_signature'
|
|
49
|
+
/** Anthropic extra-usage tier gate */
|
|
50
|
+
| 'long_context_tier'
|
|
51
|
+
/** OAuth long-context beta forbidden */
|
|
52
|
+
| 'oauth_long_context_beta_forbidden'
|
|
53
|
+
/** llama.cpp grammar pattern regex rejection */
|
|
54
|
+
| 'llama_cpp_grammar_pattern'
|
|
55
|
+
// --- Catch-all ---
|
|
56
|
+
| 'unknown';
|
|
57
|
+
|
|
58
|
+
/**
|
|
59
|
+
* Structured classification of an LLM API error with deterministic recovery hints.
|
|
60
|
+
*
|
|
61
|
+
* Produced by `classifyError` in `@cleocode/core`. Consumers check the flags
|
|
62
|
+
* (`retryable`, `shouldCompress`, `shouldRotateCredential`, `shouldFallback`)
|
|
63
|
+
* instead of re-inspecting the raw error.
|
|
64
|
+
*
|
|
65
|
+
* @task T9270 (Phase 3 T-LLM-CRED)
|
|
66
|
+
*/
|
|
67
|
+
export interface ClassifiedError {
|
|
68
|
+
/** Structured failure reason driving recovery strategy. */
|
|
69
|
+
reason: FailoverReason;
|
|
70
|
+
/** HTTP status code extracted from the error, if available. */
|
|
71
|
+
statusCode: number | null;
|
|
72
|
+
/** Provider identifier from the call context, if supplied. */
|
|
73
|
+
provider: string | null;
|
|
74
|
+
/** Model identifier from the call context, if supplied. */
|
|
75
|
+
model: string | null;
|
|
76
|
+
/** Human-readable error message. */
|
|
77
|
+
message: string;
|
|
78
|
+
/** Whether the operation can be retried (possibly after backoff). */
|
|
79
|
+
retryable: boolean;
|
|
80
|
+
/** Whether the caller should attempt context compression before retrying. */
|
|
81
|
+
shouldCompress: boolean;
|
|
82
|
+
/** Whether the caller should rotate to a different credential. */
|
|
83
|
+
shouldRotateCredential: boolean;
|
|
84
|
+
/** Whether the caller should fall back to a different model/provider. */
|
|
85
|
+
shouldFallback: boolean;
|
|
86
|
+
}
|