openllmprovider 0.1.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/README.md +192 -0
- package/dist/auth/index.cjs +6 -0
- package/dist/auth/index.d.cts +3 -0
- package/dist/auth/index.d.mts +3 -0
- package/dist/auth/index.mjs +3 -0
- package/dist/auto-C2hXJY13.d.cts +33 -0
- package/dist/auto-C2hXJY13.d.cts.map +1 -0
- package/dist/auto-CBqNYBXs.mjs +48 -0
- package/dist/auto-CBqNYBXs.mjs.map +1 -0
- package/dist/auto-CInerwvs.d.mts +33 -0
- package/dist/auto-CInerwvs.d.mts.map +1 -0
- package/dist/auto-D77wgMqO.cjs +59 -0
- package/dist/auto-D77wgMqO.cjs.map +1 -0
- package/dist/file-DB-rxfzi.mjs +77 -0
- package/dist/file-DB-rxfzi.mjs.map +1 -0
- package/dist/file-DZ7FGcSW.cjs +73 -0
- package/dist/file-DZ7FGcSW.cjs.map +1 -0
- package/dist/index.cjs +1909 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +1239 -0
- package/dist/index.d.cts.map +1 -0
- package/dist/index.d.mts +1241 -0
- package/dist/index.d.mts.map +1 -0
- package/dist/index.mjs +1891 -0
- package/dist/index.mjs.map +1 -0
- package/dist/logger-BsHpI_fH.mjs +11 -0
- package/dist/logger-BsHpI_fH.mjs.map +1 -0
- package/dist/logger-jRimlMFR.cjs +69 -0
- package/dist/logger-jRimlMFR.cjs.map +1 -0
- package/dist/plugin/index.cjs +29 -0
- package/dist/plugin/index.cjs.map +1 -0
- package/dist/plugin/index.d.cts +10 -0
- package/dist/plugin/index.d.cts.map +1 -0
- package/dist/plugin/index.d.mts +10 -0
- package/dist/plugin/index.d.mts.map +1 -0
- package/dist/plugin/index.mjs +25 -0
- package/dist/plugin/index.mjs.map +1 -0
- package/dist/plugin-BkeUu5LW.d.mts +46 -0
- package/dist/plugin-BkeUu5LW.d.mts.map +1 -0
- package/dist/plugin-wK7RmJhZ.d.cts +46 -0
- package/dist/plugin-wK7RmJhZ.d.cts.map +1 -0
- package/dist/resolver-BA7LWSJO.mjs +645 -0
- package/dist/resolver-BA7LWSJO.mjs.map +1 -0
- package/dist/resolver-BMTvzTt9.cjs +662 -0
- package/dist/resolver-BMTvzTt9.cjs.map +1 -0
- package/dist/resolver-MgJryMWG.d.cts +75 -0
- package/dist/resolver-MgJryMWG.d.cts.map +1 -0
- package/dist/resolver-_gfXzr_S.d.mts +76 -0
- package/dist/resolver-_gfXzr_S.d.mts.map +1 -0
- package/dist/storage/index.cjs +7 -0
- package/dist/storage/index.d.cts +12 -0
- package/dist/storage/index.d.cts.map +1 -0
- package/dist/storage/index.d.mts +12 -0
- package/dist/storage/index.d.mts.map +1 -0
- package/dist/storage/index.mjs +4 -0
- package/package.json +137 -0
- package/src/auth/.gitkeep +0 -0
- package/src/auth/index.ts +10 -0
- package/src/auth/resolver.ts +46 -0
- package/src/auth/scanners.ts +462 -0
- package/src/auth/store.ts +357 -0
- package/src/catalog/.gitkeep +0 -0
- package/src/catalog/catalog.ts +302 -0
- package/src/catalog/index.ts +17 -0
- package/src/catalog/mapper.ts +129 -0
- package/src/catalog/merger.ts +99 -0
- package/src/index.ts +37 -0
- package/src/logger.ts +7 -0
- package/src/plugin/.gitkeep +0 -0
- package/src/plugin/anthropic.test.ts +505 -0
- package/src/plugin/anthropic.ts +324 -0
- package/src/plugin/codex.ts +656 -0
- package/src/plugin/copilot.ts +161 -0
- package/src/plugin/google.ts +454 -0
- package/src/plugin/index.ts +30 -0
- package/src/provider/.gitkeep +0 -0
- package/src/provider/bundled.ts +59 -0
- package/src/provider/index.ts +249 -0
- package/src/provider/state.ts +163 -0
- package/src/storage/.gitkeep +0 -0
- package/src/storage/auto.ts +32 -0
- package/src/storage/file.ts +84 -0
- package/src/storage/index.ts +10 -0
- package/src/storage/memory.ts +23 -0
- package/src/types/.gitkeep +0 -0
- package/src/types/auth.ts +18 -0
- package/src/types/errors.ts +87 -0
- package/src/types/index.ts +26 -0
- package/src/types/model.ts +88 -0
- package/src/types/plugin.ts +49 -0
- package/src/types/provider.ts +48 -0
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
import { z } from 'zod'
|
|
2
|
+
import type { ModelDefinition } from '../types/model.js'
|
|
3
|
+
|
|
4
|
+
const ModelsDevModelSchema = z
|
|
5
|
+
.object({
|
|
6
|
+
id: z.string().optional(),
|
|
7
|
+
name: z.string().optional(),
|
|
8
|
+
family: z.string().optional(),
|
|
9
|
+
|
|
10
|
+
reasoning: z.boolean().optional(),
|
|
11
|
+
tool_call: z.boolean().optional(),
|
|
12
|
+
structured_output: z.boolean().optional(),
|
|
13
|
+
temperature: z.boolean().optional(),
|
|
14
|
+
attachment: z.boolean().optional(),
|
|
15
|
+
streaming: z.boolean().optional(),
|
|
16
|
+
system_message: z.boolean().optional(),
|
|
17
|
+
|
|
18
|
+
modalities: z
|
|
19
|
+
.object({
|
|
20
|
+
input: z.array(z.string()),
|
|
21
|
+
output: z.array(z.string()),
|
|
22
|
+
})
|
|
23
|
+
.passthrough(),
|
|
24
|
+
|
|
25
|
+
limit: z
|
|
26
|
+
.object({
|
|
27
|
+
context: z.number(),
|
|
28
|
+
output: z.number(),
|
|
29
|
+
input_images: z.number().optional(),
|
|
30
|
+
})
|
|
31
|
+
.passthrough(),
|
|
32
|
+
|
|
33
|
+
cost: z
|
|
34
|
+
.object({
|
|
35
|
+
input: z.number(),
|
|
36
|
+
output: z.number(),
|
|
37
|
+
cache_read: z.number().optional(),
|
|
38
|
+
cache_write: z.number().optional(),
|
|
39
|
+
})
|
|
40
|
+
.passthrough()
|
|
41
|
+
.optional(),
|
|
42
|
+
|
|
43
|
+
status: z.enum(['stable', 'beta', 'deprecated']).optional(),
|
|
44
|
+
knowledge: z.string().optional(),
|
|
45
|
+
})
|
|
46
|
+
.passthrough()
|
|
47
|
+
|
|
48
|
+
const ModelsDevProviderSchema = z
|
|
49
|
+
.object({
|
|
50
|
+
id: z.string().optional(),
|
|
51
|
+
name: z.string().optional(),
|
|
52
|
+
env: z.array(z.string()).optional(),
|
|
53
|
+
api: z.string().optional(),
|
|
54
|
+
npm: z.string().optional(),
|
|
55
|
+
doc: z.string().optional(),
|
|
56
|
+
models: z.record(z.string(), z.unknown()).optional(),
|
|
57
|
+
})
|
|
58
|
+
.passthrough()
|
|
59
|
+
|
|
60
|
+
export function mapModelsDevToModelDefinition(
|
|
61
|
+
modelId: string,
|
|
62
|
+
raw: unknown,
|
|
63
|
+
provenance?: 'snapshot' | 'remote'
|
|
64
|
+
): ModelDefinition | null {
|
|
65
|
+
const parsed = ModelsDevModelSchema.safeParse(raw)
|
|
66
|
+
if (!parsed.success) return null
|
|
67
|
+
|
|
68
|
+
const { id: _id, knowledge, ...rest } = parsed.data
|
|
69
|
+
|
|
70
|
+
const result: Record<string, unknown> = {
|
|
71
|
+
...rest,
|
|
72
|
+
modelId,
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
if (knowledge !== undefined) {
|
|
76
|
+
result.knowledgeCutoff = knowledge
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
if (provenance !== undefined) {
|
|
80
|
+
result.provenance = provenance
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
return result as unknown as ModelDefinition
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
export function mapModelsDevProvider(
|
|
87
|
+
providerId: string,
|
|
88
|
+
raw: unknown,
|
|
89
|
+
provenance?: 'snapshot' | 'remote'
|
|
90
|
+
): {
|
|
91
|
+
provider: { id: string; name: string; env?: string[]; api?: string; doc?: string }
|
|
92
|
+
models: ModelDefinition[]
|
|
93
|
+
} {
|
|
94
|
+
const parsed = ModelsDevProviderSchema.safeParse(raw)
|
|
95
|
+
const name = parsed.success ? (parsed.data.name ?? providerId) : providerId
|
|
96
|
+
const rawModels = parsed.success ? (parsed.data.models ?? {}) : {}
|
|
97
|
+
|
|
98
|
+
const models: ModelDefinition[] = []
|
|
99
|
+
for (const [modelId, modelRaw] of Object.entries(rawModels)) {
|
|
100
|
+
const mapped = mapModelsDevToModelDefinition(modelId, modelRaw, provenance)
|
|
101
|
+
if (mapped) models.push(mapped)
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
return {
|
|
105
|
+
provider: {
|
|
106
|
+
id: providerId,
|
|
107
|
+
name,
|
|
108
|
+
...(parsed.success && parsed.data.env !== undefined ? { env: parsed.data.env } : {}),
|
|
109
|
+
...(parsed.success && parsed.data.api !== undefined ? { api: parsed.data.api } : {}),
|
|
110
|
+
...(parsed.success && parsed.data.doc !== undefined ? { doc: parsed.data.doc } : {}),
|
|
111
|
+
},
|
|
112
|
+
models,
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
export function mapModelsDevProviderMetadata(
|
|
117
|
+
providerId: string,
|
|
118
|
+
raw: unknown
|
|
119
|
+
): { id: string; name: string; env?: string[]; api?: string; doc?: string } {
|
|
120
|
+
const parsed = ModelsDevProviderSchema.safeParse(raw)
|
|
121
|
+
|
|
122
|
+
return {
|
|
123
|
+
id: providerId,
|
|
124
|
+
name: parsed.success ? (parsed.data.name ?? providerId) : providerId,
|
|
125
|
+
...(parsed.success && parsed.data.env !== undefined ? { env: parsed.data.env } : {}),
|
|
126
|
+
...(parsed.success && parsed.data.api !== undefined ? { api: parsed.data.api } : {}),
|
|
127
|
+
...(parsed.success && parsed.data.doc !== undefined ? { doc: parsed.data.doc } : {}),
|
|
128
|
+
}
|
|
129
|
+
}
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
import type { ModelDefinition } from '../types/model.js'
|
|
2
|
+
|
|
3
|
+
type NestedObject = Record<string, unknown>
|
|
4
|
+
|
|
5
|
+
const FIELD_LEVEL_MERGE_KEYS: ReadonlySet<string> = new Set(['limit', 'cost'])
|
|
6
|
+
const REPLACE_KEYS: ReadonlySet<string> = new Set(['modalities'])
|
|
7
|
+
|
|
8
|
+
function mergeNestedObject(
|
|
9
|
+
base: NestedObject | undefined,
|
|
10
|
+
overlay: NestedObject | undefined
|
|
11
|
+
): NestedObject | undefined {
|
|
12
|
+
if (!overlay) return base ? { ...base } : undefined
|
|
13
|
+
if (!base) return { ...overlay }
|
|
14
|
+
const result = { ...base }
|
|
15
|
+
for (const key of Object.keys(overlay)) {
|
|
16
|
+
if (overlay[key] !== undefined) {
|
|
17
|
+
result[key] = overlay[key]
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
return result
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
export function mergeModelDefinitions(base: ModelDefinition, overlay: Partial<ModelDefinition>): ModelDefinition {
|
|
24
|
+
const result = { ...base }
|
|
25
|
+
|
|
26
|
+
for (const key of Object.keys(overlay) as Array<keyof ModelDefinition>) {
|
|
27
|
+
if (key === 'modelId') continue
|
|
28
|
+
|
|
29
|
+
const overlayValue = overlay[key]
|
|
30
|
+
if (overlayValue === undefined) continue
|
|
31
|
+
|
|
32
|
+
if (FIELD_LEVEL_MERGE_KEYS.has(key)) {
|
|
33
|
+
const merged = mergeNestedObject(base[key] as NestedObject | undefined, overlayValue as NestedObject)
|
|
34
|
+
if (merged !== undefined) {
|
|
35
|
+
;(result as Record<string, unknown>)[key] = merged
|
|
36
|
+
}
|
|
37
|
+
continue
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
if (REPLACE_KEYS.has(key)) {
|
|
41
|
+
;(result as Record<string, unknown>)[key] = overlayValue
|
|
42
|
+
continue
|
|
43
|
+
}
|
|
44
|
+
;(result as Record<string, unknown>)[key] = overlayValue
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
return result
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
export function mergeCatalogData(
|
|
51
|
+
snapshot: Map<string, ModelDefinition>,
|
|
52
|
+
remote: Map<string, ModelDefinition>,
|
|
53
|
+
overrides: Map<string, Partial<ModelDefinition>>
|
|
54
|
+
): Map<string, ModelDefinition> {
|
|
55
|
+
const allModelIds = new Set([...snapshot.keys(), ...remote.keys()])
|
|
56
|
+
const result = new Map<string, ModelDefinition>()
|
|
57
|
+
|
|
58
|
+
for (const modelId of allModelIds) {
|
|
59
|
+
const snap = snapshot.get(modelId)
|
|
60
|
+
const rem = remote.get(modelId)
|
|
61
|
+
const override = overrides.get(modelId)
|
|
62
|
+
|
|
63
|
+
const inSnapshot = snap !== undefined
|
|
64
|
+
const inRemote = rem !== undefined
|
|
65
|
+
const hasOverride = override !== undefined
|
|
66
|
+
|
|
67
|
+
let merged: ModelDefinition
|
|
68
|
+
|
|
69
|
+
if (inSnapshot && inRemote) {
|
|
70
|
+
merged = mergeModelDefinitions(snap, rem)
|
|
71
|
+
} else if (inRemote) {
|
|
72
|
+
merged = { ...rem }
|
|
73
|
+
} else if (snap) {
|
|
74
|
+
merged = { ...snap }
|
|
75
|
+
} else {
|
|
76
|
+
continue
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
if (hasOverride) {
|
|
80
|
+
merged = mergeModelDefinitions(merged, override)
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
if (hasOverride) {
|
|
84
|
+
merged.provenance = 'user-override'
|
|
85
|
+
} else if (inRemote) {
|
|
86
|
+
merged.provenance = 'remote'
|
|
87
|
+
} else {
|
|
88
|
+
merged.provenance = 'snapshot'
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
if (inSnapshot && !inRemote) {
|
|
92
|
+
merged.status = 'deprecated'
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
result.set(modelId, merged)
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
return result
|
|
99
|
+
}
|
package/src/index.ts
ADDED
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
export {
|
|
2
|
+
createProviderStore,
|
|
3
|
+
getLanguageModel,
|
|
4
|
+
loadProvider,
|
|
5
|
+
isProviderInstalled,
|
|
6
|
+
getAllProviderPackages,
|
|
7
|
+
} from './provider/index.js'
|
|
8
|
+
export type {
|
|
9
|
+
ProviderStore,
|
|
10
|
+
ProviderStoreConfig,
|
|
11
|
+
ProviderListOptions,
|
|
12
|
+
ModelListOptions,
|
|
13
|
+
GetModelOptions,
|
|
14
|
+
} from './provider/index.js'
|
|
15
|
+
|
|
16
|
+
export { createAuthStore } from './auth/index.js'
|
|
17
|
+
export type { AuthStore, AuthStoreOptions, DiscoveredCredential, DiscoverOptions } from './auth/index.js'
|
|
18
|
+
export { DEFAULT_SCANNERS } from './auth/index.js'
|
|
19
|
+
export type { DiskScanner, DiskScanResult, ScanContext } from './auth/index.js'
|
|
20
|
+
|
|
21
|
+
export { registerPlugin, getPlugins, getPluginForProvider } from './plugin/index.js'
|
|
22
|
+
export { copilotPlugin } from './plugin/copilot.js'
|
|
23
|
+
export { codexPlugin } from './plugin/codex.js'
|
|
24
|
+
export { googlePlugin } from './plugin/google.js'
|
|
25
|
+
export { anthropicPlugin } from './plugin/anthropic.js'
|
|
26
|
+
|
|
27
|
+
export { MemoryStorage, FileStorage, createDefaultStorage } from './storage/index.js'
|
|
28
|
+
export type { StorageAdapter } from './storage/index.js'
|
|
29
|
+
|
|
30
|
+
export type { LanguageModel, LanguageModelV3 } from './types/index.js'
|
|
31
|
+
export type { ExtendConfig, ExtendProviderConfig, ExtendModelConfig, CatalogProvider } from './catalog/catalog.js'
|
|
32
|
+
export type { ModelDefinition } from './types/index.js'
|
|
33
|
+
export type { AuthHook, AuthMethod, AuthCredential, ProviderInfo } from './types/index.js'
|
|
34
|
+
export type { SecretRef, SecretResolver } from './types/index.js'
|
|
35
|
+
export type { ProviderUserConfig } from './types/index.js'
|
|
36
|
+
|
|
37
|
+
export { createLogger } from './logger.js'
|
package/src/logger.ts
ADDED
|
File without changes
|