@x12i/ai-tools 1.0.4 → 2.0.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 +23 -0
- package/README.md +146 -204
- package/dist/AiModelsCatalogClient-B5FMI9gj.d.cts +58 -0
- package/dist/AiModelsCatalogClient-CPPNI6Ry.d.ts +58 -0
- package/dist/aliases/index.cjs +4 -3
- package/dist/aliases/index.cjs.map +1 -1
- package/dist/aliases/index.d.cts +3 -5
- package/dist/aliases/index.d.ts +3 -5
- package/dist/aliases/index.js +2 -2
- package/dist/catalog/index.cjs +18 -9
- package/dist/catalog/index.cjs.map +1 -1
- package/dist/catalog/index.d.cts +13 -100
- package/dist/catalog/index.d.ts +13 -100
- package/dist/catalog/index.js +31 -23
- package/dist/{chunk-AJEKEWWB.js → chunk-2PTCWPHV.js} +17 -3
- package/dist/chunk-2PTCWPHV.js.map +1 -0
- package/dist/chunk-56R4XA2S.js +1 -0
- package/dist/chunk-5GUKLOEK.cjs +1 -0
- package/dist/chunk-5GUKLOEK.cjs.map +1 -0
- package/dist/chunk-5XAAMBDO.cjs +1988 -0
- package/dist/chunk-5XAAMBDO.cjs.map +1 -0
- package/dist/chunk-6BQBKROR.js +95 -0
- package/dist/chunk-6BQBKROR.js.map +1 -0
- package/dist/chunk-AB5GNXJ4.js +46 -0
- package/dist/chunk-AB5GNXJ4.js.map +1 -0
- package/dist/{chunk-O2A6OVEH.js → chunk-ANVONYJF.js} +2 -2
- package/dist/{chunk-O2A6OVEH.js.map → chunk-ANVONYJF.js.map} +1 -1
- package/dist/chunk-B3V2EHRY.js +225 -0
- package/dist/chunk-B3V2EHRY.js.map +1 -0
- package/dist/{chunk-QWAX7VQO.cjs → chunk-BAHBDADJ.cjs} +11 -11
- package/dist/{chunk-QWAX7VQO.cjs.map → chunk-BAHBDADJ.cjs.map} +1 -1
- package/dist/{chunk-TF4L2NEC.cjs → chunk-DXZOL3VN.cjs} +62 -313
- package/dist/chunk-DXZOL3VN.cjs.map +1 -0
- package/dist/chunk-EDMCKHO6.cjs +225 -0
- package/dist/chunk-EDMCKHO6.cjs.map +1 -0
- package/dist/{chunk-DJ5SWJDY.js → chunk-EYHMQVAL.js} +48 -299
- package/dist/chunk-EYHMQVAL.js.map +1 -0
- package/dist/chunk-GS7T56RP.cjs +8 -0
- package/dist/chunk-GS7T56RP.cjs.map +1 -0
- package/dist/chunk-NF2SKQR7.cjs +973 -0
- package/dist/chunk-NF2SKQR7.cjs.map +1 -0
- package/dist/chunk-OPN6BGNH.js +1985 -0
- package/dist/chunk-OPN6BGNH.js.map +1 -0
- package/dist/{chunk-7Q742NI3.cjs → chunk-PADNCGZB.cjs} +17 -3
- package/dist/chunk-PADNCGZB.cjs.map +1 -0
- package/dist/chunk-PRCICORG.cjs +95 -0
- package/dist/chunk-PRCICORG.cjs.map +1 -0
- package/dist/{chunk-6QGDZTGH.js → chunk-SIH4GPV4.js} +4 -29
- package/dist/chunk-SIH4GPV4.js.map +1 -0
- package/dist/chunk-U2YDDUVP.js +970 -0
- package/dist/chunk-U2YDDUVP.js.map +1 -0
- package/dist/{chunk-4NAY6HRP.js → chunk-VJHLO2R3.js} +7 -58
- package/dist/chunk-VJHLO2R3.js.map +1 -0
- package/dist/chunk-XAWBTX3N.cjs +46 -0
- package/dist/chunk-XAWBTX3N.cjs.map +1 -0
- package/dist/{chunk-AV6OE2YQ.cjs → chunk-XOKUDUUI.cjs} +14 -39
- package/dist/chunk-XOKUDUUI.cjs.map +1 -0
- package/dist/chunk-YQDSN6R6.cjs +86 -0
- package/dist/chunk-YQDSN6R6.cjs.map +1 -0
- package/dist/cli/index.cjs +59 -201
- package/dist/cli/index.cjs.map +1 -1
- package/dist/cli/index.js +53 -198
- package/dist/cli/index.js.map +1 -1
- package/dist/cost/index.cjs +19 -3
- package/dist/cost/index.cjs.map +1 -1
- package/dist/cost/index.d.cts +10 -50
- package/dist/cost/index.d.ts +10 -50
- package/dist/cost/index.js +18 -3
- package/dist/index.cjs +24 -16
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +13 -13
- package/dist/index.d.ts +13 -13
- package/dist/index.js +44 -37
- package/dist/modelCache-BzRn6t_C.d.ts +113 -0
- package/dist/modelCache-CJftI-Ko.d.cts +113 -0
- package/dist/{modelNameResolver-DqFt7g6W.d.ts → modelNameResolver-5XkBMctP.d.ts} +2 -6
- package/dist/{modelNameResolver-D9V_GfUK.d.cts → modelNameResolver-C5CSTGFF.d.cts} +2 -6
- package/dist/models/index.cjs +9 -6
- package/dist/models/index.cjs.map +1 -1
- package/dist/models/index.d.cts +9 -31
- package/dist/models/index.d.ts +9 -31
- package/dist/models/index.js +9 -7
- package/dist/resolveUsageModel-BFwf80Hz.d.ts +140 -0
- package/dist/resolveUsageModel-C_YmGR1M.d.cts +140 -0
- package/dist/sync/index.cjs +7 -9
- package/dist/sync/index.cjs.map +1 -1
- package/dist/sync/index.d.cts +3 -8
- package/dist/sync/index.d.ts +3 -8
- package/dist/sync/index.js +8 -11
- package/dist/toolbox/index.cjs +1 -0
- package/dist/toolbox/index.cjs.map +1 -1
- package/dist/types-BrzJWsTU.d.cts +277 -0
- package/dist/types-BrzJWsTU.d.ts +277 -0
- package/package.json +9 -20
- package/src/data/models-catalog.json +670 -0
- package/src/data/openrouter-models-catalog.json +857 -0
- package/dist/AiModelsCatalogClient-4RF5BCDL.cjs +0 -9
- package/dist/AiModelsCatalogClient-4RF5BCDL.cjs.map +0 -1
- package/dist/AiModelsCatalogClient-CNeqFiFs.d.cts +0 -30
- package/dist/AiModelsCatalogClient-NUF3CBLW.js +0 -9
- package/dist/AiModelsCatalogClient-nwFoEaqL.d.ts +0 -30
- package/dist/catalox/index.cjs +0 -21
- package/dist/catalox/index.cjs.map +0 -1
- package/dist/catalox/index.d.cts +0 -11
- package/dist/catalox/index.d.ts +0 -11
- package/dist/catalox/index.js +0 -21
- package/dist/catalox/index.js.map +0 -1
- package/dist/chunk-4NAY6HRP.js.map +0 -1
- package/dist/chunk-6QGDZTGH.js.map +0 -1
- package/dist/chunk-7Q742NI3.cjs.map +0 -1
- package/dist/chunk-AJEKEWWB.js.map +0 -1
- package/dist/chunk-AV6OE2YQ.cjs.map +0 -1
- package/dist/chunk-C3H7RTFR.cjs +0 -1
- package/dist/chunk-C3H7RTFR.cjs.map +0 -1
- package/dist/chunk-DJ5SWJDY.js.map +0 -1
- package/dist/chunk-DKHGWHXP.cjs +0 -169
- package/dist/chunk-DKHGWHXP.cjs.map +0 -1
- package/dist/chunk-F2F4UEFD.cjs +0 -75
- package/dist/chunk-F2F4UEFD.cjs.map +0 -1
- package/dist/chunk-FGP3QXWL.cjs +0 -163
- package/dist/chunk-FGP3QXWL.cjs.map +0 -1
- package/dist/chunk-G2G4KSC5.js +0 -30
- package/dist/chunk-G2G4KSC5.js.map +0 -1
- package/dist/chunk-HN6UAQAE.cjs +0 -83
- package/dist/chunk-HN6UAQAE.cjs.map +0 -1
- package/dist/chunk-HS74X2OJ.cjs +0 -172
- package/dist/chunk-HS74X2OJ.cjs.map +0 -1
- package/dist/chunk-HYGXZY25.js +0 -163
- package/dist/chunk-HYGXZY25.js.map +0 -1
- package/dist/chunk-KQOALKKX.js +0 -75
- package/dist/chunk-KQOALKKX.js.map +0 -1
- package/dist/chunk-LYOU7CA2.cjs +0 -30
- package/dist/chunk-LYOU7CA2.cjs.map +0 -1
- package/dist/chunk-M5TMA73F.js +0 -1
- package/dist/chunk-M5TMA73F.js.map +0 -1
- package/dist/chunk-MX3AMQFC.js +0 -172
- package/dist/chunk-MX3AMQFC.js.map +0 -1
- package/dist/chunk-QCRLKVB3.cjs +0 -137
- package/dist/chunk-QCRLKVB3.cjs.map +0 -1
- package/dist/chunk-TF4L2NEC.cjs.map +0 -1
- package/dist/chunk-VRFVF5RH.js +0 -169
- package/dist/chunk-VRFVF5RH.js.map +0 -1
- package/dist/chunk-YHO57D2V.js +0 -83
- package/dist/chunk-YHO57D2V.js.map +0 -1
- package/dist/syncAiModelsCatalog-CnXRLm2c.d.cts +0 -32
- package/dist/syncAiModelsCatalog-DpkN_w7S.d.ts +0 -32
- package/dist/types-BYXnCvKx.d.cts +0 -137
- package/dist/types-BYXnCvKx.d.ts +0 -137
- package/dist/types-CX6QFNNy.d.cts +0 -144
- package/dist/types-CuiPDcVs.d.ts +0 -144
- package/dist/upsertAiModelRecord-C831wOIF.d.ts +0 -35
- package/dist/upsertAiModelRecord-CjY-sny0.d.cts +0 -35
- /package/dist/{AiModelsCatalogClient-NUF3CBLW.js.map → chunk-56R4XA2S.js.map} +0 -0
package/dist/sync/index.cjs
CHANGED
|
@@ -2,14 +2,13 @@
|
|
|
2
2
|
|
|
3
3
|
|
|
4
4
|
|
|
5
|
-
var _chunkLYOU7CA2cjs = require('../chunk-LYOU7CA2.cjs');
|
|
6
5
|
|
|
6
|
+
var _chunkPRCICORGcjs = require('../chunk-PRCICORG.cjs');
|
|
7
|
+
require('../chunk-XOKUDUUI.cjs');
|
|
7
8
|
|
|
8
9
|
|
|
9
|
-
var _chunkDKHGWHXPcjs = require('../chunk-DKHGWHXP.cjs');
|
|
10
|
-
require('../chunk-FGP3QXWL.cjs');
|
|
11
|
-
require('../chunk-AV6OE2YQ.cjs');
|
|
12
10
|
|
|
11
|
+
var _chunkDXZOL3VNcjs = require('../chunk-DXZOL3VN.cjs');
|
|
13
12
|
|
|
14
13
|
|
|
15
14
|
|
|
@@ -17,9 +16,10 @@ require('../chunk-AV6OE2YQ.cjs');
|
|
|
17
16
|
|
|
18
17
|
|
|
19
18
|
|
|
19
|
+
var _chunkEDMCKHO6cjs = require('../chunk-EDMCKHO6.cjs');
|
|
20
|
+
require('../chunk-PADNCGZB.cjs');
|
|
21
|
+
require('../chunk-GS7T56RP.cjs');
|
|
20
22
|
|
|
21
|
-
var _chunkTF4L2NECcjs = require('../chunk-TF4L2NEC.cjs');
|
|
22
|
-
require('../chunk-7Q742NI3.cjs');
|
|
23
23
|
|
|
24
24
|
|
|
25
25
|
|
|
@@ -32,7 +32,5 @@ require('../chunk-7Q742NI3.cjs');
|
|
|
32
32
|
|
|
33
33
|
|
|
34
34
|
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
exports.ModelNameResolver = _chunkTF4L2NECcjs.ModelNameResolver; exports.OpenRouterSyncProvider = _chunkDKHGWHXPcjs.OpenRouterSyncProvider; exports.buildCatalogIndexes = _chunkTF4L2NECcjs.buildCatalogIndexes; exports.createModelNameResolver = _chunkLYOU7CA2cjs.createModelNameResolver; exports.isRoutedViaOpenRouter = _chunkLYOU7CA2cjs.isRoutedViaOpenRouter; exports.loadOpenRouterRoutingEnv = _chunkTF4L2NECcjs.loadOpenRouterRoutingEnv; exports.normalizeProvider = _chunkTF4L2NECcjs.normalizeProvider; exports.normalizeString = _chunkTF4L2NECcjs.normalizeString; exports.providerIdToEnvKeyPrefix = _chunkTF4L2NECcjs.providerIdToEnvKeyPrefix; exports.resolveModel = _chunkLYOU7CA2cjs.resolveModel; exports.shouldDefaultRouteViaOpenRouter = _chunkTF4L2NECcjs.shouldDefaultRouteViaOpenRouter; exports.syncAiModelsCatalog = _chunkDKHGWHXPcjs.syncAiModelsCatalog; exports.vendorApiKeyEnvName = _chunkTF4L2NECcjs.vendorApiKeyEnvName;
|
|
35
|
+
exports.ModelNameResolver = _chunkDXZOL3VNcjs.ModelNameResolver; exports.OpenRouterSyncProvider = _chunkPRCICORGcjs.OpenRouterSyncProvider; exports.buildCatalogIndexes = _chunkDXZOL3VNcjs.buildCatalogIndexes; exports.createModelNameResolver = _chunkPRCICORGcjs.createModelNameResolver; exports.isRoutedViaOpenRouter = _chunkPRCICORGcjs.isRoutedViaOpenRouter; exports.loadOpenRouterRoutingEnv = _chunkEDMCKHO6cjs.loadOpenRouterRoutingEnv; exports.normalizeProvider = _chunkEDMCKHO6cjs.normalizeProvider; exports.normalizeString = _chunkEDMCKHO6cjs.normalizeString; exports.providerIdToEnvKeyPrefix = _chunkEDMCKHO6cjs.providerIdToEnvKeyPrefix; exports.resolveModel = _chunkPRCICORGcjs.resolveModel; exports.shouldDefaultRouteViaOpenRouter = _chunkEDMCKHO6cjs.shouldDefaultRouteViaOpenRouter; exports.vendorApiKeyEnvName = _chunkEDMCKHO6cjs.vendorApiKeyEnvName;
|
|
38
36
|
//# sourceMappingURL=index.cjs.map
|
package/dist/sync/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["/Users/ami/Documents/prometheus/x12i/ai-tools/dist/sync/index.cjs"],"names":[],"mappings":"AAAA;AACE;AACA;AACA;AACF,yDAA8B;AAC9B;AACE;AACA;AACF,yDAA8B;AAC9B
|
|
1
|
+
{"version":3,"sources":["/Users/ami/Documents/prometheus/x12i/ai-tools/dist/sync/index.cjs"],"names":[],"mappings":"AAAA;AACE;AACA;AACA;AACA;AACF,yDAA8B;AAC9B,iCAA8B;AAC9B;AACE;AACA;AACF,yDAA8B;AAC9B;AACE;AACA;AACA;AACA;AACA;AACA;AACF,yDAA8B;AAC9B,iCAA8B;AAC9B,iCAA8B;AAC9B;AACE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACF,21BAAC","file":"/Users/ami/Documents/prometheus/x12i/ai-tools/dist/sync/index.cjs"}
|
package/dist/sync/index.d.cts
CHANGED
|
@@ -1,11 +1,6 @@
|
|
|
1
|
-
export { M as ModelNameResolver, O as OpenRouterSyncProvider, a as OpenRouterSyncProviderOptions, c as createModelNameResolver, i as isRoutedViaOpenRouter, r as resolveModel } from '../modelNameResolver-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
export { M as ModelResolutionInput, f as ModelResolutionResult, g as ModelResolutionSuccess, h as ModelResolverOptions, O as OpenRouterRoutingConfig, R as ResolutionStrategy, i as ResolvedModel, l as loadOpenRouterRoutingEnv, p as providerIdToEnvKeyPrefix, s as shouldDefaultRouteViaOpenRouter, v as vendorApiKeyEnvName } from '../types-CX6QFNNy.cjs';
|
|
5
|
-
import { a as AiModelRecord } from '../types-BYXnCvKx.cjs';
|
|
6
|
-
import '@x12i/catalox';
|
|
7
|
-
import 'firebase-admin/firestore';
|
|
8
|
-
import '../upsertAiModelRecord-CjY-sny0.cjs';
|
|
1
|
+
export { M as ModelNameResolver, O as OpenRouterSyncProvider, a as OpenRouterSyncProviderOptions, c as createModelNameResolver, i as isRoutedViaOpenRouter, r as resolveModel } from '../modelNameResolver-C5CSTGFF.cjs';
|
|
2
|
+
import { a as AiModelRecord, C as CatalogIndexes } from '../types-BrzJWsTU.cjs';
|
|
3
|
+
export { h as ModelResolutionInput, j as ModelResolutionResult, k as ModelResolutionSuccess, l as ModelResolverOptions, r as OpenRouterRoutingConfig, R as ResolutionStrategy, t as ResolvedModel, v as loadOpenRouterRoutingEnv, w as providerIdToEnvKeyPrefix, x as shouldDefaultRouteViaOpenRouter, y as vendorApiKeyEnvName } from '../types-BrzJWsTU.cjs';
|
|
9
4
|
|
|
10
5
|
declare function buildCatalogIndexes(catalog: Map<string, AiModelRecord>): CatalogIndexes;
|
|
11
6
|
|
package/dist/sync/index.d.ts
CHANGED
|
@@ -1,11 +1,6 @@
|
|
|
1
|
-
export { M as ModelNameResolver, O as OpenRouterSyncProvider, a as OpenRouterSyncProviderOptions, c as createModelNameResolver, i as isRoutedViaOpenRouter, r as resolveModel } from '../modelNameResolver-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
export { M as ModelResolutionInput, f as ModelResolutionResult, g as ModelResolutionSuccess, h as ModelResolverOptions, O as OpenRouterRoutingConfig, R as ResolutionStrategy, i as ResolvedModel, l as loadOpenRouterRoutingEnv, p as providerIdToEnvKeyPrefix, s as shouldDefaultRouteViaOpenRouter, v as vendorApiKeyEnvName } from '../types-CuiPDcVs.js';
|
|
5
|
-
import { a as AiModelRecord } from '../types-BYXnCvKx.js';
|
|
6
|
-
import '@x12i/catalox';
|
|
7
|
-
import 'firebase-admin/firestore';
|
|
8
|
-
import '../upsertAiModelRecord-C831wOIF.js';
|
|
1
|
+
export { M as ModelNameResolver, O as OpenRouterSyncProvider, a as OpenRouterSyncProviderOptions, c as createModelNameResolver, i as isRoutedViaOpenRouter, r as resolveModel } from '../modelNameResolver-5XkBMctP.js';
|
|
2
|
+
import { a as AiModelRecord, C as CatalogIndexes } from '../types-BrzJWsTU.js';
|
|
3
|
+
export { h as ModelResolutionInput, j as ModelResolutionResult, k as ModelResolutionSuccess, l as ModelResolverOptions, r as OpenRouterRoutingConfig, R as ResolutionStrategy, t as ResolvedModel, v as loadOpenRouterRoutingEnv, w as providerIdToEnvKeyPrefix, x as shouldDefaultRouteViaOpenRouter, y as vendorApiKeyEnvName } from '../types-BrzJWsTU.js';
|
|
9
4
|
|
|
10
5
|
declare function buildCatalogIndexes(catalog: Map<string, AiModelRecord>): CatalogIndexes;
|
|
11
6
|
|
package/dist/sync/index.js
CHANGED
|
@@ -1,25 +1,23 @@
|
|
|
1
1
|
import {
|
|
2
|
+
OpenRouterSyncProvider,
|
|
2
3
|
createModelNameResolver,
|
|
3
4
|
isRoutedViaOpenRouter,
|
|
4
5
|
resolveModel
|
|
5
|
-
} from "../chunk-
|
|
6
|
-
import
|
|
7
|
-
OpenRouterSyncProvider,
|
|
8
|
-
syncAiModelsCatalog
|
|
9
|
-
} from "../chunk-VRFVF5RH.js";
|
|
10
|
-
import "../chunk-HYGXZY25.js";
|
|
11
|
-
import "../chunk-6QGDZTGH.js";
|
|
6
|
+
} from "../chunk-6BQBKROR.js";
|
|
7
|
+
import "../chunk-SIH4GPV4.js";
|
|
12
8
|
import {
|
|
13
9
|
ModelNameResolver,
|
|
14
|
-
buildCatalogIndexes
|
|
10
|
+
buildCatalogIndexes
|
|
11
|
+
} from "../chunk-EYHMQVAL.js";
|
|
12
|
+
import {
|
|
15
13
|
loadOpenRouterRoutingEnv,
|
|
16
14
|
normalizeProvider,
|
|
17
15
|
normalizeString,
|
|
18
16
|
providerIdToEnvKeyPrefix,
|
|
19
17
|
shouldDefaultRouteViaOpenRouter,
|
|
20
18
|
vendorApiKeyEnvName
|
|
21
|
-
} from "../chunk-
|
|
22
|
-
import "../chunk-
|
|
19
|
+
} from "../chunk-B3V2EHRY.js";
|
|
20
|
+
import "../chunk-2PTCWPHV.js";
|
|
23
21
|
export {
|
|
24
22
|
ModelNameResolver,
|
|
25
23
|
OpenRouterSyncProvider,
|
|
@@ -32,7 +30,6 @@ export {
|
|
|
32
30
|
providerIdToEnvKeyPrefix,
|
|
33
31
|
resolveModel,
|
|
34
32
|
shouldDefaultRouteViaOpenRouter,
|
|
35
|
-
syncAiModelsCatalog,
|
|
36
33
|
vendorApiKeyEnvName
|
|
37
34
|
};
|
|
38
35
|
//# sourceMappingURL=index.js.map
|
package/dist/toolbox/index.cjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["/Users/ami/Documents/prometheus/x12i/ai-tools/dist/toolbox/index.cjs"],"names":[],"mappings":"AAAA;AACE;AACF,yDAA8B;AAC9B;AACE;AACF,gDAAC","file":"/Users/ami/Documents/prometheus/x12i/ai-tools/dist/toolbox/index.cjs"}
|
|
1
|
+
{"version":3,"sources":["/Users/ami/Documents/prometheus/x12i/ai-tools/dist/toolbox/index.cjs"],"names":[],"mappings":"AAAA;AACE;AACF,yDAA8B;AAC9B,iCAA8B;AAC9B;AACE;AACF,gDAAC","file":"/Users/ami/Documents/prometheus/x12i/ai-tools/dist/toolbox/index.cjs"}
|
|
@@ -0,0 +1,277 @@
|
|
|
1
|
+
/** OpenRouter Models API — https://openrouter.ai/api/v1/models */
|
|
2
|
+
type OpenRouterOutputModality = "text" | "image" | "audio" | "embeddings" | "video" | "speech" | "transcription" | "all";
|
|
3
|
+
type OpenRouterModelsQuery = {
|
|
4
|
+
/** Comma-separated or "all" — default on our sync is "all". */
|
|
5
|
+
output_modalities?: string;
|
|
6
|
+
supported_parameters?: string;
|
|
7
|
+
};
|
|
8
|
+
type OpenRouterPricingApi = {
|
|
9
|
+
prompt: string;
|
|
10
|
+
completion: string;
|
|
11
|
+
request: string;
|
|
12
|
+
image: string;
|
|
13
|
+
web_search?: string;
|
|
14
|
+
internal_reasoning?: string;
|
|
15
|
+
input_cache_read?: string;
|
|
16
|
+
input_cache_write?: string;
|
|
17
|
+
};
|
|
18
|
+
type OpenRouterArchitectureApi = {
|
|
19
|
+
modality?: string;
|
|
20
|
+
input_modalities: string[];
|
|
21
|
+
output_modalities: string[];
|
|
22
|
+
tokenizer: string;
|
|
23
|
+
instruct_type: string | null;
|
|
24
|
+
};
|
|
25
|
+
type OpenRouterTopProviderApi = {
|
|
26
|
+
context_length: number;
|
|
27
|
+
max_completion_tokens: number | null;
|
|
28
|
+
is_moderated: boolean;
|
|
29
|
+
};
|
|
30
|
+
type OpenRouterDefaultParametersApi = {
|
|
31
|
+
temperature?: number | null;
|
|
32
|
+
top_p?: number | null;
|
|
33
|
+
top_k?: number | null;
|
|
34
|
+
frequency_penalty?: number | null;
|
|
35
|
+
presence_penalty?: number | null;
|
|
36
|
+
repetition_penalty?: number | null;
|
|
37
|
+
};
|
|
38
|
+
type OpenRouterModelApi = {
|
|
39
|
+
id: string;
|
|
40
|
+
canonical_slug: string;
|
|
41
|
+
hugging_face_id?: string | null;
|
|
42
|
+
name: string;
|
|
43
|
+
created: number;
|
|
44
|
+
description: string;
|
|
45
|
+
context_length: number;
|
|
46
|
+
architecture: OpenRouterArchitectureApi;
|
|
47
|
+
pricing: OpenRouterPricingApi;
|
|
48
|
+
top_provider: OpenRouterTopProviderApi;
|
|
49
|
+
per_request_limits: unknown | null;
|
|
50
|
+
supported_parameters: string[];
|
|
51
|
+
default_parameters: OpenRouterDefaultParametersApi | null;
|
|
52
|
+
supported_voices?: unknown | null;
|
|
53
|
+
knowledge_cutoff?: string | null;
|
|
54
|
+
expiration_date?: string | null;
|
|
55
|
+
links?: {
|
|
56
|
+
details?: string;
|
|
57
|
+
} | null;
|
|
58
|
+
};
|
|
59
|
+
type OpenRouterModelsResponse = {
|
|
60
|
+
data: OpenRouterModelApi[];
|
|
61
|
+
};
|
|
62
|
+
|
|
63
|
+
type AiModelPricing = {
|
|
64
|
+
promptUsdPerToken: number;
|
|
65
|
+
completionUsdPerToken: number;
|
|
66
|
+
imageUsdPerUnit: number;
|
|
67
|
+
requestUsdPerRequest: number;
|
|
68
|
+
cacheReadUsdPerToken?: number;
|
|
69
|
+
cacheWriteUsdPerToken?: number;
|
|
70
|
+
reasoningUsdPerToken?: number;
|
|
71
|
+
webSearchUsdPerRequest?: number;
|
|
72
|
+
openRouterMarkupUsdPerInputToken?: number;
|
|
73
|
+
openRouterMarkupUsdPerOutputToken?: number;
|
|
74
|
+
pricedAt: string;
|
|
75
|
+
source: "openrouter" | "direct" | "manual";
|
|
76
|
+
};
|
|
77
|
+
/**
|
|
78
|
+
* Canonical catalog record — mirrors OpenRouter Models API fields plus normalized pricing.
|
|
79
|
+
* Canonical catalog record loaded from x12i open-assets JSON catalogs.
|
|
80
|
+
*/
|
|
81
|
+
type AiModelRecord = {
|
|
82
|
+
modelId: string;
|
|
83
|
+
name: string;
|
|
84
|
+
providerId: string;
|
|
85
|
+
canonicalSlug: string;
|
|
86
|
+
status: "active" | "deprecated" | "unknown";
|
|
87
|
+
description: string;
|
|
88
|
+
created: number;
|
|
89
|
+
expirationDate: string | null;
|
|
90
|
+
contextLength: number;
|
|
91
|
+
maxCompletionTokens: number | null;
|
|
92
|
+
isModerated: boolean;
|
|
93
|
+
modality: string;
|
|
94
|
+
inputModalities: string[];
|
|
95
|
+
outputModalities: string[];
|
|
96
|
+
tokenizer: string;
|
|
97
|
+
instructType: string | null;
|
|
98
|
+
supportedParameters: string[];
|
|
99
|
+
defaultParameters: OpenRouterDefaultParametersApi | null;
|
|
100
|
+
perRequestLimits: unknown | null;
|
|
101
|
+
pricing: AiModelPricing;
|
|
102
|
+
/** Raw OpenRouter pricing strings (USD per token/request/unit). */
|
|
103
|
+
openRouterPricing: OpenRouterPricingApi;
|
|
104
|
+
architecture: OpenRouterArchitectureApi;
|
|
105
|
+
topProvider: OpenRouterTopProviderApi;
|
|
106
|
+
/** Full OpenRouter API object — complete mirror for forward compatibility. */
|
|
107
|
+
openRouter: OpenRouterModelApi;
|
|
108
|
+
aliases: string[];
|
|
109
|
+
availableOnOpenRouter: boolean;
|
|
110
|
+
supportsStreaming: boolean;
|
|
111
|
+
supportsTools: boolean;
|
|
112
|
+
/** Exposes reasoning/thinking tokens (OpenRouter `reasoning` param and/or `internal_reasoning` pricing). */
|
|
113
|
+
supportsReasoning: boolean;
|
|
114
|
+
primaryOutputModality: string;
|
|
115
|
+
syncedAt: string;
|
|
116
|
+
syncSource: "openrouter" | "manual";
|
|
117
|
+
};
|
|
118
|
+
type ModelListFilters = {
|
|
119
|
+
providerId?: string;
|
|
120
|
+
status?: AiModelRecord["status"];
|
|
121
|
+
outputModality?: string;
|
|
122
|
+
inputModality?: string;
|
|
123
|
+
supportedParameter?: string;
|
|
124
|
+
supportsTools?: boolean;
|
|
125
|
+
supportsReasoning?: boolean;
|
|
126
|
+
search?: string;
|
|
127
|
+
limit?: number;
|
|
128
|
+
offset?: number;
|
|
129
|
+
};
|
|
130
|
+
type ModelListResult = {
|
|
131
|
+
models: AiModelRecord[];
|
|
132
|
+
total: number;
|
|
133
|
+
limit: number;
|
|
134
|
+
offset: number;
|
|
135
|
+
};
|
|
136
|
+
|
|
137
|
+
type AliasEntry = {
|
|
138
|
+
modelId: string;
|
|
139
|
+
provider: string;
|
|
140
|
+
description?: string;
|
|
141
|
+
tags?: string[];
|
|
142
|
+
addedAt: string;
|
|
143
|
+
updatedAt: string;
|
|
144
|
+
};
|
|
145
|
+
type AliasFileSchema = {
|
|
146
|
+
$schema?: string;
|
|
147
|
+
version: 1;
|
|
148
|
+
updatedAt: string;
|
|
149
|
+
aliases: Record<string, AliasEntry>;
|
|
150
|
+
};
|
|
151
|
+
type ResolvedModelRef = {
|
|
152
|
+
alias: string;
|
|
153
|
+
entry: AliasEntry;
|
|
154
|
+
modelRecord: AiModelRecord | null;
|
|
155
|
+
modelId: string;
|
|
156
|
+
provider: string;
|
|
157
|
+
name: string;
|
|
158
|
+
};
|
|
159
|
+
type AliasValidationReport = {
|
|
160
|
+
total: number;
|
|
161
|
+
ok: number;
|
|
162
|
+
unknown: number;
|
|
163
|
+
broken: number;
|
|
164
|
+
entries: Array<{
|
|
165
|
+
name: string;
|
|
166
|
+
status: "ok" | "unknown" | "broken";
|
|
167
|
+
modelId: string;
|
|
168
|
+
resolvedName?: string;
|
|
169
|
+
issue?: string;
|
|
170
|
+
}>;
|
|
171
|
+
};
|
|
172
|
+
|
|
173
|
+
type AliasRegistryOptions = {
|
|
174
|
+
aliasesPath?: string;
|
|
175
|
+
};
|
|
176
|
+
declare class AliasRegistry {
|
|
177
|
+
private readonly aliasesPath;
|
|
178
|
+
constructor(options?: AliasRegistryOptions);
|
|
179
|
+
get path(): string;
|
|
180
|
+
exists(): boolean;
|
|
181
|
+
init(): void;
|
|
182
|
+
load(): AliasFileSchema;
|
|
183
|
+
get(aliasName: string): AliasEntry | null;
|
|
184
|
+
list(filter?: {
|
|
185
|
+
tag?: string;
|
|
186
|
+
}): Array<{
|
|
187
|
+
name: string;
|
|
188
|
+
} & AliasEntry>;
|
|
189
|
+
set(aliasName: string, entry: Omit<AliasEntry, "addedAt" | "updatedAt">): AliasEntry;
|
|
190
|
+
remove(aliasName: string): boolean;
|
|
191
|
+
rename(from: string, to: string, options?: {
|
|
192
|
+
force?: boolean;
|
|
193
|
+
}): void;
|
|
194
|
+
private writeFile;
|
|
195
|
+
}
|
|
196
|
+
|
|
197
|
+
/**
|
|
198
|
+
* Env naming for vendor direct API keys: `{VENDOR}_API_KEY`
|
|
199
|
+
* where VENDOR is the provider id in UPPER_SNAKE (hyphens → underscores).
|
|
200
|
+
*
|
|
201
|
+
* Examples: `OPENAI_API_KEY`, `ANTHROPIC_API_KEY`, `META_LLAMA_API_KEY`, `X_AI_API_KEY`
|
|
202
|
+
*/
|
|
203
|
+
declare function providerIdToEnvKeyPrefix(providerId: string): string;
|
|
204
|
+
declare function vendorApiKeyEnvName(providerId: string): string;
|
|
205
|
+
type OpenRouterRoutingConfig = {
|
|
206
|
+
/** OPENROUTER_API_KEY is set and non-empty */
|
|
207
|
+
hasOpenRouterKey: boolean;
|
|
208
|
+
/** USE_OPENROUTER=true or USE_OPENROUTER=1 */
|
|
209
|
+
useOpenRouterExplicit: boolean;
|
|
210
|
+
/** Read `{PROVIDER}_API_KEY` for a catalog provider id */
|
|
211
|
+
getVendorApiKey(providerId: string): string | undefined;
|
|
212
|
+
};
|
|
213
|
+
/**
|
|
214
|
+
* Load routing hints from process env and optional `.env` (via @x12/env).
|
|
215
|
+
*/
|
|
216
|
+
declare function loadOpenRouterRoutingEnv(env?: Record<string, string | undefined>): OpenRouterRoutingConfig;
|
|
217
|
+
/**
|
|
218
|
+
* Default route via OpenRouter when:
|
|
219
|
+
* 1. OPENROUTER_API_KEY is set AND USE_OPENROUTER=true|1, or
|
|
220
|
+
* 2. OPENROUTER_API_KEY is set AND the vendor's `{VENDOR}_API_KEY` is missing.
|
|
221
|
+
*/
|
|
222
|
+
declare function shouldDefaultRouteViaOpenRouter(providerId: string | undefined, config: OpenRouterRoutingConfig): boolean;
|
|
223
|
+
|
|
224
|
+
type ModelResolutionInput = {
|
|
225
|
+
/** Provider hint (openrouter, openai, anthropic, …). May be omitted. */
|
|
226
|
+
provider?: string;
|
|
227
|
+
/** Model id, alias, shorthand, or partial name. Required. */
|
|
228
|
+
model: string;
|
|
229
|
+
};
|
|
230
|
+
type ResolutionStrategy = "alias-registry" | "alias-as-provider-correction" | "exact-match" | "catalog-alias-match" | "canonical-slug-match" | "provider-prefix-injection" | "cross-provider-correction" | "version-suffix-strip" | "date-suffix-strip" | "shorthand-expansion" | "partial-name-match" | "local-provider-passthrough";
|
|
231
|
+
type ModelResolutionSuccess = {
|
|
232
|
+
found: true;
|
|
233
|
+
modelId: string;
|
|
234
|
+
record: AiModelRecord | null;
|
|
235
|
+
routedViaOpenRouter: boolean;
|
|
236
|
+
confidence: number;
|
|
237
|
+
resolvedVia: ResolutionStrategy[];
|
|
238
|
+
resolvedReason: string;
|
|
239
|
+
normalisedInput: string;
|
|
240
|
+
};
|
|
241
|
+
type ModelResolutionNotFound = {
|
|
242
|
+
found: false;
|
|
243
|
+
modelId: null;
|
|
244
|
+
record: null;
|
|
245
|
+
attemptedStrategies: ResolutionStrategy[];
|
|
246
|
+
bestRejectedCandidate?: {
|
|
247
|
+
modelId: string;
|
|
248
|
+
confidence: number;
|
|
249
|
+
reason: string;
|
|
250
|
+
};
|
|
251
|
+
reason: string;
|
|
252
|
+
};
|
|
253
|
+
type ModelResolutionResult = ModelResolutionSuccess | ModelResolutionNotFound;
|
|
254
|
+
type ModelResolverOptions = {
|
|
255
|
+
confidenceThreshold?: number;
|
|
256
|
+
aliasRegistry?: AliasRegistry;
|
|
257
|
+
additionalShorthands?: Record<string, string>;
|
|
258
|
+
additionalProviderPatterns?: Array<{
|
|
259
|
+
pattern: RegExp;
|
|
260
|
+
provider: string;
|
|
261
|
+
}>;
|
|
262
|
+
additionalLocalProviders?: string[];
|
|
263
|
+
/** Env-based OpenRouter vs direct routing. Defaults to loadOpenRouterRoutingEnv(). */
|
|
264
|
+
routingEnv?: OpenRouterRoutingConfig;
|
|
265
|
+
};
|
|
266
|
+
type CatalogIndexes = {
|
|
267
|
+
aliasIndex: Map<string, string>;
|
|
268
|
+
slugIndex: Map<string, string>;
|
|
269
|
+
providerPrefixesBySize: string[];
|
|
270
|
+
};
|
|
271
|
+
type ResolvedModel = {
|
|
272
|
+
catalogModel: AiModelRecord;
|
|
273
|
+
matchedAlias: string;
|
|
274
|
+
routedViaOpenRouter: boolean;
|
|
275
|
+
};
|
|
276
|
+
|
|
277
|
+
export { type AiModelPricing as A, type CatalogIndexes as C, type ModelListFilters as M, type OpenRouterArchitectureApi as O, type ResolutionStrategy as R, type AiModelRecord as a, type AliasEntry as b, type AliasFileSchema as c, AliasRegistry as d, type AliasRegistryOptions as e, type AliasValidationReport as f, type ModelListResult as g, type ModelResolutionInput as h, type ModelResolutionNotFound as i, type ModelResolutionResult as j, type ModelResolutionSuccess as k, type ModelResolverOptions as l, type OpenRouterModelApi as m, type OpenRouterModelsQuery as n, type OpenRouterModelsResponse as o, type OpenRouterOutputModality as p, type OpenRouterPricingApi as q, type OpenRouterRoutingConfig as r, type OpenRouterTopProviderApi as s, type ResolvedModel as t, type ResolvedModelRef as u, loadOpenRouterRoutingEnv as v, providerIdToEnvKeyPrefix as w, shouldDefaultRouteViaOpenRouter as x, vendorApiKeyEnvName as y };
|
|
@@ -0,0 +1,277 @@
|
|
|
1
|
+
/** OpenRouter Models API — https://openrouter.ai/api/v1/models */
|
|
2
|
+
type OpenRouterOutputModality = "text" | "image" | "audio" | "embeddings" | "video" | "speech" | "transcription" | "all";
|
|
3
|
+
type OpenRouterModelsQuery = {
|
|
4
|
+
/** Comma-separated or "all" — default on our sync is "all". */
|
|
5
|
+
output_modalities?: string;
|
|
6
|
+
supported_parameters?: string;
|
|
7
|
+
};
|
|
8
|
+
type OpenRouterPricingApi = {
|
|
9
|
+
prompt: string;
|
|
10
|
+
completion: string;
|
|
11
|
+
request: string;
|
|
12
|
+
image: string;
|
|
13
|
+
web_search?: string;
|
|
14
|
+
internal_reasoning?: string;
|
|
15
|
+
input_cache_read?: string;
|
|
16
|
+
input_cache_write?: string;
|
|
17
|
+
};
|
|
18
|
+
type OpenRouterArchitectureApi = {
|
|
19
|
+
modality?: string;
|
|
20
|
+
input_modalities: string[];
|
|
21
|
+
output_modalities: string[];
|
|
22
|
+
tokenizer: string;
|
|
23
|
+
instruct_type: string | null;
|
|
24
|
+
};
|
|
25
|
+
type OpenRouterTopProviderApi = {
|
|
26
|
+
context_length: number;
|
|
27
|
+
max_completion_tokens: number | null;
|
|
28
|
+
is_moderated: boolean;
|
|
29
|
+
};
|
|
30
|
+
type OpenRouterDefaultParametersApi = {
|
|
31
|
+
temperature?: number | null;
|
|
32
|
+
top_p?: number | null;
|
|
33
|
+
top_k?: number | null;
|
|
34
|
+
frequency_penalty?: number | null;
|
|
35
|
+
presence_penalty?: number | null;
|
|
36
|
+
repetition_penalty?: number | null;
|
|
37
|
+
};
|
|
38
|
+
type OpenRouterModelApi = {
|
|
39
|
+
id: string;
|
|
40
|
+
canonical_slug: string;
|
|
41
|
+
hugging_face_id?: string | null;
|
|
42
|
+
name: string;
|
|
43
|
+
created: number;
|
|
44
|
+
description: string;
|
|
45
|
+
context_length: number;
|
|
46
|
+
architecture: OpenRouterArchitectureApi;
|
|
47
|
+
pricing: OpenRouterPricingApi;
|
|
48
|
+
top_provider: OpenRouterTopProviderApi;
|
|
49
|
+
per_request_limits: unknown | null;
|
|
50
|
+
supported_parameters: string[];
|
|
51
|
+
default_parameters: OpenRouterDefaultParametersApi | null;
|
|
52
|
+
supported_voices?: unknown | null;
|
|
53
|
+
knowledge_cutoff?: string | null;
|
|
54
|
+
expiration_date?: string | null;
|
|
55
|
+
links?: {
|
|
56
|
+
details?: string;
|
|
57
|
+
} | null;
|
|
58
|
+
};
|
|
59
|
+
type OpenRouterModelsResponse = {
|
|
60
|
+
data: OpenRouterModelApi[];
|
|
61
|
+
};
|
|
62
|
+
|
|
63
|
+
type AiModelPricing = {
|
|
64
|
+
promptUsdPerToken: number;
|
|
65
|
+
completionUsdPerToken: number;
|
|
66
|
+
imageUsdPerUnit: number;
|
|
67
|
+
requestUsdPerRequest: number;
|
|
68
|
+
cacheReadUsdPerToken?: number;
|
|
69
|
+
cacheWriteUsdPerToken?: number;
|
|
70
|
+
reasoningUsdPerToken?: number;
|
|
71
|
+
webSearchUsdPerRequest?: number;
|
|
72
|
+
openRouterMarkupUsdPerInputToken?: number;
|
|
73
|
+
openRouterMarkupUsdPerOutputToken?: number;
|
|
74
|
+
pricedAt: string;
|
|
75
|
+
source: "openrouter" | "direct" | "manual";
|
|
76
|
+
};
|
|
77
|
+
/**
|
|
78
|
+
* Canonical catalog record — mirrors OpenRouter Models API fields plus normalized pricing.
|
|
79
|
+
* Canonical catalog record loaded from x12i open-assets JSON catalogs.
|
|
80
|
+
*/
|
|
81
|
+
type AiModelRecord = {
|
|
82
|
+
modelId: string;
|
|
83
|
+
name: string;
|
|
84
|
+
providerId: string;
|
|
85
|
+
canonicalSlug: string;
|
|
86
|
+
status: "active" | "deprecated" | "unknown";
|
|
87
|
+
description: string;
|
|
88
|
+
created: number;
|
|
89
|
+
expirationDate: string | null;
|
|
90
|
+
contextLength: number;
|
|
91
|
+
maxCompletionTokens: number | null;
|
|
92
|
+
isModerated: boolean;
|
|
93
|
+
modality: string;
|
|
94
|
+
inputModalities: string[];
|
|
95
|
+
outputModalities: string[];
|
|
96
|
+
tokenizer: string;
|
|
97
|
+
instructType: string | null;
|
|
98
|
+
supportedParameters: string[];
|
|
99
|
+
defaultParameters: OpenRouterDefaultParametersApi | null;
|
|
100
|
+
perRequestLimits: unknown | null;
|
|
101
|
+
pricing: AiModelPricing;
|
|
102
|
+
/** Raw OpenRouter pricing strings (USD per token/request/unit). */
|
|
103
|
+
openRouterPricing: OpenRouterPricingApi;
|
|
104
|
+
architecture: OpenRouterArchitectureApi;
|
|
105
|
+
topProvider: OpenRouterTopProviderApi;
|
|
106
|
+
/** Full OpenRouter API object — complete mirror for forward compatibility. */
|
|
107
|
+
openRouter: OpenRouterModelApi;
|
|
108
|
+
aliases: string[];
|
|
109
|
+
availableOnOpenRouter: boolean;
|
|
110
|
+
supportsStreaming: boolean;
|
|
111
|
+
supportsTools: boolean;
|
|
112
|
+
/** Exposes reasoning/thinking tokens (OpenRouter `reasoning` param and/or `internal_reasoning` pricing). */
|
|
113
|
+
supportsReasoning: boolean;
|
|
114
|
+
primaryOutputModality: string;
|
|
115
|
+
syncedAt: string;
|
|
116
|
+
syncSource: "openrouter" | "manual";
|
|
117
|
+
};
|
|
118
|
+
type ModelListFilters = {
|
|
119
|
+
providerId?: string;
|
|
120
|
+
status?: AiModelRecord["status"];
|
|
121
|
+
outputModality?: string;
|
|
122
|
+
inputModality?: string;
|
|
123
|
+
supportedParameter?: string;
|
|
124
|
+
supportsTools?: boolean;
|
|
125
|
+
supportsReasoning?: boolean;
|
|
126
|
+
search?: string;
|
|
127
|
+
limit?: number;
|
|
128
|
+
offset?: number;
|
|
129
|
+
};
|
|
130
|
+
type ModelListResult = {
|
|
131
|
+
models: AiModelRecord[];
|
|
132
|
+
total: number;
|
|
133
|
+
limit: number;
|
|
134
|
+
offset: number;
|
|
135
|
+
};
|
|
136
|
+
|
|
137
|
+
type AliasEntry = {
|
|
138
|
+
modelId: string;
|
|
139
|
+
provider: string;
|
|
140
|
+
description?: string;
|
|
141
|
+
tags?: string[];
|
|
142
|
+
addedAt: string;
|
|
143
|
+
updatedAt: string;
|
|
144
|
+
};
|
|
145
|
+
type AliasFileSchema = {
|
|
146
|
+
$schema?: string;
|
|
147
|
+
version: 1;
|
|
148
|
+
updatedAt: string;
|
|
149
|
+
aliases: Record<string, AliasEntry>;
|
|
150
|
+
};
|
|
151
|
+
type ResolvedModelRef = {
|
|
152
|
+
alias: string;
|
|
153
|
+
entry: AliasEntry;
|
|
154
|
+
modelRecord: AiModelRecord | null;
|
|
155
|
+
modelId: string;
|
|
156
|
+
provider: string;
|
|
157
|
+
name: string;
|
|
158
|
+
};
|
|
159
|
+
type AliasValidationReport = {
|
|
160
|
+
total: number;
|
|
161
|
+
ok: number;
|
|
162
|
+
unknown: number;
|
|
163
|
+
broken: number;
|
|
164
|
+
entries: Array<{
|
|
165
|
+
name: string;
|
|
166
|
+
status: "ok" | "unknown" | "broken";
|
|
167
|
+
modelId: string;
|
|
168
|
+
resolvedName?: string;
|
|
169
|
+
issue?: string;
|
|
170
|
+
}>;
|
|
171
|
+
};
|
|
172
|
+
|
|
173
|
+
type AliasRegistryOptions = {
|
|
174
|
+
aliasesPath?: string;
|
|
175
|
+
};
|
|
176
|
+
declare class AliasRegistry {
|
|
177
|
+
private readonly aliasesPath;
|
|
178
|
+
constructor(options?: AliasRegistryOptions);
|
|
179
|
+
get path(): string;
|
|
180
|
+
exists(): boolean;
|
|
181
|
+
init(): void;
|
|
182
|
+
load(): AliasFileSchema;
|
|
183
|
+
get(aliasName: string): AliasEntry | null;
|
|
184
|
+
list(filter?: {
|
|
185
|
+
tag?: string;
|
|
186
|
+
}): Array<{
|
|
187
|
+
name: string;
|
|
188
|
+
} & AliasEntry>;
|
|
189
|
+
set(aliasName: string, entry: Omit<AliasEntry, "addedAt" | "updatedAt">): AliasEntry;
|
|
190
|
+
remove(aliasName: string): boolean;
|
|
191
|
+
rename(from: string, to: string, options?: {
|
|
192
|
+
force?: boolean;
|
|
193
|
+
}): void;
|
|
194
|
+
private writeFile;
|
|
195
|
+
}
|
|
196
|
+
|
|
197
|
+
/**
|
|
198
|
+
* Env naming for vendor direct API keys: `{VENDOR}_API_KEY`
|
|
199
|
+
* where VENDOR is the provider id in UPPER_SNAKE (hyphens → underscores).
|
|
200
|
+
*
|
|
201
|
+
* Examples: `OPENAI_API_KEY`, `ANTHROPIC_API_KEY`, `META_LLAMA_API_KEY`, `X_AI_API_KEY`
|
|
202
|
+
*/
|
|
203
|
+
declare function providerIdToEnvKeyPrefix(providerId: string): string;
|
|
204
|
+
declare function vendorApiKeyEnvName(providerId: string): string;
|
|
205
|
+
type OpenRouterRoutingConfig = {
|
|
206
|
+
/** OPENROUTER_API_KEY is set and non-empty */
|
|
207
|
+
hasOpenRouterKey: boolean;
|
|
208
|
+
/** USE_OPENROUTER=true or USE_OPENROUTER=1 */
|
|
209
|
+
useOpenRouterExplicit: boolean;
|
|
210
|
+
/** Read `{PROVIDER}_API_KEY` for a catalog provider id */
|
|
211
|
+
getVendorApiKey(providerId: string): string | undefined;
|
|
212
|
+
};
|
|
213
|
+
/**
|
|
214
|
+
* Load routing hints from process env and optional `.env` (via @x12/env).
|
|
215
|
+
*/
|
|
216
|
+
declare function loadOpenRouterRoutingEnv(env?: Record<string, string | undefined>): OpenRouterRoutingConfig;
|
|
217
|
+
/**
|
|
218
|
+
* Default route via OpenRouter when:
|
|
219
|
+
* 1. OPENROUTER_API_KEY is set AND USE_OPENROUTER=true|1, or
|
|
220
|
+
* 2. OPENROUTER_API_KEY is set AND the vendor's `{VENDOR}_API_KEY` is missing.
|
|
221
|
+
*/
|
|
222
|
+
declare function shouldDefaultRouteViaOpenRouter(providerId: string | undefined, config: OpenRouterRoutingConfig): boolean;
|
|
223
|
+
|
|
224
|
+
type ModelResolutionInput = {
|
|
225
|
+
/** Provider hint (openrouter, openai, anthropic, …). May be omitted. */
|
|
226
|
+
provider?: string;
|
|
227
|
+
/** Model id, alias, shorthand, or partial name. Required. */
|
|
228
|
+
model: string;
|
|
229
|
+
};
|
|
230
|
+
type ResolutionStrategy = "alias-registry" | "alias-as-provider-correction" | "exact-match" | "catalog-alias-match" | "canonical-slug-match" | "provider-prefix-injection" | "cross-provider-correction" | "version-suffix-strip" | "date-suffix-strip" | "shorthand-expansion" | "partial-name-match" | "local-provider-passthrough";
|
|
231
|
+
type ModelResolutionSuccess = {
|
|
232
|
+
found: true;
|
|
233
|
+
modelId: string;
|
|
234
|
+
record: AiModelRecord | null;
|
|
235
|
+
routedViaOpenRouter: boolean;
|
|
236
|
+
confidence: number;
|
|
237
|
+
resolvedVia: ResolutionStrategy[];
|
|
238
|
+
resolvedReason: string;
|
|
239
|
+
normalisedInput: string;
|
|
240
|
+
};
|
|
241
|
+
type ModelResolutionNotFound = {
|
|
242
|
+
found: false;
|
|
243
|
+
modelId: null;
|
|
244
|
+
record: null;
|
|
245
|
+
attemptedStrategies: ResolutionStrategy[];
|
|
246
|
+
bestRejectedCandidate?: {
|
|
247
|
+
modelId: string;
|
|
248
|
+
confidence: number;
|
|
249
|
+
reason: string;
|
|
250
|
+
};
|
|
251
|
+
reason: string;
|
|
252
|
+
};
|
|
253
|
+
type ModelResolutionResult = ModelResolutionSuccess | ModelResolutionNotFound;
|
|
254
|
+
type ModelResolverOptions = {
|
|
255
|
+
confidenceThreshold?: number;
|
|
256
|
+
aliasRegistry?: AliasRegistry;
|
|
257
|
+
additionalShorthands?: Record<string, string>;
|
|
258
|
+
additionalProviderPatterns?: Array<{
|
|
259
|
+
pattern: RegExp;
|
|
260
|
+
provider: string;
|
|
261
|
+
}>;
|
|
262
|
+
additionalLocalProviders?: string[];
|
|
263
|
+
/** Env-based OpenRouter vs direct routing. Defaults to loadOpenRouterRoutingEnv(). */
|
|
264
|
+
routingEnv?: OpenRouterRoutingConfig;
|
|
265
|
+
};
|
|
266
|
+
type CatalogIndexes = {
|
|
267
|
+
aliasIndex: Map<string, string>;
|
|
268
|
+
slugIndex: Map<string, string>;
|
|
269
|
+
providerPrefixesBySize: string[];
|
|
270
|
+
};
|
|
271
|
+
type ResolvedModel = {
|
|
272
|
+
catalogModel: AiModelRecord;
|
|
273
|
+
matchedAlias: string;
|
|
274
|
+
routedViaOpenRouter: boolean;
|
|
275
|
+
};
|
|
276
|
+
|
|
277
|
+
export { type AiModelPricing as A, type CatalogIndexes as C, type ModelListFilters as M, type OpenRouterArchitectureApi as O, type ResolutionStrategy as R, type AiModelRecord as a, type AliasEntry as b, type AliasFileSchema as c, AliasRegistry as d, type AliasRegistryOptions as e, type AliasValidationReport as f, type ModelListResult as g, type ModelResolutionInput as h, type ModelResolutionNotFound as i, type ModelResolutionResult as j, type ModelResolutionSuccess as k, type ModelResolverOptions as l, type OpenRouterModelApi as m, type OpenRouterModelsQuery as n, type OpenRouterModelsResponse as o, type OpenRouterOutputModality as p, type OpenRouterPricingApi as q, type OpenRouterRoutingConfig as r, type OpenRouterTopProviderApi as s, type ResolvedModel as t, type ResolvedModelRef as u, loadOpenRouterRoutingEnv as v, providerIdToEnvKeyPrefix as w, shouldDefaultRouteViaOpenRouter as x, vendorApiKeyEnvName as y };
|